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:
on the testing file @image(image_id)
always return inside <p></p>
tag, that's not result i expected.
via Muh Ghazali Akbar