2018-05-08 13:28:33 -04:00
|
|
|
if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'graphql') == -1
|
|
|
|
|
|
|
|
if exists('b:current_syntax')
|
|
|
|
let s:current_syntax = b:current_syntax
|
|
|
|
unlet b:current_syntax
|
|
|
|
endif
|
|
|
|
syn include @GraphQLSyntax syntax/graphql.vim
|
|
|
|
if exists('s:current_syntax')
|
|
|
|
let b:current_syntax = s:current_syntax
|
|
|
|
endif
|
|
|
|
|
2018-07-08 09:16:28 -04:00
|
|
|
let s:tags = '\%(' . join(g:graphql_javascript_tags, '\|') . '\)'
|
|
|
|
|
|
|
|
exec 'syntax region graphqlTemplateString start=+' . s:tags . '\@20<=`+ skip=+\\`+ end=+`+ contains=@GraphQLSyntax,jsTemplateExpression,jsSpecial extend'
|
|
|
|
exec 'syntax match graphqlTaggedTemplate +' . s:tags . '\ze`+ nextgroup=graphqlTemplateString'
|
|
|
|
|
|
|
|
" Support expression interpolation ((${...})) inside template strings.
|
|
|
|
syntax region graphqlTemplateExpression start=+${+ end=+}+ contained contains=jsTemplateExpression containedin=graphqlFold keepend
|
2018-05-08 13:28:33 -04:00
|
|
|
|
|
|
|
hi def link graphqlTemplateString jsTemplateString
|
|
|
|
hi def link graphqlTaggedTemplate jsTaggedTemplate
|
2018-07-08 09:16:28 -04:00
|
|
|
hi def link graphqlTemplateExpression jsTemplateExpression
|
2018-05-08 13:28:33 -04:00
|
|
|
|
|
|
|
syn cluster jsExpression add=graphqlTaggedTemplate
|
|
|
|
syn cluster graphqlTaggedTemplate add=graphqlTemplateString
|
|
|
|
|
|
|
|
endif
|