@zohodesk/components 1.0.0-test-252 → 1.0.0

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 (601) hide show
  1. package/README.md +161 -1
  2. package/assets/Appearance/dark/mode/darkMode.module.css +181 -179
  3. package/assets/Appearance/dark/themes/blue/blueDarkCTAModifyCategory.module.css +452 -0
  4. package/assets/Appearance/dark/themes/blue/blueDarkCTATheme.module.css +31 -31
  5. package/assets/Appearance/dark/themes/blue/blueDarkComponentTheme.module.css +3 -0
  6. package/assets/Appearance/dark/themes/green/greenDarkCTAModifyCategory.module.css +452 -0
  7. package/assets/Appearance/dark/themes/green/greenDarkCTATheme.module.css +30 -30
  8. package/assets/Appearance/dark/themes/green/greenDarkComponentTheme.module.css +3 -0
  9. package/assets/Appearance/dark/themes/orange/orangeDarkCTAModifyCategory.module.css +452 -0
  10. package/assets/Appearance/dark/themes/orange/orangeDarkCTATheme.module.css +30 -30
  11. package/assets/Appearance/dark/themes/orange/orangeDarkComponentTheme.module.css +3 -0
  12. package/assets/Appearance/dark/themes/red/redDarkCTAModifyCategory.module.css +452 -0
  13. package/assets/Appearance/dark/themes/red/redDarkCTATheme.module.css +30 -30
  14. package/assets/Appearance/dark/themes/red/redDarkComponentTheme.module.css +3 -0
  15. package/assets/Appearance/dark/themes/yellow/yellowDarkCTAModifyCategory.module.css +452 -0
  16. package/assets/Appearance/dark/themes/yellow/yellowDarkCTATheme.module.css +30 -30
  17. package/assets/Appearance/dark/themes/yellow/yellowDarkComponentTheme.module.css +3 -0
  18. package/assets/Appearance/default/mode/defaultMode.module.css +177 -175
  19. package/assets/Appearance/default/themes/blue/blueDefaultCTAModifyCategory.module.css +452 -0
  20. package/assets/Appearance/default/themes/blue/blueDefaultCTATheme.module.css +31 -31
  21. package/assets/Appearance/default/themes/blue/blueDefaultComponentTheme.module.css +3 -0
  22. package/assets/Appearance/default/themes/green/greenDefaultCTAModifyCategory.module.css +452 -0
  23. package/assets/Appearance/default/themes/green/greenDefaultCTATheme.module.css +30 -30
  24. package/assets/Appearance/default/themes/green/greenDefaultComponentTheme.module.css +3 -0
  25. package/assets/Appearance/default/themes/orange/orangeDefaultCTAModifyCategory.module.css +452 -0
  26. package/assets/Appearance/default/themes/orange/orangeDefaultCTATheme.module.css +30 -30
  27. package/assets/Appearance/default/themes/orange/orangeDefaultComponentTheme.module.css +3 -0
  28. package/assets/Appearance/default/themes/red/redDefaultCTAModifyCategory.module.css +452 -0
  29. package/assets/Appearance/default/themes/red/redDefaultCTATheme.module.css +30 -30
  30. package/assets/Appearance/default/themes/red/redDefaultComponentTheme.module.css +3 -0
  31. package/assets/Appearance/default/themes/yellow/yellowDefaultCTAModifyCategory.module.css +452 -0
  32. package/assets/Appearance/default/themes/yellow/yellowDefaultCTATheme.module.css +30 -30
  33. package/assets/Appearance/default/themes/yellow/yellowDefaultComponentTheme.module.css +3 -0
  34. package/assets/Appearance/pureDark/mode/pureDarkMode.module.css +182 -180
  35. package/assets/Appearance/pureDark/themes/blue/bluePureDarkCTAModifyCategory.module.css +452 -0
  36. package/assets/Appearance/pureDark/themes/blue/bluePureDarkCTATheme.module.css +31 -31
  37. package/assets/Appearance/pureDark/themes/blue/bluePureDarkComponentTheme.module.css +3 -0
  38. package/assets/Appearance/pureDark/themes/green/greenPureDarkCTAModifyCategory.module.css +452 -0
  39. package/assets/Appearance/pureDark/themes/green/greenPureDarkCTATheme.module.css +30 -30
  40. package/assets/Appearance/pureDark/themes/green/greenPureDarkComponentTheme.module.css +3 -0
  41. package/assets/Appearance/pureDark/themes/orange/orangePureDarkCTAModifyCategory.module.css +452 -0
  42. package/assets/Appearance/pureDark/themes/orange/orangePureDarkCTATheme.module.css +30 -30
  43. package/assets/Appearance/pureDark/themes/orange/orangePureDarkComponentTheme.module.css +3 -0
  44. package/assets/Appearance/pureDark/themes/red/redPureDarkCTAModifyCategory.module.css +452 -0
  45. package/assets/Appearance/pureDark/themes/red/redPureDarkCTATheme.module.css +30 -30
  46. package/assets/Appearance/pureDark/themes/red/redPureDarkComponentTheme.module.css +3 -0
  47. package/assets/Appearance/pureDark/themes/yellow/yellowPureDarkCTAModifyCategory.module.css +452 -0
  48. package/assets/Appearance/pureDark/themes/yellow/yellowPureDarkCTATheme.module.css +30 -30
  49. package/assets/Appearance/pureDark/themes/yellow/yellowPureDarkComponentTheme.module.css +3 -0
  50. package/assets/Contrast/darkContrastLightness.module.css +39 -0
  51. package/assets/Contrast/defaultContrastLightness.module.css +39 -0
  52. package/assets/Contrast/pureDarkContrastLightness.module.css +39 -0
  53. package/css_error.log +1 -0
  54. package/es/Accordion/Accordion.js +19 -9
  55. package/es/Accordion/AccordionItem.js +13 -8
  56. package/es/Accordion/props/defaultProps.js +6 -2
  57. package/es/Accordion/props/propTypes.js +3 -0
  58. package/es/Animation/Animation.js +10 -9
  59. package/es/AppContainer/AppContainer.js +38 -15
  60. package/es/AppContainer/AppContainer.module.css +2 -2
  61. package/es/AppContainer/props/defaultProps.js +3 -1
  62. package/es/AppContainer/props/propTypes.js +2 -0
  63. package/es/Avatar/Avatar.js +48 -25
  64. package/es/Avatar/Avatar.module.css +59 -18
  65. package/es/Avatar/props/defaultProps.js +4 -1
  66. package/es/Avatar/props/propTypes.js +5 -2
  67. package/es/AvatarTeam/AvatarTeam.js +21 -11
  68. package/es/AvatarTeam/AvatarTeam.module.css +49 -21
  69. package/es/AvatarTeam/props/defaultProps.js +5 -1
  70. package/es/AvatarTeam/props/propTypes.js +5 -1
  71. package/es/Button/Button.js +55 -51
  72. package/{lib/Button → es/Button/css}/Button.module.css +62 -58
  73. package/es/Button/css/cssJSLogic.js +53 -0
  74. package/es/Button/index.js +2 -0
  75. package/es/Button/props/defaultProps.js +3 -1
  76. package/es/Button/props/propTypes.js +6 -2
  77. package/es/Buttongroup/Buttongroup.js +24 -16
  78. package/es/Buttongroup/Buttongroup.module.css +45 -28
  79. package/es/Buttongroup/props/defaultProps.js +3 -1
  80. package/es/Buttongroup/props/propTypes.js +3 -1
  81. package/es/Card/Card.js +48 -26
  82. package/es/Card/props/defaultProps.js +12 -2
  83. package/es/Card/props/propTypes.js +2 -2
  84. package/es/CheckBox/CheckBox.js +13 -9
  85. package/es/CheckBox/CheckBox.module.css +16 -16
  86. package/es/CheckBox/props/propTypes.js +1 -0
  87. package/es/DateTime/CalendarView.js +46 -19
  88. package/es/DateTime/DateTime.js +139 -77
  89. package/es/DateTime/DateTime.module.css +51 -48
  90. package/es/DateTime/DateTimePopupFooter.js +4 -2
  91. package/es/DateTime/DateTimePopupHeader.js +30 -11
  92. package/es/DateTime/DateWidget.js +122 -51
  93. package/es/DateTime/DateWidget.module.css +5 -5
  94. package/es/DateTime/DaysRow.js +6 -3
  95. package/es/DateTime/Time.js +10 -2
  96. package/es/DateTime/YearView.js +41 -9
  97. package/es/DateTime/YearView.module.css +33 -15
  98. package/es/DateTime/__tests__/CalendarView.spec.js +1 -0
  99. package/es/DateTime/__tests__/DateTime.spec.js +1 -0
  100. package/es/DateTime/__tests__/DateWidget.spec.js +2 -3
  101. package/es/DateTime/common.js +3 -0
  102. package/es/DateTime/constants.js +1 -0
  103. package/es/DateTime/dateFormatUtils/dateFormat.js +63 -30
  104. package/es/DateTime/dateFormatUtils/dateFormats.js +42 -0
  105. package/es/DateTime/dateFormatUtils/dayChange.js +13 -4
  106. package/es/DateTime/dateFormatUtils/index.js +59 -2
  107. package/es/DateTime/dateFormatUtils/monthChange.js +8 -0
  108. package/es/DateTime/dateFormatUtils/timeChange.js +22 -6
  109. package/es/DateTime/dateFormatUtils/yearChange.js +11 -2
  110. package/es/DateTime/index.js +1 -1
  111. package/es/DateTime/objectUtils.js +14 -20
  112. package/es/DateTime/props/defaultProps.js +2 -1
  113. package/es/DateTime/props/propTypes.js +5 -2
  114. package/es/DateTime/typeChecker.js +3 -0
  115. package/es/DateTime/validator.js +58 -6
  116. package/es/DropBox/DropBox.js +82 -218
  117. package/es/DropBox/DropBoxElement/DropBoxElement.js +132 -0
  118. package/es/DropBox/DropBoxElement/css/DropBoxElement.module.css +435 -0
  119. package/es/DropBox/DropBoxElement/css/cssJSLogic.js +91 -0
  120. package/es/DropBox/DropBoxElement/props/defaultProps.js +18 -0
  121. package/es/DropBox/DropBoxElement/props/propTypes.js +45 -0
  122. package/es/DropBox/DropBoxElement/useDropboxPosCalc.js +54 -0
  123. package/es/DropBox/__tests__/DropBox.spec.js +2 -2
  124. package/es/DropBox/css/DropBox.module.css +59 -0
  125. package/es/DropBox/css/cssJSLogic.js +14 -0
  126. package/es/DropBox/props/defaultProps.js +9 -15
  127. package/es/DropBox/props/propTypes.js +9 -41
  128. package/es/DropDown/DropDown.js +16 -9
  129. package/es/DropDown/DropDown.module.css +2 -2
  130. package/es/DropDown/DropDownHeading.js +18 -11
  131. package/es/DropDown/DropDownHeading.module.css +3 -3
  132. package/es/DropDown/DropDownItem.js +8 -1
  133. package/es/DropDown/DropDownItem.module.css +9 -9
  134. package/es/DropDown/DropDownSearch.js +4 -0
  135. package/es/DropDown/DropDownSeparator.js +1 -0
  136. package/es/DropDown/DropDownSeparator.module.css +2 -2
  137. package/es/DropDown/__tests__/DropDown.spec.js +1 -2
  138. package/es/DropDown/index.js +7 -0
  139. package/es/DropDown/props/defaultProps.js +3 -1
  140. package/es/DropDown/props/propTypes.js +2 -1
  141. package/es/Heading/Heading.js +8 -7
  142. package/es/Heading/Heading.module.css +2 -2
  143. package/es/Label/Label.js +14 -9
  144. package/es/Label/Label.module.css +1 -1
  145. package/es/Label/props/defaultProps.js +2 -1
  146. package/es/Label/props/propTypes.js +1 -0
  147. package/es/Layout/Box.js +19 -4
  148. package/es/Layout/Container.js +18 -5
  149. package/es/Layout/Layout.module.css +15 -15
  150. package/es/Layout/index.js +9 -10
  151. package/es/Layout/props/defaultProps.js +6 -2
  152. package/es/Layout/props/propTypes.js +7 -3
  153. package/es/Layout/utils.js +5 -1
  154. package/es/ListItem/ListContainer.js +21 -9
  155. package/es/ListItem/ListItem.js +30 -14
  156. package/es/ListItem/ListItem.module.css +37 -30
  157. package/es/ListItem/ListItemWithAvatar.js +30 -15
  158. package/es/ListItem/ListItemWithCheckBox.js +22 -10
  159. package/es/ListItem/ListItemWithIcon.js +29 -14
  160. package/es/ListItem/ListItemWithRadio.js +22 -10
  161. package/es/ListItem/index.js +6 -0
  162. package/es/ListItem/props/defaultProps.js +18 -6
  163. package/es/ListItem/props/propTypes.js +13 -1
  164. package/es/Modal/Modal.js +35 -17
  165. package/es/MultiSelect/AdvancedGroupMultiSelect.js +100 -20
  166. package/es/MultiSelect/AdvancedMultiSelect.js +45 -19
  167. package/es/MultiSelect/EmptyState.js +6 -0
  168. package/es/MultiSelect/MultiSelect.js +129 -46
  169. package/es/MultiSelect/MultiSelect.module.css +32 -31
  170. package/es/MultiSelect/MultiSelectHeader.js +3 -0
  171. package/es/MultiSelect/MultiSelectWithAvatar.js +43 -19
  172. package/es/MultiSelect/SelectedOptions.js +6 -3
  173. package/es/MultiSelect/SelectedOptions.module.css +5 -5
  174. package/es/MultiSelect/Suggestions.js +13 -6
  175. package/es/MultiSelect/__tests__/MultiSelect.spec.js +4 -6
  176. package/es/MultiSelect/index.js +4 -0
  177. package/es/MultiSelect/props/defaultProps.js +11 -4
  178. package/es/MultiSelect/props/propTypes.js +17 -5
  179. package/es/PopOver/PopOver.js +25 -9
  180. package/es/PopOver/__tests__/PopOver.spec.js +2 -1
  181. package/es/PopOver/index.js +3 -0
  182. package/es/Popup/Popup.js +80 -31
  183. package/es/Popup/__tests__/Popup.spec.js +17 -5
  184. package/es/Popup/viewPort.js +16 -4
  185. package/es/Provider/AvatarSize.js +1 -0
  186. package/es/Provider/IdProvider.js +16 -10
  187. package/es/Provider/LibraryContext.js +6 -4
  188. package/es/Provider/NumberGenerator/NumberGenerator.js +21 -7
  189. package/es/Provider/ZindexProvider.js +9 -2
  190. package/es/Provider/index.js +4 -0
  191. package/es/Radio/Radio.js +9 -7
  192. package/es/Radio/Radio.module.css +3 -3
  193. package/es/Responsive/CustomResponsive.js +37 -21
  194. package/es/Responsive/RefWrapper.js +6 -7
  195. package/es/Responsive/ResizeComponent.js +35 -25
  196. package/es/Responsive/ResizeObserver.js +26 -6
  197. package/es/Responsive/Responsive.js +34 -20
  198. package/es/Responsive/index.js +9 -8
  199. package/es/Responsive/sizeObservers.js +28 -7
  200. package/es/Responsive/utils/index.js +7 -5
  201. package/es/Responsive/utils/shallowCompare.js +7 -2
  202. package/es/Responsive/windowResizeObserver.js +7 -0
  203. package/es/ResponsiveDropBox/ResponsiveDropBox.js +4 -0
  204. package/es/ResponsiveDropBox/ResponsiveDropBox.module.css +2 -2
  205. package/es/Ribbon/Ribbon.js +21 -15
  206. package/es/Ribbon/Ribbon.module.css +133 -55
  207. package/es/Ribbon/props/defaultProps.js +2 -1
  208. package/es/Ribbon/props/propTypes.js +2 -1
  209. package/es/RippleEffect/RippleEffect.js +6 -7
  210. package/es/Select/GroupSelect.js +71 -23
  211. package/es/Select/Select.js +115 -50
  212. package/es/Select/Select.module.css +23 -23
  213. package/es/Select/SelectWithAvatar.js +31 -12
  214. package/es/Select/SelectWithIcon.js +60 -14
  215. package/es/Select/__tests__/Select.spec.js +6 -8
  216. package/es/Select/index.js +4 -0
  217. package/es/Select/props/defaultProps.js +6 -1
  218. package/es/Select/props/propTypes.js +10 -4
  219. package/es/Stencils/Stencils.js +10 -9
  220. package/es/Stencils/Stencils.module.css +2 -2
  221. package/es/Switch/Switch.js +14 -8
  222. package/es/Switch/Switch.module.css +49 -32
  223. package/es/Switch/props/defaultProps.js +2 -1
  224. package/es/Switch/props/propTypes.js +1 -0
  225. package/es/Tab/Tab.js +14 -11
  226. package/es/Tab/Tab.module.css +14 -15
  227. package/es/Tab/TabContent.js +6 -3
  228. package/es/Tab/TabContentWrapper.js +6 -2
  229. package/es/Tab/TabWrapper.js +9 -4
  230. package/es/Tab/Tabs.js +85 -21
  231. package/es/Tab/Tabs.module.css +36 -40
  232. package/es/Tab/__tests__/Tab.spec.js +4 -12
  233. package/es/Tab/__tests__/TabWrapper.spec.js +1 -0
  234. package/es/Tab/props/defaultProps.js +10 -5
  235. package/es/Tab/props/propTypes.js +10 -5
  236. package/es/Tag/Tag.js +16 -10
  237. package/es/Tag/Tag.module.css +10 -10
  238. package/es/Tag/props/defaultProps.js +2 -1
  239. package/es/Tag/props/propTypes.js +2 -1
  240. package/es/TextBox/TextBox.js +26 -10
  241. package/es/TextBox/TextBox.module.css +6 -5
  242. package/es/TextBox/__tests__/TextBox.spec.js +1 -4
  243. package/es/TextBox/props/defaultProps.js +2 -1
  244. package/es/TextBox/props/propTypes.js +2 -1
  245. package/es/TextBoxIcon/TextBoxIcon.js +39 -13
  246. package/es/TextBoxIcon/TextBoxIcon.module.css +7 -6
  247. package/es/TextBoxIcon/__tests__/TextBoxIcon.spec.js +2 -7
  248. package/es/TextBoxIcon/props/defaultProps.js +2 -1
  249. package/es/TextBoxIcon/props/propTypes.js +1 -0
  250. package/es/Textarea/Textarea.js +23 -10
  251. package/es/Textarea/Textarea.module.css +6 -6
  252. package/es/Textarea/__tests__/Textarea.spec.js +2 -2
  253. package/es/Textarea/props/defaultProps.js +2 -1
  254. package/es/Textarea/props/propTypes.js +1 -0
  255. package/es/Tooltip/Tooltip.js +67 -21
  256. package/es/Tooltip/Tooltip.module.css +40 -8
  257. package/es/Tooltip/__tests__/Tooltip.spec.js +5 -0
  258. package/es/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +7 -6
  259. package/es/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +11 -8
  260. package/es/VelocityAnimation/index.js +2 -0
  261. package/es/common/a11y.module.css +4 -0
  262. package/es/common/animation.module.css +8 -8
  263. package/es/common/avatarsizes.module.css +6 -2
  264. package/es/common/basicReset.module.css +3 -3
  265. package/es/common/boxShadow.module.css +34 -0
  266. package/es/common/common.module.css +24 -24
  267. package/es/common/customscroll.module.css +4 -2
  268. package/es/common/reset.module.css +1 -0
  269. package/es/css.js +2 -1
  270. package/es/deprecated/AdvancedMultiSelect.module.css +18 -18
  271. package/es/deprecated/PortalLayer/PortalLayer.js +30 -24
  272. package/es/index.js +30 -146
  273. package/es/semantic/Button/Button.js +9 -7
  274. package/es/semantic/Button/semanticButton.module.css +1 -1
  275. package/es/semantic/index.js +1 -0
  276. package/es/utils/Common.js +74 -7
  277. package/es/utils/ContextOptimizer.js +4 -5
  278. package/es/utils/__tests__/debounce.spec.js +2 -2
  279. package/es/utils/constructFullName.js +2 -0
  280. package/es/utils/css/compileClassNames.js +28 -0
  281. package/es/utils/css/mergeStyle.js +57 -0
  282. package/es/utils/css/utils.js +24 -0
  283. package/es/utils/datetime/GMTZones.js +48 -0
  284. package/es/utils/datetime/common.js +31 -7
  285. package/es/utils/debounce.js +5 -1
  286. package/es/utils/dropDownUtils.js +71 -13
  287. package/es/utils/getInitial.js +4 -0
  288. package/es/utils/index.js +3 -0
  289. package/es/utils/shallowEqual.js +6 -0
  290. package/install.md +10 -0
  291. package/lib/Accordion/Accordion.js +50 -18
  292. package/lib/Accordion/AccordionItem.js +47 -20
  293. package/lib/Accordion/__tests__/Accordion.spec.js +3 -0
  294. package/lib/Accordion/index.js +3 -0
  295. package/lib/Accordion/props/defaultProps.js +6 -2
  296. package/lib/Accordion/props/propTypes.js +6 -0
  297. package/lib/Animation/Animation.js +44 -21
  298. package/lib/Animation/__tests__/Animation.spec.js +11 -7
  299. package/lib/Animation/props/propTypes.js +3 -0
  300. package/lib/AppContainer/AppContainer.js +75 -27
  301. package/lib/AppContainer/AppContainer.module.css +2 -2
  302. package/lib/AppContainer/props/defaultProps.js +3 -1
  303. package/lib/AppContainer/props/propTypes.js +5 -0
  304. package/lib/Avatar/Avatar.js +97 -44
  305. package/lib/Avatar/Avatar.module.css +59 -18
  306. package/lib/Avatar/__tests__/Avatar.spec.js +44 -0
  307. package/lib/Avatar/props/defaultProps.js +4 -1
  308. package/lib/Avatar/props/propTypes.js +8 -2
  309. package/lib/AvatarTeam/AvatarTeam.js +64 -30
  310. package/lib/AvatarTeam/AvatarTeam.module.css +49 -21
  311. package/lib/AvatarTeam/__tests__/AvatarTeam.spec.js +13 -0
  312. package/lib/AvatarTeam/props/defaultProps.js +5 -1
  313. package/lib/AvatarTeam/props/propTypes.js +8 -1
  314. package/lib/Button/Button.js +64 -74
  315. package/{es/Button → lib/Button/css}/Button.module.css +62 -58
  316. package/lib/Button/css/cssJSLogic.js +41 -0
  317. package/lib/Button/index.js +23 -0
  318. package/lib/Button/props/defaultProps.js +5 -1
  319. package/lib/Button/props/propTypes.js +11 -3
  320. package/lib/Buttongroup/Buttongroup.js +49 -19
  321. package/lib/Buttongroup/Buttongroup.module.css +45 -28
  322. package/lib/Buttongroup/__test__/Buttongroup.spec.js +10 -0
  323. package/lib/Buttongroup/props/defaultProps.js +3 -1
  324. package/lib/Buttongroup/props/propTypes.js +6 -1
  325. package/lib/Card/Card.js +119 -55
  326. package/lib/Card/__tests__/Card.spec.js +10 -1
  327. package/lib/Card/index.js +4 -0
  328. package/lib/Card/props/defaultProps.js +16 -4
  329. package/lib/Card/props/propTypes.js +5 -2
  330. package/lib/CheckBox/CheckBox.js +76 -48
  331. package/lib/CheckBox/CheckBox.module.css +16 -16
  332. package/lib/CheckBox/__tests__/CheckBox.spec.js +3 -0
  333. package/lib/CheckBox/props/propTypes.js +4 -0
  334. package/lib/DateTime/CalendarView.js +95 -38
  335. package/lib/DateTime/DateTime.js +309 -216
  336. package/lib/DateTime/DateTime.module.css +51 -48
  337. package/lib/DateTime/DateTimePopupFooter.js +30 -5
  338. package/lib/DateTime/DateTimePopupHeader.js +69 -23
  339. package/lib/DateTime/DateWidget.js +370 -260
  340. package/lib/DateTime/DateWidget.module.css +5 -5
  341. package/lib/DateTime/DaysRow.js +28 -3
  342. package/lib/DateTime/Time.js +72 -29
  343. package/lib/DateTime/YearView.js +89 -30
  344. package/lib/DateTime/YearView.module.css +33 -15
  345. package/lib/DateTime/__tests__/CalendarView.spec.js +13 -5
  346. package/lib/DateTime/__tests__/DateTime.spec.js +51 -37
  347. package/lib/DateTime/__tests__/DateWidget.spec.js +10 -8
  348. package/lib/DateTime/common.js +6 -0
  349. package/lib/DateTime/constants.js +1 -0
  350. package/lib/DateTime/dateFormatUtils/dateFormat.js +184 -122
  351. package/lib/DateTime/dateFormatUtils/dateFormats.js +50 -0
  352. package/lib/DateTime/dateFormatUtils/dayChange.js +14 -7
  353. package/lib/DateTime/dateFormatUtils/index.js +99 -13
  354. package/lib/DateTime/dateFormatUtils/monthChange.js +19 -9
  355. package/lib/DateTime/dateFormatUtils/timeChange.js +52 -20
  356. package/lib/DateTime/dateFormatUtils/yearChange.js +22 -11
  357. package/lib/DateTime/index.js +3 -1
  358. package/lib/DateTime/objectUtils.js +24 -20
  359. package/lib/DateTime/props/defaultProps.js +2 -1
  360. package/lib/DateTime/props/propTypes.js +21 -2
  361. package/lib/DateTime/typeChecker.js +4 -0
  362. package/lib/DateTime/validator.js +69 -6
  363. package/lib/DropBox/DropBox.js +102 -249
  364. package/lib/DropBox/DropBoxElement/DropBoxElement.js +145 -0
  365. package/lib/DropBox/DropBoxElement/css/DropBoxElement.module.css +435 -0
  366. package/lib/DropBox/DropBoxElement/css/cssJSLogic.js +81 -0
  367. package/lib/DropBox/DropBoxElement/props/defaultProps.js +25 -0
  368. package/lib/DropBox/DropBoxElement/props/propTypes.js +56 -0
  369. package/lib/DropBox/DropBoxElement/useDropboxPosCalc.js +60 -0
  370. package/lib/DropBox/__tests__/DropBox.spec.js +8 -4
  371. package/lib/DropBox/css/DropBox.module.css +59 -0
  372. package/lib/DropBox/css/cssJSLogic.js +20 -0
  373. package/lib/DropBox/props/defaultProps.js +20 -17
  374. package/lib/DropBox/props/propTypes.js +22 -43
  375. package/lib/DropDown/DropDown.js +58 -10
  376. package/lib/DropDown/DropDown.module.css +2 -2
  377. package/lib/DropDown/DropDownHeading.js +47 -18
  378. package/lib/DropDown/DropDownHeading.module.css +3 -3
  379. package/lib/DropDown/DropDownItem.js +43 -18
  380. package/lib/DropDown/DropDownItem.module.css +9 -9
  381. package/lib/DropDown/DropDownSearch.js +39 -14
  382. package/lib/DropDown/DropDownSeparator.js +23 -1
  383. package/lib/DropDown/DropDownSeparator.module.css +2 -2
  384. package/lib/DropDown/__tests__/DropDown.spec.js +15 -9
  385. package/lib/DropDown/__tests__/DropDownItem.spec.js +9 -4
  386. package/lib/DropDown/__tests__/DropDownSearch.spec.js +3 -0
  387. package/lib/DropDown/index.js +65 -0
  388. package/lib/DropDown/props/defaultProps.js +3 -1
  389. package/lib/DropDown/props/propTypes.js +7 -1
  390. package/lib/Heading/Heading.js +42 -16
  391. package/lib/Heading/Heading.module.css +2 -2
  392. package/lib/Heading/props/propTypes.js +3 -0
  393. package/lib/Label/Label.js +47 -19
  394. package/lib/Label/Label.module.css +1 -1
  395. package/lib/Label/__tests__/Label.spec.js +14 -1
  396. package/lib/Label/props/defaultProps.js +2 -1
  397. package/lib/Label/props/propTypes.js +4 -0
  398. package/lib/Layout/Box.js +41 -16
  399. package/lib/Layout/Container.js +39 -15
  400. package/lib/Layout/Layout.module.css +15 -15
  401. package/lib/Layout/__tests__/Box.spec.js +65 -49
  402. package/lib/Layout/__tests__/Container.spec.js +67 -50
  403. package/lib/Layout/index.js +4 -11
  404. package/lib/Layout/props/defaultProps.js +6 -2
  405. package/lib/Layout/props/propTypes.js +10 -3
  406. package/lib/Layout/utils.js +15 -1
  407. package/lib/ListItem/ListContainer.js +61 -34
  408. package/lib/ListItem/ListItem.js +92 -50
  409. package/lib/ListItem/ListItem.module.css +37 -30
  410. package/lib/ListItem/ListItemWithAvatar.js +98 -54
  411. package/lib/ListItem/ListItemWithCheckBox.js +82 -41
  412. package/lib/ListItem/ListItemWithIcon.js +92 -50
  413. package/lib/ListItem/ListItemWithRadio.js +83 -42
  414. package/lib/ListItem/index.js +55 -0
  415. package/lib/ListItem/props/defaultProps.js +18 -6
  416. package/lib/ListItem/props/propTypes.js +18 -3
  417. package/lib/Modal/Modal.js +51 -13
  418. package/lib/Modal/props/propTypes.js +3 -0
  419. package/lib/MultiSelect/AdvancedGroupMultiSelect.js +300 -167
  420. package/lib/MultiSelect/AdvancedMultiSelect.js +212 -130
  421. package/lib/MultiSelect/EmptyState.js +48 -21
  422. package/lib/MultiSelect/MultiSelect.js +341 -205
  423. package/lib/MultiSelect/MultiSelect.module.css +32 -31
  424. package/lib/MultiSelect/MultiSelectHeader.js +29 -5
  425. package/lib/MultiSelect/MultiSelectWithAvatar.js +126 -65
  426. package/lib/MultiSelect/SelectedOptions.js +42 -14
  427. package/lib/MultiSelect/SelectedOptions.module.css +5 -5
  428. package/lib/MultiSelect/Suggestions.js +66 -29
  429. package/lib/MultiSelect/__tests__/MultiSelect.spec.js +86 -75
  430. package/lib/MultiSelect/index.js +39 -0
  431. package/lib/MultiSelect/props/defaultProps.js +13 -4
  432. package/lib/MultiSelect/props/propTypes.js +20 -5
  433. package/lib/PopOver/PopOver.js +101 -53
  434. package/lib/PopOver/__tests__/PopOver.spec.js +4 -1
  435. package/lib/PopOver/index.js +31 -0
  436. package/lib/PopOver/props/propTypes.js +3 -0
  437. package/lib/Popup/Popup.js +158 -83
  438. package/lib/Popup/__tests__/Popup.spec.js +42 -5
  439. package/lib/Popup/viewPort.js +28 -14
  440. package/lib/Provider/AvatarSize.js +5 -0
  441. package/lib/Provider/Config.js +2 -0
  442. package/lib/Provider/CssProvider.js +4 -0
  443. package/lib/Provider/IdProvider.js +23 -12
  444. package/lib/Provider/LibraryContext.js +32 -10
  445. package/lib/Provider/LibraryContextInit.js +4 -0
  446. package/lib/Provider/NumberGenerator/NumberGenerator.js +43 -14
  447. package/lib/Provider/ZindexProvider.js +15 -3
  448. package/lib/Provider/index.js +81 -0
  449. package/lib/Radio/Radio.js +65 -40
  450. package/lib/Radio/Radio.module.css +3 -3
  451. package/lib/Radio/__tests__/Radiospec.js +9 -5
  452. package/lib/Radio/props/propTypes.js +3 -0
  453. package/lib/Responsive/CustomResponsive.js +76 -26
  454. package/lib/Responsive/RefWrapper.js +15 -7
  455. package/lib/Responsive/ResizeComponent.js +58 -27
  456. package/lib/Responsive/ResizeObserver.js +23 -6
  457. package/lib/Responsive/Responsive.js +76 -24
  458. package/lib/Responsive/index.js +49 -22
  459. package/lib/Responsive/props/propTypes.js +3 -0
  460. package/lib/Responsive/sizeObservers.js +51 -13
  461. package/lib/Responsive/utils/index.js +11 -3
  462. package/lib/Responsive/utils/shallowCompare.js +11 -2
  463. package/lib/Responsive/windowResizeObserver.js +8 -0
  464. package/lib/ResponsiveDropBox/ResponsiveDropBox.js +44 -14
  465. package/lib/ResponsiveDropBox/ResponsiveDropBox.module.css +2 -2
  466. package/lib/ResponsiveDropBox/props/propTypes.js +3 -0
  467. package/lib/Ribbon/Ribbon.js +48 -21
  468. package/lib/Ribbon/Ribbon.module.css +133 -55
  469. package/lib/Ribbon/__tests__/Ribbon.spec.js +22 -0
  470. package/lib/Ribbon/props/defaultProps.js +2 -1
  471. package/lib/Ribbon/props/propTypes.js +5 -1
  472. package/lib/RippleEffect/RippleEffect.js +23 -14
  473. package/lib/RippleEffect/props/propTypes.js +3 -0
  474. package/lib/Select/GroupSelect.js +240 -137
  475. package/lib/Select/Select.js +320 -220
  476. package/lib/Select/Select.module.css +23 -23
  477. package/lib/Select/SelectWithAvatar.js +112 -59
  478. package/lib/Select/SelectWithIcon.js +145 -82
  479. package/lib/Select/__tests__/Select.spec.js +131 -89
  480. package/lib/Select/index.js +39 -0
  481. package/lib/Select/props/defaultProps.js +10 -2
  482. package/lib/Select/props/propTypes.js +13 -4
  483. package/lib/Stencils/Stencils.js +35 -13
  484. package/lib/Stencils/Stencils.module.css +2 -2
  485. package/lib/Stencils/__tests__/Stencils.spec.js +12 -0
  486. package/lib/Stencils/props/propTypes.js +3 -0
  487. package/lib/Switch/Switch.js +64 -35
  488. package/lib/Switch/Switch.module.css +49 -32
  489. package/lib/Switch/props/defaultProps.js +2 -1
  490. package/lib/Switch/props/propTypes.js +4 -0
  491. package/lib/Tab/Tab.js +49 -33
  492. package/lib/Tab/Tab.module.css +14 -15
  493. package/lib/Tab/TabContent.js +15 -6
  494. package/lib/Tab/TabContentWrapper.js +15 -6
  495. package/lib/Tab/TabWrapper.js +37 -17
  496. package/lib/Tab/Tabs.js +193 -94
  497. package/lib/Tab/Tabs.module.css +36 -40
  498. package/lib/Tab/__tests__/Tab.spec.js +74 -70
  499. package/lib/Tab/__tests__/TabContent.spec.js +10 -6
  500. package/lib/Tab/__tests__/TabContentWrapper.spec.js +28 -20
  501. package/lib/Tab/__tests__/TabWrapper.spec.js +12 -0
  502. package/lib/Tab/__tests__/Tabs.spec.js +53 -39
  503. package/lib/Tab/index.js +6 -0
  504. package/lib/Tab/props/defaultProps.js +10 -5
  505. package/lib/Tab/props/propTypes.js +13 -5
  506. package/lib/Tag/Tag.js +82 -48
  507. package/lib/Tag/Tag.module.css +10 -10
  508. package/lib/Tag/__tests__/Tag.spec.js +14 -8
  509. package/lib/Tag/props/defaultProps.js +2 -1
  510. package/lib/Tag/props/propTypes.js +5 -1
  511. package/lib/TextBox/TextBox.js +93 -61
  512. package/lib/TextBox/TextBox.module.css +6 -5
  513. package/lib/TextBox/__tests__/TextBox.spec.js +14 -4
  514. package/lib/TextBox/props/defaultProps.js +2 -1
  515. package/lib/TextBox/props/propTypes.js +6 -1
  516. package/lib/TextBoxIcon/TextBoxIcon.js +108 -60
  517. package/lib/TextBoxIcon/TextBoxIcon.module.css +7 -6
  518. package/lib/TextBoxIcon/__tests__/TextBoxIcon.spec.js +14 -5
  519. package/lib/TextBoxIcon/props/defaultProps.js +2 -1
  520. package/lib/TextBoxIcon/props/propTypes.js +4 -0
  521. package/lib/Textarea/Textarea.js +63 -32
  522. package/lib/Textarea/Textarea.module.css +6 -6
  523. package/lib/Textarea/__tests__/Textarea.spec.js +14 -2
  524. package/lib/Textarea/props/defaultProps.js +2 -1
  525. package/lib/Textarea/props/propTypes.js +4 -0
  526. package/lib/Tooltip/Tooltip.js +102 -35
  527. package/lib/Tooltip/Tooltip.module.css +40 -8
  528. package/lib/Tooltip/__tests__/Tooltip.spec.js +23 -0
  529. package/lib/Tooltip/props/propTypes.js +3 -0
  530. package/lib/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +43 -17
  531. package/lib/VelocityAnimation/VelocityAnimation/props/propTypes.js +3 -0
  532. package/lib/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +55 -24
  533. package/lib/VelocityAnimation/VelocityAnimationGroup/props/propTypes.js +3 -0
  534. package/lib/VelocityAnimation/index.js +23 -0
  535. package/lib/common/a11y.module.css +4 -0
  536. package/lib/common/animation.module.css +8 -8
  537. package/lib/common/avatarsizes.module.css +6 -2
  538. package/lib/common/basicReset.module.css +3 -3
  539. package/lib/common/boxShadow.module.css +34 -0
  540. package/lib/common/common.module.css +24 -24
  541. package/lib/common/customscroll.module.css +4 -2
  542. package/lib/common/reset.module.css +1 -0
  543. package/lib/css.js +42 -1
  544. package/lib/deprecated/AdvancedMultiSelect.module.css +18 -18
  545. package/lib/deprecated/PortalLayer/PortalLayer.js +50 -24
  546. package/lib/deprecated/PortalLayer/props/propTypes.js +3 -0
  547. package/lib/index.js +214 -210
  548. package/lib/semantic/Button/Button.js +47 -24
  549. package/lib/semantic/Button/props/propTypes.js +3 -0
  550. package/lib/semantic/Button/semanticButton.module.css +1 -1
  551. package/lib/semantic/index.js +15 -0
  552. package/lib/utils/Common.js +136 -17
  553. package/lib/utils/ContextOptimizer.js +16 -10
  554. package/lib/utils/__tests__/constructFullName.spec.js +1 -0
  555. package/lib/utils/__tests__/debounce.spec.js +3 -2
  556. package/lib/utils/__tests__/getInitial.spec.js +1 -0
  557. package/lib/utils/constructFullName.js +11 -2
  558. package/lib/utils/css/compileClassNames.js +37 -0
  559. package/lib/utils/css/mergeStyle.js +69 -0
  560. package/lib/utils/css/utils.js +41 -0
  561. package/lib/utils/datetime/GMTZones.js +55 -0
  562. package/lib/utils/datetime/common.js +52 -7
  563. package/lib/utils/debounce.js +6 -1
  564. package/lib/utils/dropDownUtils.js +177 -56
  565. package/lib/utils/dummyFunction.js +2 -0
  566. package/lib/utils/getHTMLFontSize.js +1 -0
  567. package/lib/utils/getInitial.js +6 -0
  568. package/lib/utils/index.js +121 -0
  569. package/lib/utils/scrollTo.js +2 -0
  570. package/lib/utils/shallowEqual.js +8 -0
  571. package/package.json +61 -26
  572. package/postPublish.js +8 -0
  573. package/prePublish.js +70 -0
  574. package/docs/external/active-line.js +0 -72
  575. package/docs/external/autorefresh.js +0 -47
  576. package/docs/external/codemirror.js +0 -9681
  577. package/docs/external/css/hopscotch.css +0 -576
  578. package/docs/external/css/styleGuide.css +0 -1100
  579. package/docs/external/css.js +0 -466
  580. package/docs/external/designTokens.js +0 -1
  581. package/docs/external/foldcode.js +0 -152
  582. package/docs/external/format.js +0 -129
  583. package/docs/external/htmlmixed.js +0 -84
  584. package/docs/external/images/bottom.png +0 -0
  585. package/docs/external/images/bottombg.jpg +0 -0
  586. package/docs/external/images/desk.png +0 -0
  587. package/docs/external/images/desklogo.png +0 -0
  588. package/docs/external/images/menu.png +0 -0
  589. package/docs/external/index.html +0 -127
  590. package/docs/external/javascript.js +0 -422
  591. package/docs/external/jsx.js +0 -148
  592. package/docs/external/matchbrackets.js +0 -145
  593. package/docs/external/xml.js +0 -322
  594. package/docs/package.json +0 -41
  595. package/docs/src/index.js +0 -1311
  596. package/es/Button/__tests__/Button.spec.js +0 -190
  597. package/es/Button/__tests__/__snapshots__/Button.spec.js.snap +0 -191
  598. package/es/DropBox/DropBox.module.css +0 -406
  599. package/lib/Button/__tests__/Button.spec.js +0 -193
  600. package/lib/Button/__tests__/__snapshots__/Button.spec.js.snap +0 -191
  601. package/lib/DropBox/DropBox.module.css +0 -406
