Improve syntax highlighting of code
Squashed commit of the following: commit eb55e94ed89a1b8ccd1db10a36efd28d8896f316 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Thu Jan 24 18:45:00 2019 +0000 Remove un-needed use statments, fix tests now we have 2 articles commit f1c12c1b43d071fe0484407a9692ee4184542437 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Wed Jan 23 19:39:56 2019 +0000 Remove prism files commit 3a1d12d9181600f661593c662dbc18d152413b28 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Wed Jan 23 19:39:24 2019 +0000 Use the new css file in the search page commit 119b6b5163c217a15770004a45b07bacdfb766f0 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Wed Jan 23 19:36:14 2019 +0000 Recompress assets commit afae245d0211dd31fcc131cecb0fab4084895612 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 19:33:56 2019 +0000 Style codeblocks in articles as well commit 53be0a2023755c2f16ba1560d88f9c66675b581d Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 19:23:25 2019 +0000 Styled codeblocks are now on the notes pages commit 818add06f349874501cc44baf332dc63dfdcfab1 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 19:08:56 2019 +0000 Install spatie’s commonmark highlighter, use it for notes commit fb69d98b2bd3bb56540854fe16200c027e5ef6b2 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 18:54:27 2019 +0000 Remove links to prism code in the notes pages commit dc89fcd4711b25e8407be9b25b58cd4cd1e9980e Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 18:54:11 2019 +0000 Add a note to the seeder which has a code block
This commit is contained in:
parent
ffa9756cb7
commit
427b79f278
103 changed files with 287 additions and 251 deletions
|
@ -4,11 +4,16 @@ declare(strict_types=1);
|
|||
|
||||
namespace App\Models;
|
||||
|
||||
use League\CommonMark\Environment;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Cviebrock\EloquentSluggable\Sluggable;
|
||||
use League\CommonMark\CommonMarkConverter;
|
||||
use Illuminate\Database\Eloquent\SoftDeletes;
|
||||
use League\CommonMark\Block\Element\FencedCode;
|
||||
use League\CommonMark\Block\Element\IndentedCode;
|
||||
use Spatie\CommonMarkHighlighter\FencedCodeRenderer;
|
||||
use Spatie\CommonMarkHighlighter\IndentedCodeRenderer;
|
||||
|
||||
class Article extends Model
|
||||
{
|
||||
|
@ -57,15 +62,12 @@ class Article extends Model
|
|||
*/
|
||||
public function getHtmlAttribute(): string
|
||||
{
|
||||
$markdown = new CommonMarkConverter();
|
||||
$html = $markdown->convertToHtml($this->main);
|
||||
// changes <pre><code>[lang] ~> <pre><code data-language="lang">
|
||||
$match = '/<pre><code>\[(.*)\]\n/';
|
||||
$replace = '<pre><code class="language-$1">';
|
||||
$text = preg_replace($match, $replace, $html);
|
||||
$default = preg_replace('/<pre><code>/', '<pre><code class="language-markdown">', $text);
|
||||
$environment = Environment::createCommonMarkEnvironment();
|
||||
$environment->addBlockRenderer(FencedCode::class, new FencedCodeRenderer());
|
||||
$environment->addBlockRenderer(IndentedCode::class, new IndentedCodeRenderer());
|
||||
$commonMarkConverter = new CommonMarkConverter([], $environment);
|
||||
|
||||
return $default;
|
||||
return $commonMarkConverter->convertToHtml($this->main);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -9,17 +9,19 @@ use Twitter;
|
|||
use Normalizer;
|
||||
use GuzzleHttp\Client;
|
||||
use Laravel\Scout\Searchable;
|
||||
use League\CommonMark\Converter;
|
||||
use League\CommonMark\DocParser;
|
||||
use Jonnybarnes\IndieWeb\Numbers;
|
||||
use League\CommonMark\Environment;
|
||||
use League\CommonMark\HtmlRenderer;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Jonnybarnes\EmojiA11y\EmojiModifier;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use League\CommonMark\CommonMarkConverter;
|
||||
use App\Exceptions\TwitterContentException;
|
||||
use Illuminate\Database\Eloquent\SoftDeletes;
|
||||
use League\CommonMark\Block\Element\FencedCode;
|
||||
use League\CommonMark\Block\Element\IndentedCode;
|
||||
use Jonnybarnes\CommonmarkLinkify\LinkifyExtension;
|
||||
use Spatie\CommonMarkHighlighter\FencedCodeRenderer;
|
||||
use Spatie\CommonMarkHighlighter\IndentedCodeRenderer;
|
||||
|
||||
class Note extends Model
|
||||
{
|
||||
|
@ -513,7 +515,9 @@ class Note extends Model
|
|||
{
|
||||
$environment = Environment::createCommonMarkEnvironment();
|
||||
$environment->addExtension(new LinkifyExtension());
|
||||
$converter = new Converter(new DocParser($environment), new HtmlRenderer($environment));
|
||||
$environment->addBlockRenderer(FencedCode::class, new FencedCodeRenderer());
|
||||
$environment->addBlockRenderer(IndentedCode::class, new IndentedCodeRenderer());
|
||||
$converter = new CommonMarkConverter([], $environment);
|
||||
|
||||
return $converter->convertToHtml($note);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue