Tuesday, April 4, 2017

CommonMark Markdown Inline parser always return inside ` ` tag

i am using League's CommonMark package, and create custom extension to show <img> tag using custom tag markdown like this: @image(image_id).

In markdown is: @image(image_id)

Result i expected:

<figure>
   <img src="image_url" alt="image_alt"></img>
</figure>

Here's code i have tried:ImageParser.php

<?php

namespace App\Markdown\Extensions\Image;

use League\CommonMark\Inline\Element\HtmlInline;
use League\CommonMark\Inline\Parser\AbstractInlineParser;
use League\CommonMark\InlineParserContext;
use App\Storage\Image;

class ImageParser extends AbstractInlineParser
{

    /**
     * @return string[]
     */
    public function getCharacters()
    {
        return ['@'];
    }

    /**
     * @param InlineParserContext $inlineContext
     *
     * @return bool
     */
    public function parse(InlineParserContext $inlineContext)
    {
        $cursor = $inlineContext->getCursor();

        $previous = $cursor->peek(-1);
        if ($previous !== null && $previous !== ' ') {
            return false;
        }

        $previousState = $cursor->saveState();
        $cursor->advance();

        $handle = $cursor->match('/image\((\d+)\)/');
        if (empty($handle)) {
            $cursor->restoreState($previousState);

            return false;
        }

        $imageId = preg_replace("/image\((\d+)\)/", "$1", $handle);
        $image = Image::find($imageId);

        if (is_null($image)) {
            return false;
        }

        $inlineContext->getContainer()->appendChild(new HtmlInline($this->render($image)));

        return true;
    }

    /**
     * Render the image figure.
     *
     * @param \PYM\Storage\Image $image
     *
     * @return string
     */
    protected function render(Image $image)
    {
        $source = empty($image->source) ? null : "<figcaption>{$image->source}</figcaption>";

        return '<figure><img src="' . $image->getUrl('wide') . '" alt="' . $image->alt_tag . '">' . $source . '</figure>';
    }
}

Test code: ImageExtensionText.php

<?php

namespace Tests\Unit\Markdown;

use Tests\TestCase;

class ImageExtensionTest extends TestCase
{
    /** @test */
    public function converts_to_a_image_tag()
    {
        $image = factoryImage();

        $string = \Markdown::convertToHtml("First paragraph

        @image({$image->id})

        Last paragraph");

        dd($string);
        $expected = '<img src="'.$image->getUrl('wide').'" alt="'.$image->alt_tag.'">';

        $this->assertEquals($string, $expected);
    }
}

and here the result on testing: enter image description here

on the testing file @image(image_id) always return inside <p></p> tag, that's not result i expected.



via Muh Ghazali Akbar

Advertisement