demi / cropper
Yii2 wrapper for Image Cropper javascript library
Installs: 22 674
Dependents: 1
Suggesters: 0
Security: 0
Stars: 12
Watchers: 6
Forks: 4
Open Issues: 5
Type:yii2-extension
Requires
- php: >=5.4.0
- bower-asset/cropper: *
- yiisoft/yii2: *
README
Wrapper for Image Cropper javascript library
Installation
Run
composer require "demi/cropper" "~1.0"
Usage
hint: functionality of this extension is already implemented into my extension to image uploading
echo Cropper::widget([ // If true - it's output button for toggle modal crop window 'modal' => true, // You can customize modal window. Copy /vendor/demi/cropper/views/modal.php 'modalView' => '@backend/views/image/custom_modal', // URL-address for the crop-handling request // By default, sent the following post-params: x, y, width, height, rotate 'cropUrl' => ['cropImage', 'id' => $image->id], // Url-path to original image for cropping 'image' => Yii::$app->request->baseUrl . '/images/' . $image->src, // The aspect ratio for the area of cropping 'aspectRatio' => 4 / 3, // or 16/9(wide) or 1/1(square) or any other ratio. Null - free ratio // Additional params for JS cropper plugin 'pluginOptions' => [ // All possible options: https://github.com/fengyuanchen/cropper/blob/master/README.md#options 'minCropBoxWidth' => 400, // minimal crop area width 'minCropBoxHeight' => 300, // minimal crop area height ], // HTML-options for widget container 'options' => [], // HTML-options for cropper image tag 'imageOptions' => [], // Translated messages 'messages' => [ 'cropBtn' => Yii::t('app', 'Crop'), 'cropModalTitle' => Yii::t('app', 'Select crop area and click "Crop" button'), 'closeModalBtn' => Yii::t('app', 'Close'), 'cropModalBtn' => Yii::t('app', 'Crop selected'), ], // Additional ajax-options for send crop-request. See jQuery $.ajax() options 'ajaxOptions' => [ 'success' => new JsExpression(<<<JS function(data) { // data - your JSON response from [[cropUrl]] $("#myImage").attr("src", data.croppedImageSrc); } JS ), ], ]);