2017 © Pedro Peláez
 

yii2-extension yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

image

ruvents/yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

  • Thursday, July 28, 2016
  • by RUVENTS
  • Repository
  • 2 Watchers
  • 1 Stars
  • 16 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 122 Forks
  • 0 Open issues
  • 9 Versions
  • 7 % Grown

The README.md

BlueImp File Upload Widget for Yii2

Latest Version Software License Build Status Coverage Status Quality Score Total Downloads, (*1)

Renders a BlueImp jQuery File Upload plugin. That plugin integrates multiple file selection, drag&drop support, progress bars, validation and preview of images., (*2)

Installation

The preferred way to install this extension is through composer., (*3)

Either run, (*4)

$ composer require 2amigos/yii2-file-upload-widget:~1.0

or add, (*5)

"2amigos/yii2-file-upload-widget": "~1.0"

to the require section of your composer.json file., (*6)

Usage

The widget comes with two flavors:, (*7)



= FileUpload::widget([
    'model' => $model,
    'attribute' => 'image',
    'url' => ['media/upload', 'id' => $model->id], // your url, this is just for demo purposes,
    'options' => ['accept' => 'image/*'],
    'clientOptions' => [
        'maxFileSize' => 2000000
    ],
    // Also, you can specify jQuery-File-Upload events
    // see: https://github.com/blueimp/jQuery-File-Upload/wiki/Options#processing-callback-options
    'clientEvents' => [
        'fileuploaddone' => 'function(e, data) {
                                console.log(e);
                                console.log(data);
                            }',
        'fileuploadfail' => 'function(e, data) {
                                console.log(e);
                                console.log(data);
                            }',
    ],
]);?>


= FileUploadUI::widget([
    'model' => $model,
    'attribute' => 'image',
    'url' => ['media/upload', 'id' => $tour_id],
    'gallery' => false,
    'fieldOptions' => [
            'accept' => 'image/*'
    ],
    'clientOptions' => [
            'maxFileSize' => 2000000
    ],
    // ...
    'clientEvents' => [
            'fileuploaddone' => 'function(e, data) {
                                    console.log(e);
                                    console.log(data);
                                }',
            'fileuploadfail' => 'function(e, data) {
                                    console.log(e);
                                    console.log(data);
                                }',
    ],
]);
?>

<?php

// action examples

public function actionImageUpload()
{
    $imageFile = UploadedFile::getInstanceByName('Transport[name]');
    $directory = \Yii::getAlias('@frontend/web/img/temp') . DIRECTORY_SEPARATOR . Yii::$app->session->id . DIRECTORY_SEPARATOR;
    if (!is_dir($directory)) {
        mkdir($directory);
    }
    if ($imageFile) {
        $uid = uniqid(time(), true);
        $fileName = $uid . '.' . $imageFile->extension;
        $filePath = $directory . $fileName;
        if ($imageFile->saveAs($filePath)) {
            $path = '/img/temp/' . Yii::$app->session->id . DIRECTORY_SEPARATOR . $fileName;
            return Json::encode([
                'files' => [[
                    'name' => $fileName,
                    'size' => $imageFile->size,
                    "url" => $path,
                    "thumbnailUrl" => $path,
                    "deleteUrl" => 'image-delete?name=' . $fileName,
                    "deleteType" => "POST"
                ]]
            ]);
        }
    }
    return '';
}

public function actionImageDelete($name)
{
    $directory = \Yii::getAlias('@frontend/web/img/temp') . DIRECTORY_SEPARATOR . Yii::$app->session->id;
    if (is_file($directory . DIRECTORY_SEPARATOR . $name)) {
        unlink($directory . DIRECTORY_SEPARATOR . $name);
    }
    $files = FileHelper::findFiles($directory);
    $output = [];
    foreach ($files as $file){
        $path = '/img/temp/' . Yii::$app->session->id . DIRECTORY_SEPARATOR . basename($file);
        $output['files'][] = [
            'name' => basename($file),
            'size' => filesize($file),
            "url" => $path,
            "thumbnailUrl" => $path,
            "deleteUrl" => 'image-delete?name=' . basename($file),
            "deleteType" => "POST"
        ];
    }
    return Json::encode($output);
}

Please, check the jQuery File Upload documentation for further information about its configuration options., (*8)

Testing

$ ./vendor/bin/phpunit

Contributing

Please see CONTRIBUTING for details., (*9)

Credits

License

The BSD License (BSD). Please see License File for more information., (*10)


web development has never been so fun
www.2amigos.us

The Versions

28/07 2016

dev-master

9999999-dev https://github.com/ruvents/yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Vera Miroshnichenko

yii2 upload yii yii 2 widget ruvents

07/03 2016

1.0.4

1.0.4.0 https://github.com/2amigos/yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 upload 2amigos yii yii 2 widget

04/03 2016

1.0.3

1.0.3.0 https://github.com/2amigos/yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 upload 2amigos yii yii 2 widget

14/04 2015

1.0.2

1.0.2.0 https://github.com/2amigos/yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 upload 2amigos yii yii 2 widget

13/04 2015

1.0.1

1.0.1.0 https://github.com/2amigos/yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 upload 2amigos yii yii 2 widget

12/04 2015

1.0.0

1.0.0.0 https://github.com/2amigos/yii2-file-upload-widget

Blueimp file upload widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 upload 2amigos yii yii 2 widget

27/11 2014

0.1.2

0.1.2.0

BlueImp jQuery File Upload Widget for Yii2.

  Sources   Download

BSD-3-Clause

The Requires

 

extension upload yii widget

26/05 2014

0.1.1

0.1.1.0

BlueImp jQuery File Upload Widget for Yii2.

  Sources   Download

BSD-3-Clause

The Requires

 

extension upload yii widget

25/04 2014

0.1.0

0.1.0.0

BlueImp jQuery File Upload Widget for Yii2.

  Sources   Download

BSD-3-Clause

The Requires

 

extension upload yii widget