12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- // CodeMirror, copyright (c) by Marijn Haverbeke and others
- // Distributed under an MIT license: https://codemirror.net/LICENSE
- (function() {
- var mode = CodeMirror.getMode({indentUnit: 2}, "jsx")
- function MT(name) { test.mode(name, mode, Array.prototype.slice.call(arguments, 1)) }
- MT("selfclose",
- "[keyword var] [def x] [operator =] [bracket&tag <] [tag foo] [bracket&tag />] [operator +] [number 1];")
- MT("openclose",
- "([bracket&tag <][tag foo][bracket&tag >]hello [atom &][bracket&tag </][tag foo][bracket&tag >][operator ++])")
- MT("openclosefragment",
- "([bracket&tag <><][tag foo][bracket&tag >]hello [atom &][bracket&tag </][tag foo][bracket&tag ></>][operator ++])")
- MT("attr",
- "([bracket&tag <][tag foo] [attribute abc]=[string 'value'][bracket&tag >]hello [atom &][bracket&tag </][tag foo][bracket&tag >][operator ++])")
- MT("braced_attr",
- "([bracket&tag <][tag foo] [attribute abc]={[number 10]}[bracket&tag >]hello [atom &][bracket&tag </][tag foo][bracket&tag >][operator ++])")
- MT("braced_text",
- "([bracket&tag <][tag foo][bracket&tag >]hello {[number 10]} [atom &][bracket&tag </][tag foo][bracket&tag >][operator ++])")
- MT("nested_tag",
- "([bracket&tag <][tag foo][bracket&tag ><][tag bar][bracket&tag ></][tag bar][bracket&tag ></][tag foo][bracket&tag >][operator ++])")
- MT("nested_jsx",
- "[keyword return] (",
- " [bracket&tag <][tag foo][bracket&tag >]",
- " say {[number 1] [operator +] [bracket&tag <][tag bar] [attribute attr]={[number 10]}[bracket&tag />]}!",
- " [bracket&tag </][tag foo][bracket&tag >][operator ++]",
- ")")
- MT("preserve_js_context",
- "[variable x] [operator =] [string-2 `quasi${][bracket&tag <][tag foo][bracket&tag />][string-2 }quoted`]")
- MT("string_interpolation",
- "[variable x] [operator =] [string-2 `quasi<code>${] [number 10] [string-2 }</code>`]")
- MT("line_comment",
- "([bracket&tag <][tag foo] [comment // hello]",
- " [bracket&tag ></][tag foo][bracket&tag >][operator ++])")
- MT("line_comment_not_in_tag",
- "([bracket&tag <][tag foo][bracket&tag >] // hello",
- " [bracket&tag </][tag foo][bracket&tag >][operator ++])")
- MT("block_comment",
- "([bracket&tag <][tag foo] [comment /* hello]",
- "[comment line 2]",
- "[comment line 3 */] [bracket&tag ></][tag foo][bracket&tag >][operator ++])")
- MT("block_comment_not_in_tag",
- "([bracket&tag <][tag foo][bracket&tag >]/* hello",
- " line 2",
- " line 3 */ [bracket&tag </][tag foo][bracket&tag >][operator ++])")
- MT("missing_attr",
- "([bracket&tag <][tag foo] [attribute selected][bracket&tag />][operator ++])")
- MT("indent_js",
- "([bracket&tag <][tag foo][bracket&tag >]",
- " [bracket&tag <][tag bar] [attribute baz]={[keyword function]() {",
- " [keyword return] [number 10]",
- " }}[bracket&tag />]",
- " [bracket&tag </][tag foo][bracket&tag >])")
- MT("spread",
- "([bracket&tag <][tag foo] [attribute bar]={[meta ...][variable baz] [operator /][number 2]}[bracket&tag />])")
- MT("tag_attribute",
- "([bracket&tag <][tag foo] [attribute bar]=[bracket&tag <][tag foo][bracket&tag />/>][operator ++])")
- var ts_mode = CodeMirror.getMode({indentUnit: 2}, "text/typescript-jsx")
- function TS(name) { test.mode(name, ts_mode, Array.prototype.slice.call(arguments, 1)) }
- TS("tsx_react_integration",
- "[keyword interface] [def Props] {",
- " [property foo]: [type string];",
- "}",
- "[keyword class] [def MyComponent] [keyword extends] [type React].[type Component] [operator <] [type Props], [type any] [operator >] {",
- " [property render]() {",
- " [keyword return] [bracket&tag <][tag span][bracket&tag >]{[keyword this].[property props].[property foo]}[bracket&tag </][tag span][bracket&tag >]",
- " }",
- "}",
- "[bracket&tag <][tag MyComponent] [attribute foo]=[string \"bar\"] [bracket&tag />]; [comment //ok]",
- "[bracket&tag <][tag MyComponent] [attribute foo]={[number 0]} [bracket&tag />]; [comment //error]")
- })()
|