@zohodesk/components 1.0.0-alpha-250 → 1.0.0-alpha-252

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 (534) hide show
  1. package/README.md +18 -0
  2. package/assets/Appearance/dark/mode/darkMode.module.css +2 -1
  3. package/assets/Appearance/default/mode/defaultMode.module.css +2 -1
  4. package/assets/Appearance/pureDark/mode/pureDarkMode.module.css +2 -1
  5. package/es/Accordion/Accordion.js +0 -7
  6. package/es/Accordion/AccordionItem.js +0 -4
  7. package/es/Accordion/docs/Accordion__Demo.docs.js +0 -2
  8. package/es/Animation/Animation.js +0 -3
  9. package/es/Animation/docs/Animation__default.docs.js +0 -2
  10. package/es/Animation/docs/Animation__fadeIn.docs.js +0 -2
  11. package/es/Animation/docs/Animation__scaleIn.docs.js +0 -2
  12. package/es/Animation/docs/Animation__skewIn.docs.js +0 -2
  13. package/es/Animation/docs/Animation__slideDown.docs.js +0 -2
  14. package/es/Animation/docs/Animation__slideLeft.docs.js +0 -2
  15. package/es/Animation/docs/Animation__zoomIn.docs.js +0 -2
  16. package/es/AppContainer/AppContainer.js +2 -13
  17. package/es/AppContainer/docs/AppContainer__default.docs.js +0 -2
  18. package/es/Avatar/Avatar.js +7 -21
  19. package/es/Avatar/docs/Avatar__custom.docs.js +1 -3
  20. package/es/Avatar/docs/Avatar__default.docs.js +1 -3
  21. package/es/Avatar/docs/Avatar__palette.docs.js +1 -3
  22. package/es/Avatar/docs/Avatar__text.docs.js +1 -3
  23. package/es/AvatarTeam/AvatarTeam.js +0 -3
  24. package/es/AvatarTeam/docs/AvatarTeam__custom.docs.js +0 -2
  25. package/es/AvatarTeam/docs/AvatarTeam__default.docs.js +0 -2
  26. package/es/AvatarTeam/docs/AvatarTeam__palette.docs.js +0 -2
  27. package/es/AvatarTeam/docs/AvatarTeam__size.docs.js +0 -2
  28. package/es/Button/Button.js +0 -4
  29. package/es/Button/docs/Button__custom.docs.js +11 -13
  30. package/es/Button/docs/Button__default.docs.js +11 -13
  31. package/es/Buttongroup/Buttongroup.js +0 -3
  32. package/es/Buttongroup/docs/Buttongroup__custom.docs.js +0 -2
  33. package/es/Buttongroup/docs/Buttongroup__footer.docs.js +0 -2
  34. package/es/Buttongroup/docs/Buttongroup__header.docs.js +0 -2
  35. package/es/Card/Card.js +7 -22
  36. package/es/Card/docs/Card__Custom.docs.js +0 -2
  37. package/es/Card/docs/Card__Default.docs.js +0 -2
  38. package/es/Card/docs/Card__Scroll.docs.js +0 -3
  39. package/es/CheckBox/CheckBox.js +0 -5
  40. package/es/CheckBox/docs/CheckBox__custom.docs.js +12 -16
  41. package/es/CheckBox/docs/CheckBox__default.docs.js +12 -16
  42. package/es/DateTime/CalendarView.js +26 -34
  43. package/es/DateTime/DateTime.js +22 -77
  44. package/es/DateTime/DateTime.module.css +50 -5
  45. package/es/DateTime/DateTimePopupFooter.js +2 -4
  46. package/es/DateTime/DateTimePopupHeader.js +2 -8
  47. package/es/DateTime/DateWidget.js +34 -101
  48. package/es/DateTime/DaysRow.js +2 -4
  49. package/es/DateTime/Time.js +2 -10
  50. package/es/DateTime/YearView.js +4 -28
  51. package/es/DateTime/__tests__/CalendarView.spec.js +0 -1
  52. package/es/DateTime/__tests__/DateTime.spec.js +0 -1
  53. package/es/DateTime/__tests__/DateWidget.spec.js +3 -2
  54. package/es/DateTime/common.js +0 -3
  55. package/es/DateTime/constants.js +0 -1
  56. package/es/DateTime/dateFormatUtils/dateFormat.js +30 -63
  57. package/es/DateTime/dateFormatUtils/dayChange.js +4 -13
  58. package/es/DateTime/dateFormatUtils/index.js +2 -28
  59. package/es/DateTime/dateFormatUtils/monthChange.js +0 -8
  60. package/es/DateTime/dateFormatUtils/timeChange.js +6 -22
  61. package/es/DateTime/dateFormatUtils/yearChange.js +2 -11
  62. package/es/DateTime/docs/DateTime__default.docs.js +6 -9
  63. package/es/DateTime/docs/DateWidget__default.docs.js +0 -5
  64. package/es/DateTime/objectUtils.js +20 -14
  65. package/es/DateTime/props/propTypes.js +4 -2
  66. package/es/DateTime/typeChecker.js +0 -3
  67. package/es/DateTime/validator.js +6 -58
  68. package/es/DropBox/DropBox.js +5 -28
  69. package/es/DropBox/docs/DropBox__custom.docs.js +25 -27
  70. package/es/DropBox/docs/DropBox__customOrder.docs.js +0 -7
  71. package/es/DropBox/docs/DropBox__fixedPosition.docs.js +0 -7
  72. package/es/DropBox/docs/DropBox__position.docs.js +35 -37
  73. package/es/DropBox/docs/DropBox__size.docs.js +28 -30
  74. package/es/DropDown/DropDown.js +1 -9
  75. package/es/DropDown/DropDownHeading.js +2 -4
  76. package/es/DropDown/DropDownItem.js +0 -6
  77. package/es/DropDown/DropDownSearch.js +0 -4
  78. package/es/DropDown/DropDownSeparator.js +0 -1
  79. package/es/DropDown/__tests__/DropDown.spec.js +2 -1
  80. package/es/DropDown/docs/DropDownHeading__custom.docs.js +0 -2
  81. package/es/DropDown/docs/DropDownHeading__default.docs.js +0 -2
  82. package/es/Heading/Heading.js +0 -2
  83. package/es/Heading/Heading.module.css +3 -3
  84. package/es/Heading/docs/Heading__default.docs.js +0 -2
  85. package/es/Label/Label.js +0 -2
  86. package/es/Label/docs/Label__clipped.docs.js +0 -2
  87. package/es/Label/docs/Label__custom.docs.js +0 -2
  88. package/es/Label/docs/Label__palette.docs.js +0 -2
  89. package/es/Label/docs/Label__size.docs.js +0 -2
  90. package/es/Label/docs/Label__type.docs.js +0 -2
  91. package/es/Layout/Box.js +0 -13
  92. package/es/Layout/Container.js +1 -12
  93. package/es/Layout/docs/Layout__Hidden.docs.js +0 -1
  94. package/es/Layout/docs/Layout__default.docs.js +0 -1
  95. package/es/Layout/docs/Layout__four_Column.docs.js +0 -1
  96. package/es/Layout/docs/Layout__three_Column.docs.js +0 -1
  97. package/es/Layout/docs/Layout__two_Column.docs.js +0 -1
  98. package/es/LightNightMode/docs/AlternativeColors.docs.js +0 -2
  99. package/es/ListItem/ListContainer.js +0 -8
  100. package/es/ListItem/ListItem.js +0 -9
  101. package/es/ListItem/ListItemWithAvatar.js +1 -9
  102. package/es/ListItem/ListItemWithCheckBox.js +0 -7
  103. package/es/ListItem/ListItemWithIcon.js +0 -8
  104. package/es/ListItem/ListItemWithRadio.js +0 -7
  105. package/es/ListItem/docs/ListItemWithAvatar__custom.docs.js +0 -2
  106. package/es/ListItem/docs/ListItemWithAvatar__default.docs.js +0 -2
  107. package/es/ListItem/docs/ListItemWithCheckBox__custom.docs.js +0 -2
  108. package/es/ListItem/docs/ListItemWithCheckBox__default.docs.js +0 -2
  109. package/es/ListItem/docs/ListItemWithIcon__custom.docs.js +0 -2
  110. package/es/ListItem/docs/ListItemWithIcon__default.docs.js +0 -2
  111. package/es/ListItem/docs/ListItemWithRadio__custom.docs.js +0 -2
  112. package/es/ListItem/docs/ListItemWithRadio__default.docs.js +0 -2
  113. package/es/ListItem/docs/ListItem__custom.docs.js +0 -2
  114. package/es/ListItem/docs/ListItem__default.docs.js +0 -2
  115. package/es/Modal/Modal.js +8 -28
  116. package/es/Modal/__docs__/Modal__default.docs.js +1 -5
  117. package/es/MultiSelect/AdvancedGroupMultiSelect.js +11 -90
  118. package/es/MultiSelect/AdvancedMultiSelect.js +21 -39
  119. package/es/MultiSelect/EmptyState.js +0 -2
  120. package/es/MultiSelect/MultiSelect.js +49 -112
  121. package/es/MultiSelect/MultiSelectHeader.js +0 -3
  122. package/es/MultiSelect/MultiSelectWithAvatar.js +16 -17
  123. package/es/MultiSelect/SelectedOptions.js +3 -6
  124. package/es/MultiSelect/Suggestions.js +3 -7
  125. package/es/MultiSelect/__tests__/MultiSelect.spec.js +6 -4
  126. package/es/MultiSelect/docs/AdvancedGroupMultiSelect__default.docs.js +0 -7
  127. package/es/MultiSelect/docs/AdvancedMultiSelect__default.docs.js +1 -7
  128. package/es/MultiSelect/docs/MultiSelectWithAvatar__default.docs.js +1 -5
  129. package/es/MultiSelect/docs/MultiSelect__default.docs.js +1 -6
  130. package/es/MultiSelect/props/defaultProps.js +8 -4
  131. package/es/MultiSelect/props/propTypes.js +8 -6
  132. package/es/PopOver/PopOver.js +0 -18
  133. package/es/PopOver/__tests__/PopOver.spec.js +1 -2
  134. package/es/PopOver/docs/PopOver__default.docs.js +0 -2
  135. package/es/Popup/Popup.js +24 -77
  136. package/es/Popup/__tests__/Popup.spec.js +5 -17
  137. package/es/Popup/viewPort.js +4 -16
  138. package/es/Provider/IdProvider.js +2 -9
  139. package/es/Provider/LibraryContext.js +4 -6
  140. package/es/Provider/NumberGenerator/NumberGenerator.js +7 -21
  141. package/es/Provider/ZindexProvider.js +2 -9
  142. package/es/Provider/docs/Provider_Id__Class.docs.js +3 -4
  143. package/es/Provider/docs/Provider_Id__Function.docs.js +0 -1
  144. package/es/Provider/docs/Provider_Zindex__Class.docs.js +3 -4
  145. package/es/Provider/docs/Provider_Zindex__Function.docs.js +0 -1
  146. package/es/Provider.js +3 -7
  147. package/es/Radio/Radio.js +0 -4
  148. package/es/Radio/docs/Radio__custom.docs.js +12 -16
  149. package/es/Radio/docs/Radio__default.docs.js +12 -16
  150. package/es/Responsive/CustomResponsive.js +18 -28
  151. package/es/Responsive/RefWrapper.js +7 -6
  152. package/es/Responsive/ResizeComponent.js +25 -35
  153. package/es/Responsive/ResizeObserver.js +6 -26
  154. package/es/Responsive/Responsive.js +20 -34
  155. package/es/Responsive/docs/Responsive__Custom.docs.js +22 -14
  156. package/es/Responsive/docs/Responsive__default.docs.js +1 -3
  157. package/es/Responsive/sizeObservers.js +7 -28
  158. package/es/Responsive/utils/index.js +5 -7
  159. package/es/Responsive/utils/shallowCompare.js +2 -7
  160. package/es/Responsive/windowResizeObserver.js +0 -7
  161. package/es/ResponsiveDropBox/ResponsiveDropBox.js +0 -4
  162. package/es/Ribbon/Ribbon.js +0 -3
  163. package/es/Ribbon/docs/Ribbon__custom.docs.js +13 -14
  164. package/es/Ribbon/docs/Ribbon__default.docs.js +13 -14
  165. package/es/RippleEffect/RippleEffect.js +0 -1
  166. package/es/RippleEffect/docs/RippleEffect__default.docs.js +12 -14
  167. package/es/Select/GroupSelect.js +28 -67
  168. package/es/Select/Select.js +47 -97
  169. package/es/Select/Select.module.css +3 -0
  170. package/es/Select/SelectWithAvatar.js +15 -24
  171. package/es/Select/SelectWithIcon.js +73 -53
  172. package/es/Select/__tests__/Select.spec.js +8 -6
  173. package/es/Select/docs/GroupSelect__default.docs.js +1 -6
  174. package/es/Select/docs/SelectWithAvatar__default.docs.js +0 -4
  175. package/es/Select/docs/SelectWithIcon__default.docs.js +0 -4
  176. package/es/Select/docs/Select__default.docs.js +0 -5
  177. package/es/Select/props/defaultProps.js +8 -4
  178. package/es/Select/props/propTypes.js +8 -5
  179. package/es/Stencils/Stencils.js +0 -3
  180. package/es/Stencils/docs/Stencils__custom.docs.js +0 -2
  181. package/es/Stencils/docs/Stencils__default.docs.js +0 -2
  182. package/es/Switch/Switch.js +0 -5
  183. package/es/Switch/docs/Switch__custom.docs.js +12 -14
  184. package/es/Switch/docs/Switch__default.docs.js +12 -14
  185. package/es/Tab/Tab.js +1 -4
  186. package/es/Tab/TabContent.js +0 -1
  187. package/es/Tab/TabContentWrapper.js +0 -2
  188. package/es/Tab/TabWrapper.js +2 -5
  189. package/es/Tab/Tabs.js +7 -54
  190. package/es/Tab/__tests__/Tab.spec.js +2 -1
  191. package/es/Tab/__tests__/TabWrapper.spec.js +0 -1
  192. package/es/Tab/docs/Tab__default.docs.js +0 -5
  193. package/es/Tag/Tag.js +1 -6
  194. package/es/Tag/docs/Tag__custom.docs.js +11 -13
  195. package/es/Tag/docs/Tag__default.docs.js +11 -13
  196. package/es/TextBox/TextBox.js +0 -15
  197. package/es/TextBox/__tests__/TextBox.spec.js +4 -1
  198. package/es/TextBox/docs/TextBox__custom.docs.js +0 -2
  199. package/es/TextBox/docs/TextBox__default.docs.js +0 -2
  200. package/es/TextBox/docs/TextBox__size.docs.js +0 -2
  201. package/es/TextBox/docs/TextBox__variant.docs.js +0 -2
  202. package/es/TextBoxIcon/TextBoxIcon.js +0 -7
  203. package/es/TextBoxIcon/__tests__/TextBoxIcon.spec.js +7 -2
  204. package/es/TextBoxIcon/docs/TextBoxIcon__custom.docs.js +0 -2
  205. package/es/TextBoxIcon/docs/TextBoxIcon__default.docs.js +0 -2
  206. package/es/Textarea/Textarea.js +0 -12
  207. package/es/Textarea/__tests__/Textarea.spec.js +2 -2
  208. package/es/Textarea/docs/Textarea__animated.docs.js +0 -2
  209. package/es/Textarea/docs/Textarea__custom.docs.js +0 -2
  210. package/es/Textarea/docs/Textarea__default.docs.js +0 -2
  211. package/es/Textarea/docs/Textarea__disabled.docs.js +0 -2
  212. package/es/Tooltip/Tooltip.js +11 -58
  213. package/es/Tooltip/__tests__/Tooltip.spec.js +0 -5
  214. package/es/Tooltip/docs/Tooltip__default.docs.js +63 -67
  215. package/es/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +0 -3
  216. package/es/VelocityAnimation/VelocityAnimation/docs/VelocityAnimation__demo.docs.js +0 -5
  217. package/es/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +2 -7
  218. package/es/VelocityAnimation/VelocityAnimationGroup/docs/VelocityAnimationGroup__demo.docs.js +17 -28
  219. package/es/deprecated/PortalLayer/PortalLayer.js +17 -25
  220. package/es/deprecated/PortalLayer/docs/PortalLayer__default.docs.js +0 -7
  221. package/es/index.js +2 -1
  222. package/es/semantic/Button/Button.js +0 -3
  223. package/es/semantic/Button/docs/Button__default.docs.js +0 -3
  224. package/es/utils/Common.js +23 -47
  225. package/es/utils/ContextOptimizer.js +5 -4
  226. package/es/utils/__tests__/debounce.spec.js +2 -2
  227. package/es/utils/constructFullName.js +0 -2
  228. package/es/utils/datetime/common.js +5 -16
  229. package/es/utils/debounce.js +1 -5
  230. package/es/utils/dropDownUtils.js +11 -67
  231. package/es/utils/getInitial.js +0 -4
  232. package/es/utils/shallowEqual.js +0 -6
  233. package/lib/Accordion/Accordion.js +10 -39
  234. package/lib/Accordion/AccordionItem.js +12 -38
  235. package/lib/Accordion/__tests__/Accordion.spec.js +0 -3
  236. package/lib/Accordion/docs/Accordion__Demo.docs.js +0 -22
  237. package/lib/Accordion/index.js +0 -3
  238. package/lib/Accordion/props/propTypes.js +0 -3
  239. package/lib/Animation/Animation.js +12 -37
  240. package/lib/Animation/__tests__/Animation.spec.js +7 -11
  241. package/lib/Animation/docs/Animation__default.docs.js +0 -24
  242. package/lib/Animation/docs/Animation__fadeIn.docs.js +0 -24
  243. package/lib/Animation/docs/Animation__scaleIn.docs.js +0 -24
  244. package/lib/Animation/docs/Animation__skewIn.docs.js +0 -24
  245. package/lib/Animation/docs/Animation__slideDown.docs.js +0 -24
  246. package/lib/Animation/docs/Animation__slideLeft.docs.js +0 -24
  247. package/lib/Animation/docs/Animation__zoomIn.docs.js +0 -24
  248. package/lib/Animation/props/propTypes.js +0 -3
  249. package/lib/AppContainer/AppContainer.js +14 -52
  250. package/lib/AppContainer/docs/AppContainer__default.docs.js +0 -23
  251. package/lib/AppContainer/props/propTypes.js +0 -3
  252. package/lib/Avatar/Avatar.js +27 -71
  253. package/lib/Avatar/__tests__/Avatar.spec.js +0 -44
  254. package/lib/Avatar/docs/Avatar__custom.docs.js +1 -26
  255. package/lib/Avatar/docs/Avatar__default.docs.js +1 -24
  256. package/lib/Avatar/docs/Avatar__palette.docs.js +1 -26
  257. package/lib/Avatar/docs/Avatar__text.docs.js +1 -26
  258. package/lib/Avatar/props/propTypes.js +0 -3
  259. package/lib/AvatarTeam/AvatarTeam.js +20 -47
  260. package/lib/AvatarTeam/__tests__/AvatarTeam.spec.js +0 -13
  261. package/lib/AvatarTeam/docs/AvatarTeam__custom.docs.js +0 -24
  262. package/lib/AvatarTeam/docs/AvatarTeam__default.docs.js +0 -24
  263. package/lib/AvatarTeam/docs/AvatarTeam__palette.docs.js +0 -24
  264. package/lib/AvatarTeam/docs/AvatarTeam__size.docs.js +0 -24
  265. package/lib/AvatarTeam/props/propTypes.js +0 -3
  266. package/lib/Button/Button.js +19 -44
  267. package/lib/Button/__tests__/Button.spec.js +0 -40
  268. package/lib/Button/docs/Button__custom.docs.js +11 -37
  269. package/lib/Button/docs/Button__default.docs.js +11 -36
  270. package/lib/Button/props/defaultProps.js +0 -2
  271. package/lib/Button/props/propTypes.js +0 -3
  272. package/lib/Buttongroup/Buttongroup.js +5 -31
  273. package/lib/Buttongroup/__test__/Buttongroup.spec.js +0 -10
  274. package/lib/Buttongroup/docs/Buttongroup__custom.docs.js +0 -25
  275. package/lib/Buttongroup/docs/Buttongroup__footer.docs.js +0 -25
  276. package/lib/Buttongroup/docs/Buttongroup__header.docs.js +0 -27
  277. package/lib/Buttongroup/props/propTypes.js +0 -3
  278. package/lib/Card/Card.js +41 -102
  279. package/lib/Card/__tests__/Card.spec.js +1 -10
  280. package/lib/Card/docs/Card__Custom.docs.js +0 -27
  281. package/lib/Card/docs/Card__Default.docs.js +0 -26
  282. package/lib/Card/docs/Card__Scroll.docs.js +3 -30
  283. package/lib/Card/index.js +0 -4
  284. package/lib/Card/props/propTypes.js +0 -3
  285. package/lib/CheckBox/CheckBox.js +40 -69
  286. package/lib/CheckBox/__tests__/CheckBox.spec.js +0 -3
  287. package/lib/CheckBox/docs/CheckBox__custom.docs.js +12 -37
  288. package/lib/CheckBox/docs/CheckBox__default.docs.js +12 -36
  289. package/lib/CheckBox/props/propTypes.js +0 -3
  290. package/lib/DateTime/CalendarView.js +40 -79
  291. package/lib/DateTime/DateTime.js +164 -245
  292. package/lib/DateTime/DateTime.module.css +50 -5
  293. package/lib/DateTime/DateTimePopupFooter.js +5 -30
  294. package/lib/DateTime/DateTimePopupHeader.js +13 -45
  295. package/lib/DateTime/DateWidget.js +243 -349
  296. package/lib/DateTime/DaysRow.js +2 -26
  297. package/lib/DateTime/Time.js +29 -72
  298. package/lib/DateTime/YearView.js +25 -75
  299. package/lib/DateTime/__tests__/CalendarView.spec.js +5 -13
  300. package/lib/DateTime/__tests__/DateTime.spec.js +37 -51
  301. package/lib/DateTime/__tests__/DateWidget.spec.js +8 -10
  302. package/lib/DateTime/common.js +0 -6
  303. package/lib/DateTime/constants.js +0 -1
  304. package/lib/DateTime/dateFormatUtils/dateFormat.js +122 -184
  305. package/lib/DateTime/dateFormatUtils/dayChange.js +7 -14
  306. package/lib/DateTime/dateFormatUtils/index.js +12 -61
  307. package/lib/DateTime/dateFormatUtils/monthChange.js +9 -19
  308. package/lib/DateTime/dateFormatUtils/timeChange.js +20 -52
  309. package/lib/DateTime/dateFormatUtils/yearChange.js +11 -22
  310. package/lib/DateTime/docs/DateTime__default.docs.js +10 -33
  311. package/lib/DateTime/docs/DateWidget__default.docs.js +2 -30
  312. package/lib/DateTime/index.js +0 -2
  313. package/lib/DateTime/objectUtils.js +20 -24
  314. package/lib/DateTime/props/propTypes.js +4 -5
  315. package/lib/DateTime/typeChecker.js +0 -4
  316. package/lib/DateTime/validator.js +6 -69
  317. package/lib/DropBox/DropBox.js +58 -119
  318. package/lib/DropBox/__tests__/DropBox.spec.js +2 -6
  319. package/lib/DropBox/docs/DropBox__custom.docs.js +25 -50
  320. package/lib/DropBox/docs/DropBox__customOrder.docs.js +9 -36
  321. package/lib/DropBox/docs/DropBox__fixedPosition.docs.js +9 -36
  322. package/lib/DropBox/docs/DropBox__position.docs.js +35 -59
  323. package/lib/DropBox/docs/DropBox__size.docs.js +28 -52
  324. package/lib/DropBox/props/propTypes.js +0 -3
  325. package/lib/DropDown/DropDown.js +3 -53
  326. package/lib/DropDown/DropDownHeading.js +11 -35
  327. package/lib/DropDown/DropDownItem.js +17 -41
  328. package/lib/DropDown/DropDownSearch.js +15 -41
  329. package/lib/DropDown/DropDownSeparator.js +1 -23
  330. package/lib/DropDown/__tests__/DropDown.spec.js +9 -15
  331. package/lib/DropDown/__tests__/DropDownItem.spec.js +4 -9
  332. package/lib/DropDown/__tests__/DropDownSearch.spec.js +0 -3
  333. package/lib/DropDown/docs/DropDownHeading__custom.docs.js +0 -23
  334. package/lib/DropDown/docs/DropDownHeading__default.docs.js +0 -22
  335. package/lib/DropDown/props/propTypes.js +0 -5
  336. package/lib/Heading/Heading.js +8 -35
  337. package/lib/Heading/Heading.module.css +3 -3
  338. package/lib/Heading/docs/Heading__default.docs.js +0 -24
  339. package/lib/Heading/props/propTypes.js +0 -3
  340. package/lib/Label/Label.js +11 -36
  341. package/lib/Label/__tests__/Label.spec.js +1 -14
  342. package/lib/Label/docs/Label__clipped.docs.js +0 -25
  343. package/lib/Label/docs/Label__custom.docs.js +0 -26
  344. package/lib/Label/docs/Label__palette.docs.js +0 -25
  345. package/lib/Label/docs/Label__size.docs.js +0 -25
  346. package/lib/Label/docs/Label__type.docs.js +0 -25
  347. package/lib/Label/props/propTypes.js +0 -3
  348. package/lib/Layout/Box.js +11 -31
  349. package/lib/Layout/Container.js +10 -29
  350. package/lib/Layout/__tests__/Box.spec.js +49 -65
  351. package/lib/Layout/__tests__/Container.spec.js +50 -67
  352. package/lib/Layout/docs/Layout__Hidden.docs.js +0 -22
  353. package/lib/Layout/docs/Layout__default.docs.js +0 -21
  354. package/lib/Layout/docs/Layout__four_Column.docs.js +0 -22
  355. package/lib/Layout/docs/Layout__three_Column.docs.js +0 -22
  356. package/lib/Layout/docs/Layout__two_Column.docs.js +0 -22
  357. package/lib/Layout/index.js +0 -4
  358. package/lib/Layout/props/propTypes.js +0 -3
  359. package/lib/Layout/utils.js +0 -10
  360. package/lib/LightNightMode/docs/AlternativeColors.docs.js +1 -26
  361. package/lib/ListItem/ListContainer.js +25 -46
  362. package/lib/ListItem/ListItem.js +37 -66
  363. package/lib/ListItem/ListItemWithAvatar.js +41 -72
  364. package/lib/ListItem/ListItemWithCheckBox.js +32 -61
  365. package/lib/ListItem/ListItemWithIcon.js +36 -65
  366. package/lib/ListItem/ListItemWithRadio.js +33 -62
  367. package/lib/ListItem/docs/ListItemWithAvatar__custom.docs.js +0 -24
  368. package/lib/ListItem/docs/ListItemWithAvatar__default.docs.js +0 -23
  369. package/lib/ListItem/docs/ListItemWithCheckBox__custom.docs.js +0 -24
  370. package/lib/ListItem/docs/ListItemWithCheckBox__default.docs.js +0 -23
  371. package/lib/ListItem/docs/ListItemWithIcon__custom.docs.js +0 -24
  372. package/lib/ListItem/docs/ListItemWithIcon__default.docs.js +0 -23
  373. package/lib/ListItem/docs/ListItemWithRadio__custom.docs.js +0 -24
  374. package/lib/ListItem/docs/ListItemWithRadio__default.docs.js +0 -23
  375. package/lib/ListItem/docs/ListItem__custom.docs.js +0 -23
  376. package/lib/ListItem/docs/ListItem__default.docs.js +0 -22
  377. package/lib/ListItem/props/propTypes.js +0 -5
  378. package/lib/Modal/Modal.js +4 -44
  379. package/lib/Modal/__docs__/Modal__default.docs.js +0 -23
  380. package/lib/Modal/props/propTypes.js +0 -3
  381. package/lib/MultiSelect/AdvancedGroupMultiSelect.js +157 -289
  382. package/lib/MultiSelect/AdvancedMultiSelect.js +130 -203
  383. package/lib/MultiSelect/EmptyState.js +21 -44
  384. package/lib/MultiSelect/MultiSelect.js +213 -325
  385. package/lib/MultiSelect/MultiSelectHeader.js +5 -29
  386. package/lib/MultiSelect/MultiSelectWithAvatar.js +61 -98
  387. package/lib/MultiSelect/SelectedOptions.js +15 -44
  388. package/lib/MultiSelect/Suggestions.js +26 -59
  389. package/lib/MultiSelect/__tests__/MultiSelect.spec.js +75 -86
  390. package/lib/MultiSelect/docs/AdvancedGroupMultiSelect__default.docs.js +0 -23
  391. package/lib/MultiSelect/docs/AdvancedMultiSelect__default.docs.js +3 -28
  392. package/lib/MultiSelect/docs/MultiSelectWithAvatar__default.docs.js +2 -28
  393. package/lib/MultiSelect/docs/MultiSelect__default.docs.js +2 -30
  394. package/lib/MultiSelect/props/defaultProps.js +8 -6
  395. package/lib/MultiSelect/props/propTypes.js +8 -9
  396. package/lib/PopOver/PopOver.js +44 -94
  397. package/lib/PopOver/__tests__/PopOver.spec.js +1 -4
  398. package/lib/PopOver/docs/PopOver__default.docs.js +0 -25
  399. package/lib/PopOver/props/propTypes.js +0 -3
  400. package/lib/Popup/Popup.js +77 -156
  401. package/lib/Popup/__tests__/Popup.spec.js +5 -42
  402. package/lib/Popup/viewPort.js +14 -28
  403. package/lib/Provider/AvatarSize.js +0 -4
  404. package/lib/Provider/Config.js +0 -2
  405. package/lib/Provider/CssProvider.js +0 -4
  406. package/lib/Provider/IdProvider.js +3 -17
  407. package/lib/Provider/LibraryContext.js +10 -32
  408. package/lib/Provider/LibraryContextInit.js +0 -4
  409. package/lib/Provider/NumberGenerator/NumberGenerator.js +14 -43
  410. package/lib/Provider/ZindexProvider.js +3 -15
  411. package/lib/Provider/docs/Provider_Id__Class.docs.js +3 -24
  412. package/lib/Provider/docs/Provider_Id__Function.docs.js +0 -5
  413. package/lib/Provider/docs/Provider_Zindex__Class.docs.js +3 -24
  414. package/lib/Provider/docs/Provider_Zindex__Function.docs.js +0 -5
  415. package/lib/Provider.js +2 -61
  416. package/lib/Radio/Radio.js +33 -60
  417. package/lib/Radio/__tests__/Radiospec.js +5 -9
  418. package/lib/Radio/docs/Radio__custom.docs.js +12 -38
  419. package/lib/Radio/docs/Radio__default.docs.js +12 -37
  420. package/lib/Radio/props/propTypes.js +0 -3
  421. package/lib/Responsive/CustomResponsive.js +23 -67
  422. package/lib/Responsive/RefWrapper.js +7 -15
  423. package/lib/Responsive/ResizeComponent.js +27 -58
  424. package/lib/Responsive/ResizeObserver.js +6 -23
  425. package/lib/Responsive/Responsive.js +24 -76
  426. package/lib/Responsive/docs/Responsive__Custom.docs.js +29 -54
  427. package/lib/Responsive/docs/Responsive__default.docs.js +4 -28
  428. package/lib/Responsive/index.js +0 -2
  429. package/lib/Responsive/props/propTypes.js +0 -3
  430. package/lib/Responsive/sizeObservers.js +13 -51
  431. package/lib/Responsive/utils/index.js +3 -11
  432. package/lib/Responsive/utils/shallowCompare.js +2 -11
  433. package/lib/Responsive/windowResizeObserver.js +0 -8
  434. package/lib/ResponsiveDropBox/ResponsiveDropBox.js +14 -44
  435. package/lib/ResponsiveDropBox/props/propTypes.js +0 -3
  436. package/lib/Ribbon/Ribbon.js +7 -31
  437. package/lib/Ribbon/__tests__/Ribbon.spec.js +0 -22
  438. package/lib/Ribbon/docs/Ribbon__custom.docs.js +13 -36
  439. package/lib/Ribbon/docs/Ribbon__default.docs.js +13 -35
  440. package/lib/Ribbon/props/propTypes.js +0 -3
  441. package/lib/RippleEffect/RippleEffect.js +7 -18
  442. package/lib/RippleEffect/docs/RippleEffect__default.docs.js +12 -34
  443. package/lib/RippleEffect/props/propTypes.js +0 -3
  444. package/lib/Select/GroupSelect.js +138 -230
  445. package/lib/Select/Select.js +213 -297
  446. package/lib/Select/Select.module.css +3 -0
  447. package/lib/Select/SelectWithAvatar.js +61 -104
  448. package/lib/Select/SelectWithIcon.js +149 -143
  449. package/lib/Select/__tests__/Select.spec.js +89 -131
  450. package/lib/Select/docs/GroupSelect__default.docs.js +0 -26
  451. package/lib/Select/docs/SelectWithAvatar__default.docs.js +0 -28
  452. package/lib/Select/docs/SelectWithIcon__default.docs.js +4 -29
  453. package/lib/Select/docs/Select__default.docs.js +0 -27
  454. package/lib/Select/props/defaultProps.js +7 -8
  455. package/lib/Select/props/propTypes.js +8 -8
  456. package/lib/Stencils/Stencils.js +4 -28
  457. package/lib/Stencils/__tests__/Stencils.spec.js +0 -12
  458. package/lib/Stencils/docs/Stencils__custom.docs.js +0 -24
  459. package/lib/Stencils/docs/Stencils__default.docs.js +0 -24
  460. package/lib/Stencils/props/propTypes.js +0 -3
  461. package/lib/Switch/Switch.js +27 -55
  462. package/lib/Switch/docs/Switch__custom.docs.js +12 -35
  463. package/lib/Switch/docs/Switch__default.docs.js +12 -34
  464. package/lib/Switch/props/propTypes.js +0 -3
  465. package/lib/Tab/Tab.js +23 -39
  466. package/lib/Tab/TabContent.js +4 -11
  467. package/lib/Tab/TabContentWrapper.js +5 -12
  468. package/lib/Tab/TabWrapper.js +16 -34
  469. package/lib/Tab/Tabs.js +85 -166
  470. package/lib/Tab/__tests__/Tab.spec.js +63 -74
  471. package/lib/Tab/__tests__/TabContent.spec.js +6 -10
  472. package/lib/Tab/__tests__/TabContentWrapper.spec.js +20 -28
  473. package/lib/Tab/__tests__/TabWrapper.spec.js +0 -12
  474. package/lib/Tab/__tests__/Tabs.spec.js +39 -53
  475. package/lib/Tab/docs/Tab__default.docs.js +0 -25
  476. package/lib/Tab/index.js +0 -6
  477. package/lib/Tab/props/propTypes.js +0 -3
  478. package/lib/Tag/Tag.js +37 -70
  479. package/lib/Tag/__tests__/Tag.spec.js +8 -14
  480. package/lib/Tag/docs/Tag__custom.docs.js +11 -37
  481. package/lib/Tag/docs/Tag__default.docs.js +11 -36
  482. package/lib/Tag/props/propTypes.js +0 -3
  483. package/lib/TextBox/TextBox.js +52 -83
  484. package/lib/TextBox/__tests__/TextBox.spec.js +4 -14
  485. package/lib/TextBox/docs/TextBox__custom.docs.js +0 -26
  486. package/lib/TextBox/docs/TextBox__default.docs.js +0 -26
  487. package/lib/TextBox/docs/TextBox__size.docs.js +0 -26
  488. package/lib/TextBox/docs/TextBox__variant.docs.js +0 -26
  489. package/lib/TextBox/props/propTypes.js +0 -5
  490. package/lib/TextBoxIcon/TextBoxIcon.js +48 -80
  491. package/lib/TextBoxIcon/__tests__/TextBoxIcon.spec.js +5 -14
  492. package/lib/TextBoxIcon/docs/TextBoxIcon__custom.docs.js +0 -27
  493. package/lib/TextBoxIcon/docs/TextBoxIcon__default.docs.js +0 -27
  494. package/lib/TextBoxIcon/props/propTypes.js +0 -3
  495. package/lib/Textarea/Textarea.js +22 -52
  496. package/lib/Textarea/__tests__/Textarea.spec.js +2 -14
  497. package/lib/Textarea/docs/Textarea__animated.docs.js +0 -25
  498. package/lib/Textarea/docs/Textarea__custom.docs.js +0 -26
  499. package/lib/Textarea/docs/Textarea__default.docs.js +0 -25
  500. package/lib/Textarea/docs/Textarea__disabled.docs.js +0 -25
  501. package/lib/Textarea/props/propTypes.js +0 -3
  502. package/lib/Tooltip/Tooltip.js +25 -92
  503. package/lib/Tooltip/__tests__/Tooltip.spec.js +0 -23
  504. package/lib/Tooltip/docs/Tooltip__default.docs.js +63 -91
  505. package/lib/Tooltip/props/propTypes.js +0 -3
  506. package/lib/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +11 -39
  507. package/lib/VelocityAnimation/VelocityAnimation/docs/VelocityAnimation__demo.docs.js +2 -29
  508. package/lib/VelocityAnimation/VelocityAnimation/props/propTypes.js +0 -3
  509. package/lib/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +18 -51
  510. package/lib/VelocityAnimation/VelocityAnimationGroup/docs/VelocityAnimationGroup__demo.docs.js +22 -54
  511. package/lib/VelocityAnimation/VelocityAnimationGroup/props/propTypes.js +0 -3
  512. package/lib/css.js +0 -39
  513. package/lib/deprecated/PortalLayer/PortalLayer.js +17 -45
  514. package/lib/deprecated/PortalLayer/docs/PortalLayer__default.docs.js +2 -36
  515. package/lib/deprecated/PortalLayer/props/propTypes.js +0 -3
  516. package/lib/index.js +0 -158
  517. package/lib/semantic/Button/Button.js +17 -41
  518. package/lib/semantic/Button/docs/Button__default.docs.js +0 -23
  519. package/lib/semantic/Button/props/propTypes.js +0 -3
  520. package/lib/utils/Common.js +29 -95
  521. package/lib/utils/ContextOptimizer.js +10 -16
  522. package/lib/utils/__tests__/constructFullName.spec.js +0 -1
  523. package/lib/utils/__tests__/debounce.spec.js +2 -3
  524. package/lib/utils/__tests__/getInitial.spec.js +0 -1
  525. package/lib/utils/constructFullName.js +2 -11
  526. package/lib/utils/datetime/common.js +5 -32
  527. package/lib/utils/debounce.js +1 -6
  528. package/lib/utils/dropDownUtils.js +54 -171
  529. package/lib/utils/dummyFunction.js +0 -2
  530. package/lib/utils/getHTMLFontSize.js +0 -1
  531. package/lib/utils/getInitial.js +0 -6
  532. package/lib/utils/scrollTo.js +0 -2
  533. package/lib/utils/shallowEqual.js +0 -8
  534. package/package.json +1 -1
