From 006b15b467a5cd835a6eab1b49023100bdc8f2e6 Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Fri, 13 Oct 2023 19:32:56 +0200 Subject: 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. --- public/prism/prism-cooklang.js | 140 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 140 insertions(+) create mode 100644 public/prism/prism-cooklang.js (limited to 'public/prism/prism-cooklang.js') 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); -- cgit v1.2.3