aboutsummaryrefslogtreecommitdiffstats
path: root/public/prism/prism-cooklang.js
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2023-10-13 19:32:56 +0200
committerArmand Philippot <git@armandphilippot.com>2023-11-11 18:14:41 +0100
commit006b15b467a5cd835a6eab1b49023100bdc8f2e6 (patch)
tree949c7295c2e206f42357f135bab4696ddf6576ec /public/prism/prism-cooklang.js
parent00f147a7a687d5772bcc538bc606cfff972178cd (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.js140
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);