afzalroq / yii2-cms
Yii2 cms extension
Installs: 1 256
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 2
Forks: 4
Open Issues: 0
Type:yii2-extension
Requires
- abdualiym/yii2-language: ^1.0
- kartik-v/yii2-widget-fileinput: @dev
- mihaildev/yii2-elfinder: *
- sadovojav/yii2-ckeditor: dev-master
- yii-dream-team/yii2-upload-behavior: ^1.2.3
- yiisoft/yii2: ~2.0
- zelenin/yii2-slug-behavior: ~1.5.1
Requires (Dev)
- phpunit/phpunit: 4.*
This package is auto-updated.
Last update: 2024-11-22 20:03:21 UTC
README
The extension allows:
- make html blocks of html contents, files, images.
- make collections for options like tags, categories
- make entities for items like sliders, products, reviews, articles, pages
- support up to 5 languages
- support SEO meta tags
- make multiple menu with parenting feature
Upgrade notes
- remove first key property
- use first node of languages as firstKey
Installation
- Install with composer:
composer require afzalroq/yii2-cms "^1.0"
- After composer install run console command for create tables:
Add to console config for auto discover migrations
'controllerMap' => [ 'migrate' => [ 'class' => MigrateController::class, 'autoDiscover' => true, 'migrationPaths' => [ '@vendor/afzalroq/yii2-cms/migrations' ], ], ]
php yii migrate/up --migrationPath=@vendor/afzalroq/yii2-cms/migrations
Setup in common config file
CKEditor use Elfinder plugin for save files and images. Refer Elfinder readme for proper configuration
- Language indexes related with database columns.
- Admin panel tabs render by array values order
- For Items, Options and Menu must be isset common\models\User model
'modules' => [ 'cms' => [ // don`t change module key 'class' => '@afzalroq\cms\Module', // storage 'path' => $params['storageRoot'], // dirname(__DIR__, 2) . '/storage' 'host' => $params['storageHostInfo'], // 'https://site.example' 'cache' => 'cache', // default cache component name 'cacheDuration' => 3600, // default cache duration 3600 second 'optimized' => false, // set true for get items with options as $item->o // images 'imageOperation' => 'cropResize', 'imageBackground' => 'transparent', 'imageXPos' => 'center', 'imageYPos' => 'center', 'fallback' => $params['storageRoot'] . '/fallback.png', 'watermark' => $params['storageRoot'] . '/logo.png', // i18n 'languages' => [ 'ru' => [ 'id' => 0, // must start from 0 up to 4 'name' => 'English', ], 'en' => [ 'id' => 1, 'name' => 'Русский', ], 'uz' => [ 'id' => 2, 'name' => 'O`zbek tili', ], ], // for add to menu controller actions 'menuActions' => [ '' => 'Home', 'site/contacts' => 'Contacts', ] ], ]
By default uses for caching component with name "cache". Config as belove:
'components' => [ 'cache' => [ 'class' => 'yii\caching\FileCache', 'cachePath' => Yii::getAlias('@frontend') . '/runtime/cache' ], ]
- In admin panel open management via link:
/cms/home/index
Added Laravels dd() (dump and die) method
$array = ['a', 'b']; dd($array);
Examples
TODO
- test
- Copy from extension root directory example widgets for frontend integration
Usage
Use in frontend CController extending CMSController for proper menu generated links work
class CController extends CMSController { public function actionCollection(string $c) { } public function actionOption(string $c, string $o) { } public function actionEntity(string $e) { } public function actionItem(string $e, int $i) { } }
Unit getter
Unit::get('slug'); // will return data using cache
Item Getters
\afzalroq\cms\entities\front\OaI::getItemIdsByCollection($slug) : array // of item Ids \afzalroq\cms\entities\front\OaI::getItemIdsByOption($slug) : array // of item Ids
$item->getText1(); // for get Text 1 $item->getText2(); // for get Text 2 $item->getText3(); // for get Text 3 $item->getText4(); // for get Text 4 $item->getText5(); // for get Text 5 $item->getText6(); // for get Text 6 $item->getText7(); // for get Text 7 //for to get meta description and meta keywords just use this command below: $item-registerMetaTags(); //it generates meta tags in your view page
Return File URI
$item->getFile1(); // for get File 1 $item->getFile2(); // for get File 2 $item->getFile3(); // for get File 3
Return Datetime with specified format
$item->getDate($format); // for get date with format like "d.m.Y H:i:s"
Return image URI by specified operation(default cropResize
)
View all image operations & examples from documentation
// get gallery main photo URI $item->getGalleryPhoto(width, height, operation, background, xPos, yPos) // get gallery photos URI $items->getPhotos() // and use with "foreach(){}" // item photos URI $item->getPhoto1(width, height, operation, background, xPos, yPos); // for get Photo 1 $item->getPhoto2(width, height, operation, background, xPos, yPos); // for get Photo 2 $item->getPhoto3(width, height, operation, background, xPos, yPos); // for get Photo 3
Option Getters
$option->getName(); // for get Name $option->getContent(); // for get Content $option->getPhoto1(); // for get Photo 1 $option->getPhoto2(); // for get Photo 2 $option->getFile1(); // for get File 1 $option->getFile2(); // for get File 2 //for to get meta description and meta keywords just use this command below: $option-registerMetaTags(); //it generates meta tags in your view page
Option and Items searches
\afzalroq\cms\entities\front\Items::getEntityItemSearchResults((array) $entitySlugs, $search); // get search results with entity and items \afzalroq\cms\entities\front\Items::getOptionItemSearchResults((array) $optionSlugs, $search); // get search results with option and items \afzalroq\cms\entities\front\Options::getOptionSearchResults((array) $optionSlugs, $search); // get search results with options