@zohodesk/components 1.0.0-temp-107 → 1.0.0-temp-108

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 (559) hide show
  1. package/README.md +1102 -1102
  2. package/assets/Appearance/dark/mode/darkMode.module.css +168 -168
  3. package/assets/Appearance/dark/themes/blue/blueDarkCTATheme.module.css +32 -32
  4. package/assets/Appearance/dark/themes/green/greenDarkCTATheme.module.css +32 -32
  5. package/assets/Appearance/dark/themes/orange/orangeDarkCTATheme.module.css +32 -32
  6. package/assets/Appearance/dark/themes/red/redDarkCTATheme.module.css +32 -32
  7. package/assets/Appearance/dark/themes/yellow/yellowDarkCTATheme.module.css +32 -32
  8. package/assets/Appearance/default/mode/defaultMode.module.css +164 -164
  9. package/assets/Appearance/default/themes/blue/blueDefaultCTATheme.module.css +32 -32
  10. package/assets/Appearance/default/themes/green/greenDefaultCTATheme.module.css +32 -32
  11. package/assets/Appearance/default/themes/orange/orangeDefaultCTATheme.module.css +32 -32
  12. package/assets/Appearance/default/themes/red/redDefaultCTATheme.module.css +32 -32
  13. package/assets/Appearance/default/themes/yellow/yellowDefaultCTATheme.module.css +32 -32
  14. package/assets/Appearance/pureDark/mode/pureDarkMode.module.css +170 -170
  15. package/assets/Appearance/pureDark/themes/blue/bluePureDarkCTATheme.module.css +32 -32
  16. package/assets/Appearance/pureDark/themes/green/greenPureDarkCTATheme.module.css +32 -32
  17. package/assets/Appearance/pureDark/themes/orange/orangePureDarkCTATheme.module.css +32 -32
  18. package/assets/Appearance/pureDark/themes/red/redPureDarkCTATheme.module.css +32 -32
  19. package/assets/Appearance/pureDark/themes/yellow/yellowPureDarkCTATheme.module.css +32 -32
  20. package/assets/Contrast/darkContrastLightness.module.css +25 -0
  21. package/assets/Contrast/defaultContrastLightness.module.css +25 -0
  22. package/assets/Contrast/pureDarkContrastLightness.module.css +25 -0
  23. package/css_error.log +5 -0
  24. package/docs/external/active-line.js +72 -72
  25. package/docs/external/autorefresh.js +47 -47
  26. package/docs/external/codemirror.js +9681 -9681
  27. package/docs/external/css/hopscotch.css +576 -576
  28. package/docs/external/css/styleGuide.css +1100 -1100
  29. package/docs/external/css.js +466 -466
  30. package/docs/external/designTokens.js +1 -1
  31. package/docs/external/foldcode.js +151 -151
  32. package/docs/external/format.js +129 -129
  33. package/docs/external/htmlmixed.js +84 -84
  34. package/docs/external/index.html +127 -127
  35. package/docs/external/javascript.js +422 -422
  36. package/docs/external/jsx.js +147 -147
  37. package/docs/external/matchbrackets.js +145 -145
  38. package/docs/external/xml.js +322 -322
  39. package/docs/package.json +41 -41
  40. package/docs/src/index.js +1311 -1311
  41. package/es/AppContainer/AppContainer.module.css +18 -18
  42. package/es/Avatar/Avatar.js +10 -12
  43. package/es/Avatar/Avatar.module.css +135 -123
  44. package/es/Avatar/__tests__/__snapshots__/Avatar.spec.js.snap +288 -288
  45. package/es/AvatarTeam/AvatarTeam.js +7 -7
  46. package/es/AvatarTeam/AvatarTeam.module.css +161 -147
  47. package/es/AvatarTeam/__tests__/__snapshots__/AvatarTeam.spec.js.snap +226 -226
  48. package/es/Button/Button.js +4 -4
  49. package/es/Button/Button.module.css +521 -448
  50. package/es/Button/__tests__/__snapshots__/Button.spec.js.snap +191 -191
  51. package/es/Buttongroup/Buttongroup.js +1 -1
  52. package/es/Buttongroup/Buttongroup.module.css +89 -60
  53. package/es/Buttongroup/__test__/__snapshots__/Buttongroup.spec.js.snap +146 -146
  54. package/es/Card/Card.js +4 -4
  55. package/es/Card/Card.module.css +20 -20
  56. package/es/CheckBox/CheckBox.js +0 -0
  57. package/es/CheckBox/CheckBox.module.css +157 -151
  58. package/es/DateTime/CalendarView.js +2 -4
  59. package/es/DateTime/DateTime.js +0 -0
  60. package/es/DateTime/DateTime.module.css +232 -201
  61. package/es/DateTime/DateTimePopupHeader.js +9 -24
  62. package/es/DateTime/DateWidget.js +2 -4
  63. package/es/DateTime/DateWidget.module.css +38 -34
  64. package/es/DateTime/DaysRow.js +2 -5
  65. package/es/DateTime/YearView.js +4 -12
  66. package/es/DateTime/YearView.module.css +81 -86
  67. package/es/DateTime/common.js +0 -0
  68. package/es/DateTime/index.js +0 -0
  69. package/es/DateTime/objectUtils.js +0 -0
  70. package/es/DateTime/typeChecker.js +0 -0
  71. package/es/DateTime/validator.js +0 -0
  72. package/es/DropBox/DropBox.js +0 -0
  73. package/es/DropBox/DropBox.module.css +406 -370
  74. package/es/DropBox/DropBoxPositionMapping.json +144 -144
  75. package/es/DropDown/DropDown.js +0 -0
  76. package/es/DropDown/DropDown.module.css +5 -5
  77. package/es/DropDown/DropDownHeading.js +1 -3
  78. package/es/DropDown/DropDownHeading.module.css +53 -49
  79. package/es/DropDown/DropDownItem.js +0 -0
  80. package/es/DropDown/DropDownItem.module.css +94 -68
  81. package/es/DropDown/DropDownSearch.js +0 -0
  82. package/es/DropDown/DropDownSearch.module.css +14 -14
  83. package/es/DropDown/DropDownSeparator.js +0 -0
  84. package/es/DropDown/DropDownSeparator.module.css +7 -7
  85. package/es/DropDown/props/propTypes.js +1 -2
  86. package/es/Heading/Heading.module.css +4 -4
  87. package/es/Label/Label.js +4 -6
  88. package/es/Label/Label.module.css +52 -52
  89. package/es/Label/LabelColors.module.css +20 -20
  90. package/es/Label/__tests__/__snapshots__/Label.spec.js.snap +101 -101
  91. package/es/Layout/Box.js +0 -0
  92. package/es/Layout/Container.js +0 -0
  93. package/es/Layout/Layout.module.css +335 -335
  94. package/es/Layout/utils.js +0 -0
  95. package/es/ListItem/ListContainer.js +2 -4
  96. package/es/ListItem/ListItem.js +1 -2
  97. package/es/ListItem/ListItem.module.css +209 -177
  98. package/es/MultiSelect/AdvancedGroupMultiSelect.js +5 -5
  99. package/es/MultiSelect/MultiSelect.js +7 -9
  100. package/es/MultiSelect/MultiSelect.module.css +205 -188
  101. package/es/MultiSelect/MultiSelectWithAvatar.js +0 -0
  102. package/es/MultiSelect/SelectedOptions.module.css +15 -9
  103. package/es/MultiSelect/Suggestions.js +1 -2
  104. package/es/MultiSelect/__tests__/MultiSelect.spec.js +0 -0
  105. package/es/PopOver/PopOver.module.css +8 -8
  106. package/es/Popup/Popup.js +0 -0
  107. package/es/Popup/PositionMapping.json +73 -73
  108. package/es/Radio/Radio.js +0 -0
  109. package/es/Radio/Radio.module.css +112 -106
  110. package/es/Responsive/CustomResponsive.js +0 -0
  111. package/es/ResponsiveDropBox/ResponsiveDropBox.module.css +6 -6
  112. package/es/Ribbon/Ribbon.js +0 -0
  113. package/es/Ribbon/Ribbon.module.css +376 -311
  114. package/es/Ribbon/__tests__/__snapshots__/Ribbon.spec.js.snap +163 -163
  115. package/es/RippleEffect/RippleEffect.module.css +92 -110
  116. package/es/Select/GroupSelect.js +0 -0
  117. package/es/Select/Select.js +4 -7
  118. package/es/Select/Select.module.css +108 -98
  119. package/es/Select/SelectWithAvatar.js +0 -0
  120. package/es/Select/SelectWithIcon.js +1 -2
  121. package/es/Select/__tests__/Select.spec.js +0 -0
  122. package/es/Stencils/Stencils.js +0 -0
  123. package/es/Stencils/Stencils.module.css +96 -78
  124. package/es/Stencils/__tests__/__snapshots__/Stencils.spec.js.snap +49 -49
  125. package/es/Switch/Switch.js +0 -0
  126. package/es/Switch/Switch.module.css +110 -111
  127. package/es/Tab/Tab.js +1 -2
  128. package/es/Tab/Tab.module.css +101 -92
  129. package/es/Tab/TabContent.module.css +4 -4
  130. package/es/Tab/Tabs.js +20 -24
  131. package/es/Tab/Tabs.module.css +141 -107
  132. package/es/Tag/Tag.js +8 -8
  133. package/es/Tag/Tag.module.css +254 -232
  134. package/es/TextBox/TextBox.js +0 -0
  135. package/es/TextBox/TextBox.module.css +157 -161
  136. package/es/TextBox/__tests__/__snapshots__/TextBox.spec.js.snap +127 -127
  137. package/es/TextBoxIcon/TextBoxIcon.js +0 -0
  138. package/es/TextBoxIcon/TextBoxIcon.module.css +78 -71
  139. package/es/TextBoxIcon/__tests__/__snapshots__/TextBoxIcon.spec.js.snap +334 -334
  140. package/es/Textarea/Textarea.js +0 -0
  141. package/es/Textarea/Textarea.module.css +139 -140
  142. package/es/Textarea/__tests__/__snapshots__/Textarea.spec.js.snap +97 -97
  143. package/es/Tooltip/Tooltip.module.css +109 -108
  144. package/es/common/animation.module.css +624 -426
  145. package/es/common/avatarsizes.module.css +44 -44
  146. package/es/common/basic.module.css +33 -33
  147. package/es/common/basicReset.module.css +40 -50
  148. package/es/common/common.module.css +524 -478
  149. package/es/common/customscroll.module.css +89 -93
  150. package/es/common/reset.module.css +12 -12
  151. package/es/common/transition.module.css +146 -106
  152. package/es/deprecated/AdvancedMultiSelect.module.css +126 -112
  153. package/es/index.js +107 -106
  154. package/es/semantic/Button/semanticButton.module.css +9 -9
  155. package/es/utils/Common.js +0 -0
  156. package/es/utils/dropDownUtils.js +0 -0
  157. package/lib/Accordion/Accordion.js +102 -0
  158. package/lib/Accordion/AccordionItem.js +84 -0
  159. package/lib/Accordion/__tests__/Accordion.spec.js +82 -0
  160. package/lib/Accordion/index.js +20 -0
  161. package/lib/Accordion/props/defaultProps.js +16 -0
  162. package/lib/Accordion/props/propTypes.js +39 -0
  163. package/lib/Animation/Animation.js +161 -0
  164. package/lib/Animation/__tests__/Animation.spec.js +19 -0
  165. package/lib/Animation/props/defaultProps.js +14 -0
  166. package/lib/Animation/props/propTypes.js +20 -0
  167. package/lib/AppContainer/AppContainer.js +156 -0
  168. package/lib/AppContainer/AppContainer.module.css +18 -0
  169. package/lib/AppContainer/props/defaultProps.js +15 -0
  170. package/lib/AppContainer/props/propTypes.js +23 -0
  171. package/lib/Avatar/Avatar.js +199 -0
  172. package/lib/Avatar/Avatar.module.css +135 -0
  173. package/lib/Avatar/__tests__/Avatar.spec.js +164 -0
  174. package/lib/Avatar/__tests__/__snapshots__/Avatar.spec.js.snap +288 -0
  175. package/lib/Avatar/props/defaultProps.js +21 -0
  176. package/lib/Avatar/props/propTypes.js +31 -0
  177. package/lib/AvatarTeam/AvatarTeam.js +99 -0
  178. package/lib/AvatarTeam/AvatarTeam.module.css +161 -0
  179. package/lib/AvatarTeam/__tests__/AvatarTeam.spec.js +79 -0
  180. package/lib/AvatarTeam/__tests__/__snapshots__/AvatarTeam.spec.js.snap +226 -0
  181. package/lib/AvatarTeam/props/defaultProps.js +20 -0
  182. package/lib/AvatarTeam/props/propTypes.js +31 -0
  183. package/lib/Button/Button.js +90 -0
  184. package/lib/Button/Button.module.css +522 -0
  185. package/lib/Button/__tests__/Button.spec.js +193 -0
  186. package/lib/Button/__tests__/__snapshots__/Button.spec.js.snap +191 -0
  187. package/lib/Button/props/defaultProps.js +22 -0
  188. package/lib/Button/props/propTypes.js +30 -0
  189. package/lib/Buttongroup/Buttongroup.js +69 -0
  190. package/lib/Buttongroup/Buttongroup.module.css +89 -0
  191. package/lib/Buttongroup/__test__/Buttongroup.spec.js +76 -0
  192. package/lib/Buttongroup/__test__/__snapshots__/Buttongroup.spec.js.snap +146 -0
  193. package/lib/Buttongroup/props/defaultProps.js +11 -0
  194. package/lib/Buttongroup/props/propTypes.js +15 -0
  195. package/lib/Card/Card.js +301 -0
  196. package/lib/Card/Card.module.css +20 -0
  197. package/lib/Card/__tests__/Card.spec.js +47 -0
  198. package/lib/Card/index.js +33 -0
  199. package/lib/Card/props/defaultProps.js +23 -0
  200. package/lib/Card/props/propTypes.js +54 -0
  201. package/lib/CheckBox/CheckBox.js +183 -0
  202. package/lib/CheckBox/CheckBox.module.css +157 -0
  203. package/lib/CheckBox/__tests__/CheckBox.spec.js +15 -0
  204. package/lib/CheckBox/props/defaultProps.js +25 -0
  205. package/lib/CheckBox/props/propTypes.js +49 -0
  206. package/lib/DateTime/CalendarView.js +227 -0
  207. package/lib/DateTime/DateTime.js +779 -0
  208. package/lib/DateTime/DateTime.module.css +233 -0
  209. package/lib/DateTime/DateTimePopupFooter.js +65 -0
  210. package/lib/DateTime/DateTimePopupHeader.js +117 -0
  211. package/lib/DateTime/DateWidget.js +1015 -0
  212. package/lib/DateTime/DateWidget.module.css +38 -0
  213. package/lib/DateTime/DaysRow.js +52 -0
  214. package/lib/DateTime/Time.js +205 -0
  215. package/lib/DateTime/YearView.js +267 -0
  216. package/lib/DateTime/YearView.module.css +81 -0
  217. package/lib/DateTime/__tests__/CalendarView.spec.js +37 -0
  218. package/lib/DateTime/__tests__/DateTime.spec.js +113 -0
  219. package/lib/DateTime/__tests__/DateWidget.spec.js +79 -0
  220. package/lib/DateTime/common.js +30 -0
  221. package/lib/DateTime/constants.js +76 -0
  222. package/lib/DateTime/dateFormatUtils/dateFormat.js +551 -0
  223. package/lib/DateTime/dateFormatUtils/dayChange.js +74 -0
  224. package/lib/DateTime/dateFormatUtils/index.js +225 -0
  225. package/lib/DateTime/dateFormatUtils/monthChange.js +84 -0
  226. package/lib/DateTime/dateFormatUtils/timeChange.js +208 -0
  227. package/lib/DateTime/dateFormatUtils/yearChange.js +108 -0
  228. package/lib/DateTime/index.js +13 -0
  229. package/lib/DateTime/objectUtils.js +72 -0
  230. package/lib/DateTime/props/defaultProps.js +61 -0
  231. package/lib/DateTime/props/propTypes.js +144 -0
  232. package/lib/DateTime/typeChecker.js +22 -0
  233. package/lib/DateTime/validator.js +290 -0
  234. package/lib/DropBox/DropBox.js +266 -0
  235. package/lib/DropBox/DropBox.module.css +406 -0
  236. package/lib/DropBox/DropBoxPositionMapping.json +145 -0
  237. package/lib/DropBox/__tests__/DropBox.spec.js +83 -0
  238. package/lib/DropBox/props/defaultProps.js +27 -0
  239. package/lib/DropBox/props/propTypes.js +55 -0
  240. package/lib/DropDown/DropDown.js +127 -0
  241. package/lib/DropDown/DropDown.module.css +5 -0
  242. package/lib/DropDown/DropDownHeading.js +64 -0
  243. package/lib/DropDown/DropDownHeading.module.css +53 -0
  244. package/lib/DropDown/DropDownItem.js +102 -0
  245. package/lib/DropDown/DropDownItem.module.css +94 -0
  246. package/lib/DropDown/DropDownSearch.js +88 -0
  247. package/lib/DropDown/DropDownSearch.module.css +14 -0
  248. package/lib/DropDown/DropDownSeparator.js +42 -0
  249. package/lib/DropDown/DropDownSeparator.module.css +7 -0
  250. package/lib/DropDown/__tests__/DropDown.spec.js +44 -0
  251. package/lib/DropDown/__tests__/DropDownItem.spec.js +46 -0
  252. package/lib/DropDown/__tests__/DropDownSearch.spec.js +14 -0
  253. package/lib/DropDown/props/defaultProps.js +28 -0
  254. package/lib/DropDown/props/propTypes.js +89 -0
  255. package/lib/Heading/Heading.js +64 -0
  256. package/lib/Heading/Heading.module.css +5 -0
  257. package/lib/Heading/props/defaultProps.js +12 -0
  258. package/lib/Heading/props/propTypes.js +19 -0
  259. package/lib/Label/Label.js +65 -0
  260. package/lib/Label/Label.module.css +52 -0
  261. package/lib/Label/LabelColors.module.css +21 -0
  262. package/lib/Label/__tests__/Label.spec.js +124 -0
  263. package/lib/Label/__tests__/__snapshots__/Label.spec.js.snap +101 -0
  264. package/lib/Label/props/defaultProps.js +17 -0
  265. package/lib/Label/props/propTypes.js +22 -0
  266. package/lib/Layout/Box.js +104 -0
  267. package/lib/Layout/Container.js +122 -0
  268. package/lib/Layout/Layout.module.css +336 -0
  269. package/lib/Layout/__tests__/Box.spec.js +105 -0
  270. package/lib/Layout/__tests__/Container.spec.js +110 -0
  271. package/lib/Layout/index.js +30 -0
  272. package/lib/Layout/props/defaultProps.js +20 -0
  273. package/lib/Layout/props/propTypes.js +51 -0
  274. package/lib/Layout/utils.js +45 -0
  275. package/lib/ListItem/ListContainer.js +93 -0
  276. package/lib/ListItem/ListItem.js +153 -0
  277. package/lib/ListItem/ListItem.module.css +209 -0
  278. package/lib/ListItem/ListItemWithAvatar.js +175 -0
  279. package/lib/ListItem/ListItemWithCheckBox.js +141 -0
  280. package/lib/ListItem/ListItemWithIcon.js +158 -0
  281. package/lib/ListItem/ListItemWithRadio.js +143 -0
  282. package/lib/ListItem/props/defaultProps.js +97 -0
  283. package/lib/ListItem/props/propTypes.js +176 -0
  284. package/lib/Modal/Modal.js +174 -0
  285. package/lib/Modal/props/defaultProps.js +10 -0
  286. package/lib/Modal/props/propTypes.js +14 -0
  287. package/lib/MultiSelect/AdvancedGroupMultiSelect.js +1032 -0
  288. package/lib/MultiSelect/AdvancedMultiSelect.js +552 -0
  289. package/lib/MultiSelect/EmptyState.js +85 -0
  290. package/lib/MultiSelect/MultiSelect.js +1044 -0
  291. package/lib/MultiSelect/MultiSelect.module.css +206 -0
  292. package/lib/MultiSelect/MultiSelectHeader.js +55 -0
  293. package/lib/MultiSelect/MultiSelectWithAvatar.js +304 -0
  294. package/lib/MultiSelect/SelectedOptions.js +97 -0
  295. package/lib/MultiSelect/SelectedOptions.module.css +15 -0
  296. package/lib/MultiSelect/Suggestions.js +158 -0
  297. package/lib/MultiSelect/__tests__/MultiSelect.spec.js +159 -0
  298. package/lib/MultiSelect/props/defaultProps.js +158 -0
  299. package/lib/MultiSelect/props/propTypes.js +377 -0
  300. package/lib/PopOver/PopOver.js +252 -0
  301. package/lib/PopOver/PopOver.module.css +8 -0
  302. package/lib/PopOver/__tests__/PopOver.spec.js +17 -0
  303. package/lib/PopOver/props/defaultProps.js +15 -0
  304. package/lib/PopOver/props/propTypes.js +63 -0
  305. package/lib/Popup/Popup.js +640 -0
  306. package/lib/Popup/PositionMapping.json +74 -0
  307. package/lib/Popup/__tests__/Popup.spec.js +155 -0
  308. package/lib/Popup/viewPort.js +354 -0
  309. package/lib/Provider/AvatarSize.js +19 -0
  310. package/lib/Provider/Config.js +25 -0
  311. package/lib/Provider/CssProvider.js +23 -0
  312. package/lib/Provider/IdProvider.js +68 -0
  313. package/lib/Provider/LibraryContext.js +54 -0
  314. package/lib/Provider/LibraryContextInit.js +11 -0
  315. package/lib/Provider/NumberGenerator/NumberGenerator.js +145 -0
  316. package/lib/Provider/ZindexProvider.js +57 -0
  317. package/lib/Radio/Radio.js +146 -0
  318. package/lib/Radio/Radio.module.css +112 -0
  319. package/lib/Radio/__tests__/Radiospec.js +25 -0
  320. package/lib/Radio/props/defaultProps.js +21 -0
  321. package/lib/Radio/props/propTypes.js +40 -0
  322. package/lib/Responsive/CustomResponsive.js +192 -0
  323. package/lib/Responsive/RefWrapper.js +47 -0
  324. package/lib/Responsive/ResizeComponent.js +237 -0
  325. package/lib/Responsive/ResizeObserver.js +151 -0
  326. package/lib/Responsive/Responsive.js +222 -0
  327. package/lib/Responsive/index.js +28 -0
  328. package/lib/Responsive/props/defaultProps.js +23 -0
  329. package/lib/Responsive/props/propTypes.js +36 -0
  330. package/lib/Responsive/sizeObservers.js +176 -0
  331. package/lib/Responsive/utils/index.js +62 -0
  332. package/lib/Responsive/utils/shallowCompare.js +29 -0
  333. package/lib/Responsive/windowResizeObserver.js +55 -0
  334. package/lib/ResponsiveDropBox/ResponsiveDropBox.js +94 -0
  335. package/lib/ResponsiveDropBox/ResponsiveDropBox.module.css +6 -0
  336. package/lib/ResponsiveDropBox/props/defaultProps.js +11 -0
  337. package/lib/ResponsiveDropBox/props/propTypes.js +15 -0
  338. package/lib/Ribbon/Ribbon.js +71 -0
  339. package/lib/Ribbon/Ribbon.module.css +377 -0
  340. package/lib/Ribbon/__tests__/Ribbon.spec.js +171 -0
  341. package/lib/Ribbon/__tests__/__snapshots__/Ribbon.spec.js.snap +163 -0
  342. package/lib/Ribbon/props/defaultProps.js +15 -0
  343. package/lib/Ribbon/props/propTypes.js +18 -0
  344. package/lib/RippleEffect/RippleEffect.js +35 -0
  345. package/lib/RippleEffect/RippleEffect.module.css +92 -0
  346. package/lib/RippleEffect/props/defaultProps.js +16 -0
  347. package/lib/RippleEffect/props/propTypes.js +19 -0
  348. package/lib/Select/GroupSelect.js +771 -0
  349. package/lib/Select/Select.js +910 -0
  350. package/lib/Select/Select.module.css +109 -0
  351. package/lib/Select/SelectWithAvatar.js +340 -0
  352. package/lib/Select/SelectWithIcon.js +530 -0
  353. package/lib/Select/__tests__/Select.spec.js +341 -0
  354. package/lib/Select/props/defaultProps.js +112 -0
  355. package/lib/Select/props/propTypes.js +280 -0
  356. package/lib/Stencils/Stencils.js +57 -0
  357. package/lib/Stencils/Stencils.module.css +96 -0
  358. package/lib/Stencils/__tests__/Stencils.spec.js +72 -0
  359. package/lib/Stencils/__tests__/__snapshots__/Stencils.spec.js.snap +49 -0
  360. package/lib/Stencils/props/defaultProps.js +13 -0
  361. package/lib/Stencils/props/propTypes.js +15 -0
  362. package/lib/Switch/Switch.js +123 -0
  363. package/lib/Switch/Switch.module.css +111 -0
  364. package/lib/Switch/props/defaultProps.js +17 -0
  365. package/lib/Switch/props/propTypes.js +35 -0
  366. package/lib/Tab/Tab.js +116 -0
  367. package/lib/Tab/Tab.module.css +101 -0
  368. package/lib/Tab/TabContent.js +33 -0
  369. package/lib/Tab/TabContent.module.css +4 -0
  370. package/lib/Tab/TabContentWrapper.js +33 -0
  371. package/lib/Tab/TabWrapper.js +69 -0
  372. package/lib/Tab/Tabs.js +581 -0
  373. package/lib/Tab/Tabs.module.css +141 -0
  374. package/lib/Tab/__tests__/Tab.spec.js +119 -0
  375. package/lib/Tab/__tests__/TabContent.spec.js +18 -0
  376. package/lib/Tab/__tests__/TabContentWrapper.spec.js +51 -0
  377. package/lib/Tab/__tests__/TabWrapper.spec.js +88 -0
  378. package/lib/Tab/__tests__/Tabs.spec.js +109 -0
  379. package/lib/Tab/index.js +41 -0
  380. package/lib/Tab/props/defaultProps.js +50 -0
  381. package/lib/Tab/props/propTypes.js +114 -0
  382. package/lib/Tag/Tag.js +177 -0
  383. package/lib/Tag/Tag.module.css +255 -0
  384. package/lib/Tag/__tests__/Tag.spec.js +29 -0
  385. package/lib/Tag/props/defaultProps.js +20 -0
  386. package/lib/Tag/props/propTypes.js +42 -0
  387. package/lib/TextBox/TextBox.js +193 -0
  388. package/lib/TextBox/TextBox.module.css +157 -0
  389. package/lib/TextBox/__tests__/TextBox.spec.js +195 -0
  390. package/lib/TextBox/__tests__/__snapshots__/TextBox.spec.js.snap +127 -0
  391. package/lib/TextBox/props/defaultProps.js +26 -0
  392. package/lib/TextBox/props/propTypes.js +57 -0
  393. package/lib/TextBoxIcon/TextBoxIcon.js +187 -0
  394. package/lib/TextBoxIcon/TextBoxIcon.module.css +78 -0
  395. package/lib/TextBoxIcon/__tests__/TextBoxIcon.spec.js +219 -0
  396. package/lib/TextBoxIcon/__tests__/__snapshots__/TextBoxIcon.spec.js.snap +334 -0
  397. package/lib/TextBoxIcon/props/defaultProps.js +28 -0
  398. package/lib/TextBoxIcon/props/propTypes.js +57 -0
  399. package/lib/Textarea/Textarea.js +130 -0
  400. package/lib/Textarea/Textarea.module.css +139 -0
  401. package/lib/Textarea/__tests__/Textarea.spec.js +174 -0
  402. package/lib/Textarea/__tests__/__snapshots__/Textarea.spec.js.snap +97 -0
  403. package/lib/Textarea/props/defaultProps.js +23 -0
  404. package/lib/Textarea/props/propTypes.js +39 -0
  405. package/lib/Tooltip/Tooltip.js +519 -0
  406. package/lib/Tooltip/Tooltip.module.css +109 -0
  407. package/lib/Tooltip/__tests__/Tooltip.spec.js +75 -0
  408. package/lib/Tooltip/props/defaultProps.js +11 -0
  409. package/lib/Tooltip/props/propTypes.js +16 -0
  410. package/lib/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +100 -0
  411. package/lib/VelocityAnimation/VelocityAnimation/props/defaultProps.js +14 -0
  412. package/lib/VelocityAnimation/VelocityAnimation/props/propTypes.js +20 -0
  413. package/lib/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +131 -0
  414. package/lib/VelocityAnimation/VelocityAnimationGroup/props/defaultProps.js +22 -0
  415. package/lib/VelocityAnimation/VelocityAnimationGroup/props/propTypes.js +27 -0
  416. package/lib/common/animation.module.css +624 -0
  417. package/lib/common/avatarsizes.module.css +45 -0
  418. package/lib/common/basic.module.css +33 -0
  419. package/lib/common/basicReset.module.css +40 -0
  420. package/lib/common/common.module.css +525 -0
  421. package/lib/common/customscroll.module.css +89 -0
  422. package/lib/common/reset.module.css +12 -0
  423. package/lib/common/transition.module.css +146 -0
  424. package/lib/css.js +42 -0
  425. package/lib/deprecated/AdvancedMultiSelect.module.css +127 -0
  426. package/lib/deprecated/PortalLayer/PortalLayer.js +126 -0
  427. package/lib/deprecated/PortalLayer/props/defaultProps.js +12 -0
  428. package/lib/deprecated/PortalLayer/props/propTypes.js +19 -0
  429. package/lib/deprecated/advancedMultiSelectVariableJson.js +82 -0
  430. package/lib/index.js +404 -0
  431. package/lib/semantic/Button/Button.js +81 -0
  432. package/lib/semantic/Button/props/defaultProps.js +19 -0
  433. package/lib/semantic/Button/props/propTypes.js +34 -0
  434. package/lib/semantic/Button/semanticButton.module.css +9 -0
  435. package/lib/utils/Common.js +391 -0
  436. package/lib/utils/ContextOptimizer.js +43 -0
  437. package/lib/utils/__tests__/constructFullName.spec.js +11 -0
  438. package/lib/utils/__tests__/debounce.spec.js +39 -0
  439. package/lib/utils/__tests__/getInitial.spec.js +25 -0
  440. package/lib/utils/constant.js +10 -0
  441. package/lib/utils/constructFullName.js +25 -0
  442. package/lib/utils/datetime/common.js +206 -0
  443. package/lib/utils/debounce.js +25 -0
  444. package/lib/utils/dropDownUtils.js +491 -0
  445. package/lib/utils/dummyFunction.js +8 -0
  446. package/lib/utils/getHTMLFontSize.js +10 -0
  447. package/lib/utils/getInitial.js +27 -0
  448. package/lib/utils/scrollTo.js +20 -0
  449. package/lib/utils/shallowEqual.js +33 -0
  450. package/package.json +86 -81
  451. package/es/Accordion/docs/Accordion__Demo.docs.js +0 -78
  452. package/es/Animation/docs/Animation__default.docs.js +0 -32
  453. package/es/Animation/docs/Animation__fadeIn.docs.js +0 -32
  454. package/es/Animation/docs/Animation__scaleIn.docs.js +0 -32
  455. package/es/Animation/docs/Animation__skewIn.docs.js +0 -32
  456. package/es/Animation/docs/Animation__slideDown.docs.js +0 -32
  457. package/es/Animation/docs/Animation__slideLeft.docs.js +0 -32
  458. package/es/Animation/docs/Animation__zoomIn.docs.js +0 -32
  459. package/es/AppContainer/docs/AppContainer__default.docs.js +0 -18
  460. package/es/Avatar/docs/Avatar__custom.docs.js +0 -27
  461. package/es/Avatar/docs/Avatar__default.docs.js +0 -27
  462. package/es/Avatar/docs/Avatar__palette.docs.js +0 -47
  463. package/es/Avatar/docs/Avatar__text.docs.js +0 -26
  464. package/es/AvatarTeam/docs/AvatarTeam__custom.docs.js +0 -71
  465. package/es/AvatarTeam/docs/AvatarTeam__default.docs.js +0 -29
  466. package/es/AvatarTeam/docs/AvatarTeam__palette.docs.js +0 -48
  467. package/es/AvatarTeam/docs/AvatarTeam__size.docs.js +0 -47
  468. package/es/Button/docs/Button__custom.docs.js +0 -769
  469. package/es/Button/docs/Button__default.docs.js +0 -534
  470. package/es/Buttongroup/docs/Buttongroup__custom.docs.js +0 -35
  471. package/es/Buttongroup/docs/Buttongroup__footer.docs.js +0 -31
  472. package/es/Buttongroup/docs/Buttongroup__header.docs.js +0 -40
  473. package/es/Card/docs/Card__Custom.docs.js +0 -32
  474. package/es/Card/docs/Card__Default.docs.js +0 -35
  475. package/es/Card/docs/Card__Scroll.docs.js +0 -56
  476. package/es/CheckBox/docs/CheckBox__custom.docs.js +0 -289
  477. package/es/CheckBox/docs/CheckBox__default.docs.js +0 -215
  478. package/es/DateTime/docs/DateTime__default.docs.js +0 -88
  479. package/es/DateTime/docs/DateWidget__default.docs.js +0 -178
  480. package/es/DateTime/docs/timezonedata.json +0 -1
  481. package/es/DropBox/docs/DropBox__custom.docs.js +0 -64
  482. package/es/DropBox/docs/DropBox__customOrder.docs.js +0 -85
  483. package/es/DropBox/docs/DropBox__fixedPosition.docs.js +0 -84
  484. package/es/DropBox/docs/DropBox__position.docs.js +0 -85
  485. package/es/DropBox/docs/DropBox__size.docs.js +0 -59
  486. package/es/DropDown/docs/DropDownHeading__custom.docs.js +0 -21
  487. package/es/DropDown/docs/DropDownHeading__default.docs.js +0 -19
  488. package/es/FramerAnimation/FramerAnimation.js +0 -206
  489. package/es/FramerAnimation/docs/FramerAnimation__default.docs.js +0 -123
  490. package/es/Heading/docs/Heading__default.docs.js +0 -19
  491. package/es/Label/docs/Label__clipped.docs.js +0 -25
  492. package/es/Label/docs/Label__custom.docs.js +0 -28
  493. package/es/Label/docs/Label__palette.docs.js +0 -40
  494. package/es/Label/docs/Label__size.docs.js +0 -27
  495. package/es/Label/docs/Label__type.docs.js +0 -35
  496. package/es/Layout/docs/Layout__Hidden.docs.js +0 -76
  497. package/es/Layout/docs/Layout__default.docs.js +0 -48
  498. package/es/Layout/docs/Layout__four_Column.docs.js +0 -78
  499. package/es/Layout/docs/Layout__three_Column.docs.js +0 -75
  500. package/es/Layout/docs/Layout__two_Column.docs.js +0 -68
  501. package/es/LightNightMode/Colors.json +0 -497
  502. package/es/LightNightMode/docs/AlternativeColors.docs.js +0 -92
  503. package/es/ListItem/docs/ListItemWithAvatar__custom.docs.js +0 -153
  504. package/es/ListItem/docs/ListItemWithAvatar__default.docs.js +0 -110
  505. package/es/ListItem/docs/ListItemWithCheckBox__custom.docs.js +0 -89
  506. package/es/ListItem/docs/ListItemWithCheckBox__default.docs.js +0 -63
  507. package/es/ListItem/docs/ListItemWithIcon__custom.docs.js +0 -66
  508. package/es/ListItem/docs/ListItemWithIcon__default.docs.js +0 -60
  509. package/es/ListItem/docs/ListItemWithRadio__custom.docs.js +0 -89
  510. package/es/ListItem/docs/ListItemWithRadio__default.docs.js +0 -63
  511. package/es/ListItem/docs/ListItem__custom.docs.js +0 -112
  512. package/es/ListItem/docs/ListItem__default.docs.js +0 -80
  513. package/es/Modal/__docs__/Modal__default.docs.js +0 -42
  514. package/es/MultiSelect/docs/AdvancedGroupMultiSelect__default.docs.js +0 -118
  515. package/es/MultiSelect/docs/AdvancedMultiSelect__default.docs.js +0 -108
  516. package/es/MultiSelect/docs/MultiSelectWithAvatar__default.docs.js +0 -137
  517. package/es/MultiSelect/docs/MultiSelect__default.docs.js +0 -156
  518. package/es/PopOver/docs/PopOver__default.docs.js +0 -30
  519. package/es/Provider/docs/Provider_Id__Class.docs.js +0 -28
  520. package/es/Provider/docs/Provider_Id__Function.docs.js +0 -17
  521. package/es/Provider/docs/Provider_Zindex__Class.docs.js +0 -31
  522. package/es/Provider/docs/Provider_Zindex__Function.docs.js +0 -22
  523. package/es/Provider.js +0 -91
  524. package/es/Radio/docs/Radio__custom.docs.js +0 -241
  525. package/es/Radio/docs/Radio__default.docs.js +0 -165
  526. package/es/Responsive/docs/Responsive__Custom.docs.js +0 -214
  527. package/es/Responsive/docs/Responsive__default.docs.js +0 -95
  528. package/es/Responsive/docs/style.module.css +0 -47
  529. package/es/Ribbon/docs/Ribbon__custom.docs.js +0 -385
  530. package/es/Ribbon/docs/Ribbon__default.docs.js +0 -341
  531. package/es/RippleEffect/docs/RippleEffect__default.docs.js +0 -433
  532. package/es/Select/docs/GroupSelect__default.docs.js +0 -144
  533. package/es/Select/docs/SelectWithAvatar__default.docs.js +0 -93
  534. package/es/Select/docs/SelectWithIcon__default.docs.js +0 -134
  535. package/es/Select/docs/Select__default.docs.js +0 -283
  536. package/es/Stencils/docs/Stencils__custom.docs.js +0 -43
  537. package/es/Stencils/docs/Stencils__default.docs.js +0 -48
  538. package/es/Switch/docs/Switch__custom.docs.js +0 -151
  539. package/es/Switch/docs/Switch__default.docs.js +0 -105
  540. package/es/Tab/docs/Tab__default.docs.js +0 -253
  541. package/es/Tab/docs/tabdocs.module.css +0 -29
  542. package/es/Tag/docs/Tag__custom.docs.js +0 -366
  543. package/es/Tag/docs/Tag__default.docs.js +0 -321
  544. package/es/TextBox/docs/TextBox__custom.docs.js +0 -41
  545. package/es/TextBox/docs/TextBox__default.docs.js +0 -38
  546. package/es/TextBox/docs/TextBox__size.docs.js +0 -36
  547. package/es/TextBox/docs/TextBox__variant.docs.js +0 -36
  548. package/es/TextBoxIcon/docs/TextBoxIcon__custom.docs.js +0 -87
  549. package/es/TextBoxIcon/docs/TextBoxIcon__default.docs.js +0 -59
  550. package/es/Textarea/docs/Textarea__animated.docs.js +0 -39
  551. package/es/Textarea/docs/Textarea__custom.docs.js +0 -80
  552. package/es/Textarea/docs/Textarea__default.docs.js +0 -74
  553. package/es/Textarea/docs/Textarea__disabled.docs.js +0 -27
  554. package/es/Tooltip/docs/Tooltip__default.docs.js +0 -367
  555. package/es/VelocityAnimation/VelocityAnimation/docs/VelocityAnimation__demo.docs.js +0 -92
  556. package/es/VelocityAnimation/VelocityAnimationGroup/docs/VelocityAnimationGroup__demo.docs.js +0 -139
  557. package/es/common/docStyle.module.css +0 -719
  558. package/es/deprecated/PortalLayer/docs/PortalLayer__default.docs.js +0 -65
  559. package/es/semantic/Button/docs/Button__default.docs.js +0 -17
@@ -1,422 +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 });
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 });