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-cooklang.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-cooklang.js')
| -rw-r--r-- | public/prism/prism-cooklang.js | 140 |
1 files changed, 140 insertions, 0 deletions
diff --git a/public/prism/prism-cooklang.js b/public/prism/prism-cooklang.js new file mode 100644 index 0000000..445d856 --- /dev/null +++ b/public/prism/prism-cooklang.js @@ -0,0 +1,140 @@ +(function (Prism) { + // see https://github.com/cooklang/spec/blob/main/EBNF.md + + var single_token_suffix = /(?:(?!\s)[\d$+<=a-zA-Z\x80-\uFFFF])+/.source; + var multi_token_infix = /[^{}@#]+/.source; + var multi_token_suffix = /\{[^}#@]*\}/.source; + + var multi_token = multi_token_infix + multi_token_suffix; + + var timer_units = /(?:h|hours|hrs|m|min|minutes)/.source; + + var amount_group_impl = { + pattern: /\{[^{}]*\}/, + inside: { + amount: { + pattern: /([\{|])[^{}|*%]+/, + lookbehind: true, + alias: 'number', + }, + unit: { + pattern: /(%)[^}]+/, + lookbehind: true, + alias: 'symbol', + }, + 'servings-scaler': { + pattern: /\*/, + alias: 'operator', + }, + 'servings-alternative-separator': { + pattern: /\|/, + alias: 'operator', + }, + 'unit-separator': { + pattern: /(?:%|(\*)%)/, + lookbehind: true, + alias: 'operator', + }, + punctuation: /[{}]/, + }, + }; + + Prism.languages.cooklang = { + comment: { + // [- comment -] + // -- comment + pattern: /\[-[\s\S]*?-\]|--.*/, + greedy: true, + }, + meta: { + // >> key: value + pattern: />>.*:.*/, + inside: { + property: { + // key: + pattern: /(>>\s*)[^\s:](?:[^:]*[^\s:])?/, + lookbehind: true, + }, + }, + }, + 'cookware-group': { + // #...{...}, #... + pattern: new RegExp( + '#(?:' + multi_token + '|' + single_token_suffix + ')' + ), + inside: { + cookware: { + pattern: new RegExp('(^#)(?:' + multi_token_infix + ')'), + lookbehind: true, + alias: 'variable', + }, + 'cookware-keyword': { + pattern: /^#/, + alias: 'keyword', + }, + 'quantity-group': { + pattern: new RegExp(/\{[^{}@#]*\}/), + inside: { + quantity: { + pattern: new RegExp(/(^\{)/.source + multi_token_infix), + lookbehind: true, + alias: 'number', + }, + punctuation: /[{}]/, + }, + }, + }, + }, + 'ingredient-group': { + // @...{...}, @... + pattern: new RegExp( + '@(?:' + multi_token + '|' + single_token_suffix + ')' + ), + inside: { + ingredient: { + pattern: new RegExp('(^@)(?:' + multi_token_infix + ')'), + lookbehind: true, + alias: 'variable', + }, + 'ingredient-keyword': { + pattern: /^@/, + alias: 'keyword', + }, + 'amount-group': amount_group_impl, + }, + }, + 'timer-group': { + // ~timer{...} + // eslint-disable-next-line regexp/sort-alternatives + pattern: /~(?!\s)[^@#~{}]*\{[^{}]*\}/, + inside: { + timer: { + pattern: /(^~)[^{]+/, + lookbehind: true, + alias: 'variable', + }, + 'duration-group': { + // {...} + pattern: /\{[^{}]*\}/, + inside: { + punctuation: /[{}]/, + unit: { + pattern: new RegExp(/(%\s*)/.source + timer_units + /\b/.source), + lookbehind: true, + alias: 'symbol', + }, + operator: /%/, + duration: { + pattern: /\d+/, + alias: 'number', + }, + }, + }, + 'timer-keyword': { + pattern: /^~/, + alias: 'keyword', + }, + }, + }, + }; +})(Prism); |
