-
-
Notifications
You must be signed in to change notification settings - Fork 34
/
liquid.js
79 lines (78 loc) · 3.07 KB
/
liquid.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
// @ts-nocheck
import refractorMarkupTemplating from './markup-templating.js'
liquid.displayName = 'liquid'
liquid.aliases = []
/** @type {import('../core.js').Syntax} */
export default function liquid(Prism) {
Prism.register(refractorMarkupTemplating)
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')
})
}