@zohodesk/components 1.0.0-alpha-238 → 1.0.0-alpha-239

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (242) hide show
  1. package/README.md +5 -0
  2. package/assets/Appearance/pureDark/mode/pureDarkMode.module.css +10 -10
  3. package/assets/Appearance/pureDark/themes/blue/bluePureDarkComponentTheme.module.css +2 -2
  4. package/assets/Appearance/pureDark/themes/green/greenPureDarkComponentTheme.module.css +2 -2
  5. package/assets/Appearance/pureDark/themes/orange/orangePureDarkComponentTheme.module.css +2 -2
  6. package/assets/Appearance/pureDark/themes/red/redPureDarkComponentTheme.module.css +2 -2
  7. package/assets/Appearance/pureDark/themes/yellow/yellowPureDarkComponentTheme.module.css +2 -2
  8. package/docs/external/active-line.js +72 -0
  9. package/docs/external/autorefresh.js +47 -0
  10. package/docs/external/codemirror.js +9681 -0
  11. package/docs/external/css/hopscotch.css +576 -0
  12. package/docs/external/css/styleGuide.css +1100 -0
  13. package/docs/external/css.js +466 -0
  14. package/docs/external/designTokens.js +1 -0
  15. package/docs/external/foldcode.js +152 -0
  16. package/docs/external/format.js +129 -0
  17. package/docs/external/htmlmixed.js +84 -0
  18. package/docs/external/images/bottom.png +0 -0
  19. package/docs/external/images/bottombg.jpg +0 -0
  20. package/docs/external/images/desk.png +0 -0
  21. package/docs/external/images/desklogo.png +0 -0
  22. package/docs/external/images/menu.png +0 -0
  23. package/docs/external/index.html +127 -0
  24. package/docs/external/javascript.js +422 -0
  25. package/docs/external/jsx.js +148 -0
  26. package/docs/external/matchbrackets.js +145 -0
  27. package/docs/external/xml.js +322 -0
  28. package/docs/package.json +41 -0
  29. package/docs/src/index.js +1311 -0
  30. package/es/Accordion/docs/Accordion__Demo.docs.js +80 -0
  31. package/es/Animation/docs/Animation__default.docs.js +34 -0
  32. package/es/Animation/docs/Animation__fadeIn.docs.js +34 -0
  33. package/es/Animation/docs/Animation__scaleIn.docs.js +34 -0
  34. package/es/Animation/docs/Animation__skewIn.docs.js +34 -0
  35. package/es/Animation/docs/Animation__slideDown.docs.js +34 -0
  36. package/es/Animation/docs/Animation__slideLeft.docs.js +34 -0
  37. package/es/Animation/docs/Animation__zoomIn.docs.js +34 -0
  38. package/es/AppContainer/docs/AppContainer__default.docs.js +20 -0
  39. package/es/Avatar/docs/Avatar__custom.docs.js +29 -0
  40. package/es/Avatar/docs/Avatar__default.docs.js +29 -0
  41. package/es/Avatar/docs/Avatar__palette.docs.js +49 -0
  42. package/es/Avatar/docs/Avatar__text.docs.js +28 -0
  43. package/es/AvatarTeam/docs/AvatarTeam__custom.docs.js +73 -0
  44. package/es/AvatarTeam/docs/AvatarTeam__default.docs.js +31 -0
  45. package/es/AvatarTeam/docs/AvatarTeam__palette.docs.js +50 -0
  46. package/es/AvatarTeam/docs/AvatarTeam__size.docs.js +49 -0
  47. package/es/Button/docs/Button__custom.docs.js +771 -0
  48. package/es/Button/docs/Button__default.docs.js +536 -0
  49. package/es/Buttongroup/docs/Buttongroup__custom.docs.js +37 -0
  50. package/es/Buttongroup/docs/Buttongroup__footer.docs.js +33 -0
  51. package/es/Buttongroup/docs/Buttongroup__header.docs.js +42 -0
  52. package/es/Card/docs/Card__Custom.docs.js +34 -0
  53. package/es/Card/docs/Card__Default.docs.js +37 -0
  54. package/es/Card/docs/Card__Scroll.docs.js +59 -0
  55. package/es/CheckBox/docs/CheckBox__custom.docs.js +293 -0
  56. package/es/CheckBox/docs/CheckBox__default.docs.js +219 -0
  57. package/es/DateTime/DateTime.js +8 -2
  58. package/es/DateTime/DateWidget.js +10 -2
  59. package/es/DateTime/docs/DateTime__default.docs.js +91 -0
  60. package/es/DateTime/docs/DateWidget__default.docs.js +183 -0
  61. package/es/DateTime/docs/timezonedata.json +1 -0
  62. package/es/DropBox/docs/DropBox__custom.docs.js +66 -0
  63. package/es/DropBox/docs/DropBox__customOrder.docs.js +92 -0
  64. package/es/DropBox/docs/DropBox__fixedPosition.docs.js +91 -0
  65. package/es/DropBox/docs/DropBox__position.docs.js +87 -0
  66. package/es/DropBox/docs/DropBox__size.docs.js +61 -0
  67. package/es/DropDown/docs/DropDownHeading__custom.docs.js +23 -0
  68. package/es/DropDown/docs/DropDownHeading__default.docs.js +21 -0
  69. package/es/Label/docs/Label__clipped.docs.js +27 -0
  70. package/es/Label/docs/Label__custom.docs.js +30 -0
  71. package/es/Label/docs/Label__palette.docs.js +42 -0
  72. package/es/Label/docs/Label__size.docs.js +29 -0
  73. package/es/Label/docs/Label__type.docs.js +37 -0
  74. package/es/Layout/docs/Layout__Hidden.docs.js +77 -0
  75. package/es/Layout/docs/Layout__default.docs.js +49 -0
  76. package/es/Layout/docs/Layout__four_Column.docs.js +85 -0
  77. package/es/Layout/docs/Layout__three_Column.docs.js +76 -0
  78. package/es/Layout/docs/Layout__two_Column.docs.js +69 -0
  79. package/es/LightNightMode/docs/AlternativeColors.docs.js +74 -0
  80. package/es/ListItem/docs/ListItemWithAvatar__custom.docs.js +155 -0
  81. package/es/ListItem/docs/ListItemWithAvatar__default.docs.js +112 -0
  82. package/es/ListItem/docs/ListItemWithCheckBox__custom.docs.js +91 -0
  83. package/es/ListItem/docs/ListItemWithCheckBox__default.docs.js +65 -0
  84. package/es/ListItem/docs/ListItemWithIcon__custom.docs.js +68 -0
  85. package/es/ListItem/docs/ListItemWithIcon__default.docs.js +62 -0
  86. package/es/ListItem/docs/ListItemWithRadio__custom.docs.js +91 -0
  87. package/es/ListItem/docs/ListItemWithRadio__default.docs.js +65 -0
  88. package/es/ListItem/docs/ListItem__custom.docs.js +114 -0
  89. package/es/ListItem/docs/ListItem__default.docs.js +82 -0
  90. package/es/MultiSelect/docs/AdvancedGroupMultiSelect__default.docs.js +125 -0
  91. package/es/MultiSelect/docs/AdvancedMultiSelect__default.docs.js +114 -0
  92. package/es/MultiSelect/docs/MultiSelectWithAvatar__default.docs.js +141 -0
  93. package/es/MultiSelect/docs/MultiSelect__default.docs.js +161 -0
  94. package/es/PopOver/docs/PopOver__default.docs.js +32 -0
  95. package/es/Provider/docs/Provider_Id__Class.docs.js +29 -0
  96. package/es/Provider/docs/Provider_Id__Function.docs.js +18 -0
  97. package/es/Provider/docs/Provider_Zindex__Class.docs.js +32 -0
  98. package/es/Provider/docs/Provider_Zindex__Function.docs.js +23 -0
  99. package/es/Radio/docs/Radio__custom.docs.js +245 -0
  100. package/es/Radio/docs/Radio__default.docs.js +169 -0
  101. package/es/Responsive/docs/Responsive__Custom.docs.js +206 -0
  102. package/es/Responsive/docs/Responsive__default.docs.js +97 -0
  103. package/es/Responsive/docs/style.module.css +56 -0
  104. package/es/Ribbon/docs/Ribbon__custom.docs.js +386 -0
  105. package/es/Ribbon/docs/Ribbon__default.docs.js +342 -0
  106. package/es/RippleEffect/docs/RippleEffect__default.docs.js +435 -0
  107. package/es/Select/docs/GroupSelect__default.docs.js +149 -0
  108. package/es/Select/docs/SelectWithAvatar__default.docs.js +97 -0
  109. package/es/Select/docs/SelectWithIcon__default.docs.js +138 -0
  110. package/es/Select/docs/Select__default.docs.js +288 -0
  111. package/es/Stencils/docs/Stencils__custom.docs.js +45 -0
  112. package/es/Stencils/docs/Stencils__default.docs.js +50 -0
  113. package/es/Switch/docs/Switch__custom.docs.js +153 -0
  114. package/es/Switch/docs/Switch__default.docs.js +107 -0
  115. package/es/Tab/docs/Tab__default.docs.js +258 -0
  116. package/es/Tab/docs/tabdocs.module.css +29 -0
  117. package/es/Tag/docs/Tag__custom.docs.js +368 -0
  118. package/es/Tag/docs/Tag__default.docs.js +323 -0
  119. package/es/TextBox/docs/TextBox__custom.docs.js +43 -0
  120. package/es/TextBox/docs/TextBox__default.docs.js +40 -0
  121. package/es/TextBox/docs/TextBox__size.docs.js +38 -0
  122. package/es/TextBox/docs/TextBox__variant.docs.js +38 -0
  123. package/es/TextBoxIcon/docs/TextBoxIcon__custom.docs.js +89 -0
  124. package/es/TextBoxIcon/docs/TextBoxIcon__default.docs.js +61 -0
  125. package/es/Textarea/docs/Textarea__animated.docs.js +41 -0
  126. package/es/Textarea/docs/Textarea__custom.docs.js +82 -0
  127. package/es/Textarea/docs/Textarea__default.docs.js +76 -0
  128. package/es/Textarea/docs/Textarea__disabled.docs.js +29 -0
  129. package/es/Tooltip/docs/Tooltip__default.docs.js +371 -0
  130. package/es/VelocityAnimation/VelocityAnimation/docs/VelocityAnimation__demo.docs.js +97 -0
  131. package/es/VelocityAnimation/VelocityAnimationGroup/docs/VelocityAnimationGroup__demo.docs.js +150 -0
  132. package/es/a11y/FocusScope/docs/FocusScope__default.docs.js +139 -0
  133. package/es/beta/FocusRing/docs/FocusRing__default.docs.js +48 -0
  134. package/es/deprecated/PortalLayer/docs/PortalLayer__default.docs.js +72 -0
  135. package/es/semantic/Button/docs/Button__default.docs.js +20 -0
  136. package/lib/Accordion/docs/Accordion__Demo.docs.js +126 -0
  137. package/lib/Animation/docs/Animation__default.docs.js +85 -0
  138. package/lib/Animation/docs/Animation__fadeIn.docs.js +85 -0
  139. package/lib/Animation/docs/Animation__scaleIn.docs.js +85 -0
  140. package/lib/Animation/docs/Animation__skewIn.docs.js +85 -0
  141. package/lib/Animation/docs/Animation__slideDown.docs.js +85 -0
  142. package/lib/Animation/docs/Animation__slideLeft.docs.js +85 -0
  143. package/lib/Animation/docs/Animation__zoomIn.docs.js +85 -0
  144. package/lib/AppContainer/docs/AppContainer__default.docs.js +70 -0
  145. package/lib/Avatar/docs/Avatar__custom.docs.js +87 -0
  146. package/lib/Avatar/docs/Avatar__default.docs.js +83 -0
  147. package/lib/Avatar/docs/Avatar__palette.docs.js +107 -0
  148. package/lib/Avatar/docs/Avatar__text.docs.js +86 -0
  149. package/lib/AvatarTeam/docs/AvatarTeam__custom.docs.js +124 -0
  150. package/lib/AvatarTeam/docs/AvatarTeam__default.docs.js +82 -0
  151. package/lib/AvatarTeam/docs/AvatarTeam__palette.docs.js +101 -0
  152. package/lib/AvatarTeam/docs/AvatarTeam__size.docs.js +100 -0
  153. package/lib/Button/docs/Button__custom.docs.js +826 -0
  154. package/lib/Button/docs/Button__default.docs.js +590 -0
  155. package/lib/Buttongroup/docs/Buttongroup__custom.docs.js +89 -0
  156. package/lib/Buttongroup/docs/Buttongroup__footer.docs.js +85 -0
  157. package/lib/Buttongroup/docs/Buttongroup__header.docs.js +98 -0
  158. package/lib/Card/docs/Card__Custom.docs.js +90 -0
  159. package/lib/Card/docs/Card__Default.docs.js +92 -0
  160. package/lib/Card/docs/Card__Scroll.docs.js +114 -0
  161. package/lib/CheckBox/docs/CheckBox__custom.docs.js +348 -0
  162. package/lib/CheckBox/docs/CheckBox__default.docs.js +273 -0
  163. package/lib/DateTime/DateTime.js +8 -2
  164. package/lib/DateTime/DateWidget.js +10 -2
  165. package/lib/DateTime/docs/DateTime__default.docs.js +142 -0
  166. package/lib/DateTime/docs/DateWidget__default.docs.js +240 -0
  167. package/lib/DateTime/docs/timezonedata.json +1 -0
  168. package/lib/DropBox/docs/DropBox__custom.docs.js +122 -0
  169. package/lib/DropBox/docs/DropBox__customOrder.docs.js +141 -0
  170. package/lib/DropBox/docs/DropBox__fixedPosition.docs.js +140 -0
  171. package/lib/DropBox/docs/DropBox__position.docs.js +142 -0
  172. package/lib/DropBox/docs/DropBox__size.docs.js +116 -0
  173. package/lib/DropDown/docs/DropDownHeading__custom.docs.js +73 -0
  174. package/lib/DropDown/docs/DropDownHeading__default.docs.js +70 -0
  175. package/lib/Label/docs/Label__clipped.docs.js +81 -0
  176. package/lib/Label/docs/Label__custom.docs.js +85 -0
  177. package/lib/Label/docs/Label__palette.docs.js +96 -0
  178. package/lib/Label/docs/Label__size.docs.js +83 -0
  179. package/lib/Label/docs/Label__type.docs.js +91 -0
  180. package/lib/Layout/docs/Layout__Hidden.docs.js +127 -0
  181. package/lib/Layout/docs/Layout__default.docs.js +98 -0
  182. package/lib/Layout/docs/Layout__four_Column.docs.js +135 -0
  183. package/lib/Layout/docs/Layout__three_Column.docs.js +126 -0
  184. package/lib/Layout/docs/Layout__two_Column.docs.js +119 -0
  185. package/lib/LightNightMode/docs/AlternativeColors.docs.js +131 -0
  186. package/lib/ListItem/docs/ListItemWithAvatar__custom.docs.js +206 -0
  187. package/lib/ListItem/docs/ListItemWithAvatar__default.docs.js +162 -0
  188. package/lib/ListItem/docs/ListItemWithCheckBox__custom.docs.js +142 -0
  189. package/lib/ListItem/docs/ListItemWithCheckBox__default.docs.js +115 -0
  190. package/lib/ListItem/docs/ListItemWithIcon__custom.docs.js +119 -0
  191. package/lib/ListItem/docs/ListItemWithIcon__default.docs.js +112 -0
  192. package/lib/ListItem/docs/ListItemWithRadio__custom.docs.js +142 -0
  193. package/lib/ListItem/docs/ListItemWithRadio__default.docs.js +115 -0
  194. package/lib/ListItem/docs/ListItem__custom.docs.js +164 -0
  195. package/lib/ListItem/docs/ListItem__default.docs.js +131 -0
  196. package/lib/MultiSelect/docs/AdvancedGroupMultiSelect__default.docs.js +177 -0
  197. package/lib/MultiSelect/docs/AdvancedMultiSelect__default.docs.js +165 -0
  198. package/lib/MultiSelect/docs/MultiSelectWithAvatar__default.docs.js +191 -0
  199. package/lib/MultiSelect/docs/MultiSelect__default.docs.js +214 -0
  200. package/lib/PopOver/docs/PopOver__default.docs.js +86 -0
  201. package/lib/Provider/docs/Provider_Id__Class.docs.js +77 -0
  202. package/lib/Provider/docs/Provider_Id__Function.docs.js +29 -0
  203. package/lib/Provider/docs/Provider_Zindex__Class.docs.js +80 -0
  204. package/lib/Provider/docs/Provider_Zindex__Function.docs.js +34 -0
  205. package/lib/Radio/docs/Radio__custom.docs.js +299 -0
  206. package/lib/Radio/docs/Radio__default.docs.js +222 -0
  207. package/lib/Responsive/docs/Responsive__Custom.docs.js +272 -0
  208. package/lib/Responsive/docs/Responsive__default.docs.js +142 -0
  209. package/lib/Responsive/docs/style.module.css +56 -0
  210. package/lib/Ribbon/docs/Ribbon__custom.docs.js +437 -0
  211. package/lib/Ribbon/docs/Ribbon__default.docs.js +392 -0
  212. package/lib/RippleEffect/docs/RippleEffect__default.docs.js +484 -0
  213. package/lib/Select/docs/GroupSelect__default.docs.js +199 -0
  214. package/lib/Select/docs/SelectWithAvatar__default.docs.js +152 -0
  215. package/lib/Select/docs/SelectWithIcon__default.docs.js +190 -0
  216. package/lib/Select/docs/Select__default.docs.js +340 -0
  217. package/lib/Stencils/docs/Stencils__custom.docs.js +96 -0
  218. package/lib/Stencils/docs/Stencils__default.docs.js +101 -0
  219. package/lib/Switch/docs/Switch__custom.docs.js +203 -0
  220. package/lib/Switch/docs/Switch__default.docs.js +156 -0
  221. package/lib/Tab/docs/Tab__default.docs.js +308 -0
  222. package/lib/Tab/docs/tabdocs.module.css +29 -0
  223. package/lib/Tag/docs/Tag__custom.docs.js +423 -0
  224. package/lib/Tag/docs/Tag__default.docs.js +377 -0
  225. package/lib/TextBox/docs/TextBox__custom.docs.js +98 -0
  226. package/lib/TextBox/docs/TextBox__default.docs.js +95 -0
  227. package/lib/TextBox/docs/TextBox__size.docs.js +93 -0
  228. package/lib/TextBox/docs/TextBox__variant.docs.js +93 -0
  229. package/lib/TextBoxIcon/docs/TextBoxIcon__custom.docs.js +145 -0
  230. package/lib/TextBoxIcon/docs/TextBoxIcon__default.docs.js +117 -0
  231. package/lib/Textarea/docs/Textarea__animated.docs.js +95 -0
  232. package/lib/Textarea/docs/Textarea__custom.docs.js +137 -0
  233. package/lib/Textarea/docs/Textarea__default.docs.js +130 -0
  234. package/lib/Textarea/docs/Textarea__disabled.docs.js +83 -0
  235. package/lib/Tooltip/docs/Tooltip__default.docs.js +430 -0
  236. package/lib/VelocityAnimation/VelocityAnimation/docs/VelocityAnimation__demo.docs.js +150 -0
  237. package/lib/VelocityAnimation/VelocityAnimationGroup/docs/VelocityAnimationGroup__demo.docs.js +206 -0
  238. package/lib/a11y/FocusScope/docs/FocusScope__default.docs.js +191 -0
  239. package/lib/beta/FocusRing/docs/FocusRing__default.docs.js +101 -0
  240. package/lib/deprecated/PortalLayer/docs/PortalLayer__default.docs.js +145 -0
  241. package/lib/semantic/Button/docs/Button__default.docs.js +66 -0
  242. package/package.json +1 -1
