Соната медиа-пакет, как включить редактирование pixlr?
Я включил pixlr, как описано здесь, но не включен, пытался много раз. Нет редактирования с кнопкой pixlr, видимой в медиа-форме.
Я что-то упускаю, Бьюсь надолго. Пожалуйста, помогите, есть ли какие-либо дополнительные конфигурации, кроме этого?
Вот мой конфиг
sonata_media:
pixlr:
enabled: true
secret: theSecretHash
referrer: Demo
# if you don't use default namespace configuration
class:
media: App\Application\Sonata\MediaBundle\Entity\Media
gallery: App\Application\Sonata\MediaBundle\Entity\Gallery
gallery_has_media: App\Application\Sonata\MediaBundle\Entity\GalleryHasMedia
category: App\Application\Sonata\ClassificationBundle\Entity\Category
db_driver: doctrine_orm # or doctrine_mongodb, doctrine_phpcr it is mandatory to choose one here
default_context: default # you need to set a context
contexts:
default: # the default context is mandatory
providers:
- sonata.media.provider.dailymotion
- sonata.media.provider.youtube
- sonata.media.provider.image
- sonata.media.provider.file
- sonata.media.provider.vimeo
formats:
small: { width: 100 , quality: 70 }
big: { width: 500 , quality: 70 }
gallery:
providers:
- sonata.media.provider.dailymotion
- sonata.media.provider.youtube
- sonata.media.provider.image
- sonata.media.provider.file
- sonata.media.provider.vimeo
formats:
original: { width: 500, quality: 100 }
thumbnail: { width: 200, height: 200, quality: 100 }
cdn:
server:
path: http://127.0.0.1:8000/uploads/media # http://media.sonata-project.org/
filesystem:
local:
directory: "%kernel.root_dir%/../public/uploads/media" #flex
#directory: "%kernel.root_dir%/../web/uploads/media" #non-flex
create: false
1 ответ
После изучения кода я обнаружил, что проблема заключается в том, что Symfony 4 делает службы частными по умолчанию.
И вот как соната медиа-пакет позволяет pixlr
Сначала он проверяет, если sonata.media.extra.pixlr
услуга доступна в контейнере. Если нет, то это не активирует pixlr. Так как сервис закрытого контейнера не имеет доступа к сервису.
// Sonata\MediaBundle\Twig\GlobalVariable
/**
* @return Pixlr|bool
*/
public function getPixlr()
{
return $this->container->has('sonata.media.extra.pixlr') ? $this->container->get('sonata.media.extra.pixlr') : false;
}
Обходной путь для этого состоит в том, чтобы переопределить определение сервиса и сделать его общедоступным:)
sonata.media.extra.pixlr:
public: true
class: Sonata\MediaBundle\Extra\Pixlr
arguments: [~,~,"@sonata.media.pool", "@sonata.media.manager.media", "@router", "@sonata.templating", "@service_container"]
Теперь вы можете увидеть кнопку редактирования pixlr в медиа-форме