@zohodesk/components 1.0.0-temp-164 → 1.0.0-temp-166

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 (478) hide show
  1. package/README.md +34 -0
  2. package/assets/Appearance/dark/mode/Component_DarkMode.module.css +151 -151
  3. package/assets/Appearance/dark/themes/blue/blue_CTA_DarkModifyCategory.module.css +450 -450
  4. package/assets/Appearance/dark/themes/blue/blue_CTA_DarkTheme.module.css +30 -30
  5. package/assets/Appearance/dark/themes/green/green_CTA_DarkModifyCategory.module.css +450 -450
  6. package/assets/Appearance/dark/themes/green/green_CTA_DarkTheme.module.css +30 -30
  7. package/assets/Appearance/dark/themes/orange/orange_CTA_DarkModifyCategory.module.css +450 -450
  8. package/assets/Appearance/dark/themes/orange/orange_CTA_DarkTheme.module.css +30 -30
  9. package/assets/Appearance/dark/themes/red/red_CTA_DarkModifyCategory.module.css +450 -450
  10. package/assets/Appearance/dark/themes/red/red_CTA_DarkTheme.module.css +30 -30
  11. package/assets/Appearance/dark/themes/yellow/yellow_CTA_DarkModifyCategory.module.css +450 -450
  12. package/assets/Appearance/dark/themes/yellow/yellow_CTA_DarkTheme.module.css +30 -30
  13. package/assets/Appearance/light/mode/Component_LightMode.module.css +148 -148
  14. package/assets/Appearance/light/themes/blue/blue_CTA_LightModifyCategory.module.css +450 -450
  15. package/assets/Appearance/light/themes/blue/blue_CTA_LightTheme.module.css +30 -30
  16. package/assets/Appearance/light/themes/green/green_CTA_LightModifyCategory.module.css +450 -450
  17. package/assets/Appearance/light/themes/green/green_CTA_LightTheme.module.css +30 -30
  18. package/assets/Appearance/light/themes/orange/orange_CTA_LightModifyCategory.module.css +450 -450
  19. package/assets/Appearance/light/themes/orange/orange_CTA_LightTheme.module.css +30 -30
  20. package/assets/Appearance/light/themes/red/red_CTA_LightModifyCategory.module.css +450 -450
  21. package/assets/Appearance/light/themes/red/red_CTA_LightTheme.module.css +30 -30
  22. package/assets/Appearance/light/themes/yellow/yellow_CTA_LightModifyCategory.module.css +450 -450
  23. package/assets/Appearance/light/themes/yellow/yellow_CTA_LightTheme.module.css +30 -30
  24. package/assets/Appearance/pureDark/mode/Component_PureDarkMode.module.css +153 -153
  25. package/assets/Appearance/pureDark/themes/blue/blue_CTA_PureDarkModifyCategory.module.css +450 -450
  26. package/assets/Appearance/pureDark/themes/blue/blue_CTA_PureDarkTheme.module.css +30 -30
  27. package/assets/Appearance/pureDark/themes/green/green_CTA_PureDarkModifyCategory.module.css +450 -450
  28. package/assets/Appearance/pureDark/themes/green/green_CTA_PureDarkTheme.module.css +30 -30
  29. package/assets/Appearance/pureDark/themes/orange/orange_CTA_PureDarkModifyCategory.module.css +450 -450
  30. package/assets/Appearance/pureDark/themes/orange/orange_CTA_PureDarkTheme.module.css +30 -30
  31. package/assets/Appearance/pureDark/themes/red/red_CTA_PureDarkModifyCategory.module.css +450 -450
  32. package/assets/Appearance/pureDark/themes/red/red_CTA_PureDarkTheme.module.css +30 -30
  33. package/assets/Appearance/pureDark/themes/yellow/yellow_CTA_PureDarkModifyCategory.module.css +450 -450
  34. package/assets/Appearance/pureDark/themes/yellow/yellow_CTA_PureDarkTheme.module.css +30 -30
  35. package/es/Accordion/Accordion.js +8 -3
  36. package/es/Accordion/AccordionItem.js +5 -2
  37. package/es/Animation/Animation.js +3 -3
  38. package/es/AppContainer/AppContainer.js +27 -10
  39. package/es/AppContainer/AppContainer.module.css +2 -2
  40. package/es/AppContainer/props/defaultProps.js +2 -1
  41. package/es/AppContainer/props/propTypes.js +1 -0
  42. package/es/Avatar/Avatar.js +26 -11
  43. package/es/Avatar/Avatar.module.css +18 -18
  44. package/es/AvatarTeam/AvatarTeam.js +4 -3
  45. package/es/AvatarTeam/AvatarTeam.module.css +35 -35
  46. package/es/Button/Button.js +5 -3
  47. package/es/Button/css/Button.module.css +70 -70
  48. package/es/Buttongroup/Buttongroup.js +4 -3
  49. package/es/Buttongroup/Buttongroup.module.css +14 -15
  50. package/es/Card/Card.js +21 -10
  51. package/es/CheckBox/CheckBox.js +5 -3
  52. package/es/CheckBox/CheckBox.module.css +15 -15
  53. package/es/DateTime/CalendarView.js +33 -20
  54. package/es/DateTime/DateTime.js +113 -12
  55. package/es/DateTime/DateTime.module.css +39 -39
  56. package/es/DateTime/DateTimePopupFooter.js +4 -2
  57. package/es/DateTime/DateTimePopupHeader.js +8 -2
  58. package/es/DateTime/DateWidget.js +100 -35
  59. package/es/DateTime/DateWidget.module.css +5 -5
  60. package/es/DateTime/DaysRow.js +4 -2
  61. package/es/DateTime/Time.js +10 -2
  62. package/es/DateTime/YearView.js +28 -4
  63. package/es/DateTime/YearView.module.css +15 -15
  64. package/es/DateTime/__tests__/CalendarView.spec.js +1 -0
  65. package/es/DateTime/__tests__/DateTime.spec.js +1 -0
  66. package/es/DateTime/__tests__/DateWidget.spec.js +2 -3
  67. package/es/DateTime/common.js +3 -0
  68. package/es/DateTime/constants.js +1 -0
  69. package/es/DateTime/dateFormatUtils/dateFormat.js +63 -30
  70. package/es/DateTime/dateFormatUtils/dateFormats.js +0 -1
  71. package/es/DateTime/dateFormatUtils/dayChange.js +13 -4
  72. package/es/DateTime/dateFormatUtils/index.js +32 -2
  73. package/es/DateTime/dateFormatUtils/monthChange.js +8 -0
  74. package/es/DateTime/dateFormatUtils/timeChange.js +22 -6
  75. package/es/DateTime/dateFormatUtils/yearChange.js +11 -2
  76. package/es/DateTime/objectUtils.js +14 -20
  77. package/es/DateTime/props/defaultProps.js +2 -1
  78. package/es/DateTime/typeChecker.js +3 -0
  79. package/es/DateTime/validator.js +58 -6
  80. package/es/DropBox/DropBox.js +9 -5
  81. package/es/DropBox/DropBoxElement/DropBoxElement.js +18 -6
  82. package/es/DropBox/DropBoxElement/css/DropBoxElement.module.css +85 -79
  83. package/es/DropBox/DropBoxElement/css/cssJSLogic.js +6 -4
  84. package/es/DropBox/DropBoxElement/props/propTypes.js +1 -1
  85. package/es/DropBox/DropBoxElement/useDropboxPosCalc.js +3 -0
  86. package/es/DropBox/__tests__/DropBox.spec.js +2 -2
  87. package/es/DropBox/css/DropBox.module.css +6 -6
  88. package/es/DropBox/props/defaultProps.js +1 -2
  89. package/es/DropBox/props/propTypes.js +1 -2
  90. package/es/DropDown/DropDown.js +10 -5
  91. package/es/DropDown/DropDown.module.css +2 -2
  92. package/es/DropDown/DropDownHeading.js +5 -5
  93. package/es/DropDown/DropDownHeading.module.css +6 -6
  94. package/es/DropDown/DropDownItem.js +8 -1
  95. package/es/DropDown/DropDownItem.module.css +12 -12
  96. package/es/DropDown/DropDownSearch.js +4 -0
  97. package/es/DropDown/DropDownSearch.module.css +3 -3
  98. package/es/DropDown/DropDownSeparator.js +1 -0
  99. package/es/DropDown/DropDownSeparator.module.css +2 -2
  100. package/es/DropDown/__tests__/DropDown.spec.js +1 -2
  101. package/es/Heading/Heading.js +3 -3
  102. package/es/Heading/Heading.module.css +2 -2
  103. package/es/Label/Label.js +3 -3
  104. package/es/Label/Label.module.css +5 -5
  105. package/es/Layout/Box.js +17 -3
  106. package/es/Layout/Container.js +16 -4
  107. package/es/Layout/Layout.module.css +15 -15
  108. package/es/Layout/index.js +1 -2
  109. package/es/Layout/props/defaultProps.js +2 -0
  110. package/es/Layout/props/propTypes.js +2 -0
  111. package/es/Layout/utils.js +5 -1
  112. package/es/ListItem/ListContainer.js +8 -3
  113. package/es/ListItem/ListItem.js +9 -3
  114. package/es/ListItem/ListItem.module.css +38 -38
  115. package/es/ListItem/ListItemWithAvatar.js +9 -3
  116. package/es/ListItem/ListItemWithCheckBox.js +7 -2
  117. package/es/ListItem/ListItemWithIcon.js +8 -3
  118. package/es/ListItem/ListItemWithRadio.js +7 -3
  119. package/es/Modal/Modal.js +28 -11
  120. package/es/MultiSelect/AdvancedGroupMultiSelect.js +90 -13
  121. package/es/MultiSelect/AdvancedMultiSelect.js +33 -9
  122. package/es/MultiSelect/EmptyState.js +6 -0
  123. package/es/MultiSelect/MultiSelect.js +100 -32
  124. package/es/MultiSelect/MultiSelect.module.css +31 -31
  125. package/es/MultiSelect/MultiSelectHeader.js +3 -0
  126. package/es/MultiSelect/MultiSelectWithAvatar.js +13 -6
  127. package/es/MultiSelect/SelectedOptions.js +6 -3
  128. package/es/MultiSelect/SelectedOptions.module.css +5 -5
  129. package/es/MultiSelect/Suggestions.js +7 -3
  130. package/es/MultiSelect/__tests__/MultiSelect.spec.js +4 -6
  131. package/es/MultiSelect/props/propTypes.js +2 -0
  132. package/es/PopOver/PopOver.js +18 -2
  133. package/es/PopOver/__tests__/PopOver.spec.js +2 -1
  134. package/es/Popup/Popup.js +77 -27
  135. package/es/Popup/__tests__/Popup.spec.js +17 -5
  136. package/es/Popup/viewPort.js +16 -4
  137. package/es/Provider/IdProvider.js +10 -5
  138. package/es/Provider/LibraryContext.js +6 -4
  139. package/es/Provider/NumberGenerator/NumberGenerator.js +21 -7
  140. package/es/Provider/ZindexProvider.js +9 -2
  141. package/es/Radio/Radio.js +4 -2
  142. package/es/Radio/Radio.module.css +9 -9
  143. package/es/Responsive/CustomResponsive.js +30 -18
  144. package/es/Responsive/RefWrapper.js +6 -7
  145. package/es/Responsive/ResizeComponent.js +35 -25
  146. package/es/Responsive/ResizeObserver.js +26 -6
  147. package/es/Responsive/Responsive.js +34 -20
  148. package/es/Responsive/index.js +1 -3
  149. package/es/Responsive/sizeObservers.js +28 -7
  150. package/es/Responsive/utils/index.js +7 -5
  151. package/es/Responsive/utils/shallowCompare.js +7 -2
  152. package/es/Responsive/windowResizeObserver.js +7 -0
  153. package/es/ResponsiveDropBox/ResponsiveDropBox.js +4 -0
  154. package/es/ResponsiveDropBox/ResponsiveDropBox.module.css +2 -2
  155. package/es/Ribbon/Ribbon.js +4 -2
  156. package/es/Ribbon/Ribbon.module.css +46 -48
  157. package/es/RippleEffect/RippleEffect.js +1 -3
  158. package/es/Select/GroupSelect.js +59 -14
  159. package/es/Select/Select.js +81 -34
  160. package/es/Select/Select.module.css +23 -23
  161. package/es/Select/SelectWithAvatar.js +19 -4
  162. package/es/Select/SelectWithIcon.js +48 -6
  163. package/es/Select/__tests__/Select.spec.js +6 -8
  164. package/es/Select/props/propTypes.js +1 -0
  165. package/es/Stencils/Stencils.js +3 -3
  166. package/es/Stencils/Stencils.module.css +11 -11
  167. package/es/Switch/Switch.js +6 -3
  168. package/es/Switch/Switch.module.css +23 -23
  169. package/es/Tab/Tab.js +4 -4
  170. package/es/Tab/Tab.module.css +14 -14
  171. package/es/Tab/TabContent.js +1 -0
  172. package/es/Tab/TabContentWrapper.js +2 -0
  173. package/es/Tab/TabWrapper.js +5 -2
  174. package/es/Tab/Tabs.js +56 -8
  175. package/es/Tab/Tabs.module.css +24 -42
  176. package/es/Tab/__tests__/Tab.spec.js +1 -3
  177. package/es/Tab/__tests__/TabWrapper.spec.js +1 -0
  178. package/es/Tag/Tag.js +7 -3
  179. package/es/Tag/Tag.module.css +25 -25
  180. package/es/TextBox/TextBox.js +16 -3
  181. package/es/TextBox/TextBox.module.css +9 -9
  182. package/es/TextBox/__tests__/TextBox.spec.js +1 -4
  183. package/es/TextBoxIcon/TextBoxIcon.js +9 -2
  184. package/es/TextBoxIcon/TextBoxIcon.module.css +7 -7
  185. package/es/TextBoxIcon/__tests__/TextBoxIcon.spec.js +2 -7
  186. package/es/Textarea/Textarea.js +13 -3
  187. package/es/Textarea/Textarea.module.css +21 -21
  188. package/es/Textarea/__tests__/Textarea.spec.js +2 -2
  189. package/es/Tooltip/Tooltip.js +60 -15
  190. package/es/Tooltip/Tooltip.module.css +5 -5
  191. package/es/Tooltip/__tests__/Tooltip.spec.js +5 -0
  192. package/es/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +3 -2
  193. package/es/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +7 -5
  194. package/es/common/animation.module.css +8 -8
  195. package/es/common/avatarsizes.module.css +16 -16
  196. package/es/common/basicReset.module.css +3 -3
  197. package/es/common/common.module.css +24 -24
  198. package/es/common/customscroll.module.css +2 -2
  199. package/es/deprecated/AdvancedMultiSelect.module.css +18 -18
  200. package/es/deprecated/PortalLayer/PortalLayer.js +25 -20
  201. package/es/semantic/Button/Button.js +4 -2
  202. package/es/semantic/Button/semanticButton.module.css +1 -1
  203. package/es/utils/Common.js +58 -9
  204. package/es/utils/ContextOptimizer.js +4 -5
  205. package/es/utils/__tests__/debounce.spec.js +2 -2
  206. package/es/utils/constructFullName.js +2 -0
  207. package/es/utils/css/compileClassNames.js +5 -0
  208. package/es/utils/css/mergeStyle.js +7 -6
  209. package/es/utils/css/utils.js +1 -0
  210. package/es/utils/datetime/GMTZones.js +48 -0
  211. package/es/utils/datetime/common.js +31 -7
  212. package/es/utils/debounce.js +5 -1
  213. package/es/utils/dropDownUtils.js +68 -11
  214. package/es/utils/getInitial.js +4 -0
  215. package/es/utils/shallowEqual.js +6 -0
  216. package/lib/Accordion/Accordion.js +43 -18
  217. package/lib/Accordion/AccordionItem.js +41 -18
  218. package/lib/Accordion/__tests__/Accordion.spec.js +3 -0
  219. package/lib/Accordion/index.js +3 -0
  220. package/lib/Accordion/props/propTypes.js +3 -0
  221. package/lib/Animation/Animation.js +38 -18
  222. package/lib/Animation/__tests__/Animation.spec.js +11 -7
  223. package/lib/Animation/props/propTypes.js +3 -0
  224. package/lib/AppContainer/AppContainer.js +66 -26
  225. package/lib/AppContainer/AppContainer.module.css +2 -2
  226. package/lib/AppContainer/props/defaultProps.js +2 -1
  227. package/lib/AppContainer/props/propTypes.js +4 -0
  228. package/lib/Avatar/Avatar.js +81 -38
  229. package/lib/Avatar/Avatar.module.css +18 -18
  230. package/lib/Avatar/__tests__/Avatar.spec.js +44 -0
  231. package/lib/Avatar/props/propTypes.js +3 -0
  232. package/lib/AvatarTeam/AvatarTeam.js +53 -30
  233. package/lib/AvatarTeam/AvatarTeam.module.css +35 -35
  234. package/lib/AvatarTeam/__tests__/AvatarTeam.spec.js +13 -0
  235. package/lib/AvatarTeam/props/propTypes.js +3 -0
  236. package/lib/Button/Button.js +32 -20
  237. package/lib/Button/css/Button.module.css +70 -70
  238. package/lib/Button/css/cssJSLogic.js +18 -17
  239. package/lib/Button/index.js +3 -0
  240. package/lib/Button/props/defaultProps.js +2 -0
  241. package/lib/Button/props/propTypes.js +3 -0
  242. package/lib/Buttongroup/Buttongroup.js +33 -12
  243. package/lib/Buttongroup/Buttongroup.module.css +14 -15
  244. package/lib/Buttongroup/__test__/Buttongroup.spec.js +10 -0
  245. package/lib/Buttongroup/props/propTypes.js +3 -0
  246. package/lib/Card/Card.js +102 -46
  247. package/lib/Card/__tests__/Card.spec.js +10 -1
  248. package/lib/Card/index.js +4 -0
  249. package/lib/Card/props/propTypes.js +3 -0
  250. package/lib/CheckBox/CheckBox.js +71 -47
  251. package/lib/CheckBox/CheckBox.module.css +15 -15
  252. package/lib/CheckBox/__tests__/CheckBox.spec.js +3 -0
  253. package/lib/CheckBox/props/propTypes.js +3 -0
  254. package/lib/DateTime/CalendarView.js +83 -42
  255. package/lib/DateTime/DateTime.js +287 -160
  256. package/lib/DateTime/DateTime.module.css +39 -39
  257. package/lib/DateTime/DateTimePopupFooter.js +31 -8
  258. package/lib/DateTime/DateTimePopupHeader.js +48 -17
  259. package/lib/DateTime/DateWidget.js +354 -250
  260. package/lib/DateTime/DateWidget.module.css +5 -5
  261. package/lib/DateTime/DaysRow.js +27 -5
  262. package/lib/DateTime/Time.js +73 -32
  263. package/lib/DateTime/YearView.js +77 -28
  264. package/lib/DateTime/YearView.module.css +15 -15
  265. package/lib/DateTime/__tests__/CalendarView.spec.js +13 -5
  266. package/lib/DateTime/__tests__/DateTime.spec.js +51 -37
  267. package/lib/DateTime/__tests__/DateWidget.spec.js +10 -8
  268. package/lib/DateTime/common.js +6 -0
  269. package/lib/DateTime/constants.js +1 -0
  270. package/lib/DateTime/dateFormatUtils/dateFormat.js +184 -122
  271. package/lib/DateTime/dateFormatUtils/dateFormats.js +0 -1
  272. package/lib/DateTime/dateFormatUtils/dayChange.js +14 -7
  273. package/lib/DateTime/dateFormatUtils/index.js +74 -16
  274. package/lib/DateTime/dateFormatUtils/monthChange.js +19 -9
  275. package/lib/DateTime/dateFormatUtils/timeChange.js +54 -22
  276. package/lib/DateTime/dateFormatUtils/yearChange.js +22 -11
  277. package/lib/DateTime/index.js +2 -0
  278. package/lib/DateTime/objectUtils.js +24 -20
  279. package/lib/DateTime/props/defaultProps.js +2 -1
  280. package/lib/DateTime/props/propTypes.js +11 -1
  281. package/lib/DateTime/typeChecker.js +4 -0
  282. package/lib/DateTime/validator.js +73 -10
  283. package/lib/DropBox/DropBox.js +36 -12
  284. package/lib/DropBox/DropBoxElement/DropBoxElement.js +68 -42
  285. package/lib/DropBox/DropBoxElement/css/DropBoxElement.module.css +85 -79
  286. package/lib/DropBox/DropBoxElement/css/cssJSLogic.js +43 -34
  287. package/lib/DropBox/DropBoxElement/props/propTypes.js +4 -1
  288. package/lib/DropBox/DropBoxElement/useDropboxPosCalc.js +14 -9
  289. package/lib/DropBox/__tests__/DropBox.spec.js +8 -4
  290. package/lib/DropBox/css/DropBox.module.css +6 -6
  291. package/lib/DropBox/css/cssJSLogic.js +3 -1
  292. package/lib/DropBox/props/defaultProps.js +8 -4
  293. package/lib/DropBox/props/propTypes.js +10 -4
  294. package/lib/DropDown/DropDown.js +54 -9
  295. package/lib/DropDown/DropDown.module.css +2 -2
  296. package/lib/DropDown/DropDownHeading.js +40 -20
  297. package/lib/DropDown/DropDownHeading.module.css +6 -6
  298. package/lib/DropDown/DropDownItem.js +44 -21
  299. package/lib/DropDown/DropDownItem.module.css +12 -12
  300. package/lib/DropDown/DropDownSearch.js +40 -17
  301. package/lib/DropDown/DropDownSearch.module.css +3 -3
  302. package/lib/DropDown/DropDownSeparator.js +24 -4
  303. package/lib/DropDown/DropDownSeparator.module.css +2 -2
  304. package/lib/DropDown/__tests__/DropDown.spec.js +15 -9
  305. package/lib/DropDown/__tests__/DropDownItem.spec.js +9 -4
  306. package/lib/DropDown/__tests__/DropDownSearch.spec.js +3 -0
  307. package/lib/DropDown/index.js +9 -0
  308. package/lib/DropDown/props/propTypes.js +6 -4
  309. package/lib/Heading/Heading.js +39 -16
  310. package/lib/Heading/Heading.module.css +2 -2
  311. package/lib/Heading/props/propTypes.js +3 -0
  312. package/lib/Label/Label.js +40 -19
  313. package/lib/Label/Label.module.css +5 -5
  314. package/lib/Label/__tests__/Label.spec.js +14 -1
  315. package/lib/Label/props/propTypes.js +3 -0
  316. package/lib/Layout/Box.js +39 -15
  317. package/lib/Layout/Container.js +37 -14
  318. package/lib/Layout/Layout.module.css +15 -15
  319. package/lib/Layout/__tests__/Box.spec.js +65 -49
  320. package/lib/Layout/__tests__/Container.spec.js +67 -50
  321. package/lib/Layout/index.js +3 -0
  322. package/lib/Layout/props/defaultProps.js +2 -0
  323. package/lib/Layout/props/propTypes.js +5 -0
  324. package/lib/Layout/utils.js +15 -1
  325. package/lib/ListItem/ListContainer.js +48 -27
  326. package/lib/ListItem/ListItem.js +69 -45
  327. package/lib/ListItem/ListItem.module.css +38 -38
  328. package/lib/ListItem/ListItemWithAvatar.js +75 -48
  329. package/lib/ListItem/ListItemWithCheckBox.js +64 -39
  330. package/lib/ListItem/ListItemWithIcon.js +68 -44
  331. package/lib/ListItem/ListItemWithRadio.js +65 -41
  332. package/lib/ListItem/index.js +7 -0
  333. package/lib/ListItem/props/propTypes.js +6 -4
  334. package/lib/Modal/Modal.js +45 -10
  335. package/lib/Modal/props/propTypes.js +3 -0
  336. package/lib/MultiSelect/AdvancedGroupMultiSelect.js +295 -166
  337. package/lib/MultiSelect/AdvancedMultiSelect.js +203 -125
  338. package/lib/MultiSelect/EmptyState.js +49 -24
  339. package/lib/MultiSelect/MultiSelect.js +324 -206
  340. package/lib/MultiSelect/MultiSelect.module.css +31 -31
  341. package/lib/MultiSelect/MultiSelectHeader.js +30 -8
  342. package/lib/MultiSelect/MultiSelectWithAvatar.js +106 -63
  343. package/lib/MultiSelect/SelectedOptions.js +43 -17
  344. package/lib/MultiSelect/SelectedOptions.module.css +5 -5
  345. package/lib/MultiSelect/Suggestions.js +64 -32
  346. package/lib/MultiSelect/__tests__/MultiSelect.spec.js +86 -75
  347. package/lib/MultiSelect/index.js +5 -0
  348. package/lib/MultiSelect/props/defaultProps.js +2 -0
  349. package/lib/MultiSelect/props/propTypes.js +5 -0
  350. package/lib/PopOver/PopOver.js +95 -49
  351. package/lib/PopOver/__tests__/PopOver.spec.js +4 -1
  352. package/lib/PopOver/index.js +4 -0
  353. package/lib/PopOver/props/propTypes.js +3 -0
  354. package/lib/Popup/Popup.js +158 -84
  355. package/lib/Popup/__tests__/Popup.spec.js +43 -8
  356. package/lib/Popup/viewPort.js +28 -14
  357. package/lib/Provider/AvatarSize.js +4 -0
  358. package/lib/Provider/Config.js +2 -0
  359. package/lib/Provider/CssProvider.js +4 -0
  360. package/lib/Provider/IdProvider.js +17 -6
  361. package/lib/Provider/LibraryContext.js +35 -15
  362. package/lib/Provider/LibraryContextInit.js +4 -0
  363. package/lib/Provider/NumberGenerator/NumberGenerator.js +44 -15
  364. package/lib/Provider/ZindexProvider.js +15 -3
  365. package/lib/Provider/index.js +5 -0
  366. package/lib/Radio/Radio.js +61 -38
  367. package/lib/Radio/Radio.module.css +9 -9
  368. package/lib/Radio/__tests__/Radiospec.js +9 -5
  369. package/lib/Radio/props/propTypes.js +3 -0
  370. package/lib/Responsive/CustomResponsive.js +73 -29
  371. package/lib/Responsive/RefWrapper.js +17 -11
  372. package/lib/Responsive/ResizeComponent.js +62 -36
  373. package/lib/Responsive/ResizeObserver.js +24 -10
  374. package/lib/Responsive/Responsive.js +80 -30
  375. package/lib/Responsive/index.js +4 -0
  376. package/lib/Responsive/props/propTypes.js +3 -0
  377. package/lib/Responsive/sizeObservers.js +53 -17
  378. package/lib/Responsive/utils/index.js +11 -3
  379. package/lib/Responsive/utils/shallowCompare.js +11 -2
  380. package/lib/Responsive/windowResizeObserver.js +8 -0
  381. package/lib/ResponsiveDropBox/ResponsiveDropBox.js +45 -17
  382. package/lib/ResponsiveDropBox/ResponsiveDropBox.module.css +2 -2
  383. package/lib/ResponsiveDropBox/props/propTypes.js +3 -0
  384. package/lib/Ribbon/Ribbon.js +34 -13
  385. package/lib/Ribbon/Ribbon.module.css +46 -48
  386. package/lib/Ribbon/__tests__/Ribbon.spec.js +22 -0
  387. package/lib/Ribbon/props/propTypes.js +3 -0
  388. package/lib/RippleEffect/RippleEffect.js +18 -10
  389. package/lib/RippleEffect/props/propTypes.js +3 -0
  390. package/lib/Select/GroupSelect.js +230 -130
  391. package/lib/Select/Select.js +292 -210
  392. package/lib/Select/Select.module.css +23 -23
  393. package/lib/Select/SelectWithAvatar.js +104 -56
  394. package/lib/Select/SelectWithIcon.js +134 -77
  395. package/lib/Select/__tests__/Select.spec.js +133 -91
  396. package/lib/Select/index.js +5 -0
  397. package/lib/Select/props/defaultProps.js +5 -4
  398. package/lib/Select/props/propTypes.js +4 -0
  399. package/lib/Stencils/Stencils.js +29 -10
  400. package/lib/Stencils/Stencils.module.css +11 -11
  401. package/lib/Stencils/__tests__/Stencils.spec.js +12 -0
  402. package/lib/Stencils/props/propTypes.js +3 -0
  403. package/lib/Switch/Switch.js +58 -34
  404. package/lib/Switch/Switch.module.css +23 -23
  405. package/lib/Switch/props/propTypes.js +3 -0
  406. package/lib/Tab/Tab.js +40 -27
  407. package/lib/Tab/Tab.module.css +14 -14
  408. package/lib/Tab/TabContent.js +12 -5
  409. package/lib/Tab/TabContentWrapper.js +13 -6
  410. package/lib/Tab/TabWrapper.js +37 -19
  411. package/lib/Tab/Tabs.js +173 -92
  412. package/lib/Tab/Tabs.module.css +24 -42
  413. package/lib/Tab/__tests__/Tab.spec.js +67 -58
  414. package/lib/Tab/__tests__/TabContent.spec.js +10 -6
  415. package/lib/Tab/__tests__/TabContentWrapper.spec.js +28 -20
  416. package/lib/Tab/__tests__/TabWrapper.spec.js +12 -0
  417. package/lib/Tab/__tests__/Tabs.spec.js +53 -39
  418. package/lib/Tab/index.js +6 -0
  419. package/lib/Tab/props/propTypes.js +3 -0
  420. package/lib/Tag/Tag.js +73 -43
  421. package/lib/Tag/Tag.module.css +25 -25
  422. package/lib/Tag/__tests__/Tag.spec.js +14 -8
  423. package/lib/Tag/props/propTypes.js +3 -0
  424. package/lib/TextBox/TextBox.js +86 -59
  425. package/lib/TextBox/TextBox.module.css +9 -9
  426. package/lib/TextBox/__tests__/TextBox.spec.js +14 -4
  427. package/lib/TextBox/props/propTypes.js +6 -4
  428. package/lib/TextBoxIcon/TextBoxIcon.js +79 -52
  429. package/lib/TextBoxIcon/TextBoxIcon.module.css +7 -7
  430. package/lib/TextBoxIcon/__tests__/TextBoxIcon.spec.js +14 -5
  431. package/lib/TextBoxIcon/props/propTypes.js +3 -0
  432. package/lib/Textarea/Textarea.js +55 -29
  433. package/lib/Textarea/Textarea.module.css +21 -21
  434. package/lib/Textarea/__tests__/Textarea.spec.js +14 -2
  435. package/lib/Textarea/props/propTypes.js +3 -0
  436. package/lib/Tooltip/Tooltip.js +96 -32
  437. package/lib/Tooltip/Tooltip.module.css +5 -5
  438. package/lib/Tooltip/__tests__/Tooltip.spec.js +24 -3
  439. package/lib/Tooltip/props/propTypes.js +3 -0
  440. package/lib/VelocityAnimation/VelocityAnimation/VelocityAnimation.js +40 -16
  441. package/lib/VelocityAnimation/VelocityAnimation/props/propTypes.js +3 -0
  442. package/lib/VelocityAnimation/VelocityAnimationGroup/VelocityAnimationGroup.js +53 -25
  443. package/lib/VelocityAnimation/VelocityAnimationGroup/props/propTypes.js +3 -0
  444. package/lib/VelocityAnimation/index.js +3 -0
  445. package/lib/common/animation.module.css +8 -8
  446. package/lib/common/avatarsizes.module.css +16 -16
  447. package/lib/common/basicReset.module.css +3 -3
  448. package/lib/common/common.module.css +24 -24
  449. package/lib/common/customscroll.module.css +2 -2
  450. package/lib/css.js +40 -0
  451. package/lib/deprecated/AdvancedMultiSelect.module.css +18 -18
  452. package/lib/deprecated/PortalLayer/PortalLayer.js +46 -23
  453. package/lib/deprecated/PortalLayer/props/propTypes.js +3 -0
  454. package/lib/index.js +57 -0
  455. package/lib/semantic/Button/Button.js +43 -22
  456. package/lib/semantic/Button/props/propTypes.js +3 -0
  457. package/lib/semantic/Button/semanticButton.module.css +1 -1
  458. package/lib/semantic/index.js +2 -0
  459. package/lib/utils/Common.js +117 -19
  460. package/lib/utils/ContextOptimizer.js +16 -10
  461. package/lib/utils/__tests__/constructFullName.spec.js +1 -0
  462. package/lib/utils/__tests__/debounce.spec.js +3 -2
  463. package/lib/utils/__tests__/getInitial.spec.js +1 -0
  464. package/lib/utils/constructFullName.js +13 -4
  465. package/lib/utils/css/compileClassNames.js +6 -0
  466. package/lib/utils/css/mergeStyle.js +10 -7
  467. package/lib/utils/css/utils.js +8 -0
  468. package/lib/utils/datetime/GMTZones.js +55 -0
  469. package/lib/utils/datetime/common.js +52 -7
  470. package/lib/utils/debounce.js +6 -1
  471. package/lib/utils/dropDownUtils.js +175 -59
  472. package/lib/utils/dummyFunction.js +2 -0
  473. package/lib/utils/getHTMLFontSize.js +1 -0
  474. package/lib/utils/getInitial.js +6 -0
  475. package/lib/utils/index.js +4 -0
  476. package/lib/utils/scrollTo.js +2 -0
  477. package/lib/utils/shallowEqual.js +8 -0
  478. package/package.json +18 -27
