2022-08-03 09:09:44 +04:00
|
|
|
; inherits: ecma
|
2022-04-02 05:07:35 +04:00
|
|
|
|
|
|
|
; Highlight component names differently
|
|
|
|
(jsx_opening_element ((identifier) @constructor
|
|
|
|
(#match? @constructor "^[A-Z]")))
|
|
|
|
|
|
|
|
; Handle the dot operator effectively - <My.Component>
|
|
|
|
(jsx_opening_element ((nested_identifier (identifier) @tag (identifier) @constructor)))
|
|
|
|
|
|
|
|
(jsx_closing_element ((identifier) @constructor
|
|
|
|
(#match? @constructor "^[A-Z]")))
|
|
|
|
|
|
|
|
; Handle the dot operator effectively - </My.Component>
|
|
|
|
(jsx_closing_element ((nested_identifier (identifier) @tag (identifier) @constructor)))
|
|
|
|
|
|
|
|
(jsx_self_closing_element ((identifier) @constructor
|
|
|
|
(#match? @constructor "^[A-Z]")))
|
|
|
|
|
|
|
|
; Handle the dot operator effectively - <My.Component />
|
|
|
|
(jsx_self_closing_element ((nested_identifier (identifier) @tag (identifier) @constructor)))
|
|
|
|
|
|
|
|
; TODO: also tag @punctuation.delimiter?
|
|
|
|
|
|
|
|
(jsx_opening_element (identifier) @tag)
|
|
|
|
(jsx_closing_element (identifier) @tag)
|
|
|
|
(jsx_self_closing_element (identifier) @tag)
|
|
|
|
(jsx_attribute (property_identifier) @variable.other.member)
|