Grav CMS: вывод сообщения в панели отладки из собственного PHP

Я работаю над пользовательским фильтром Twig, который изменяет размеры ваших изображений до заданной ширины (и автоматической высоты).

{# TWIG CODE #}
{% set imgpath = page.header.custom.bgimage|first.path %}
<div class="thumb" style="background-image: url({{ url(imgpath|resize(240)) }})"></div>

Пока он отлично работает, но я столкнулся с некоторыми ошибками при изменении порядка страниц. Я бы хотел использовать панель отладки Grav для отладки, поскольку она очень удобна и поддерживает чистоту кода.

Внутри Twig вы можете просто использовать {{ dump(message) }},
К сожалению, процесс изменения размера происходит внутри нативного PHP, поэтому мне нужен способ вывода сообщений из PHP на панель отладки Grav.
Как указано в Документах, вы можете использовать $grav['debugger']->addMessage($this),

Это вызывает ошибку при вызове фильтра Twig изменения размера:

Twig_Error_Runtime
An exception has been thrown during the rendering of a template ("Undefined variable: grav").

Почему переменная $grav не определено?

<?php namespace Grav\Common;

use \Grav\Common\Grav;
use \Grav\Common\Page\Page;
use \RocketTheme\Toolbox\ResourceLocator\UniformResourceLocator;
use \Eventviva\ImageResize;

include_once getcwd().'/user/plugins/resizer/lib/ImageResize.php';

class TwigResizerFilters extends \Twig_Extension
{
    private $grav;

    public function __construct() {
            $this->grav = Grav::instance();
    }

    public function getName() {
        return 'TwigResizeFilters';
    }

    public function getFilters() {
        return [
            new \Twig_SimpleFilter( 'resize', [$this, 'resizeImage'] )
        ];
    }

    public function resizeImage($mediapath, $maxWidth = 1920) {

        if (file_exists($mediapath)) {
            // if file exists

            if ($currImg = getimagesize($mediapath)) {
                // if is image

                if (preg_match('(jpg|jpeg|png)', $currImg['mime'])) {
                    // if file format correct

                    $resizedFolder = 'images/resized/';

                    // calculate exact img dimensions for proper naming
                    $maxHeight = floor(($maxWidth/$currImg[0]) * $currImg[1]);


                    if (!file_exists($resizedFolder)) {
                        // create folder if it does not exist
                        mkdir($resizedFolder, 0777, true);
                    }

                    // create filename
                    $resizedExtension = '.'.pathinfo($mediapath, PATHINFO_EXTENSION);
                    $resizedFilename = basename($mediapath, $resizedExtension).'@'.$maxWidth.'x'.$maxHeight.$resizedExtension;

                    if (file_exists($resizedFolder.$resizedFilename)) {
                        // if file already has been cached, just potput
                        return $resizedFolder.$resizedFilename;
                    } else {
                        // if not cached, resize to desired size

                        $image = new ImageResize($mediapath);
                        $image->resize($maxWidth, $maxHeight);
                        $image->save($resizedFolder.$resizedFilename);

                        return $resizedFolder.$resizedFilename;
                    }

                } else {
                    $grav['debugger']->addMessage("File type of ".$mediapath." is not supported.");
                }

            } else {
                $grav['debugger']->addMessage($mediapath." is not an image.");
            }

        } else {
            $grav['debugger']->addMessage("File ".$mediapath." does not exist.");
        }
    }

    private function mergeConfig( Page $page ) {
        $defaults = (array) $this->grav['config']->get('plugins.resizer');
        if ( isset($page->header()->resizer) ) {
            $this->grav['config']->set('plugins.resizer', array_merge($defaults, $page->header()->resizer));
        }
    }
}

0 ответов

Другие вопросы по тегам