@@ -11,17 +11,21 @@ const validator = {
11
11
  let newValidationRules = validationRules ? validationRules : {};
12
12
  let checkPropsRules = defaultCheckPropsRules;
13
13
  let checkPropsOrder = [];
14
+
14
15
  for (let i = 0; i < checkPropsRules.length; i++) {
15
16
  let prop = checkPropsRules[i];
17
+
16
18
  if (Object.prototype.hasOwnProperty.call(currentProps, prop)) {
17
19
  if (newValidationRulesOrder.indexOf(prop) === -1) {
18
20
  checkPropsOrder.push(prop);
19
21
  }
22
+
20
23
  if (!Object.prototype.hasOwnProperty.call(newValidationRules, prop)) {
21
24
  newValidationRules[prop] = currentProps[prop];
22
25
  }
23
26
  }
24
27
  }
28
+
25
29
  newValidationRulesOrder = !Object.prototype.hasOwnProperty.call(newValidation, 'rulesOrder') ? checkPropsOrder.concat(newValidationRulesOrder) : validationRulesOrder;
26
30
  let isRulesFound = Object.keys(newValidationRules).length;
27
31
  newValidationRules = isRulesFound ? validator.composeRulesForValidation(newType, defaultValidateRules, newValidationRules) : newValidationRules;
@@ -47,22 +51,28 @@ const validator = {
47
51
  onFailValidation
48
52
  } = validationObj;
49
53
  let skipIfEmptyField = null;
54
+
50
55
  if (validationRules.required === false && (fieldType !== 'radio' || fieldType !== 'checkbox')) {
51
56
  skipIfEmptyField = val => {
52
57
  if (fieldType === 'onegroup' || fieldType === 'multigroup') {
53
58
  return !val || !(val.length > 0);
54
59
  }
60
+
55
61
  let value = (val || '').trim();
56
62
  return value.length < 1;
57
63
  };
58
64
  }
65
+
59
66
  if (skipIfEmptyField === null || skipIfEmptyField(text) === false) {
60
67
  for (let i = 0, len = validationRulesOrder.length; i < len; i++) {
61
68
  let rule = validationRulesOrder[i];
69
+
62
70
  if (!validationRules[rule] || !typeChecker.isFunction(validationRules[rule])) {
63
71
  continue;
64
72
  }
73
+
65
74
  let isInValid = validationRules[rule](text, inputTag);
75
+
66
76
  if (isInValid) {
67
77
  let message = validationMessages[rule] && typeChecker.isFunction(validationMessages[rule]) ? validationMessages[rule](text, inputTag) : validationMessages[rule];
68
78
  onFailValidation && onFailValidation(rule, message, inputTag);
@@ -70,52 +80,66 @@ const validator = {
70
80
  }
71
81
  }
72
82
  }
83
+
73
84
  onPassValidation && onPassValidation(text, inputTag);
74
85
  },
75
86
  composeRulesForValidation: (type, defaultValidateRules, newValidationRules) => {
76
87
  let defaultPatterns = validator.regexs;
88
+
77
89
  for (let i = 0, len = defaultValidateRules.length; i < len; i++) {
78
90
  let rule = defaultValidateRules[i];
79
91
  let ruleInfo = newValidationRules[rule] || '';
92
+
80
93
  if (ruleInfo && !typeChecker.isFunction(ruleInfo)) {
81
94
  if (rule === 'required' && ruleInfo === true) {
82
95
  newValidationRules[rule] = (val, el) => {
83
96
  if (el.willValidate && el.validity.valueMissing) {
84
97
  return true;
85
98
  }
99
+
86
100
  if (type === 'radio' || type === 'checkbox') {
87
101
  return el.checked === false;
88
102
  }
103
+
89
104
  if (type === 'onegroup' || type === 'multigroup') {
90
105
  return !val || val.length < 1;
91
106
  }
107
+
92
108
  let value = (val || '').replace(/\s{2,}/g, ' ').trim();
93
109
  return value.length < 1;
94
110
  };
95
111
  } else if (rule === 'maxLength' && !Number.isNaN(ruleInfo) && Number.isFinite(ruleInfo)) {
96
112
  let maxLength = Number(ruleInfo);
113
+
97
114
  newValidationRules[rule] = (val, el) => {
98
115
  if (el.willValidate && el.validity.tooLong) {
99
116
  return true;
100
117
  }
118
+
101
119
  let value = val || '';
120
+
102
121
  if (type !== 'multigroup') {
103
122
  value = val.trim();
104
123
  }
124
+
105
125
  return !(value.length <= maxLength);
106
126
  };
107
127
  } else if (rule === 'minLength' && !Number.isNaN(ruleInfo) && Number.isFinite(ruleInfo)) {
108
128
  let minLength = Number(ruleInfo);
129
+
109
130
  newValidationRules[rule] = val => {
110
131
  let value = val || '';
132
+
111
133
  if (type !== 'multigroup') {
112
134
  value = val.trim();
113
135
  }
136
+
114
137
  return !(value.length >= minLength);
115
138
  };
116
139
  } else if (rule === 'rangeLength' && /^([-+\d]+)*([,]{1,1}([-+\d]+))$/.test(ruleInfo) === true) {
117
140
  let rangeLength = ruleInfo;
118
141
  rangeLength = rangeLength.split(',').map(a => Number(a));
142
+
119
143
  newValidationRules[rule] = val => {
120
144
  let value = (val || '').trim();
121
145
  return !(value.length >= rangeLength[0] && value.length <= rangeLength[1]);
@@ -123,119 +147,146 @@ const validator = {
123
147
  } else if (rule === 'step' && ruleInfo) {
124
148
  let step = Number(ruleInfo);
125
149
  let stepTypes = ['number', 'range', 'date', 'datetime', 'datetime-local', 'month', 'time', 'week'];
150
+
126
151
  newValidationRules[rule] = (val, el) => {
127
152
  if (stepTypes.indexOf(type) !== -1) {
128
153
  if (el.willValidate && el.validity.stepMismatch) {
129
154
  return true;
130
155
  }
156
+
131
157
  return false;
132
158
  }
159
+
133
160
  let value = (val || '').trim();
134
161
  value = Number(value);
162
+
135
163
  if (Number.isNaN(value) || !Number.isFinite(value) || Number.isNaN(step) || !Number.isFinite(step)) {
136
164
  return true;
137
165
  }
166
+
138
167
  return !(value % step === 0);
139
168
  };
140
169
  } else if (rule === 'max') {
141
170
  let max = Number(ruleInfo);
142
171
  let maxTypes = ['number', 'range', 'date', 'datetime', 'datetime-local', 'month', 'time', 'week'];
172
+
143
173
  newValidationRules[rule] = (val, el) => {
144
174
  if (maxTypes.indexOf(type) !== -1) {
145
175
  if (el.willValidate && el.validity.rangeOverflow) {
146
176
  return true;
147
177
  }
178
+
148
179
  return false;
149
180
  }
181
+
150
182
  let value = (val || '').trim();
151
183
  value = Number(value);
184
+
152
185
  if (Number.isNaN(value) || !Number.isFinite(value) || Number.isNaN(max) || !Number.isFinite(max)) {
153
186
  return true;
154
187
  }
188
+
155
189
  return !(value <= max);
156
190
  };
157
191
  } else if (rule === 'min') {
158
192
  let min = Number(ruleInfo);
159
193
  let minTypes = ['number', 'range', 'date', 'datetime', 'datetime-local', 'month', 'time', 'week'];
194
+
160
195
  newValidationRules[rule] = (val, el) => {
161
196
  if (minTypes.indexOf(type) !== -1) {
162
197
  if (el.willValidate && el.validity.rangeUnderflow) {
163
198
  return true;
164
199
  }
200
+
165
201
  return false;
166
202
  }
203
+
167
204
  let value = (val || '').trim();
168
205
  value = Number(value);
206
+
169
207
  if (Number.isNaN(value) || !Number.isFinite(value) || Number.isNaN(min) || !Number.isFinite(min)) {
170
208
  return true;
171
209
  }
210
+
172
211
  return !(value >= min);
173
212
  };
174
213
  } else if (rule === 'range' && /^([-+\d]+)*([,]{1,1}([-+\d]+))$/.test(ruleInfo) === true) {
175
214
  let ranges;
176
215
  ranges = ranges.split(',').map(a => Number(a));
216
+
177
217
  newValidationRules[rule] = val => {
178
218
  let value = (val || '').trim();
179
219
  value = Number(value);
220
+
180
221
  if (Number.isNaN(value) || !Number.isFinite(value)) {
181
222
  return true;
182
223
  }
224
+
183
225
  return !(value >= ranges[0] && value <= ranges[1]);
184
226
  };
185
227
  } else if ((rule === 'digits' || rule === 'integer' || rule === 'double') && ruleInfo === true) {
186
228
  newValidationRules[rule] = val => {
187
229
  let value = (val || '').trim();
188
230
  value = Number(value);
231
+
189
232
  if (Number.isNaN(value) || !Number.isFinite(value)) {
190
233
  return true;
191
234
  }
235
+
192
236
  let condition = true;
237
+
193
238
  if (rule === 'integer') {
194
239
  condition = Number.isSafeInteger(value);
195
240
  }
241
+
196
242
  if (rule === 'double') {
197
243
  condition = -Number.MAX_VALUE <= value && Number.MAX_VALUE >= value;
198
244
  }
245
+
199
246
  return !defaultPatterns[rule].test(value) && condition;
200
247
  };
201
248
  } else if ((rule === 'timezonedate' || rule === 'datetimezone' || rule === 'date' || rule === 'datetime') && ruleInfo === true) {
202
249
  newValidationRules[rule] = val => {
203
250
  let value = (val || '').trim();
251
+
204
252
  if (!defaultPatterns[rule].test(value)) {
205
253
  return true;
206
254
  }
255
+
207
256
  if (rule === 'datetime') {
208
257
  let index = 0;
209
- value = value.split('T')[index];
210
- //let timings = value[1].replace("Z","").split(":")
258
+ value = value.split('T')[index]; //let timings = value[1].replace("Z","").split(":")
211
259
  //let
212
260
  //if( !defaultPatterns[rule].test(value); )
213
261
  }
214
262
 
215
263
  value = value.replace('/', '-');
216
264
  value = value.replace(':', '-');
217
- let values = value.split('-');
265
+ let values = value.split('-'); // Extract the string into month, date and year
218
266
 
219
- // Extract the string into month, date and year
220
267
  let yy = parseInt(values[0]);
221
268
  let mm = parseInt(values[1]);
222
- let dd = parseInt(values[2]);
269
+ let dd = parseInt(values[2]); // Create list of days of a month [assume there is no leap year by default]
223
270
 
224
- // Create list of days of a month [assume there is no leap year by default]
225
271
  let ListofDays = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
272
+
226
273
  if (mm === 1 || mm > 2) {
227
274
  if (dd > ListofDays[mm - 1]) {
228
275
  return true;
229
276
  }
230
277
  }
278
+
231
279
  if (mm === 2) {
232
280
  let lyear = false;
281
+
233
282
  if (!(yy % 4) && yy % 100 || !(yy % 400)) {
234
283
  lyear = true;
235
284
  }
285
+
236
286
  if (lyear === false && dd >= 29) {
237
287
  return true;
238
288
  }
289
+
239
290
  if (lyear === true && dd > 29) {
240
291
  return true;
241
292
  }
@@ -254,6 +305,7 @@ const validator = {
254
305
  }
255
306
  }
256
307
  }
308
+
257
309
  return newValidationRules;
258
310
  },
259
311
  regexs: {
@@ -1,227 +1,91 @@
1
1
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
- import React, { Fragment } from 'react';
3
- import { defaultProps } from './props/defaultProps';
4
- import { propTypes } from './props/propTypes';
5
- import { remConvert } from '../utils/Common';
2
+
3
+ import React, { useRef, Fragment, useContext } from 'react';
4
+ import FocusScope from '@zohodesk/a11y/es/FocusScope/FocusScope';
6
5
  import Modal from '../Modal/Modal';
7
- import style from './DropBox.module.css';
8
- import { positionMapping } from './DropBoxPositionMapping.json';
9
- import { getZIndex } from '../Provider/ZindexProvider';
10
6
  import { getLibraryConfig } from '../Provider/Config';
11
7
  import LibraryContext from '../Provider/LibraryContextInit';
12
- export class DropBoxElement extends React.Component {
13
- constructor(props) {
14
- super(props);
15
- this.getRef = this.getRef.bind(this);
16
- }
17
- getRef(ele) {
18
- const {
19
- getRef,
20
- forwardRef
21
- } = this.props;
22
- getRef && getRef(ele);
23
- if (forwardRef) {
24
- forwardRef.current = ele;
25
- }
26
- }
27
- render() {
28
- let {
29
- children,
30
- isAnimate,
31
- isArrow,
32
- arrowPosition,
33
- boxPosition,
34
- size,
35
- right,
36
- left,
37
- top,
38
- arrowRight,
39
- arrowLeft,
40
- arrowTop,
41
- arrowBottom,
42
- bottom,
43
- onClick,
44
- isRadius,
45
- animationStyle,
46
- isActive,
47
- dataId,
48
- isModel,
49
- isAbsolutePositioningNeeded,
50
- tourId,
51
- isBoxPaddingNeed,
52
- isPadding,
53
- customClass,
54
- htmlId,
55
- a11y,
56
- direction,
57
- tabIndex,
58
- palette,
59
- positionsOffset,
60
- targetOffset,
61
- zIndexStyle,
62
- customStyle
63
- } = this.props;
64
- let {
65
- isReducedMotion
66
- } = this.context || {};
67
- if (!isAbsolutePositioningNeeded && size === 'default' && !isActive) {
68
- isAbsolutePositioningNeeded = true;
69
- }
70
- const {
71
- role,
72
- ariaMultiselectable,
73
- ariaLabelledby
74
- } = a11y;
75
- const {
76
- customDropBox = '',
77
- customMobileDropBox = '',
78
- customDropBoxWrap = '',
79
- customMobileDropBoxWrap = ''
80
- } = customClass;
81
- const unit = 'rem';
82
- let boxstyle = {};
83
- let arrowstyle = {};
84
- const needBoxStyle = right || left || top || bottom;
85
- const needArrowStyle = arrowLeft || arrowRight || arrowTop || arrowBottom;
86
- if (needBoxStyle) {
87
- boxstyle = !isModel ? direction === 'rtl' ? {
88
- right: [remConvert(left)] + unit,
89
- left: [remConvert(right)] + unit,
90
- top: [remConvert(top)] + unit,
91
- bottom: [remConvert(bottom)] + unit
92
- } : {
93
- right: [remConvert(right)] + unit,
94
- left: [remConvert(left)] + unit,
95
- top: [remConvert(top)] + unit,
96
- bottom: [remConvert(bottom)] + unit
97
- } : {};
98
- }
99
- if (needArrowStyle) {
100
- arrowstyle = !isModel ? direction === 'rtl' ? {
101
- right: [remConvert(arrowLeft)] + unit,
102
- left: [remConvert(arrowRight)] + unit,
103
- top: [remConvert(arrowTop)] + unit,
104
- bottom: [remConvert(arrowBottom)] + unit
105
- } : {
106
- right: [remConvert(arrowRight)] + unit,
107
- left: [remConvert(arrowLeft)] + unit,
108
- top: [remConvert(arrowTop)] + unit,
109
- bottom: [remConvert(arrowBottom)] + unit
110
- } : {};
111
- }
112
- boxPosition = boxPosition && boxPosition != 'undefined' ? boxPosition : 'bottomCenter';
113
- const boxDirection = positionMapping[boxPosition].direction; /*getting box direction*/
114
- if (isAbsolutePositioningNeeded) {
115
- arrowPosition = arrowPosition ? arrowPosition : positionMapping[boxPosition].arrowPosition;
116
- boxPosition = positionMapping[boxPosition].positionStyle;
117
- } else {
118
- arrowPosition = positionMapping[boxPosition].arrowPosition;
119
- }
120
- const boxClassName = `${style.main} ${!isActive ? style.hidden : ''} ${isModel ? `${style.responsive} ${customMobileDropBoxWrap}` : `${customDropBoxWrap} ${size ? style[size] : ''} ${isActive ? `${isArrow ? `${style[boxDirection]} ${isAbsolutePositioningNeeded ? style[`arrow${boxDirection}`] : ''}` : isPadding ? style[`paddingSpace_${boxDirection}`] : ''}` : ''} ${isAbsolutePositioningNeeded ? `${style.container} ${style[boxPosition]}` : style.fixedContainer}`}`;
121
- const subContainerClass = `${style.subContainer} ${isModel ? ` ${customMobileDropBox} ${style.mobRadius} ${isActive ? style.slideUp : ''} ` : `${customDropBox} ${style[`${boxDirection}_shadow`]} ${isRadius ? style.radius : ''} ${isAnimate && !isReducedMotion && isActive ? animationStyle === 'default' ? style.fadeIn : style.bounce : ''} ${isBoxPaddingNeed ? style.boxPadding : ''}`}`;
122
-
123
- // setting inlineStyle for dropbox
124
- let inlineStyle = !isModel ? isAbsolutePositioningNeeded ? needBoxStyle && boxstyle : positionsOffset && positionsOffset[boxPosition] || {} : {};
125
- if (zIndexStyle) {
126
- inlineStyle = Object.assign({}, inlineStyle, zIndexStyle);
127
- }
128
- if (!isModel && !isAbsolutePositioningNeeded && size === 'default' && targetOffset && isActive) {
129
- inlineStyle = Object.assign({}, inlineStyle, {
130
- width: targetOffset.width
131
- });
132
- }
133
- if (customStyle) {
134
- inlineStyle = Object.assign({}, inlineStyle, customStyle);
135
- }
136
- return /*#__PURE__*/React.createElement("div", {
137
- className: boxClassName,
138
- "data-id": `${dataId}`,
139
- ref: this.getRef,
140
- style: inlineStyle,
141
- "data-tour": tourId,
142
- "data-position": boxPosition,
143
- id: htmlId,
144
- role: role,
145
- "aria-multiselectable": ariaMultiselectable,
146
- "aria-labelledby": ariaLabelledby,
147
- tabIndex: tabIndex
148
- }, /*#__PURE__*/React.createElement("div", {
149
- className: `${subContainerClass} ${style[`${palette}Palette`]}`,
150
- onClick: onClick,
151
- "data-id": `${dataId}_subcontainer`
152
- }, isModel ? /*#__PURE__*/React.createElement("div", {
153
- className: style.closeBar
154
- }) : null, isArrow && !isModel && /*#__PURE__*/React.createElement("div", {
155
- className: style[arrowPosition],
156
- style: needArrowStyle && arrowstyle,
157
- "data-id": `${dataId}_arrow`
158
- }, /*#__PURE__*/React.createElement("div", {
159
- className: style.arrowShape
160
- })), children));
161
- }
162
- }
163
- export default class DropBox extends React.Component {
164
- constructor(props) {
165
- super(props);
166
- this.getNextIndex = getZIndex(this);
167
- this.onFreezeClick = this.onFreezeClick.bind(this);
168
- }
169
- onFreezeClick(e) {
170
- e && e.stopPropagation();
171
- }
172
- render() {
173
- const {
174
- needResponsive,
175
- portalId,
176
- isActive,
177
- isAbsolutePositioningNeeded,
178
- needAutoZindex,
179
- isRestrictScroll
180
- } = this.props;
181
- let windowWidth,
8
+ import cssJSLogic from './css/cssJSLogic';
9
+ import DropBoxElement from './DropBoxElement/DropBoxElement';
10
+ import { DropBoxDefaultProps } from './props/defaultProps';
11
+ import { DropBoxPropTypes } from './props/propTypes';
12
+ import { stopPropagation } from './../utils/Common';
13
+ import style from './css/DropBox.module.css';
14
+ export default function DropBox(props) {
15
+ const dropBoxRef = useRef(null);
16
+ const DropBoxContext = useContext(LibraryContext);
17
+ const {
18
+ needResponsive,
19
+ portalId,
20
+ isActive,
21
+ isAbsolutePositioningNeeded,
22
+ isRestrictScroll,
23
+ needFocusScope,
24
+ onClose,
25
+ customProps
26
+ } = props;
27
+ const {
28
+ focusScopeProps = {}
29
+ } = customProps;
30
+ const {
31
+ autoFocus = true,
32
+ restoreFocus = true,
33
+ needArrowLoop = true,
34
+ needTabLoop = false,
35
+ enableEnterAction = true
36
+ } = focusScopeProps;
37
+ const {
38
+ direction
39
+ } = DropBoxContext || {};
40
+ let windowWidth,
182
41
  mobileWidth = getLibraryConfig('mobileWidth'),
183
42
  isModel = false;
184
- if (needResponsive) {
185
- windowWidth = window.innerWidth;
186
- if (windowWidth <= mobileWidth) {
187
- isModel = true;
188
- }
43
+
44
+ if (needResponsive) {
45
+ windowWidth = window.innerWidth;
46
+
47
+ if (windowWidth <= mobileWidth) {
48
+ isModel = true;
189
49
  }
190
- const zIndexStyle = isActive && needAutoZindex ? {
191
- zIndex: this.getNextIndex()
192
- } : {};
193
- const {
194
- direction
195
- } = this.context || {};
196
- const dropBoxEle = /*#__PURE__*/React.createElement(DropBoxElement, _extends({
197
- isModel: isModel,
198
- direction: direction
199
- }, this.props, {
200
- zIndexStyle: zIndexStyle
201
- }));
202
- return isModel && isActive ? /*#__PURE__*/React.createElement(Modal, {
203
- portalId: portalId
204
- }, /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement("div", {
205
- className: `${style.freezeLayer} ${style.freeze}`,
206
- style: zIndexStyle,
207
- onClick: this.onFreezeClick
208
- }), dropBoxEle)) : !isAbsolutePositioningNeeded && isActive ? /*#__PURE__*/React.createElement(Modal, {
209
- portalId: portalId
210
- }, /*#__PURE__*/React.createElement(Fragment, null, isRestrictScroll ? /*#__PURE__*/React.createElement("div", {
211
- className: style.freezeLayer,
212
- style: zIndexStyle,
213
- onClick: this.onFreezeClick
214
- }) : null, dropBoxEle)) : dropBoxEle;
215
50
  }
51
+
52
+ const {
53
+ zIndexStyle
54
+ } = cssJSLogic(props);
55
+ const dropBoxEle = needFocusScope ? /*#__PURE__*/React.createElement(FocusScope, _extends({
56
+ onClose: onClose,
57
+ elementRef: dropBoxRef,
58
+ autoFocus: autoFocus,
59
+ restoreFocus: restoreFocus,
60
+ needArrowLoop: needArrowLoop,
61
+ needTabLoop: needTabLoop,
62
+ enableEnterAction: enableEnterAction
63
+ }, focusScopeProps), /*#__PURE__*/React.createElement(DropBoxElement, _extends({
64
+ isModel: isModel,
65
+ direction: direction
66
+ }, props, {
67
+ zIndexStyle: zIndexStyle,
68
+ subContainerRef: dropBoxRef
69
+ }))) : /*#__PURE__*/React.createElement(DropBoxElement, _extends({
70
+ isModel: isModel,
71
+ subContainerRef: dropBoxRef,
72
+ direction: direction
73
+ }, props, {
74
+ zIndexStyle: zIndexStyle
75
+ }));
76
+ return isModel && isActive ? /*#__PURE__*/React.createElement(Modal, {
77
+ portalId: portalId
78
+ }, /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
79
+ className: `${style.freezeLayer} ${style.freeze}`,
80
+ style: zIndexStyle,
81
+ onClick: stopPropagation
82
+ }), dropBoxEle)) : !isAbsolutePositioningNeeded && isActive ? /*#__PURE__*/React.createElement(Modal, {
83
+ portalId: portalId
84
+ }, /*#__PURE__*/React.createElement(React.Fragment, null, isRestrictScroll ? /*#__PURE__*/React.createElement("div", {
85
+ className: style.freezeLayer,
86
+ style: zIndexStyle,
87
+ onClick: stopPropagation
88
+ }) : null, dropBoxEle)) : dropBoxEle;
216
89
  }
217
- DropBox.propTypes = propTypes;
218
- DropBox.contextType = LibraryContext;
219
- DropBox.defaultProps = defaultProps;
220
- if (false) {
221
- DropBox.docs = {
222
- componentGroup: 'Atom',
223
- folderName: 'Style Guide',
224
- external: true,
225
- description: ' '
226
- };
227
- }
90
+ DropBox.propTypes = DropBoxPropTypes;
91
+ DropBox.defaultProps = DropBoxDefaultProps;