odilov-sh/yii2-image-cropper

Yii2 image cropper with deleting old image

1.1 2020-09-12 11:10 UTC

This package is auto-updated.

Last update: 2024-04-29 04:53:18 UTC


README

Yii-Framework extension for uploading and cropping images based on Cropper extension

Installation

The preferred way to install this extension is through composer.

Either run

php composer.phar require odilov-sh/yii2-image-cropper "@dev"

or add

"odilov-sh/yii2-image-cropper": "@dev"

to the require section of your composer.json file.

Usage

Once the extension is installed, simply use it in your code by :

use odilov\cropper\Cropper;
<?php $form = ActiveForm::begin(['id' => 'form-profile']); ?>
    <?php echo $form->field($model, 'photo')->widget(Cropper::className(), [
        'uploadUrl' => Url::toRoute('/user/user/uploadPhoto'),
    ]) ?>
    <div class="form-group">
        <?php echo Html::submitButton('Save', ['class' => 'btn btn-primary']) ?>
    </div>
<?php ActiveForm::end(); ?>

Widget has following properties:

Name Description Default Required
uploadParameter Upload parameter name file No
width The final width of the image after cropping 200 No
height The final height of the image after cropping 200 No
label Hint in box for preview It depends on application language. You can translate this message on your language and make pull-request. No
uploadUrl URL for uploading and cropping image Yes
noPhotoImage The picture, which is used when a photo is not loaded. You can see it on screenshots in this instructions No
maxSize The maximum file size (kb). 2097152 No
cropAreaWidth Width box for preview 300 No
cropAreaHeight Height box for preview 300 No
aspectRatio Fix aspect ratio of cropping area null No
extensions Allowed file extensions (string). jpeg, jpg, png, gif No

In UserController:

public function actions()
{
    return [
        'uploadPhoto' => [
            'class' => 'odilov\cropper\UploadAction',
            'url' => 'http://your_domain.com/uploads/user/photo',
            'path' => '@frontend/web/uploads/user/photo',
        ]
    ];
}

Action has following parameters:

Name Description Default Required
path Path for saving image after cripping Yes
url URL to which the downloaded images will be available. Yes
uploadParameter Upload parameter name. It must match the value of a similar parameter of the widget. file No
maxSize The maximum file size (kb). It must match the value of a similar parameter of the widget. 2097152 No
extensions Allowed file extensions (string). It must match the value of a similar parameter of the widget. jpeg, jpg, png, gif No
width The final width of the image after cropping. It must match the value of a similar parameter of the widget. 200 No
height The final height of the image after cropping. It must match the value of a similar parameter of the widget. 200 No
jpegQuality Quality of cropped image (JPG) 100 No
pngCompressionLevel Quality of cropped image (PNG) 1 No
deleteOldImage Whether delete old image after cropping new image or clicking "Delete image" button true No

You can use this widget on frontend and backend. For example: user can change his userpic and administrator can change users userpic.

For more information refer https://github.com/krivochenko/yii2-cropper