fbeen / simplecmsbundle
Complete CMS functionality for Symfony 3
Installs: 51
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 4
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: ^5.5.9|^7.0
- a2lix/auto-form-bundle: 0.1-beta.1
- a2lix/translation-form-bundle: ^2.1
- egeloen/ckeditor-bundle: ^4.0
- knplabs/doctrine-behaviors: ^1.1
- knplabs/knp-paginator-bundle: ^2.5
- sonata-project/admin-bundle: ^3.9
- sonata-project/doctrine-orm-admin-bundle: ^3.1
- symfony/framework-bundle: ^3.0
This package is not auto-updated.
Last update: 2024-11-18 15:15:27 UTC
README
Installation
Download the necessary bundles with Composer:
$ composer require fbeen/simplecmsbundle
Then add the bundles to the app/config/AppKernel.php file
// ...
// Sonata
new Sonata\CoreBundle\SonataCoreBundle(),
new Sonata\BlockBundle\SonataBlockBundle(),
new Sonata\DoctrineORMAdminBundle\SonataDoctrineORMAdminBundle(),
new Sonata\AdminBundle\SonataAdminBundle(),
// Ivory CKEditor
new Ivory\CKEditorBundle\IvoryCKEditorBundle(),
// Knp Menu
new Knp\Bundle\MenuBundle\KnpMenuBundle(),
// Doctrine behaviors
new Knp\DoctrineBehaviors\Bundle\DoctrineBehaviorsBundle,
// a2lix Translation
new A2lix\AutoFormBundle\A2lixAutoFormBundle(),
new A2lix\TranslationFormBundle\A2lixTranslationFormBundle(),
// Fbeen Simple CMS bundle
new Fbeen\SimpleCmsBundle\FbeenSimpleCmsBundle(),
new AppBundle\AppBundle(),
Required configuration in app/config/config.yml:
sonata_block:
default_contexts: [admin]
blocks:
# enable the SonataAdminBundle block
sonata.admin.block.admin_list: ~
sonata.block.service.clear_cache: ~
sonata_admin:
show_mosaic_button: false
dashboard:
groups:
cms:
label: 'SimpleCMS'
items:
- fbeen_simple_cms.admin.route
- fbeen_simple_cms.admin.content
- fbeen_simple_cms.admin.menu
- fbeen_simple_cms.admin.image
- fbeen_simple_cms.admin.simple_block_type
blocks:
-
position: left
type: sonata.admin.block.admin_list
settings:
groups: [main, docs, users, cms]
-
position: left
type: sonata.block.service.clear_cache
ivory_ck_editor:
default_config: cmf_content
configs:
cmf_content: { toolbar: standard }
a2lix_translation_form:
locale_provider: default
locales: [%locale%]
default_locale: %locale%
required_locales: [%locale%]
templating: "FbeenSimpleCmsBundle:Admin:a2lix_tabs.html.twig"
Enable translation in app/config/config.yml:
framework:
#esi: ~
translator: { fallbacks: ["%locale%"] }
Create the database and update the schema:
$ bin/console doctrine:database:create
$ bin/console doctrine:schema:update --force
Apply routing in the app/config/routing.yml
# Simple CMS
fbeen_simple_cms:
resource: .
type: fbeen_simple_cms
# Sonata-admin
admin_area:
resource: "@SonataAdminBundle/Resources/config/routing/sonata_admin.xml"
prefix: /admin
_sonata_admin:
resource: .
type: sonata_admin
prefix: /admin
# Application
app:
resource: "@AppBundle/Controller/"
type: annotation
# ...
Install the assets: (don't use the symlink option on windows)
$ bin/console assets:install --symlink
Usage
How to load a content in a normal symfony controller
Loading dynamic content is as easy as loading data from each other entity. To search content based on its name we can make use of the findCompleteContent method from the ContentRepository. The repository will join all other data like the blockContainer and the underlying blocks at once.
Example how to create a homepage with the content of the CMS and additionally some newsitems
/**
* @Route("/", name="homepage")
*/
public function indexAction(Request $request)
{
$em = $this->getDoctrine()->getManager();
$homepage = $em->getRepository('FbeenSimpleCmsBundle:Content')->findCompleteContent('homepage');
if (!$homepage) {
throw $this->createNotFoundException('No homepage configured');
}
$newsitems = $em->getRepository('AppBundle:Newsitem')->findFrontpageNews()->getResult();
return $this->render('default/index.html.twig', array(
'content' => $homepage,
'newsitems' => $newsitems,
));
}
multi languages
Imagine that you want a website that supports three languages and that you want to have dutch as default language and english and german as additional languages.
add a locales parameter under parameters:
parameters:
locale: nl
locales: [nl, en, de]
Change the a2lix translation form configuration
a2lix_translation_form:
locale_provider: default
locales: %locales%
# ...
To be continued