@@ -3,6 +3,7 @@ import React from 'react';
3
3
  import { SelectWithAvatar_defaultProps } from './props/defaultProps';
4
4
  import { SelectWithAvatar_propTypes } from './props/propTypes';
5
5
  /**** Components ****/
6
+
6
7
  import { SelectComponent } from './Select';
7
8
  import Popup from '../Popup/Popup';
8
9
  import Tag from '../Tag/Tag';
@@ -17,10 +18,11 @@ import { getUniqueId } from '../Provider/IdProvider';
17
18
  import ResponsiveDropBox from '../ResponsiveDropBox/ResponsiveDropBox';
18
19
  import { ResponsiveReceiver } from '../Responsive/CustomResponsive';
19
20
  import Loader from '@zohodesk/svg/lib/Loader/Loader';
20
-
21
21
  /**** CSS ****/
22
+
22
23
  import style from '../MultiSelect/MultiSelect.module.css';
23
24
  import selectStyle from './Select.module.css';
25
+
24
26
  class SelectWithAvatarComponent extends SelectComponent {
25
27
  constructor(props) {
26
28
  super(props);
@@ -32,6 +34,7 @@ class SelectWithAvatarComponent extends SelectComponent {
32
34
  this.handleRemoveOption = this.handleRemoveOption.bind(this);
33
35
  this.getNextAriaId = getUniqueId(this);
34
36
  }
37
+
35
38
  handleFormatOptions(props) {
36
39
  let {
37
40
  options,
@@ -47,15 +50,18 @@ class SelectWithAvatarComponent extends SelectComponent {
47
50
  optionType: 'avatar'
48
51
  });
49
52
  }
53
+
50
54
  handleActive(e) {
51
55
  let {
52
56
  isActive
53
57
  } = this.state;
58
+
54
59
  if (!isActive) {
55
60
  this.setState({
56
61
  isActive: true
57
62
  });
58
63
  }
64
+
59
65
  let {
60
66
  target
61
67
  } = e || {};
@@ -65,16 +71,19 @@ class SelectWithAvatarComponent extends SelectComponent {
65
71
  } = this.props;
66
72
  onFocus && onFocus(this.state.searchStr);
67
73
  }
74
+
68
75
  handleInactive() {
69
76
  let {
70
77
  isActive
71
78
  } = this.state;
79
+
72
80
  if (isActive) {
73
81
  this.setState({
74
82
  isActive: false
75
83
  });
76
84
  }
77
85
  }
86
+
78
87
  handleSearchChange(e) {
79
88
  let {
80
89
  isPopupOpen
@@ -82,6 +91,7 @@ class SelectWithAvatarComponent extends SelectComponent {
82
91
  !isPopupOpen && this.togglePopup(e);
83
92
  this.handleSearch(e);
84
93
  }
94
+
85
95
  handleRemoveOption(e) {
86
96
  let {
87
97
  keyCode
@@ -92,12 +102,14 @@ class SelectWithAvatarComponent extends SelectComponent {
92
102
  let {
93
103
  isDefaultSelectValue
94
104
  } = this.props;
105
+
95
106
  if (keyCode === 8 && searchStr.length === 0 && !isDefaultSelectValue) {
96
107
  this.handleChange('');
97
108
  } else {
98
109
  this.handleKeyDown(e);
99
110
  }
100
111
  }
112
+
101
113
  responsiveFunc(_ref) {
102
114
  let {
103
115
  mediaQueryOR
@@ -108,6 +120,7 @@ class SelectWithAvatarComponent extends SelectComponent {
108
120
  }])
109
121
  };
110
122
  }
123
+
111
124
  render() {
112
125
  let {
113
126
  dropBoxSize,
@@ -170,6 +183,7 @@ class SelectWithAvatarComponent extends SelectComponent {
170
183
  return /*#__PURE__*/React.createElement("div", {
171
184
  className: `${style.wrapper} ${isDisabled ? style.disabled : ''} ${isReadOnly ? style.readOnly : ''} ${needEffect && !(isDisabled || isReadOnly) ? style.effect : ''} ${className ? className : ''}`,
172
185
  "data-id": `${isDisabled ? `${dataId}_disabled` : isReadOnly ? `${dataId}_readOnly` : dataId}`,
186
+ "data-test-id": `${isDisabled ? `${dataId}_disabled` : isReadOnly ? `${dataId}_readOnly` : dataId}`,
173
187
  "data-title": isDisabled ? title : null,
174
188
  "data-selector-id": dataSelectorId
175
189
  }, /*#__PURE__*/React.createElement(Container, {
@@ -181,6 +195,7 @@ class SelectWithAvatarComponent extends SelectComponent {
181
195
  }, selectedId ? /*#__PURE__*/React.createElement(Box, {
182
196
  className: style.tag,
183
197
  "data-id": `${dataId}_SelectTag`,
198
+ "data-test-id": `${dataId}_SelectTag`,
184
199
  key: `${id}tag`
185
200
  }, /*#__PURE__*/React.createElement(Tag, {
186
201
  avatarPalette: avatarPalette,
@@ -309,14 +324,14 @@ class SelectWithAvatarComponent extends SelectComponent {
309
324
  }, /*#__PURE__*/React.createElement(Loader, null))))));
310
325
  }) : null);
311
326
  }
327
+
312
328
  }
329
+
313
330
  SelectWithAvatarComponent.propTypes = SelectWithAvatar_propTypes;
314
331
  SelectWithAvatarComponent.defaultProps = SelectWithAvatar_defaultProps;
315
332
  SelectWithAvatarComponent.displayName = 'SelectWithAvatar';
316
333
  let SelectWithAvatar = Popup(SelectWithAvatarComponent);
317
- SelectWithAvatar.defaultProps = SelectWithAvatarComponent.defaultProps;
318
-
319
- // if (__DOCS__) {
334
+ SelectWithAvatar.defaultProps = SelectWithAvatarComponent.defaultProps; // if (__DOCS__) {
320
335
  // SelectWithAvatar.docs = {
321
336
  // componentGroup: 'Form Elements',
322
337
  // folderName: 'Style Guide'
@@ -2,6 +2,7 @@ import React, { Component } from 'react';
2
2
  import { SelectWithIcon_defaultProps } from './props/defaultProps';
3
3
  import { SelectWithIcon_propTypes } from './props/propTypes';
4
4
  /**** Components ****/
5
+
5
6
  import Popup from '../Popup/Popup';
6
7
  import TextBoxIcon from '../TextBoxIcon/TextBoxIcon';
7
8
  import { Icon } from '@zohodesk/icons';
@@ -14,9 +15,12 @@ import ResponsiveDropBox from '../ResponsiveDropBox/ResponsiveDropBox';
14
15
  import { ResponsiveReceiver } from '../Responsive/CustomResponsive';
15
16
  import Loader from '@zohodesk/svg/lib/Loader/Loader';
16
17
  /**** Methods ****/
18
+
17
19
  import { scrollTo, findScrollEnd } from '../utils/Common.js';
18
20
  /**** CSS ****/
21
+
19
22
  import style from './Select.module.css';
23
+
20
24
  class SelectWithIcon extends Component {
21
25
  constructor(props) {
22
26
  super(props);
@@ -42,34 +46,43 @@ class SelectWithIcon extends Component {
42
46
  this.handleGetNextOptions = this.handleGetNextOptions.bind(this);
43
47
  this.handleFetchOptions = this.handleFetchOptions.bind(this);
44
48
  }
49
+
45
50
  componentDidMount() {
46
51
  this._isMounted = true;
47
52
  }
53
+
48
54
  componentWillUnmount() {
49
55
  this._isMounted = false;
50
56
  }
57
+
51
58
  inputRef(el) {
52
59
  this.input = el;
53
60
  }
61
+
54
62
  itemRef(ele, index, id) {
55
63
  this[`suggestion_${id}`] = ele;
56
64
  }
65
+
57
66
  searchInputRef(el) {
58
67
  this.searchInput = el;
59
68
  }
69
+
60
70
  scrollContentRef(el) {
61
71
  let {
62
72
  isPopupOpen
63
73
  } = this.props;
74
+
64
75
  if (isPopupOpen) {
65
76
  this.optionsContainer = el;
66
77
  }
67
78
  }
79
+
68
80
  handleMouseEnter(id, value, index, e) {
69
81
  this.setState({
70
82
  selectedIndex: index
71
83
  });
72
84
  }
85
+
73
86
  handleKeyDown(e) {
74
87
  let {
75
88
  keyCode
@@ -84,10 +97,12 @@ class SelectWithIcon extends Component {
84
97
  isPopupOpen,
85
98
  selectedId
86
99
  } = this.props;
100
+
87
101
  if (isPopupOpen && (keyCode === 38 || keyCode === 40) && e.preventDefault) {
88
102
  e.preventDefault(); //prevent body scroll
89
103
  } else if (!isPopupOpen && (keyCode === 40 || keyCode === 13)) {
90
104
  e.preventDefault(); //prevent body scroll
105
+
91
106
  this.togglePopup(e);
92
107
  options.map((list, index) => {
93
108
  if (list.id === selectedId) {
@@ -97,6 +112,7 @@ class SelectWithIcon extends Component {
97
112
  }
98
113
  });
99
114
  }
115
+
100
116
  if (isPopupOpen) {
101
117
  switch (keyCode) {
102
118
  case 40:
@@ -108,11 +124,14 @@ class SelectWithIcon extends Component {
108
124
  if (selectedIndex === options.length - 3) {
109
125
  this.handleGetNextOptions();
110
126
  }
127
+
111
128
  this.setState({
112
129
  selectedIndex: selectedIndex + 1
113
130
  });
114
131
  }
132
+
115
133
  break;
134
+
116
135
  case 38:
117
136
  if (selectedIndex === 0) {
118
137
  this.setState({
@@ -123,7 +142,9 @@ class SelectWithIcon extends Component {
123
142
  selectedIndex: selectedIndex - 1
124
143
  });
125
144
  }
145
+
126
146
  break;
147
+
127
148
  case 13:
128
149
  let option = options[selectedIndex];
129
150
  this.handleChange && this.handleChange(option[idKey], option[valueKey], selectedIndex, e);
@@ -131,6 +152,7 @@ class SelectWithIcon extends Component {
131
152
  }
132
153
  }
133
154
  }
155
+
134
156
  componentDidUpdate(prevProps) {
135
157
  let {
136
158
  idKey,
@@ -141,6 +163,7 @@ class SelectWithIcon extends Component {
141
163
  selectedIndex,
142
164
  options
143
165
  } = this.state;
166
+
144
167
  if (prevProps.isPopupOpen != isPopupOpen) {
145
168
  setTimeout(() => {
146
169
  isPopupOpen ? needSearch ? this.searchInput.focus({
@@ -152,32 +175,39 @@ class SelectWithIcon extends Component {
152
175
  });
153
176
  }, 10);
154
177
  }
178
+
155
179
  let option = options[selectedIndex];
156
180
  let id = option && option[idKey] || {};
157
181
  let selSuggestion = this[`suggestion_${id}`];
182
+
158
183
  if (isPopupOpen) {
159
184
  this.optionsContainer && scrollTo(this.optionsContainer, selSuggestion);
160
185
  }
161
186
  }
187
+
162
188
  searchList(searchValue) {
163
189
  let datas = [];
164
190
  let {
165
191
  options,
166
192
  valueKey
167
193
  } = this.props;
194
+
168
195
  if (options.length) {
169
196
  datas = options.filter(obj => obj[valueKey].toLowerCase().includes(searchValue.toLowerCase()));
170
197
  }
198
+
171
199
  return datas;
172
200
  }
201
+
173
202
  onSearchClear() {
174
- let options = this.searchList('');
175
- // this.searchInput.focus({preventScroll:false});
203
+ let options = this.searchList(''); // this.searchInput.focus({preventScroll:false});
204
+
176
205
  this.setState({
177
206
  searchValue: '',
178
207
  options
179
208
  });
180
209
  }
210
+
181
211
  onSearch(searchValue) {
182
212
  let options = this.searchList(searchValue);
183
213
  this.setState({
@@ -186,6 +216,7 @@ class SelectWithIcon extends Component {
186
216
  options
187
217
  });
188
218
  }
219
+
189
220
  togglePopup(e) {
190
221
  let {
191
222
  togglePopup,
@@ -194,6 +225,7 @@ class SelectWithIcon extends Component {
194
225
  } = this.props;
195
226
  !isReadOnly && togglePopup(e, boxPosition);
196
227
  }
228
+
197
229
  handleChange(id, value, index, e) {
198
230
  let {
199
231
  onChange,
@@ -202,11 +234,13 @@ class SelectWithIcon extends Component {
202
234
  !isReadOnly && onChange && onChange(id, value, index, e);
203
235
  this.togglePopup(e);
204
236
  }
237
+
205
238
  handleScroll(e) {
206
239
  let ele = e.target;
207
240
  let isScrollReachedBottom = findScrollEnd(ele);
208
241
  isScrollReachedBottom && this.handleGetNextOptions();
209
242
  }
243
+
210
244
  UNSAFE_componentWillReceiveProps(nextProps) {
211
245
  if (nextProps.options.length != this.props.options.length) {
212
246
  this.setState({
@@ -214,6 +248,7 @@ class SelectWithIcon extends Component {
214
248
  });
215
249
  }
216
250
  }
251
+
217
252
  handleGetNextOptions() {
218
253
  let {
219
254
  isNextOptions,
@@ -224,6 +259,7 @@ class SelectWithIcon extends Component {
224
259
  } = this.state;
225
260
  isNextOptions && getNextOptions && this.handleFetchOptions(getNextOptions, searchValue);
226
261
  }
262
+
227
263
  handleFetchOptions(APICall) {
228
264
  let searchValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
229
265
  let {
@@ -232,10 +268,12 @@ class SelectWithIcon extends Component {
232
268
  let {
233
269
  _isMounted
234
270
  } = this;
271
+
235
272
  if (!isFetchingOptions && APICall) {
236
273
  this.setState({
237
274
  isFetchingOptions: true
238
275
  });
276
+
239
277
  try {
240
278
  return APICall(searchValue).then(() => {
241
279
  _isMounted && this.setState({
@@ -253,6 +291,7 @@ class SelectWithIcon extends Component {
253
291
  }
254
292
  }
255
293
  }
294
+
256
295
  responsiveFunc(_ref) {
257
296
  let {
258
297
  mediaQueryOR
@@ -263,6 +302,7 @@ class SelectWithIcon extends Component {
263
302
  }])
264
303
  };
265
304
  }
305
+
266
306
  render() {
267
307
  let {
268
308
  animationStyle,
@@ -327,7 +367,8 @@ class SelectWithIcon extends Component {
327
367
  className: `${className ? className : ''}`,
328
368
  onClick: isDisabled || isReadOnly ? null : this.togglePopup,
329
369
  ref: getTargetRef,
330
- "data-id": `${isDisabled ? `${dataId}_disabled` : isReadOnly ? `${dataId}_readOnly` : dataId}`
370
+ "data-id": `${isDisabled ? `${dataId}_disabled` : isReadOnly ? `${dataId}_readOnly` : dataId}`,
371
+ "data-test-id": `${isDisabled ? `${dataId}_disabled` : isReadOnly ? `${dataId}_readOnly` : dataId}`
331
372
  }, /*#__PURE__*/React.createElement(Container, {
332
373
  alignBox: "row"
333
374
  }, needIcon ? /*#__PURE__*/React.createElement(Container, {
@@ -475,14 +516,15 @@ class SelectWithIcon extends Component {
475
516
  }, /*#__PURE__*/React.createElement(Loader, null))))));
476
517
  }) : null);
477
518
  }
519
+
478
520
  }
479
- SelectWithIcon.propTypes = SelectWithIcon_propTypes;
480
- SelectWithIcon.defaultProps = SelectWithIcon_defaultProps;
481
521
 
482
- // if (__DOCS__) {
522
+ SelectWithIcon.propTypes = SelectWithIcon_propTypes;
523
+ SelectWithIcon.defaultProps = SelectWithIcon_defaultProps; // if (__DOCS__) {
483
524
  // SelectWithIcon.docs = {
484
525
  // componentGroup: 'Form Elements',
485
526
  // folderName: 'Style Guide'
486
527
  // };
487
528
  // }
529
+
488
530
  export default Popup(SelectWithIcon);
@@ -1,8 +1,9 @@
1
1
  /* eslint-disable no-undef */
2
+
2
3
  /**** Libraries ****/
3
4
  import expect from 'expect';
4
-
5
5
  /**** Components ****/
6
+
6
7
  import Select from '../Select';
7
8
  import ListItem from '../../ListItem/ListItem';
8
9
  describe('Select component conditions', () => {
@@ -188,9 +189,8 @@ describe('Select component conditions', () => {
188
189
  target: {
189
190
  value: 'value changed'
190
191
  }
191
- });
192
+ }); //
192
193
 
193
- //
194
194
  setTimeout(() => {
195
195
  expect(props.onSearch).toHaveBeenCalled();
196
196
  expect(props.onSearch.mock.calls[0][0]).toEqual('value changed');
@@ -202,10 +202,8 @@ describe('Select component conditions', () => {
202
202
  expect(loadingEleArr.length).toBe(0);
203
203
  cb();
204
204
  });
205
- }, searchDebounceTime);
206
- //
205
+ }, searchDebounceTime); //
207
206
  });
208
-
209
207
  it('Should call onChange, When select list item', () => {
210
208
  let defaultProps = {
211
209
  options: [{
@@ -301,11 +299,11 @@ describe('Select component conditions', () => {
301
299
  };
302
300
  let {
303
301
  renderedDOM
304
- } = setup(Select, defaultProps);
305
- // let liteItemArr = TestUtils.scryRenderedComponentsWithTestid(
302
+ } = setup(Select, defaultProps); // let liteItemArr = TestUtils.scryRenderedComponentsWithTestid(
306
303
  // renderedDOM,
307
304
  // 'listItem'
308
305
  // );
306
+
309
307
  let liteItemArr = TestUtils.scryRenderedComponentsWithType(renderedDOM, ListItem);
310
308
  expect(liteItemArr.length).toBe(3);
311
309
  });
@@ -148,6 +148,7 @@ export const GroupSelect_propTypes = {
148
148
  getFooter: PropTypes.func,
149
149
  htmlId: PropTypes.string,
150
150
  iconOnHover: PropTypes.bool,
151
+
151
152
  /**** Popup Props ****/
152
153
  isPopupOpen: PropTypes.bool,
153
154
  isPopupReady: PropTypes.bool,
@@ -2,6 +2,7 @@ import React from 'react';
2
2
  import { defaultProps } from './props/defaultProps';
3
3
  import { propTypes } from './props/propTypes';
4
4
  /* eslint css-modules/no-unused-class: [2, { markAsUsed: [primary, secondary, small, default, medium, large, clarge, cmedium, cdefault, csmall] }] */
5
+
5
6
  import style from './Stencils.module.css';
6
7
  export default class Stencils extends React.PureComponent {
7
8
  render() {
@@ -17,11 +18,10 @@ export default class Stencils extends React.PureComponent {
17
18
  className: `${style.container} ${shape} ${size} ${style[palette]} ${customClass}`
18
19
  });
19
20
  }
21
+
20
22
  }
21
23
  Stencils.propTypes = propTypes;
22
- Stencils.defaultProps = defaultProps;
23
-
24
- // if (__DOCS__) {
24
+ Stencils.defaultProps = defaultProps; // if (__DOCS__) {
25
25
  // Stencils.docs = {
26
26
  // componentGroup: 'Atom',
27
27
  // folderName: 'Style Guide',
@@ -1,6 +1,6 @@
1
1
  .varClass {
2
2
  /* stencils default variables */
3
- --stencil_height: 9px;
3
+ --stencil_height: var(--zd_size9);
4
4
  --stencil_width: 100%;
5
5
  --stencil_border_radius: 5px;
6
6
  }
@@ -48,7 +48,7 @@
48
48
 
49
49
  .rectangular {
50
50
  composes: stencil;
51
- --stencil_height: 9px;
51
+ --stencil_height: var(--zd_size9);
52
52
  --stencil_border_radius: 5px;
53
53
  }
54
54
  .primary {
@@ -65,16 +65,16 @@
65
65
  }
66
66
 
67
67
  .small {
68
- --stencil_width: 110px;
68
+ --stencil_width: var(--zd_size110);
69
69
  }
70
70
  .default {
71
71
  --stencil_width: 100%;
72
72
  }
73
73
  .medium {
74
- --stencil_width: 170px;
74
+ --stencil_width: var(--zd_size170);
75
75
  }
76
76
  .large {
77
- --stencil_width: 220px;
77
+ --stencil_width: var(--zd_size220);
78
78
  }
79
79
 
80
80
  .circle {
@@ -82,15 +82,15 @@
82
82
  --stencil_border_radius: 50%;
83
83
  }
84
84
  .clarge {
85
- --stencil_width: 42px;
86
- --stencil_height: 42px;
85
+ --stencil_width: var(--zd_size42);
86
+ --stencil_height: var(--zd_size42);
87
87
  }
88
88
  .cmedium,
89
89
  .cdefault {
90
- --stencil_width: 30px;
91
- --stencil_height: 30px;
90
+ --stencil_width: var(--zd_size30);
91
+ --stencil_height: var(--zd_size30);
92
92
  }
93
93
  .csmall {
94
- --stencil_width: 20px;
95
- --stencil_height: 20px;
94
+ --stencil_width: var(--zd_size20);
95
+ --stencil_height: var(--zd_size20);
96
96
  }
@@ -1,4 +1,5 @@
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
+
2
3
  import React from 'react';
3
4
  import { defaultProps } from './props/defaultProps';
4
5
  import { propTypes } from './props/propTypes';
@@ -10,6 +11,7 @@ export default class Switch extends React.Component {
10
11
  super(props);
11
12
  this.onChange = this.onChange.bind(this);
12
13
  }
14
+
13
15
  onChange(e) {
14
16
  let {
15
17
  onChange,
@@ -17,6 +19,7 @@ export default class Switch extends React.Component {
17
19
  } = this.props;
18
20
  onChange && onChange(!checked, e);
19
21
  }
22
+
20
23
  render() {
21
24
  let {
22
25
  id,
@@ -73,6 +76,7 @@ export default class Switch extends React.Component {
73
76
  }), /*#__PURE__*/React.createElement("label", {
74
77
  htmlFor: id,
75
78
  "data-id": dataId,
79
+ "data-test-id": dataId,
76
80
  className: `${style.label} ${style[`${size}Label`]} ${customSwitch}`
77
81
  })), text && /*#__PURE__*/React.createElement(Label, _extends({
78
82
  text: text,
@@ -84,11 +88,10 @@ export default class Switch extends React.Component {
84
88
  customClass: customLabel
85
89
  }, LabelProps)));
86
90
  }
91
+
87
92
  }
88
93
  Switch.defaultProps = defaultProps;
89
- Switch.propTypes = propTypes;
90
-
91
- // if (__DOCS__) {
94
+ Switch.propTypes = propTypes; // if (__DOCS__) {
92
95
  // Switch.docs = {
93
96
  // componentGroup: 'Form Elements',
94
97
  // folderName: 'Style Guide'
@@ -41,7 +41,7 @@
41
41
  content: '';
42
42
  display: block;
43
43
  position: absolute;
44
- right: 50%;
44
+ right: 50% ;
45
45
  transition: all var(--zd_transition2);
46
46
  box-shadow: var(--switch_cricle_box_shadow);
47
47
  background-color: var(--switch_circle_bg_color);
@@ -53,7 +53,7 @@
53
53
  }
54
54
 
55
55
  .checked+.label:after {
56
- right: -1px;
56
+ right: calc( var(--zd_size1) * -1 ) ;
57
57
  }
58
58
 
59
59
  .input {
@@ -61,35 +61,35 @@
61
61
  }
62
62
 
63
63
  .small {
64
- height: 14px;
65
- width: 28px;
64
+ height: var(--zd_size14) ;
65
+ width: var(--zd_size28) ;
66
66
  }
67
67
  .switch_smallLabel {
68
- height: 9px;
69
- width: 22px;
70
- top: -2px;
71
- left: 2px;
68
+ height: var(--zd_size9) ;
69
+ width: var(--zd_size22) ;
70
+ top: calc( var(--zd_size2) * -1 ) ;
71
+ left: var(--zd_size2) ;
72
72
  }
73
73
  .switch_smallLabel:after {
74
- width: 12px;
75
- height: 12px;
76
- top: -2px;
74
+ width: var(--zd_size12) ;
75
+ height: var(--zd_size12) ;
76
+ top: calc( var(--zd_size2) * -1 ) ;
77
77
  }
78
78
 
79
79
  .medium {
80
- height: 18px;
81
- width: 34px;
80
+ height: var(--zd_size18) ;
81
+ width: var(--zd_size34) ;
82
82
  }
83
83
  .switch_mediumLabel {
84
- height: 13px;
85
- width: 31px;
86
- top: 2px;
87
- left: 2px;
84
+ height: var(--zd_size13) ;
85
+ width: var(--zd_size31) ;
86
+ top: var(--zd_size2) ;
87
+ left: var(--zd_size2) ;
88
88
  }
89
89
  .switch_mediumLabel:after {
90
- width: 18px;
91
- height: 18px;
92
- top: -3px;
90
+ width: var(--zd_size18) ;
91
+ height: var(--zd_size18) ;
92
+ top: calc( var(--zd_size3) * -1 ) ;
93
93
  }
94
94
 
95
95
  .input:disabled+.label {
@@ -116,13 +116,13 @@
116
116
 
117
117
  .switch+label {
118
118
  position: relative;
119
- top: -1px;
119
+ top: calc( var(--zd_size1) * -1 ) ;
120
120
  }
121
121
 
122
122
  [dir=ltr] .switch+label {
123
- margin-left: 12px;
123
+ margin-left: var(--zd_size12) ;
124
124
  }
125
125
 
126
126
  [dir=rtl] .switch+label {
127
- margin-right: 12px;
127
+ margin-right: var(--zd_size12) ;
128
128
  }
package/es/Tab/Tab.js CHANGED
@@ -1,7 +1,8 @@
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
+
2
3
  /* eslint-disable react/forbid-component-props */
3
- /* eslint css-modules/no-unused-class: [2, { markAsUsed: ['text', 'tabAlpha', 'alphaActive', 'gammaActive', 'betaActive', 'deltaActive', 'tabGamma', 'tabBeta', 'tabDelta',', 'specialActive', 'tabSpecial', 'alphaActive_border', 'gammaActive_border', 'betaActive_border', 'deltaActive_border'] }] */
4
4
 
5
+ /* eslint css-modules/no-unused-class: [2, { markAsUsed: ['text', 'tabAlpha', 'alphaActive', 'gammaActive', 'betaActive', 'deltaActive', 'tabGamma', 'tabBeta', 'tabDelta',', 'specialActive', 'tabSpecial', 'alphaActive_border', 'gammaActive_border', 'betaActive_border', 'deltaActive_border'] }] */
5
6
  import React, { useMemo, useCallback } from 'react';
6
7
  import { Tab_defaultProps } from './props/defaultProps';
7
8
  import { Tab_propTypes } from './props/propTypes';
@@ -55,6 +56,7 @@ export default function Tab(_ref) {
55
56
  event && event.stopPropagation();
56
57
  return;
57
58
  }
59
+
58
60
  event && event.preventDefault();
59
61
  onSelect(id);
60
62
  onClick && onClick(event);
@@ -100,9 +102,7 @@ export default function Tab(_ref) {
100
102
  }, children) : null));
101
103
  }
102
104
  Tab.defaultProps = Tab_defaultProps;
103
- Tab.propTypes = Tab_propTypes;
104
-
105
- // if (__DOCS__) {
105
+ Tab.propTypes = Tab_propTypes; // if (__DOCS__) {
106
106
  // Tab.docs = {
107
107
  // componentGroup: 'Tab',
108
108
  // folderName: 'Style Guide'