bscheshirwork / yii2-gallery-manager-imaginary
Extension for yii, that allows to manage image galleries use imaginary
Installs: 71
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 61
Type:yii2-extension
Requires
- php: >=7.2.0
- yiisoft/yii2: ~2.0.14
- yiisoft/yii2-jui: *
This package is auto-updated.
Last update: 2025-01-12 20:42:58 UTC
README
Yii2 port of https://github.com/zxbodya/yii-gallery-manager
(frontend part mostly without changes, but backend was rewritten almost completely)
Gallery manager screenshots (yii 1.x version, new one has bootstrap 3 styles):
Few more screenshots: drag & drop upload, editing image information, upload progress,
Features
- AJAX image upload
- Optional name and description for each image
- Possibility to arrange images in gallery
- Ability to generate few versions for each image with different configurations
- Drag & Drop
Decencies
- Yii2
- Twitter bootstrap assets (version 3)
- Imaginary docker image
- JQuery UI (included with Yii)
Installation:
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist bscheshirwork/yii2-gallery-manager-imaginary "*@dev"
or add
"bscheshirwork/yii2-gallery-manager-imaginary": "*@dev"
to the require section of your composer.json
file.
Usage
docker-compose
imaginary:
image: h2non/imaginary:latest
# optionally mount a volume as local image source
volumes:
- ./storage/web:/mnt/data
environment:
PORT: 9000
command: -enable-url-source -mount /mnt/data
expose:
- "9000" #for service php
ports:
- "9000:9000"
Prepare
Add migration namespace to console config:
return [ 'id' => 'app-console', ... 'controllerMap' => [ 'migrate' => [ 'class' => yii\console\controllers\MigrateController::class, // Since version 2.0.12 an array can be specified for loading migrations from multiple sources. 'migrationPath' => [ '@app/migrations', '@yii/rbac/migrations/', ], 'migrationNamespaces' => [ 'bscheshirwork\yii2\galleryManager\migrations', ... ], ], ...
Add configurations for upload and store images
Add GalleryBehavior to your model, and configure it, create folder for uploaded files.
use bscheshirwork\yii2\galleryManager\GalleryBehavior; class Product extends \yii\db\ActiveRecord { ... public function behaviors() { $model = $this; return [ 'galleryBehavior' => [ 'class' => GalleryBehavior::class, 'type' => 'nestedObject', // @see CrudController::actions() 'extension' => 'jpg', 'directory' => Yii::getAlias('@storageWeb') . ($galleryPath = '/images/gallery/product'), 'url' => Yii::getAlias('@storageUrl') . $galleryPath, 'imaginaryDirectory' => $galleryPath, 'versions' => [ 'small' => function ($originalImagePath, $originalImagePathForImagine) use ($model) { $width = 400; $height = 274; /** @var GalleryBehavior $behavior */ $behavior = $model->getBehavior('galleryBehavior'); $httpQuery = http_build_query([ 'file' => $originalImagePathForImagine, 'width' => $width, 'height' => $height, ]); $url = $behavior->imaginary . '/crop?' . $httpQuery; return file_get_contents($url); }, ], ], ]; }
See also documentations of imaginary http API for image transformations.
Add GalleryManagerAction in controller somewhere in your application. Also on this step you can add some security checks for this action.
use bscheshirwork\yii2\galleryManager\GalleryManagerAction; class ProductController extends Controller { ... public function actions() { return [ 'galleryApi' => [ 'class' => GalleryManagerAction::className(), // mappings between type names and model classes (should be the same as in behaviour) 'types' => [ 'product' => Product::className() ] ], ]; }
Add ImageAttachmentWidget somewhere in you application, for example in editing from.
use bscheshirwork\yii2\galleryManager\GalleryManager; /* @var $this yii\web\View */ /* @var $model Product */ ?> ... <?php if ($model->isNewRecord) { echo 'Can not upload images for new record'; } else { echo GalleryManager::widget( [ 'model' => $model, 'behaviorName' => 'galleryBehavior', 'apiRoute' => 'product/galleryApi' ] ); } ?>
Done!
Get uploaded images
Now, you can use uploaded images from gallery like following:
foreach($model->getBehavior('galleryBehavior')->getImages() as $image) { echo Html::img($image->getUrl('medium')); }
Options
Using non default table name for gallery images(default is {{%gallery_image}}
):
- Add migration that will create table you need
- Change
tableName
property in behavior configuration