diff options
| author | Armand Philippot <git@armandphilippot.com> | 2021-12-30 19:47:21 +0100 |
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2021-12-30 19:47:21 +0100 |
| commit | a98b5ea6fe8e8cc98a55e0fd793e6e8660ea31c1 (patch) | |
| tree | 542810ab5aef99150db228bb54fd58303dcb31c7 /public/prism/prism-liquid.js | |
| parent | ab355897a12b7bda1089a44de326d41455a0f7a3 (diff) | |
chore: add prismjs for syntax highlighting
Diffstat (limited to 'public/prism/prism-liquid.js')
| -rw-r--r-- | public/prism/prism-liquid.js | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/public/prism/prism-liquid.js b/public/prism/prism-liquid.js new file mode 100644 index 0000000..7e9d029 --- /dev/null +++ b/public/prism/prism-liquid.js @@ -0,0 +1,74 @@ +Prism.languages.liquid = { + comment: { + pattern: /(^\{%\s*comment\s*%\})[\s\S]+(?=\{%\s*endcomment\s*%\}$)/, + lookbehind: true, + }, + delimiter: { + pattern: /^\{(?:\{\{|[%\{])-?|-?(?:\}\}|[%\}])\}$/, + alias: 'punctuation', + }, + string: { + pattern: /"[^"]*"|'[^']*'/, + greedy: true, + }, + keyword: + /\b(?:as|assign|break|(?:end)?(?:capture|case|comment|for|form|if|paginate|raw|style|tablerow|unless)|continue|cycle|decrement|echo|else|elsif|in|include|increment|limit|liquid|offset|range|render|reversed|section|when|with)\b/, + object: + /\b(?:address|all_country_option_tags|article|block|blog|cart|checkout|collection|color|country|country_option_tags|currency|current_page|current_tags|customer|customer_address|date|discount_allocation|discount_application|external_video|filter|filter_value|font|forloop|fulfillment|generic_file|gift_card|group|handle|image|line_item|link|linklist|localization|location|measurement|media|metafield|model|model_source|order|page|page_description|page_image|page_title|part|policy|product|product_option|recommendations|request|robots|routes|rule|script|search|selling_plan|selling_plan_allocation|selling_plan_group|shipping_method|shop|shop_locale|sitemap|store_availability|tax_line|template|theme|transaction|unit_price_measurement|user_agent|variant|video|video_source)\b/, + function: [ + { + pattern: /(\|\s*)\w+/, + lookbehind: true, + alias: 'filter', + }, + { + // array functions + pattern: /(\.\s*)(?:first|last|size)/, + lookbehind: true, + }, + ], + boolean: /\b(?:false|nil|true)\b/, + range: { + pattern: /\.\./, + alias: 'operator', + }, + // https://github.com/Shopify/liquid/blob/698f5e0d967423e013f6169d9111bd969bd78337/lib/liquid/lexer.rb#L21 + number: /\b\d+(?:\.\d+)?\b/, + operator: /[!=]=|<>|[<>]=?|[|?:=-]|\b(?:and|contains(?=\s)|or)\b/, + punctuation: /[.,\[\]()]/, + empty: { + pattern: /\bempty\b/, + alias: 'keyword', + }, +}; + +Prism.hooks.add('before-tokenize', function (env) { + var liquidPattern = + /\{%\s*comment\s*%\}[\s\S]*?\{%\s*endcomment\s*%\}|\{(?:%[\s\S]*?%|\{\{[\s\S]*?\}\}|\{[\s\S]*?\})\}/g; + var insideRaw = false; + + Prism.languages['markup-templating'].buildPlaceholders( + env, + 'liquid', + liquidPattern, + function (match) { + var tagMatch = /^\{%-?\s*(\w+)/.exec(match); + if (tagMatch) { + var tag = tagMatch[1]; + if (tag === 'raw' && !insideRaw) { + insideRaw = true; + return true; + } else if (tag === 'endraw') { + insideRaw = false; + return true; + } + } + + return !insideRaw; + } + ); +}); + +Prism.hooks.add('after-tokenize', function (env) { + Prism.languages['markup-templating'].tokenizePlaceholders(env, 'liquid'); +}); |
