diff options
| author | Armand Philippot <git@armandphilippot.com> | 2023-10-13 19:32:56 +0200 |
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2023-11-11 18:14:41 +0100 |
| commit | 006b15b467a5cd835a6eab1b49023100bdc8f2e6 (patch) | |
| tree | 949c7295c2e206f42357f135bab4696ddf6576ec /public/prism/prism-soy.min.js | |
| parent | 00f147a7a687d5772bcc538bc606cfff972178cd (diff) | |
refactor(components): rewrite Code component and usePrism hook
* move Prism styles to Sass placeholders to avoid repeats
* let usePrism consumer define its plugins (remove default ones)
* remove `plugins` prop from Code component
* add new props to Code component to let consumer configure plugins
(and handle plugin list from the given options)
However there are some problems with Prism plugins: line-highlight and
treeview does not seems to be loaded. I don't want to use Babel instead
of SWC so I have no solution for now.
Diffstat (limited to 'public/prism/prism-soy.min.js')
| -rw-r--r-- | public/prism/prism-soy.min.js | 32 |
1 files changed, 16 insertions, 16 deletions
diff --git a/public/prism/prism-soy.min.js b/public/prism/prism-soy.min.js index 22f1d2a..1e66bc2 100644 --- a/public/prism/prism-soy.min.js +++ b/public/prism/prism-soy.min.js @@ -1,7 +1,7 @@ -!(function (t) { - var e = /(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/, - a = /\b\d+(?:\.\d+)?(?:[eE][+-]?\d+)?\b|\b0x[\dA-F]+\b/; - (t.languages.soy = { +!(function (e) { + var a = /(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/, + t = /\b\d+(?:\.\d+)?(?:[eE][+-]?\d+)?\b|\b0x[\dA-F]+\b/; + (e.languages.soy = { comment: [ /\/\*[\s\S]*?\*\//, { pattern: /(\s)\/\/.*/, lookbehind: !0, greedy: !0 }, @@ -31,33 +31,33 @@ variable: { pattern: /\$[^\W\d]\w*(?:\??(?:\.\w+|\[[^\]]+\]))*/, inside: { - string: { pattern: e, greedy: !0 }, - number: a, + string: { pattern: a, greedy: !0 }, + number: t, punctuation: /[\[\].?]/, }, }, - string: { pattern: e, greedy: !0 }, + string: { pattern: a, greedy: !0 }, function: [/\w+(?=\()/, { pattern: /(\|[^\S\r\n]*)\w+/, lookbehind: !0 }], boolean: /\b(?:false|true)\b/, - number: a, + number: t, operator: /\?:?|<=?|>=?|==?|!=|[+*/%-]|\b(?:and|not|or)\b/, punctuation: /[{}()\[\]|.,:]/, }), - t.hooks.add('before-tokenize', function (e) { - var a = !1; - t.languages['markup-templating'].buildPlaceholders( - e, + e.hooks.add('before-tokenize', function (a) { + var t = !1; + e.languages['markup-templating'].buildPlaceholders( + a, 'soy', /\{\{.+?\}\}|\{.+?\}|\s\/\/.*|\/\*[\s\S]*?\*\//g, function (e) { return ( - '{/literal}' === e && (a = !1), - !a && ('{literal}' === e && (a = !0), !0) + '{/literal}' === e && (t = !1), + !t && ('{literal}' === e && (t = !0), !0) ); } ); }), - t.hooks.add('after-tokenize', function (e) { - t.languages['markup-templating'].tokenizePlaceholders(e, 'soy'); + e.hooks.add('after-tokenize', function (a) { + e.languages['markup-templating'].tokenizePlaceholders(a, 'soy'); }); })(Prism); |
