@zohodesk/components 1.0.0-temp-72 → 1.0.0-temp-73

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