@@ -1,6 +1,6 @@
1
1
  /* eslint css-modules/no-unused-class: [0, { markAsUsed: ['datesStr', 'dateContainer', 'dateRow', 'today', 'emptySpan', 'dropDown'] }] */
2
-
3
2
  /* eslint-disable react/forbid-component-props */
3
+
4
4
  import React from 'react';
5
5
  import { DateTime_propTypes } from './props/propTypes';
6
6
  import { DateTime_defaultProps } from './props/defaultProps';
@@ -18,13 +18,11 @@ import ResponsiveDropBox from '../ResponsiveDropBox/ResponsiveDropBox';
18
18
  import { ResponsiveReceiver } from '../Responsive/CustomResponsive';
19
19
  import { Box } from '../Layout';
20
20
  import { getHourDetails } from './dateFormatUtils';
21
-
22
21
  function title(date, year, month) {
23
22
  let monthNames = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];
24
23
  const HeadingText = `${monthNames[month] || ''} ${year}`;
25
24
  return HeadingText;
26
25
  }
27
-
28
26
  export default class DateTime extends React.PureComponent {
29
27
  constructor(props) {
30
28
  super(props);
@@ -54,29 +52,22 @@ export default class DateTime extends React.PureComponent {
54
52
  startPoint: hourStart,
55
53
  endPoint: hourEnd
56
54
  } = getHourDetails(props.is24Hour);
57
-
58
55
  this.hourSuggestions = (() => {
59
56
  const hourArr = [];
60
-
61
57
  for (let hour = hourStart; hour <= hourEnd; hour++) {
62
58
  const htxt = hour < 10 ? `0${hour}` : `${hour}`;
63
59
  hourArr.push(htxt);
64
60
  }
65
-
66
61
  return hourArr;
67
62
  })();
68
-
69
63
  this.minSuggestions = (() => {
70
64
  const minArr = [];
71
-
72
65
  for (let minute = 0; minute <= 59; minute++) {
73
66
  const mtxt = minute < 10 ? `0${minute}` : `${minute}`;
74
67
  minArr.push(mtxt);
75
68
  }
76
-
77
69
  return minArr;
78
70
  })();
79
-
80
71
  this.ampmSuggestions = (() => {
81
72
  const ampmSuggestions = [];
82
73
  ampmText.forEach((text, index) => {
@@ -94,29 +85,24 @@ export default class DateTime extends React.PureComponent {
94
85
  });
95
86
  return ampmSuggestions;
96
87
  })();
97
-
98
88
  const initalStateObj = this.getStateFromProps(props);
99
89
  this.state = Object.assign({}, initalStateObj, {
100
90
  isYearView: false,
101
91
  isMonthOpen: false
102
92
  });
103
93
  }
104
-
105
94
  componentDidMount() {
106
95
  this.handleExposeMethods(true);
107
96
  }
108
-
109
97
  componentDidUpdate(prevProps) {
110
98
  const {
111
99
  value,
112
100
  isActive,
113
101
  is24Hour
114
102
  } = this.props;
115
-
116
103
  if (prevProps.value !== value || is24Hour !== prevProps.is24Hour) {
117
104
  this.setState(this.getStateFromProps(this.props));
118
105
  }
119
-
120
106
  if (prevProps.isActive !== isActive && !isActive) {
121
107
  this.setState({
122
108
  isYearView: false,
@@ -124,11 +110,9 @@ export default class DateTime extends React.PureComponent {
124
110
  });
125
111
  }
126
112
  }
127
-
128
113
  componentWillUnmount() {
129
114
  this.handleExposeMethods(false);
130
115
  }
131
-
132
116
  getStateFromProps(props) {
133
117
  let date, month, year, hours, mins, amPm;
134
118
  let {
@@ -139,16 +123,17 @@ export default class DateTime extends React.PureComponent {
139
123
  isDateTimeField,
140
124
  is24Hour
141
125
  } = props; //defaultTime --> 12:00:PM
142
-
143
126
  defaultTime = needDefaultTime ? defaultTime ? defaultTime : '12:00:PM' : '';
144
127
  let defaultHour, defaultMin, defaultAmPm;
145
-
128
+ let todayObj = new Date();
129
+ let todayDate = todayObj.getDate();
130
+ let todayMonth = todayObj.getMonth();
131
+ let todayYear = todayObj.getFullYear();
146
132
  if (!value) {
147
133
  [defaultHour, defaultMin, defaultAmPm] = defaultTime ? defaultTime.split(':') : [];
148
134
  defaultHour = parseInt(defaultHour);
149
135
  defaultMin = parseInt(defaultMin);
150
136
  }
151
-
152
137
  const dateObj = isDateTimeField ? datetime.toDate(datetime.tz.utcToTz(value, timeZone)) : value ? datetime.toDate(value) : new Date();
153
138
  date = dateObj.getDate();
154
139
  month = dateObj.getMonth();
@@ -164,13 +149,14 @@ export default class DateTime extends React.PureComponent {
164
149
  year,
165
150
  mins,
166
151
  hours,
167
- amPm
152
+ amPm,
153
+ todayDate,
154
+ todayMonth,
155
+ todayYear
168
156
  };
169
157
  }
170
-
171
158
  getHours(hoursParam, is24Hour) {
172
159
  let hours = hoursParam;
173
-
174
160
  if (!is24Hour) {
175
161
  if (hours === 0) {
176
162
  hours = 12;
@@ -178,11 +164,9 @@ export default class DateTime extends React.PureComponent {
178
164
  hours -= 12;
179
165
  }
180
166
  }
181
-
182
167
  hours = hours < 10 ? `0${hours}` : hours;
183
168
  return hours;
184
169
  }
185
-
186
170
  handleGetSelectedDate() {
187
171
  let selectedInfo = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
188
172
  const {
@@ -201,25 +185,21 @@ export default class DateTime extends React.PureComponent {
201
185
  mins,
202
186
  amPm
203
187
  } = selectedInfo;
204
-
205
188
  if (!is24Hour) {
206
189
  if (parseInt(hours) === 12) {
207
190
  hours = amPm === 'AM' ? 0 : 12;
208
191
  }
209
-
210
192
  if (amPm === 'PM') {
211
193
  if (hours < 12) {
212
194
  hours = parseInt(hours) + 12;
213
195
  }
214
196
  }
215
197
  }
216
-
217
198
  let minInMillis = min ? datetime.millis(min) : null,
218
- maxInMillis = max ? datetime.millis(max) : null,
219
- selectedInMillis,
220
- selectedValue = '',
221
- formattedValue;
222
-
199
+ maxInMillis = max ? datetime.millis(max) : null,
200
+ selectedInMillis,
201
+ selectedValue = '',
202
+ formattedValue;
223
203
  if (isDateTimeField) {
224
204
  selectedInMillis = datetime.tz.tzToUtc(Date.UTC(year, month, date, hours, mins), timeZone);
225
205
  selectedValue = datetime.ISO(selectedInMillis);
@@ -229,10 +209,8 @@ export default class DateTime extends React.PureComponent {
229
209
  selectedValue = formatDate(new Date(year, month, date), 'YYYY-MM-DD');
230
210
  formattedValue = formatDate(new Date(year, month, date), dateFormat);
231
211
  }
232
-
233
212
  let isError = false;
234
213
  let errorType = '';
235
-
236
214
  if (minInMillis && minInMillis > selectedInMillis) {
237
215
  isError = true;
238
216
  errorType = 'MIN';
@@ -240,7 +218,6 @@ export default class DateTime extends React.PureComponent {
240
218
  isError = true;
241
219
  errorType = 'MAX';
242
220
  }
243
-
244
221
  return {
245
222
  isError,
246
223
  errorType,
@@ -248,7 +225,6 @@ export default class DateTime extends React.PureComponent {
248
225
  formattedValue
249
226
  };
250
227
  }
251
-
252
228
  handleSelect(e) {
253
229
  e && e.preventDefault();
254
230
  const {
@@ -278,7 +254,6 @@ export default class DateTime extends React.PureComponent {
278
254
  mins,
279
255
  amPm
280
256
  });
281
-
282
257
  if (isError) {
283
258
  if (errorType === 'MIN') {
284
259
  onError && onError(minErrorText, true);
@@ -289,7 +264,6 @@ export default class DateTime extends React.PureComponent {
289
264
  onSelect(selectedValue, formattedValue, e);
290
265
  }
291
266
  }
292
-
293
267
  handleChange() {
294
268
  let selectedInfo = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
295
269
  const {
@@ -322,7 +296,6 @@ export default class DateTime extends React.PureComponent {
322
296
  mins: getIsEmptyValue(mins) ? oldMins : mins,
323
297
  amPm: getIsEmptyValue(amPm) ? oldAMPM : amPm
324
298
  };
325
-
326
299
  if (onChange) {
327
300
  const {
328
301
  isError,
@@ -330,7 +303,6 @@ export default class DateTime extends React.PureComponent {
330
303
  selectedValue,
331
304
  formattedValue
332
305
  } = this.handleGetSelectedDate(newSelectedInfo);
333
-
334
306
  if (isError) {
335
307
  if (errorType === 'MIN') {
336
308
  onError && onError(minErrorText, true);
@@ -345,20 +317,17 @@ export default class DateTime extends React.PureComponent {
345
317
  this.setState(newSelectedInfo);
346
318
  }
347
319
  }
348
-
349
320
  handleClear(e) {
350
321
  const {
351
322
  onSelect,
352
323
  onClear
353
324
  } = this.props;
354
-
355
325
  if (onClear) {
356
326
  onClear(e);
357
327
  } else {
358
328
  onSelect('', '', e);
359
329
  }
360
330
  }
361
-
362
331
  dateSelect(date, month, year, e) {
363
332
  this.handleChange({
364
333
  date,
@@ -390,7 +359,6 @@ export default class DateTime extends React.PureComponent {
390
359
  mins,
391
360
  amPm
392
361
  });
393
-
394
362
  if (isError) {
395
363
  if (errorType === 'MIN') {
396
364
  onError && onError(minErrorText, true);
@@ -401,31 +369,26 @@ export default class DateTime extends React.PureComponent {
401
369
  onDateSelect && onDateSelect(selectedValue, formattedValue, e);
402
370
  }
403
371
  }
404
-
405
372
  hoursSelect(hours) {
406
373
  this.handleChange({
407
374
  hours
408
375
  });
409
376
  }
410
-
411
377
  minutesSelect(mins) {
412
378
  this.handleChange({
413
379
  mins
414
380
  });
415
381
  }
416
-
417
382
  amPmSelect(amPm) {
418
383
  this.handleChange({
419
384
  amPm
420
385
  });
421
386
  }
422
- /*global closeGroupPopups*/
423
-
424
387
 
388
+ /*global closeGroupPopups*/
425
389
  closePopup() {
426
390
  closeGroupPopups('calender');
427
391
  }
428
-
429
392
  handleCalendarNavigation(type, selectedInfo) {
430
393
  const {
431
394
  year: stateYear,
@@ -435,12 +398,10 @@ export default class DateTime extends React.PureComponent {
435
398
  let date = stateDate;
436
399
  let month = stateMonth;
437
400
  const year = stateYear;
438
-
439
401
  const getDate = (month, year) => {
440
402
  const monthEnd = getMonthEnd(month, year);
441
403
  return monthEnd >= parseInt(date) ? date : monthEnd;
442
404
  };
443
-
444
405
  const modifyCalendarRecursion = recursionType => {
445
406
  if (recursionType === 'nextYear') {
446
407
  //Click next year icon
@@ -464,7 +425,6 @@ export default class DateTime extends React.PureComponent {
464
425
  month = 0;
465
426
  return modifyCalendarRecursion('nextYear');
466
427
  }
467
-
468
428
  const newMonth = month + 1;
469
429
  return {
470
430
  date: getDate(newMonth, year),
@@ -477,7 +437,6 @@ export default class DateTime extends React.PureComponent {
477
437
  month = 11;
478
438
  return modifyCalendarRecursion('previousYear');
479
439
  }
480
-
481
440
  const newMonth = month - 1;
482
441
  return {
483
442
  date: getDate(newMonth, year),
@@ -486,12 +445,10 @@ export default class DateTime extends React.PureComponent {
486
445
  };
487
446
  } else if (recursionType === 'nextDate') {
488
447
  const monthEnd = getMonthEnd(month, year);
489
-
490
448
  if (date === monthEnd) {
491
449
  date = 1;
492
450
  return modifyCalendarRecursion('nextMonth');
493
451
  }
494
-
495
452
  const newDate = parseInt(date) + 1;
496
453
  return {
497
454
  date: newDate,
@@ -503,7 +460,6 @@ export default class DateTime extends React.PureComponent {
503
460
  date = month === 0 ? getMonthEnd(11, year - 1) : getMonthEnd(month - 1, year);
504
461
  return modifyCalendarRecursion('previousMonth');
505
462
  }
506
-
507
463
  const newDate = parseInt(date) - 1;
508
464
  return {
509
465
  date: newDate,
@@ -512,10 +468,8 @@ export default class DateTime extends React.PureComponent {
512
468
  };
513
469
  }
514
470
  };
515
-
516
471
  return modifyCalendarRecursion(type);
517
472
  }
518
-
519
473
  modifyCalendar(type) {
520
474
  const {
521
475
  year,
@@ -528,11 +482,9 @@ export default class DateTime extends React.PureComponent {
528
482
  date
529
483
  }));
530
484
  }
531
-
532
485
  handleDateReset() {
533
486
  this.setState(this.getStateFromProps(this.props));
534
487
  }
535
-
536
488
  handleGetStateValues() {
537
489
  const {
538
490
  isActive
@@ -547,20 +499,17 @@ export default class DateTime extends React.PureComponent {
547
499
  isMonthOpen
548
500
  };
549
501
  }
550
-
551
502
  handleYearViewToggle(isYearOpen, isMonthOpen) {
552
503
  this.setState({
553
504
  isYearView: isYearOpen,
554
505
  isMonthOpen
555
506
  });
556
507
  }
557
-
558
508
  handleExposeMethods(isMount) {
559
509
  const {
560
510
  getMethods
561
511
  } = this.props;
562
512
  let methods = {};
563
-
564
513
  if (isMount) {
565
514
  methods = {
566
515
  resetLocalDate: this.handleDateReset,
@@ -574,10 +523,8 @@ export default class DateTime extends React.PureComponent {
574
523
  toggleYearView: null
575
524
  };
576
525
  }
577
-
578
526
  getMethods && getMethods(methods);
579
527
  }
580
-
581
528
  handleOpenYearView() {
582
529
  const {
583
530
  isYearView,
@@ -588,14 +535,12 @@ export default class DateTime extends React.PureComponent {
588
535
  isMonthOpen: !isMonthOpen
589
536
  });
590
537
  }
591
-
592
538
  handleSelectYear(year) {
593
539
  this.setState({
594
540
  year,
595
541
  isMonthOpen: true
596
542
  });
597
543
  }
598
-
599
544
  handleSelectMonth(month) {
600
545
  const {
601
546
  date,
@@ -603,17 +548,14 @@ export default class DateTime extends React.PureComponent {
603
548
  } = this.state;
604
549
  const monthEnd = getMonthEnd(month, year);
605
550
  let newDate = date;
606
-
607
551
  if (date > monthEnd) {
608
552
  newDate = monthEnd;
609
553
  }
610
-
611
554
  this.setState({
612
555
  month,
613
556
  date: newDate
614
557
  });
615
558
  }
616
-
617
559
  handleSelectMonthViaYearView(month) {
618
560
  this.handleSelectMonth(month);
619
561
  this.setState({
@@ -621,7 +563,6 @@ export default class DateTime extends React.PureComponent {
621
563
  isMonthOpen: false
622
564
  });
623
565
  }
624
-
625
566
  responsiveFunc(_ref) {
626
567
  let {
627
568
  mediaQueryOR
@@ -632,7 +573,6 @@ export default class DateTime extends React.PureComponent {
632
573
  }])
633
574
  };
634
575
  }
635
-
636
576
  render() {
637
577
  const {
638
578
  date,
@@ -642,7 +582,10 @@ export default class DateTime extends React.PureComponent {
642
582
  mins,
643
583
  amPm,
644
584
  isYearView,
645
- isMonthOpen
585
+ isMonthOpen,
586
+ todayDate,
587
+ todayMonth,
588
+ todayYear
646
589
  } = this.state;
647
590
  const {
648
591
  isDateTimeField,
@@ -703,7 +646,10 @@ export default class DateTime extends React.PureComponent {
703
646
  month: month,
704
647
  onSelect: this.dateSelect,
705
648
  dayNames: dayNames,
706
- dayNamesShort: dayNamesShort
649
+ dayNamesShort: dayNamesShort,
650
+ todayDate: todayDate,
651
+ todayMonth: todayMonth,
652
+ todayYear: todayYear
707
653
  }), isDateTimeField ? /*#__PURE__*/React.createElement(Time, {
708
654
  timeText: timeText,
709
655
  dataId: dataId,
@@ -770,7 +716,6 @@ export default class DateTime extends React.PureComponent {
770
716
  }, /*#__PURE__*/React.createElement(Box, null, childEle));
771
717
  }) : null;
772
718
  }
773
-
774
719
  }
775
720
  DateTime.propTypes = DateTime_propTypes;
776
721
  DateTime.defaultProps = DateTime_defaultProps;
@@ -1,20 +1,24 @@
1
1
  .semibold {
2
2
  font-family: var(--zd_semibold);
3
3
  }
4
+
4
5
  [dir=ltr] .boxPadding {
5
6
  padding-right: var(--zd_size19);
6
7
  padding-left: var(--zd_size19);
7
8
  }
9
+
8
10
  [dir=rtl] .boxPadding {
9
11
  padding-left: var(--zd_size19);
10
12
  padding-right: var(--zd_size19);
11
13
  }
14
+
12
15
  .container {
13
16
  font-size: var(--zd_font_size16);
14
17
  composes: offSelection from '../common/common.module.css';
15
18
  border-radius: 3px;
16
19
  background-color: var(--zdt_datetime_default_bg);
17
20
  }
21
+
18
22
  .header {
19
23
  min-height: var(--zd_size36);
20
24
  composes: boxPadding;
@@ -27,26 +31,32 @@
27
31
  .datesStr {
28
32
  font-family: var(--zd_regular);
29
33
  }
34
+
30
35
  .grid {
31
36
  width: var(--zd_size28);
32
37
  height: var(--zd_size28);
33
- line-height: var(--zd_size20);
38
+ line-height: var(--zd_size18);
34
39
  text-align: center;
35
40
  padding: var(--zd_size4) 0;
36
41
  border-radius: 50%;
42
+ border: 1px solid transparent;
37
43
  }
44
+
38
45
  .thArrow,
39
46
  .datesStr {
40
47
  font-size: var(--zd_font_size13);
41
48
  color: var(--zdt_datetime_datestr_text);
42
49
  }
50
+
43
51
  .thArrow, .datesStr {
44
52
  cursor: pointer;
45
53
  }
54
+
46
55
  .thArrow:hover,
47
56
  .datesStr:hover {
48
57
  color: var(--zdt_datetime_datestr_text);
49
58
  }
59
+
50
60
  .thArrow:hover, .datesStr:hover {
51
61
  background: var(--zdt_datetime_datestr_hover_bg);
52
62
  }
@@ -58,82 +68,109 @@
58
68
  [dir=rtl] .navigation {
59
69
  margin-right: var(--zd_size2);
60
70
  }
71
+
61
72
  .thMonYear {
62
73
  font-size: var(--zd_font_size13);
63
74
  line-height: var(--zd_size24);
64
75
  color: var(--zdt_datetime_datestr_text);
65
76
  composes: semibold;
66
77
  }
78
+
67
79
  .dateContainer {
68
80
  margin: 0 var(--zd_size19) 0 var(--zd_size19);
69
81
  padding: var(--zd_size6) 0 var(--zd_size10) 0;
70
82
  }
83
+
71
84
  .separator {
72
85
  border-bottom: 1px dotted var(--zdt_datetime_separator_border);
73
86
  }
87
+
74
88
  .days {
75
89
  min-height: var(--zd_size36);
76
90
  composes: boxPadding;
77
91
  composes: alignBetween from '../common/common.module.css';
78
92
  padding-top: var(--zd_size7);
79
93
  }
94
+
80
95
  .daysStr {
81
96
  font-size: var(--zd_font_size10);
82
97
  color: var(--zdt_datetime_daystr_text);
83
98
  text-transform: uppercase;
84
99
  composes: semibold;
85
100
  }
101
+
86
102
  .dateRow {
87
103
  height: var(--zd_size28);
88
104
  composes: alignBetween from '../common/common.module.css';
89
105
  margin: var(--zd_size1) 0 var(--zd_size5);
90
106
  }
107
+
91
108
  .dateRow:last-child {
92
109
  margin-bottom: 0;
93
110
  }
111
+
94
112
  .sunday,
95
113
  .sunday:hover,
96
114
  .invalidDate.sunday:hover {
97
115
  color: var(--zdt_datetime_invalid_hover_text);
98
116
  }
117
+
99
118
  .invalidDate {
100
119
  color: var(--zdt_datetime_invalid_text);
101
120
  }
121
+
102
122
  .invalidDate.sunday {
103
123
  color: var(--zdt_datetime_invaliddate_text);
104
124
  }
105
125
 
106
- .today,
107
- .today:hover {
126
+ .active,
127
+ .active:hover,
128
+ .active.today,
129
+ .active:hover.today:hover {
108
130
  color: var(--zdt_datetime_today_text);
109
131
  }
110
132
 
111
- .today, .today:hover {
112
- background-color: var(--zdt_datetime_today_bg);
133
+ .active, .active:hover, .active.today, .active:hover.today:hover {
134
+ background-color: var(--zdt_datetime_selected_bg);
113
135
  border-radius: 50%;
114
136
  }
115
137
 
138
+ .today {
139
+ border: 1px solid var(--zdt_datetime_today_border);
140
+ border-radius: 50%;
141
+ }
142
+
143
+ .today:hover {
144
+ border: 1px solid var(--zdt_datetime_today_border);
145
+ background-color: var(--zdt_datetime_datestr_hover_bg);
146
+ }
147
+
116
148
  .timesection {
117
149
  padding-top: var(--zd_size5);
118
150
  padding-bottom: var(--zd_size10);
119
151
  }
152
+
120
153
  .dropDownContainer {
121
154
  padding: 0 var(--zd_size5);
122
155
  }
156
+
123
157
  .dropDown {
124
158
  width: var(--zd_size60);
125
159
  display: inline-block;
126
160
  position: relative;
127
161
  margin: 0 var(--zd_size4);
128
162
  }
163
+
129
164
  .footer {
130
165
  margin-top: var(--zd_size10);
131
166
  padding-bottom: var(--zd_size12);
132
167
  }
168
+
133
169
  .timesection,
134
170
  .footer {
135
171
  composes: boxPadding;
136
172
  }
173
+
137
174
  .space {
138
175
  display: inline-block;
139
176
  width: var(--zd_size15);
@@ -150,12 +187,15 @@
150
187
  [dir=rtl] .downArrow {
151
188
  margin-right: var(--zd_size2);
152
189
  }
190
+
153
191
  .dateText {
154
192
  cursor: pointer;
155
193
  }
194
+
156
195
  .dateText:hover .downArrow {
157
196
  color: var(--zdt_datetime_datestr_text);
158
197
  }
198
+
159
199
  .text {
160
200
  composes: boxPadding;
161
201
  font-size: var(--zd_font_size11);
@@ -165,21 +205,26 @@
165
205
  display: block;
166
206
  margin-top: var(--zd_size14);
167
207
  }
208
+
168
209
  .yearContainer {
169
210
  position: absolute;
170
211
  top: 0;
171
212
  width: 100%;
172
213
  height: 100%;
173
214
  }
215
+
174
216
  [dir=ltr] .yearContainer {
175
217
  left: 0;
176
218
  }
219
+
177
220
  [dir=rtl] .yearContainer {
178
221
  right: 0;
179
222
  }
223
+
180
224
  .subContainer {
181
225
  position: relative;
182
226
  }
227
+
183
228
  .dropBox {
184
229
  width: 100%;
185
230
  border-radius: 3px;
@@ -1,13 +1,12 @@
1
1
  /* eslint-disable react/forbid-component-props */
2
-
3
2
  /** ** Libraries *** */
4
3
  import React, { PureComponent } from 'react';
5
- /** ** Components *** */
6
4
 
5
+ /** ** Components *** */
7
6
  import { Container } from '../Layout';
8
7
  import Button from '../Button/Button';
9
- /** ** CSS *** */
10
8
 
9
+ /** ** CSS *** */
11
10
  import style from './DateTime.module.css';
12
11
  export default class DateTimePopupFooter extends PureComponent {
13
12
  render() {
@@ -39,5 +38,4 @@ export default class DateTimePopupFooter extends PureComponent {
39
38
  dataId: `${dataId}_clearBtn`
40
39
  }));
41
40
  }
42
-
43
41
  }