annotate core/modules/image/src/Plugin/ImageEffect/ConvertImageEffect.php @ 19:fa3358dc1485 tip

Add ndrum files
author Chris Cannam
date Wed, 28 Aug 2019 13:14:47 +0100
parents 129ea1e6d783
children
rev   line source
Chris@0 1 <?php
Chris@0 2
Chris@0 3 namespace Drupal\image\Plugin\ImageEffect;
Chris@0 4
Chris@0 5 use Drupal\Core\Form\FormStateInterface;
Chris@0 6 use Drupal\Core\Image\ImageInterface;
Chris@0 7 use Drupal\image\ConfigurableImageEffectBase;
Chris@0 8
Chris@0 9 /**
Chris@0 10 * Converts an image resource.
Chris@0 11 *
Chris@0 12 * @ImageEffect(
Chris@0 13 * id = "image_convert",
Chris@0 14 * label = @Translation("Convert"),
Chris@0 15 * description = @Translation("Converts an image between extensions (e.g. from PNG to JPEG).")
Chris@0 16 * )
Chris@0 17 */
Chris@0 18 class ConvertImageEffect extends ConfigurableImageEffectBase {
Chris@0 19
Chris@0 20 /**
Chris@0 21 * {@inheritdoc}
Chris@0 22 */
Chris@0 23 public function applyEffect(ImageInterface $image) {
Chris@0 24 if (!$image->convert($this->configuration['extension'])) {
Chris@0 25 $this->logger->error('Image convert failed using the %toolkit toolkit on %path (%mimetype)', ['%toolkit' => $image->getToolkitId(), '%path' => $image->getSource(), '%mimetype' => $image->getMimeType()]);
Chris@0 26 return FALSE;
Chris@0 27 }
Chris@0 28 return TRUE;
Chris@0 29 }
Chris@0 30
Chris@0 31 /**
Chris@0 32 * {@inheritdoc}
Chris@0 33 */
Chris@0 34 public function getDerivativeExtension($extension) {
Chris@0 35 return $this->configuration['extension'];
Chris@0 36 }
Chris@0 37
Chris@0 38 /**
Chris@0 39 * {@inheritdoc}
Chris@0 40 */
Chris@0 41 public function getSummary() {
Chris@0 42 $summary = [
Chris@17 43 '#markup' => mb_strtoupper($this->configuration['extension']),
Chris@0 44 ];
Chris@0 45 $summary += parent::getSummary();
Chris@0 46
Chris@0 47 return $summary;
Chris@0 48 }
Chris@0 49
Chris@0 50 /**
Chris@0 51 * {@inheritdoc}
Chris@0 52 */
Chris@0 53 public function defaultConfiguration() {
Chris@0 54 return [
Chris@0 55 'extension' => NULL,
Chris@0 56 ];
Chris@0 57 }
Chris@0 58
Chris@0 59 /**
Chris@0 60 * {@inheritdoc}
Chris@0 61 */
Chris@0 62 public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
Chris@0 63 $extensions = \Drupal::service('image.toolkit.manager')->getDefaultToolkit()->getSupportedExtensions();
Chris@0 64 $options = array_combine(
Chris@0 65 $extensions,
Chris@17 66 array_map('mb_strtoupper', $extensions)
Chris@0 67 );
Chris@0 68 $form['extension'] = [
Chris@0 69 '#type' => 'select',
Chris@0 70 '#title' => t('Extension'),
Chris@0 71 '#default_value' => $this->configuration['extension'],
Chris@0 72 '#required' => TRUE,
Chris@0 73 '#options' => $options,
Chris@0 74 ];
Chris@0 75 return $form;
Chris@0 76 }
Chris@0 77
Chris@0 78 /**
Chris@0 79 * {@inheritdoc}
Chris@0 80 */
Chris@0 81 public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
Chris@0 82 parent::submitConfigurationForm($form, $form_state);
Chris@0 83 $this->configuration['extension'] = $form_state->getValue('extension');
Chris@0 84 }
Chris@0 85
Chris@0 86 }