3 namespace Drupal\image\Form;
5 use Drupal\Core\Form\FormStateInterface;
6 use Drupal\image\ImageEffectManager;
7 use Drupal\image\ImageStyleInterface;
8 use Symfony\Component\DependencyInjection\ContainerInterface;
11 * Provides an add form for image effects.
13 class ImageEffectAddForm extends ImageEffectFormBase {
16 * The image effect manager.
18 * @var \Drupal\image\ImageEffectManager
20 protected $effectManager;
23 * Constructs a new ImageEffectAddForm.
25 * @param \Drupal\image\ImageEffectManager $effect_manager
26 * The image effect manager.
28 public function __construct(ImageEffectManager $effect_manager) {
29 $this->effectManager = $effect_manager;
35 public static function create(ContainerInterface $container) {
37 $container->get('plugin.manager.image.effect')
44 public function buildForm(array $form, FormStateInterface $form_state, ImageStyleInterface $image_style = NULL, $image_effect = NULL) {
45 $form = parent::buildForm($form, $form_state, $image_style, $image_effect);
47 $form['#title'] = $this->t('Add %label effect', ['%label' => $this->imageEffect->label()]);
48 $form['actions']['submit']['#value'] = $this->t('Add effect');
56 protected function prepareImageEffect($image_effect) {
57 $image_effect = $this->effectManager->createInstance($image_effect);
58 // Set the initial weight so this effect comes last.
59 $image_effect->setWeight(count($this->imageStyle->getEffects()));