silasjoisten/sonata-multiupload-bundle

一个允许您在Sonata中启用多文件上传的包

安装次数: 78,177

依赖项: 0

建议者: 0

安全: 0

星级: 30

关注者: 3

分支: 16

开放问题: 13

类型:symfony-bundle


README

Build Status Latest Stable Version Total Downloads Latest Unstable Version License codecov

版本

示例

检查示例项目

安装

步骤 1:下载包

composer require silasjoisten/sonata-multiupload-bundle

步骤 2:启用包

然后,通过将包添加到项目中的app/AppKernel.php文件中注册的包列表中来启用包

<?php

class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...
            new SilasJoisten\Sonata\MultiUploadBundle\SonataMultiUploadBundle(),
        );

        // ...
    }

    // ...
}

如果您正在使用config/bundles.php中的flex注册包

<?php

return [
    //...
    SilasJoisten\Sonata\MultiUploadBundle\SonataMultiUploadBundle::class => ['all' => true]
];

步骤 3:配置

您必须打开此包的配置文件,并配置您想启用多上传的提供者。

# config/packages/sonata_multi_upload.yaml

sonata_multi_upload:
  # ...
  providers:
    - sonata.media.provider.image
    - sonata.media.provider.video

向SonataAdmin配置添加JavaScript和CSS

# config/packages/sonata_admin.yaml

sonata_admin:
  assets:
    extra_stylesheets:
      - bundles/sonatamultiupload/dist/sonata-multiupload.css

    extra_javascripts:
      - bundles/sonatamultiupload/dist/sonata-multiupload.js

可选

# config/packages/sonata_multi_upload.yaml

sonata_multi_upload:
  max_upload_filesize: 3000000 # 3MB the default value is 0 -> allow every size

有一个名为redirect_to的选项,允许上传完成后重定向到您配置的页面。

# config/packages/sonata_multi_upload.yaml

sonata_multi_upload:
  redirect_to: 'admin_sonata_media_media_list'

提示: MultiUploadBundle会自动将上传的Media对象的id传递给重定向路由,例如:/foo/bar?idx=%5B70%2C71%2C72%5D,因此您可以从中提取它们并创建一个媒体库。

示例:上传多个图片并自动创建Gallery

创建控制器

该控制器接收您的请求,并在本例中创建一个包含GalleryItemsGallery,然后重定向到GalleryAdmin的编辑视图。

<?php

namespace App\Controller;

use App\Entity\SonataMediaGallery;
use App\Entity\SonataMediaGalleryItem;
use Sonata\MediaBundle\Admin\GalleryAdmin;
use Sonata\MediaBundle\Entity\MediaManager;
use Sonata\MediaBundle\Entity\GalleryManager;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpFoundation\Request;

final class CreateGalleryAction
{
    public function __construct(
        private MediaManager   $mediaManager,
        private GalleryManager $galleryManager,
        private GalleryAdmin   $galleryAdmin
    ) {
    }

    public function __invoke(Request $request): RedirectResponse
    {
        $idx = $request->query->get('idx');
        $idx = json_decode($idx);

        /** @var SonataMediaGallery $gallery */
        $gallery = $this->galleryManager->create();
        $gallery->setName('Auto Created Gallery');
        $gallery->setEnabled(false);
        $gallery->setContext('default');

        foreach ($idx as $id) {
            $media = $this->mediaManager->find($id);

            $galleryHasMedia = new SonataMediaGalleryItem();
            $galleryHasMedia->setGallery($gallery);
            $galleryHasMedia->setMedia($media);
            $gallery->addGalleryItem($galleryHasMedia);
        }

        $this->galleryManager->save($gallery);

        return new RedirectResponse($this->galleryAdmin->generateObjectUrl('edit', $gallery));
    }
}

注册路由

如果您已经覆盖了默认的MediaAdmin,您可以通过以下方式在管理类中添加路由:

   protected function configureRoutes(RouteCollectionInterface $collection): void
    {
        $collection->add('create_gallery', 'multi-upload/create-gallery', [
            '_controller' => CreateGalleryAction::class,
        ]);
    }

否则,您可以创建一个如下的AdminExtension

<?php

declare(strict_types=1);

namespace App\Admin\Extension;

use App\Controller\CreateGalleryAction;
use Sonata\AdminBundle\Admin\AbstractAdminExtension;
use Sonata\AdminBundle\Admin\AdminInterface;
use Sonata\AdminBundle\Route\RouteCollectionInterface;

final class MediaAddRouteExtension extends AbstractAdminExtension
{
    public function configureRoutes(AdminInterface $admin, RouteCollectionInterface $collection): void
    {
        $collection->add('create_gallery', 'multi-upload/create-gallery', [
            '_controller' => CreateGalleryAction::class,
        ]);
    }
}

并在您的config/services.yaml中注册此扩展

services:
    # ...
    App\Admin\Extension\MediaAddRouteExtension:
        tags:
            - { name: sonata.admin.extension, target: sonata.media.admin.media }

现在在config/packages/sonata_multi_upload.yaml中配置redirect_to

sonata_multi_upload:
    redirect_to: 'admin_app_sonatamediamedia_create_gallery'

您可能需要为MediaManagerGalleryManager创建别名,如下所示

# config/services.yaml
services:
  Sonata\MediaBundle\Entity\MediaManager:
    alias: sonata.media.manager.media

  Sonata\MediaBundle\Entity\GalleryManager:
    alias: sonata.media.manager.gallery

  Sonata\MediaBundle\Admin\GalleryAdmin:
    alias: sonata.media.admin.gallery

就这样。

请注意,上传器对于YouTubeProvider,VimeoProvider等提供者将不会工作!

4. 视觉效果

multiupload

使用的库