dicr/yii2-file Filesystem components for Yii2

Файловая библиотека для Yii2

  1. Работа с файловым хранилищем
  2. Создание превью картинок
  3. Файловые аттрибуты модели

Содержит следующий функционал:

  • AbstractFileStore - абстракция файлового хранилища;

    • LocaFileStore - реализация хранилища в локальной файловой системе;
    • FtpFileStore - хранилище файлов на FTP;
    • SftpFileStore - хранилище файлов через SFTP;
    • FlysystemFileStore - хранилище через библиотеку Flysystem;
  • StoreFile - абстракция файла, поддержка операций с файлом;

    • UploadFile - загрузка файлов в хранилище из другого файла или данных $_FILES;
    • ThumbFile - создание превью картинок с кешем на диске;
    • CSVFile - абстракция для работы с CSV-файлами;
      • CSVResponseFormatter - формирование ответа в виде CSV-файла;
  • FileAttributeBehavior - поддержка файловых аттрибутов моделей;

  • FileInputWidget - поддержка полей форм для загрузки и редактирования файлов/картинок аттрибутов моделей;

Работа с файловым хранилищем

Конфигурация компонента на примере локального хранилища файлов:

'components' => [
    // хранилище файлов
    'fileStore' => [
        'class' => dicr\file\LocalFileStore::class,
        'path' => '@webroot/files', // базовый путь на диске
        'url' => '@web/files' // базовый URL для скачивания (опционально)
    ]
];

Использование:

// получаем настроенный компонент хранилища
$store = Yii::$app->get('fileStore');

// или например хранилище в локальной файловой системе
$store = LocalFileStore::root();

// список файлов хранилища в директории pdf
$files = $store->list('pdf');

// Получаем файл по имени
$file = $store->file('pdf/my-report.pdf');

// выводим содержимое файла
echo $file->content;

// выводим url файла в хранилище
echo $file->url;

Создание превью картинок

Для работы с превью нужно настроить кеш картинок в локальной файловой системе:

'components' => [
    // хранилище для превью картинок
    'thumbStore' => [
        'class' => dicr\file\LocalFileStore::class,
        'path' => '@webroot/thumb',
        'url' => '@web/thumb',
    ],

    // основное хранилище файлов
    'fileStore' => [
        'class' => dicr\file\LocalFileStore::class,
        'path' => '@webroot/files',
        // конфигурация компонента для создания превью
        'thumbFileConfig' => [
            'store' => 'thumbStore', // компонент хранилища для кэша картинок
            'noimage' => '@webroot/res/img/noimage.png' // заглушка для создания превью несуществующих файлов моделей
        ]
    ]
];

Использование превью:

// получаем файл из хранилища
$file = $store->file('images/image.jpg');

// выводим картинку превью
echo Html::img($file->thumb(['width' => 320, 'height' => 240])->url);

Файловые аттрибуты модели

Пример модели товара:

/**
 * @property-read ?StoreFile $image одна картинка
 * @property-read StoreFile[] $docs набор файлов документов
 */
class Product extends ActiveRecord
{
    /**
     * @inheritDoc
     */
    public function behaviors() : array
    {
        return [
            // добавляем файловые аттрибуты
            'file' => [
                'class' => FileAttributeBehavior::class,
                'attributes' => [
                    'image' => 1, // одна картинка
                    'docs' => 0 // неограниченное кол-во файлов
                ]
            ]   
        ];       
    }

    /**
     * @inheritDoc
     */
    public function load($data, $formName = null) : bool
    {
        $ret = parent::load($data, $formName);

        // загружаем файловые аттрибуты
        if ($this->loadFileAttributes($formName)) {
            $ret = true;
        }

        return $ret;
    }
}

Использование файловых аттрибутов:

// добавляем картинку товару
$prod->image = new UploadFile('/tmp/newimage.jpg');

// сохраняем
$prod->save();

// выводим превью картинки товара
echo Html::img((string)$prod->image->thumb(320, 200));

// выводим ссылки загрузки файлов товара
foreach ($prod->docs ?: [] as $doc) {
    echo Html::a($doc->name, $doc->url);
}

Форма редактирования файлов товара:

// поле с виджетом редактирования картинки
echo $form->field($prod, 'image')->widget(FileInputWidget::class, [
  'layout' => 'images',
  'limit' => 1,
  'accept' => 'image/*',
  'removeExt' => true
]);

// поле с виджетом редактирования документов
echo $form->field($prod, 'docs')->widget(FileInputWidget::class, [
  'layout' => 'files',
  'limit' => 0,
  'removeExt' => true
]);
0 0
1 follower
72 downloads
Yii Version: 2.0
License: MIT
Category: File System
Developed by: Igor Tarasov
Created on: Nov 19, 2020
Last updated: (not set)
Packagist Profile
Code Repository

Related Extensions