@@ -0,0 +1,422 @@
1
+ // TODO actually recognize syntax of TypeScript constructs
2
+
3
+ CodeMirror.defineMode("javascript", function(config, parserConfig) {
4
+ var indentUnit = config.indentUnit;
5
+ var jsonMode = parserConfig.json;
6
+ var isTS = parserConfig.typescript;
7
+
8
+ // Tokenizer
9
+
10
+ var keywords = function(){
11
+ function kw(type) {return {type: type, style: "keyword"};}
12
+ var A = kw("keyword a"), B = kw("keyword b"), C = kw("keyword c");
13
+ var operator = kw("operator"), atom = {type: "atom", style: "atom"};
14
+
15
+ var jsKeywords = {
16
+ "if": A, "while": A, "with": A, "else": B, "do": B, "try": B, "finally": B,
17
+ "return": C, "break": C, "continue": C, "new": C, "delete": C, "throw": C,
18
+ "var": kw("var"), "const": kw("var"), "let": kw("var"),
19
+ "function": kw("function"), "catch": kw("catch"),
20
+ "for": kw("for"), "switch": kw("switch"), "case": kw("case"), "default": kw("default"),
21
+ "in": operator, "typeof": operator, "instanceof": operator,
22
+ "true": atom, "false": atom, "null": atom, "undefined": atom, "NaN": atom, "Infinity": atom
23
+ };
24
+
25
+ // Extend the 'normal' keywords with the TypeScript language extensions
26
+ if (isTS) {
27
+ var type = {type: "variable", style: "variable-3"};
28
+ var tsKeywords = {
29
+ // object-like things
30
+ "interface": kw("interface"),
31
+ "class": kw("class"),
32
+ "extends": kw("extends"),
33
+ "constructor": kw("constructor"),
34
+
35
+ // scope modifiers
36
+ "public": kw("public"),
37
+ "private": kw("private"),
38
+ "protected": kw("protected"),
39
+ "static": kw("static"),
40
+
41
+ "super": kw("super"),
42
+
43
+ // types
44
+ "string": type, "number": type, "bool": type, "any": type
45
+ };
46
+
47
+ for (var attr in tsKeywords) {
48
+ jsKeywords[attr] = tsKeywords[attr];
49
+ }
50
+ }
51
+
52
+ return jsKeywords;
53
+ }();
54
+
55
+ var isOperatorChar = /[+\-*&%=<>!?|]/;
56
+
57
+ function chain(stream, state, f) {
58
+ state.tokenize = f;
59
+ return f(stream, state);
60
+ }
61
+
62
+ function nextUntilUnescaped(stream, end) {
63
+ var escaped = false, next;
64
+ while ((next = stream.next()) != null) {
65
+ if (next == end && !escaped)
66
+ return false;
67
+ escaped = !escaped && next == "\\";
68
+ }
69
+ return escaped;
70
+ }
71
+
72
+ // Used as scratch variables to communicate multiple values without
73
+ // consing up tons of objects.
74
+ var type, content;
75
+ function ret(tp, style, cont) {
76
+ type = tp; content = cont;
77
+ return style;
78
+ }
79
+
80
+ function jsTokenBase(stream, state) {
81
+ var ch = stream.next();
82
+ if (ch == '"' || ch == "'")
83
+ return chain(stream, state, jsTokenString(ch));
84
+ else if (/[\[\]{}\(\),;\:\.]/.test(ch))
85
+ return ret(ch);
86
+ else if (ch == "0" && stream.eat(/x/i)) {
87
+ stream.eatWhile(/[\da-f]/i);
88
+ return ret("number", "number");
89
+ }
90
+ else if (/\d/.test(ch) || ch == "-" && stream.eat(/\d/)) {
91
+ stream.match(/^\d*(?:\.\d*)?(?:[eE][+\-]?\d+)?/);
92
+ return ret("number", "number");
93
+ }
94
+ else if (ch == "/") {
95
+ if (stream.eat("*")) {
96
+ return chain(stream, state, jsTokenComment);
97
+ }
98
+ else if (stream.eat("/")) {
99
+ stream.skipToEnd();
100
+ return ret("comment", "comment");
101
+ }
102
+ else if (state.lastType == "operator" || state.lastType == "keyword c" ||
103
+ /^[\[{}\(,;:]$/.test(state.lastType)) {
104
+ nextUntilUnescaped(stream, "/");
105
+ stream.eatWhile(/[gimy]/); // 'y' is "sticky" option in Mozilla
106
+ return ret("regexp", "string-2");
107
+ }
108
+ else {
109
+ stream.eatWhile(isOperatorChar);
110
+ return ret("operator", null, stream.current());
111
+ }
112
+ }
113
+ else if (ch == "#") {
114
+ stream.skipToEnd();
115
+ return ret("error", "error");
116
+ }
117
+ else if (isOperatorChar.test(ch)) {
118
+ stream.eatWhile(isOperatorChar);
119
+ return ret("operator", null, stream.current());
120
+ }
121
+ else {
122
+ stream.eatWhile(/[\w\$_]/);
123
+ var word = stream.current(), known = keywords.propertyIsEnumerable(word) && keywords[word];
124
+ return (known && state.lastType != ".") ? ret(known.type, known.style, word) :
125
+ ret("variable", "variable", word);
126
+ }
127
+ }
128
+
129
+ function jsTokenString(quote) {
130
+ return function(stream, state) {
131
+ if (!nextUntilUnescaped(stream, quote))
132
+ state.tokenize = jsTokenBase;
133
+ return ret("string", "string");
134
+ };
135
+ }
136
+
137
+ function jsTokenComment(stream, state) {
138
+ var maybeEnd = false, ch;
139
+ while (ch = stream.next()) {
140
+ if (ch == "/" && maybeEnd) {
141
+ state.tokenize = jsTokenBase;
142
+ break;
143
+ }
144
+ maybeEnd = (ch == "*");
145
+ }
146
+ return ret("comment", "comment");
147
+ }
148
+
149
+ // Parser
150
+
151
+ var atomicTypes = {"atom": true, "number": true, "variable": true, "string": true, "regexp": true};
152
+
153
+ function JSLexical(indented, column, type, align, prev, info) {
154
+ this.indented = indented;
155
+ this.column = column;
156
+ this.type = type;
157
+ this.prev = prev;
158
+ this.info = info;
159
+ if (align != null) this.align = align;
160
+ }
161
+
162
+ function inScope(state, varname) {
163
+ for (var v = state.localVars; v; v = v.next)
164
+ if (v.name == varname) return true;
165
+ }
166
+
167
+ function parseJS(state, style, type, content, stream) {
168
+ var cc = state.cc;
169
+ // Communicate our context to the combinators.
170
+ // (Less wasteful than consing up a hundred closures on every call.)
171
+ cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc;
172
+
173
+ if (!state.lexical.hasOwnProperty("align"))
174
+ state.lexical.align = true;
175
+
176
+ while(true) {
177
+ var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement;
178
+ if (combinator(type, content)) {
179
+ while(cc.length && cc[cc.length - 1].lex)
180
+ cc.pop()();
181
+ if (cx.marked) return cx.marked;
182
+ if (type == "variable" && inScope(state, content)) return "variable-2";
183
+ return style;
184
+ }
185
+ }
186
+ }
187
+
188
+ // Combinator utils
189
+
190
+ var cx = {state: null, column: null, marked: null, cc: null};
191
+ function pass() {
192
+ for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);
193
+ }
194
+ function cont() {
195
+ pass.apply(null, arguments);
196
+ return true;
197
+ }
198
+ function register(varname) {
199
+ function inList(list) {
200
+ for (var v = list; v; v = v.next)
201
+ if (v.name == varname) return true;
202
+ return false;
203
+ }
204
+ var state = cx.state;
205
+ if (state.context) {
206
+ cx.marked = "def";
207
+ if (inList(state.localVars)) return;
208
+ state.localVars = {name: varname, next: state.localVars};
209
+ } else {
210
+ if (inList(state.globalVars)) return;
211
+ state.globalVars = {name: varname, next: state.globalVars};
212
+ }
213
+ }
214
+
215
+ // Combinators
216
+
217
+ var defaultVars = {name: "this", next: {name: "arguments"}};
218
+ function pushcontext() {
219
+ cx.state.context = {prev: cx.state.context, vars: cx.state.localVars};
220
+ cx.state.localVars = defaultVars;
221
+ }
222
+ function popcontext() {
223
+ cx.state.localVars = cx.state.context.vars;
224
+ cx.state.context = cx.state.context.prev;
225
+ }
226
+ function pushlex(type, info) {
227
+ var result = function() {
228
+ var state = cx.state;
229
+ state.lexical = new JSLexical(state.indented, cx.stream.column(), type, null, state.lexical, info);
230
+ };
231
+ result.lex = true;
232
+ return result;
233
+ }
234
+ function poplex() {
235
+ var state = cx.state;
236
+ if (state.lexical.prev) {
237
+ if (state.lexical.type == ")")
238
+ state.indented = state.lexical.indented;
239
+ state.lexical = state.lexical.prev;
240
+ }
241
+ }
242
+ poplex.lex = true;
243
+
244
+ function expect(wanted) {
245
+ return function expecting(type) {
246
+ if (type == wanted) return cont();
247
+ else if (wanted == ";") return pass();
248
+ else return cont(arguments.callee);
249
+ };
250
+ }
251
+
252
+ function statement(type) {
253
+ if (type == "var") return cont(pushlex("vardef"), vardef1, expect(";"), poplex);
254
+ if (type == "keyword a") return cont(pushlex("form"), expression, statement, poplex);
255
+ if (type == "keyword b") return cont(pushlex("form"), statement, poplex);
256
+ if (type == "{") return cont(pushlex("}"), block, poplex);
257
+ if (type == ";") return cont();
258
+ if (type == "function") return cont(functiondef);
259
+ if (type == "for") return cont(pushlex("form"), expect("("), pushlex(")"), forspec1, expect(")"),
260
+ poplex, statement, poplex);
261
+ if (type == "variable") return cont(pushlex("stat"), maybelabel);
262
+ if (type == "switch") return cont(pushlex("form"), expression, pushlex("}", "switch"), expect("{"),
263
+ block, poplex, poplex);
264
+ if (type == "case") return cont(expression, expect(":"));
265
+ if (type == "default") return cont(expect(":"));
266
+ if (type == "catch") return cont(pushlex("form"), pushcontext, expect("("), funarg, expect(")"),
267
+ statement, poplex, popcontext);
268
+ return pass(pushlex("stat"), expression, expect(";"), poplex);
269
+ }
270
+ function expression(type) {
271
+ if (atomicTypes.hasOwnProperty(type)) return cont(maybeoperator);
272
+ if (type == "function") return cont(functiondef);
273
+ if (type == "keyword c") return cont(maybeexpression);
274
+ if (type == "(") return cont(pushlex(")"), maybeexpression, expect(")"), poplex, maybeoperator);
275
+ if (type == "operator") return cont(expression);
276
+ if (type == "[") return cont(pushlex("]"), commasep(expression, "]"), poplex, maybeoperator);
277
+ if (type == "{") return cont(pushlex("}"), commasep(objprop, "}"), poplex, maybeoperator);
278
+ return cont();
279
+ }
280
+ function maybeexpression(type) {
281
+ if (type.match(/[;\}\)\],]/)) return pass();
282
+ return pass(expression);
283
+ }
284
+
285
+ function maybeoperator(type, value) {
286
+ if (type == "operator" && /\+\+|--/.test(value)) return cont(maybeoperator);
287
+ if (type == "operator" && value == "?") return cont(expression, expect(":"), expression);
288
+ if (type == ";") return;
289
+ if (type == "(") return cont(pushlex(")"), commasep(expression, ")"), poplex, maybeoperator);
290
+ if (type == ".") return cont(property, maybeoperator);
291
+ if (type == "[") return cont(pushlex("]"), expression, expect("]"), poplex, maybeoperator);
292
+ }
293
+ function maybelabel(type) {
294
+ if (type == ":") return cont(poplex, statement);
295
+ return pass(maybeoperator, expect(";"), poplex);
296
+ }
297
+ function property(type) {
298
+ if (type == "variable") {cx.marked = "property"; return cont();}
299
+ }
300
+ function objprop(type) {
301
+ if (type == "variable") cx.marked = "property";
302
+ if (atomicTypes.hasOwnProperty(type)) return cont(expect(":"), expression);
303
+ }
304
+ function commasep(what, end) {
305
+ function proceed(type) {
306
+ if (type == ",") return cont(what, proceed);
307
+ if (type == end) return cont();
308
+ return cont(expect(end));
309
+ }
310
+ return function commaSeparated(type) {
311
+ if (type == end) return cont();
312
+ else return pass(what, proceed);
313
+ };
314
+ }
315
+ function block(type) {
316
+ if (type == "}") return cont();
317
+ return pass(statement, block);
318
+ }
319
+ function maybetype(type) {
320
+ if (type == ":") return cont(typedef);
321
+ return pass();
322
+ }
323
+ function typedef(type) {
324
+ if (type == "variable"){cx.marked = "variable-3"; return cont();}
325
+ return pass();
326
+ }
327
+ function vardef1(type, value) {
328
+ if (type == "variable") {
329
+ register(value);
330
+ return isTS ? cont(maybetype, vardef2) : cont(vardef2);
331
+ }
332
+ return pass();
333
+ }
334
+ function vardef2(type, value) {
335
+ if (value == "=") return cont(expression, vardef2);
336
+ if (type == ",") return cont(vardef1);
337
+ }
338
+ function forspec1(type) {
339
+ if (type == "var") return cont(vardef1, expect(";"), forspec2);
340
+ if (type == ";") return cont(forspec2);
341
+ if (type == "variable") return cont(formaybein);
342
+ return cont(forspec2);
343
+ }
344
+ function formaybein(type, value) {
345
+ if (value == "in") return cont(expression);
346
+ return cont(maybeoperator, forspec2);
347
+ }
348
+ function forspec2(type, value) {
349
+ if (type == ";") return cont(forspec3);
350
+ if (value == "in") return cont(expression);
351
+ return cont(expression, expect(";"), forspec3);
352
+ }
353
+ function forspec3(type) {
354
+ if (type != ")") cont(expression);
355
+ }
356
+ function functiondef(type, value) {
357
+ if (type == "variable") {register(value); return cont(functiondef);}
358
+ if (type == "(") return cont(pushlex(")"), pushcontext, commasep(funarg, ")"), poplex, statement, popcontext);
359
+ }
360
+ function funarg(type, value) {
361
+ if (type == "variable") {register(value); return isTS ? cont(maybetype) : cont();}
362
+ }
363
+
364
+ // Interface
365
+
366
+ return {
367
+ startState: function(basecolumn) {
368
+ return {
369
+ tokenize: jsTokenBase,
370
+ lastType: null,
371
+ cc: [],
372
+ lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, "block", false),
373
+ localVars: parserConfig.localVars,
374
+ globalVars: parserConfig.globalVars,
375
+ context: parserConfig.localVars && {vars: parserConfig.localVars},
376
+ indented: 0
377
+ };
378
+ },
379
+
380
+ token: function(stream, state) {
381
+ if (stream.sol()) {
382
+ if (!state.lexical.hasOwnProperty("align"))
383
+ state.lexical.align = false;
384
+ state.indented = stream.indentation();
385
+ }
386
+ if (stream.eatSpace()) return null;
387
+ var style = state.tokenize(stream, state);
388
+ if (type == "comment") return style;
389
+ state.lastType = type;
390
+ return parseJS(state, style, type, content, stream);
391
+ },
392
+
393
+ indent: function(state, textAfter) {
394
+ if (state.tokenize == jsTokenComment) return CodeMirror.Pass;
395
+ if (state.tokenize != jsTokenBase) return 0;
396
+ var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical;
397
+ if (lexical.type == "stat" && firstChar == "}") lexical = lexical.prev;
398
+ var type = lexical.type, closing = firstChar == type;
399
+ if (type == "vardef") return lexical.indented + (state.lastType == "operator" || state.lastType == "," ? 4 : 0);
400
+ else if (type == "form" && firstChar == "{") return lexical.indented;
401
+ else if (type == "form") return lexical.indented + indentUnit;
402
+ else if (type == "stat")
403
+ return lexical.indented + (state.lastType == "operator" || state.lastType == "," ? indentUnit : 0);
404
+ else if (lexical.info == "switch" && !closing)
405
+ return lexical.indented + (/^(?:case|default)\b/.test(textAfter) ? indentUnit : 2 * indentUnit);
406
+ else if (lexical.align) return lexical.column + (closing ? 0 : 1);
407
+ else return lexical.indented + (closing ? 0 : indentUnit);
408
+ },
409
+
410
+ electricChars: ":{}",
411
+
412
+ jsonMode: jsonMode
413
+ };
414
+ });
415
+
416
+ CodeMirror.defineMIME("text/javascript", "javascript");
417
+ CodeMirror.defineMIME("text/ecmascript", "javascript");
418
+ CodeMirror.defineMIME("application/javascript", "javascript");
419
+ CodeMirror.defineMIME("application/ecmascript", "javascript");
420
+ CodeMirror.defineMIME("application/json", {name: "javascript", json: true});
421
+ CodeMirror.defineMIME("text/typescript", { name: "javascript", typescript: true });
422
+ CodeMirror.defineMIME("application/typescript", { name: "javascript", typescript: true });
@@ -0,0 +1,148 @@
1
+ // CodeMirror, copyright (c) by Marijn Haverbeke and others
2
+ // Distributed under an MIT license: http://codemirror.net/LICENSE
3
+
4
+ (function(mod) {
5
+ if (typeof exports == "object" && typeof module == "object") // CommonJS
6
+ mod(require("../../lib/codemirror"), require("../xml/xml"), require("../javascript/javascript"))
7
+ else if (typeof define == "function" && define.amd) // AMD
8
+ define(["../../lib/codemirror", "../xml/xml", "../javascript/javascript"], mod)
9
+ else // Plain browser env
10
+ mod(CodeMirror)
11
+ })(function(CodeMirror) {
12
+ "use strict"
13
+
14
+ // Depth means the amount of open braces in JS context, in XML
15
+ // context 0 means not in tag, 1 means in tag, and 2 means in tag
16
+ // and js block comment.
17
+ function Context(state, mode, depth, prev) {
18
+ this.state = state; this.mode = mode; this.depth = depth; this.prev = prev
19
+ }
20
+
21
+ function copyContext(context) {
22
+ return new Context(CodeMirror.copyState(context.mode, context.state),
23
+ context.mode,
24
+ context.depth,
25
+ context.prev && copyContext(context.prev))
26
+ }
27
+
28
+ CodeMirror.defineMode("jsx", function(config, modeConfig) {
29
+ var xmlMode = CodeMirror.getMode(config, {name: "xml", allowMissing: true, multilineTagIndentPastTag: false, allowMissingTagName: true})
30
+ var jsMode = CodeMirror.getMode(config, modeConfig && modeConfig.base || "javascript")
31
+
32
+ function flatXMLIndent(state) {
33
+ var tagName = state.tagName
34
+ state.tagName = null
35
+ var result = xmlMode.indent(state, "")
36
+ state.tagName = tagName
37
+ return result
38
+ }
39
+
40
+ function token(stream, state) {
41
+ if (state.context.mode == xmlMode)
42
+ return xmlToken(stream, state, state.context)
43
+ else
44
+ return jsToken(stream, state, state.context)
45
+ }
46
+
47
+ function xmlToken(stream, state, cx) {
48
+ if (cx.depth == 2) { // Inside a JS /* */ comment
49
+ if (stream.match(/^.*?\*\//)) cx.depth = 1
50
+ else stream.skipToEnd()
51
+ return "comment"
52
+ }
53
+
54
+ if (stream.peek() == "{") {
55
+ xmlMode.skipAttribute(cx.state)
56
+
57
+ var indent = flatXMLIndent(cx.state), xmlContext = cx.state.context
58
+ // If JS starts on same line as tag
59
+ if (xmlContext && stream.match(/^[^>]*>\s*$/, false)) {
60
+ while (xmlContext.prev && !xmlContext.startOfLine)
61
+ xmlContext = xmlContext.prev
62
+ // If tag starts the line, use XML indentation level
63
+ if (xmlContext.startOfLine) indent -= config.indentUnit
64
+ // Else use JS indentation level
65
+ else if (cx.prev.state.lexical) indent = cx.prev.state.lexical.indented
66
+ // Else if inside of tag
67
+ } else if (cx.depth == 1) {
68
+ indent += config.indentUnit
69
+ }
70
+
71
+ state.context = new Context(CodeMirror.startState(jsMode, indent),
72
+ jsMode, 0, state.context)
73
+ return null
74
+ }
75
+
76
+ if (cx.depth == 1) { // Inside of tag
77
+ if (stream.peek() == "<") { // Tag inside of tag
78
+ xmlMode.skipAttribute(cx.state)
79
+ state.context = new Context(CodeMirror.startState(xmlMode, flatXMLIndent(cx.state)),
80
+ xmlMode, 0, state.context)
81
+ return null
82
+ } else if (stream.match("//")) {
83
+ stream.skipToEnd()
84
+ return "comment"
85
+ } else if (stream.match("/*")) {
86
+ cx.depth = 2
87
+ return token(stream, state)
88
+ }
89
+ }
90
+
91
+ var style = xmlMode.token(stream, cx.state), cur = stream.current(), stop
92
+ if (/\btag\b/.test(style)) {
93
+ if (/>$/.test(cur)) {
94
+ if (cx.state.context) cx.depth = 0
95
+ else state.context = state.context.prev
96
+ } else if (/^</.test(cur)) {
97
+ cx.depth = 1
98
+ }
99
+ } else if (!style && (stop = cur.indexOf("{")) > -1) {
100
+ stream.backUp(cur.length - stop)
101
+ }
102
+ return style
103
+ }
104
+
105
+ function jsToken(stream, state, cx) {
106
+ if (stream.peek() == "<" && jsMode.expressionAllowed(stream, cx.state)) {
107
+ jsMode.skipExpression(cx.state)
108
+ state.context = new Context(CodeMirror.startState(xmlMode, jsMode.indent(cx.state, "")),
109
+ xmlMode, 0, state.context)
110
+ return null
111
+ }
112
+
113
+ var style = jsMode.token(stream, cx.state)
114
+ if (!style && cx.depth != null) {
115
+ var cur = stream.current()
116
+ if (cur == "{") {
117
+ cx.depth++
118
+ } else if (cur == "}") {
119
+ if (--cx.depth == 0) state.context = state.context.prev
120
+ }
121
+ }
122
+ return style
123
+ }
124
+
125
+ return {
126
+ startState: function() {
127
+ return {context: new Context(CodeMirror.startState(jsMode), jsMode)}
128
+ },
129
+
130
+ copyState: function(state) {
131
+ return {context: copyContext(state.context)}
132
+ },
133
+
134
+ token: token,
135
+
136
+ indent: function(state, textAfter, fullLine) {
137
+ return state.context.mode.indent(state.context.state, textAfter, fullLine)
138
+ },
139
+
140
+ innerMode: function(state) {
141
+ return state.context
142
+ }
143
+ }
144
+ }, "xml", "javascript")
145
+
146
+ CodeMirror.defineMIME("text/jsx", "jsx")
147
+ CodeMirror.defineMIME("text/typescript-jsx", {name: "jsx", base: {name: "javascript", typescript: true}})
148
+ });