File: /home/accemeff/vendor/craftcms/cms/src/elements/actions/EditImage.php
<?php
/**
* @link https://craftcms.com/
* @copyright Copyright (c) Pixel & Tonic, Inc.
* @license https://craftcms.github.io/license/
*/
namespace craft\elements\actions;
use Craft;
use craft\base\ElementAction;
use craft\helpers\Json;
/**
* EditImage represents an Edit Image action
*
* @author Pixel & Tonic, Inc. <support@pixelandtonic.com>
* @since 3.0
*/
class EditImage extends ElementAction
{
// Properties
// =========================================================================
/**
* @var string The trigger label
*/
public $label;
// Public Methods
// =========================================================================
/**
* @inheritdoc
*/
public function init()
{
if ($this->label === null) {
$this->label = Craft::t('app', 'Edit Image');
}
}
/**
* @inheritdoc
*/
public function getTriggerLabel(): string
{
return $this->label;
}
/**
* @inheritdoc
*/
public function getTriggerHtml()
{
$type = Json::encode(static::class);
$js = <<<EOT
(function()
{
var trigger = new Craft.ElementActionTrigger({
type: {$type},
batch: false,
_imageEditor: null,
validateSelection: function(\$selectedItems)
{
return Garnish.hasAttr(\$selectedItems.find('.element'), 'data-editable-image');
},
activate: function(\$selectedItems)
{
var \$element = \$selectedItems.find('.element:first'),
element = Craft.getElementInfo(\$element);
var settings = {
onSave: function () {
Craft.elementIndex.updateElements();
},
allowDegreeFractions: Craft.isImagick,
};
new Craft.AssetImageEditor(element.id, settings);
}
});
})();
EOT;
Craft::$app->getView()->registerJs($js);
}
}