@edvisor/product-language 0.10.2 → 0.10.3

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 (411) hide show
  1. package/index.d.ts +2 -0
  2. package/index.js +11271 -0
  3. package/lib/components/alert-banner/alert-banner.d.ts +15 -0
  4. package/lib/components/alert-banner/alert-level-flags.d.ts +18 -0
  5. package/lib/components/alert-banner/index.d.ts +1 -0
  6. package/lib/components/badge/badge-type-flags.d.ts +18 -0
  7. package/lib/components/badge/badge.d.ts +5 -0
  8. package/lib/components/badge/index.d.ts +1 -0
  9. package/{src/lib/components/card/atoms/card-frame.tsx → lib/components/card/atoms/card-frame.d.ts} +7 -16
  10. package/lib/components/card/atoms/index.d.ts +1 -0
  11. package/lib/components/card/card.d.ts +14 -0
  12. package/lib/components/card/components/card-alert-banner-slot.d.ts +6 -0
  13. package/lib/components/card/components/card-controls-slot.d.ts +5 -0
  14. package/lib/components/card/components/card-section-slot.d.ts +11 -0
  15. package/lib/components/card/components/index.d.ts +3 -0
  16. package/lib/components/card/index.d.ts +3 -0
  17. package/lib/components/card/molecules/index.d.ts +1 -0
  18. package/lib/components/card/molecules/left-right-card.d.ts +16 -0
  19. package/lib/components/checkbox/checkbox.d.ts +11 -0
  20. package/lib/components/checkbox/helpers.d.ts +12 -0
  21. package/lib/components/checkbox/index.d.ts +1 -0
  22. package/lib/components/date-picker/components/custom-calendar.d.ts +6 -0
  23. package/lib/components/date-picker/components/index.d.ts +1 -0
  24. package/lib/components/date-picker/date-picker.d.ts +4 -0
  25. package/lib/components/date-picker/helpers/date-picker-factory.d.ts +34 -0
  26. package/lib/components/date-picker/index.d.ts +1 -0
  27. package/lib/components/divider/divider-type-flags.d.ts +9 -0
  28. package/lib/components/divider/divider.d.ts +7 -0
  29. package/lib/components/divider/index.d.ts +1 -0
  30. package/lib/components/flag/flag-size-flags.d.ts +12 -0
  31. package/lib/components/flag/flag.d.ts +9 -0
  32. package/lib/components/flag/flag.list.d.ts +782 -0
  33. package/lib/components/flag/index.d.ts +1 -0
  34. package/lib/components/icon/icon-list.d.ts +132 -0
  35. package/lib/components/icon/icon.d.ts +131 -0
  36. package/lib/components/icon/index.d.ts +1 -0
  37. package/lib/components/index.d.ts +24 -0
  38. package/lib/components/input-field/components/index.d.ts +2 -0
  39. package/lib/components/input-field/components/labeled-input.d.ts +10 -0
  40. package/lib/components/input-field/components/stepper.d.ts +7 -0
  41. package/lib/components/input-field/index.d.ts +3 -0
  42. package/lib/components/input-field/input-field.d.ts +26 -0
  43. package/lib/components/input-field/input-number.d.ts +18 -0
  44. package/lib/components/input-field/input-text.d.ts +14 -0
  45. package/lib/components/layout/flex.d.ts +16 -0
  46. package/lib/components/layout/grid-layout.d.ts +11 -0
  47. package/lib/components/layout/index.d.ts +3 -0
  48. package/lib/components/layout/left-right-layout.d.ts +34 -0
  49. package/lib/components/link/index.d.ts +1 -0
  50. package/lib/components/link/link.d.ts +14 -0
  51. package/lib/components/modal/index.d.ts +3 -0
  52. package/lib/components/modal/modal-base.d.ts +28 -0
  53. package/lib/components/modal/modal-destructive.d.ts +11 -0
  54. package/lib/components/modal/modal.d.ts +13 -0
  55. package/lib/components/molecules/avatar/avatar-size-flags.d.ts +12 -0
  56. package/lib/components/molecules/avatar/avatar.d.ts +12 -0
  57. package/lib/components/molecules/avatar/index.d.ts +1 -0
  58. package/lib/components/molecules/button/button-flags.d.ts +44 -0
  59. package/lib/components/molecules/button/button.d.ts +12 -0
  60. package/lib/components/molecules/button/index.d.ts +1 -0
  61. package/lib/components/molecules/index.d.ts +3 -0
  62. package/lib/components/molecules/input-checkbox/index.d.ts +1 -0
  63. package/lib/components/molecules/input-checkbox/input-checkbox.d.ts +8 -0
  64. package/lib/components/organisms/choice-list/choice-list.d.ts +9 -0
  65. package/lib/components/organisms/choice-list/index.d.ts +1 -0
  66. package/lib/components/organisms/index.d.ts +2 -0
  67. package/lib/components/organisms/multi-choice-list/index.d.ts +1 -0
  68. package/lib/components/organisms/multi-choice-list/multi-choice-list.d.ts +11 -0
  69. package/lib/components/progress-bar/index.d.ts +1 -0
  70. package/lib/components/progress-bar/progress-bar-size-flags.d.ts +10 -0
  71. package/lib/components/progress-bar/progress-bar.d.ts +8 -0
  72. package/lib/components/radio-button/index.d.ts +1 -0
  73. package/lib/components/radio-button/radio-button.d.ts +10 -0
  74. package/lib/components/range-slider/components/bar-chart.d.ts +8 -0
  75. package/lib/components/range-slider/components/handle.d.ts +12 -0
  76. package/lib/components/range-slider/components/rail.d.ts +9 -0
  77. package/lib/components/range-slider/components/slider-component.d.ts +12 -0
  78. package/lib/components/range-slider/components/slider-inputs.d.ts +14 -0
  79. package/lib/components/range-slider/components/tick.d.ts +10 -0
  80. package/lib/components/range-slider/components/track.d.ts +11 -0
  81. package/lib/components/range-slider/index.d.ts +2 -0
  82. package/lib/components/range-slider/range-slider.d.ts +15 -0
  83. package/lib/components/range-slider/slider.d.ts +11 -0
  84. package/lib/components/range-slider/types.d.ts +11 -0
  85. package/lib/components/select/components/helpers.d.ts +17 -0
  86. package/lib/components/select/components/menu-container.d.ts +3 -0
  87. package/lib/components/select/components/menu-list.d.ts +3 -0
  88. package/lib/components/select/components/menu-row.d.ts +9 -0
  89. package/lib/components/select/components/menu.d.ts +3 -0
  90. package/lib/components/select/components/option.d.ts +3 -0
  91. package/lib/components/select/components/select-label.d.ts +1 -0
  92. package/lib/components/select/components/value-component-multi.d.ts +4 -0
  93. package/lib/components/select/components/value-component-single.d.ts +4 -0
  94. package/lib/components/select/components/value.d.ts +4 -0
  95. package/lib/components/select/index.d.ts +3 -0
  96. package/lib/components/select/select.d.ts +10 -0
  97. package/lib/components/select/types.d.ts +133 -0
  98. package/lib/components/select/utils.d.ts +15 -0
  99. package/{src/lib/components/radio-button/index.tsx → lib/components/spinner/index.d.ts} +1 -1
  100. package/lib/components/spinner/spinner-size-flags.d.ts +10 -0
  101. package/lib/components/spinner/spinner.d.ts +9 -0
  102. package/lib/components/tabs/components/index.d.ts +1 -0
  103. package/lib/components/tabs/components/tab.d.ts +8 -0
  104. package/lib/components/tabs/index.d.ts +1 -0
  105. package/lib/components/tabs/tabs.d.ts +16 -0
  106. package/lib/components/tag/components/close-button.d.ts +8 -0
  107. package/lib/components/tag/components/index.d.ts +2 -0
  108. package/lib/components/tag/components/tag-label.d.ts +8 -0
  109. package/lib/components/tag/index.d.ts +1 -0
  110. package/lib/components/tag/tag.d.ts +10 -0
  111. package/lib/components/thumbnail/index.d.ts +1 -0
  112. package/lib/components/thumbnail/thumbnail-size-flags.d.ts +10 -0
  113. package/lib/components/thumbnail/thumbnail.d.ts +10 -0
  114. package/lib/components/tooltip/index.d.ts +1 -0
  115. package/lib/components/tooltip/tooltip.d.ts +26 -0
  116. package/lib/components/tree-view/components/tree-node.d.ts +3 -0
  117. package/lib/components/tree-view/helper.d.ts +12 -0
  118. package/lib/components/tree-view/index.d.ts +2 -0
  119. package/lib/components/tree-view/tree-view.d.ts +3 -0
  120. package/lib/components/tree-view/types.d.ts +63 -0
  121. package/lib/components/typography/index.d.ts +1 -0
  122. package/lib/components/typography/typography.d.ts +24 -0
  123. package/lib/foundations/color-system/base-palette/base-palette.d.ts +76 -0
  124. package/lib/foundations/color-system/base-palette/index.d.ts +1 -0
  125. package/lib/foundations/color-system/color-guidelines/color-guidelines.d.ts +133 -0
  126. package/lib/foundations/color-system/color-guidelines/index.d.ts +1 -0
  127. package/lib/foundations/color-system/components/color-sample.d.ts +17 -0
  128. package/lib/foundations/color-system/components/index.d.ts +1 -0
  129. package/lib/foundations/color-system/index.d.ts +1 -0
  130. package/lib/foundations/index.d.ts +4 -0
  131. package/lib/foundations/shadows/components.d.ts +8 -0
  132. package/lib/foundations/shadows/index.d.ts +1 -0
  133. package/lib/foundations/shadows/shadows.d.ts +8 -0
  134. package/lib/foundations/spacing/index.d.ts +1 -0
  135. package/lib/foundations/spacing/spacing-guidelines.d.ts +33 -0
  136. package/lib/foundations/spacing/spacing.d.ts +18 -0
  137. package/lib/foundations/typography/constants.d.ts +22 -0
  138. package/lib/foundations/typography/fonts.d.ts +1 -0
  139. package/lib/foundations/typography/index.d.ts +1 -0
  140. package/lib/foundations/typography/text-aspect-flags.d.ts +19 -0
  141. package/lib/foundations/typography/typography.d.ts +24 -0
  142. package/lib/helpers/generic-types.d.ts +21 -0
  143. package/lib/helpers/index.d.ts +8 -0
  144. package/lib/helpers/isReactElementOfType.d.ts +8 -0
  145. package/lib/helpers/nothing.d.ts +10 -0
  146. package/{src/lib/helpers/numbers.ts → lib/helpers/numbers.d.ts} +50 -67
  147. package/lib/helpers/safe-navigation.d.ts +17 -0
  148. package/lib/helpers/slots.d.ts +17 -0
  149. package/lib/helpers/strings.d.ts +1 -0
  150. package/lib/helpers/useInputElementState.d.ts +30 -0
  151. package/lib/helpers/useKeyDown.d.ts +1 -0
  152. package/package.json +27 -2
  153. package/.babelrc +0 -12
  154. package/.eslintrc.json +0 -147
  155. package/.release-it.json +0 -17
  156. package/.storybook/main.js +0 -57
  157. package/.storybook/manager.js +0 -7
  158. package/.storybook/preview.js +0 -15
  159. package/.storybook/tsconfig.json +0 -30
  160. package/jest.config.ts +0 -15
  161. package/jest.setup.ts +0 -2
  162. package/project.json +0 -98
  163. package/src/README.md +0 -61
  164. package/src/assets/svg/example_icon.svg +0 -3
  165. package/src/assets/svg/example_icon_white.svg +0 -3
  166. package/src/assets/svg/spinner.svg +0 -3
  167. package/src/assets/svg/spinner_white.svg +0 -3
  168. package/src/helpers/index.ts +0 -4
  169. package/src/helpers/playground.ts +0 -26
  170. package/src/helpers/talesOf.tsx +0 -42
  171. package/src/index.ts +0 -2
  172. package/src/lib/components/README.md +0 -49
  173. package/src/lib/components/alert-banner/alert-banner.test.tsx +0 -93
  174. package/src/lib/components/alert-banner/alert-banner.tsx +0 -117
  175. package/src/lib/components/alert-banner/alert-level-flags.ts +0 -101
  176. package/src/lib/components/alert-banner/index.ts +0 -1
  177. package/src/lib/components/alert-banner/storybook/alert-banner.stories.mdx +0 -67
  178. package/src/lib/components/alert-banner/storybook/components.tsx +0 -124
  179. package/src/lib/components/badge/badge-type-flags.ts +0 -72
  180. package/src/lib/components/badge/badge.test.tsx +0 -29
  181. package/src/lib/components/badge/badge.tsx +0 -22
  182. package/src/lib/components/badge/index.ts +0 -1
  183. package/src/lib/components/badge/stories/badge.stories.mdx +0 -44
  184. package/src/lib/components/badge/stories/components.tsx +0 -49
  185. package/src/lib/components/card/atoms/index.ts +0 -1
  186. package/src/lib/components/card/card.test.tsx +0 -162
  187. package/src/lib/components/card/card.tsx +0 -78
  188. package/src/lib/components/card/components/card-alert-banner-slot.tsx +0 -16
  189. package/src/lib/components/card/components/card-controls-slot.tsx +0 -19
  190. package/src/lib/components/card/components/card-section-slot.tsx +0 -51
  191. package/src/lib/components/card/components/index.ts +0 -3
  192. package/src/lib/components/card/index.ts +0 -3
  193. package/src/lib/components/card/molecules/index.ts +0 -1
  194. package/src/lib/components/card/molecules/left-right-card.test.tsx +0 -89
  195. package/src/lib/components/card/molecules/left-right-card.tsx +0 -63
  196. package/src/lib/components/card/storybook/card.stories.mdx +0 -100
  197. package/src/lib/components/card/storybook/components.tsx +0 -227
  198. package/src/lib/components/checkbox/checkbox.test.tsx +0 -39
  199. package/src/lib/components/checkbox/checkbox.tsx +0 -70
  200. package/src/lib/components/checkbox/helpers.tsx +0 -98
  201. package/src/lib/components/checkbox/index.tsx +0 -1
  202. package/src/lib/components/checkbox/stories/checkbox.stories.mdx +0 -57
  203. package/src/lib/components/checkbox/stories/components.tsx +0 -84
  204. package/src/lib/components/date-picker/components/custom-calendar.tsx +0 -193
  205. package/src/lib/components/date-picker/components/index.ts +0 -1
  206. package/src/lib/components/date-picker/data-picker.test.tsx +0 -220
  207. package/src/lib/components/date-picker/date-picker.tsx +0 -10
  208. package/src/lib/components/date-picker/helpers/date-picker-factory.tsx +0 -210
  209. package/src/lib/components/date-picker/index.ts +0 -1
  210. package/src/lib/components/date-picker/storybook/components.tsx +0 -259
  211. package/src/lib/components/date-picker/storybook/date-picker.stories.mdx +0 -133
  212. package/src/lib/components/divider/divider-type-flags.tsx +0 -37
  213. package/src/lib/components/divider/divider.test.tsx +0 -34
  214. package/src/lib/components/divider/divider.tsx +0 -37
  215. package/src/lib/components/divider/index.tsx +0 -1
  216. package/src/lib/components/divider/stories/components.tsx +0 -13
  217. package/src/lib/components/divider/stories/divider.stories.mdx +0 -44
  218. package/src/lib/components/flag/flag-size-flags.tsx +0 -55
  219. package/src/lib/components/flag/flag.list.tsx +0 -788
  220. package/src/lib/components/flag/flag.test.tsx +0 -65
  221. package/src/lib/components/flag/flag.tsx +0 -97
  222. package/src/lib/components/flag/index.tsx +0 -1
  223. package/src/lib/components/flag/stories/components.tsx +0 -403
  224. package/src/lib/components/flag/stories/flag.stories.mdx +0 -48
  225. package/src/lib/components/flag/stories/playGround-select.tsx +0 -145
  226. package/src/lib/components/icon/icon-list.tsx +0 -135
  227. package/src/lib/components/icon/icon.test.tsx +0 -47
  228. package/src/lib/components/icon/icon.tsx +0 -181
  229. package/src/lib/components/icon/index.tsx +0 -1
  230. package/src/lib/components/icon/stories/components.tsx +0 -282
  231. package/src/lib/components/icon/stories/icon.stories.mdx +0 -65
  232. package/src/lib/components/index.ts +0 -26
  233. package/src/lib/components/input-field/components/index.ts +0 -2
  234. package/src/lib/components/input-field/components/labeled-input.tsx +0 -57
  235. package/src/lib/components/input-field/components/stepper.tsx +0 -64
  236. package/src/lib/components/input-field/index.ts +0 -6
  237. package/src/lib/components/input-field/input-field.test.tsx +0 -107
  238. package/src/lib/components/input-field/input-field.tsx +0 -154
  239. package/src/lib/components/input-field/input-number.tsx +0 -41
  240. package/src/lib/components/input-field/input-text.tsx +0 -30
  241. package/src/lib/components/input-field/storybook/components.tsx +0 -367
  242. package/src/lib/components/input-field/storybook/input-field.stories.mdx +0 -120
  243. package/src/lib/components/layout/flex.tsx +0 -22
  244. package/src/lib/components/layout/grid-layout.tsx +0 -40
  245. package/src/lib/components/layout/index.ts +0 -3
  246. package/src/lib/components/layout/left-right-layout.tsx +0 -67
  247. package/src/lib/components/link/index.ts +0 -1
  248. package/src/lib/components/link/link.test.tsx +0 -29
  249. package/src/lib/components/link/link.tsx +0 -56
  250. package/src/lib/components/link/storybook/link.stories.mdx +0 -52
  251. package/src/lib/components/modal/index.ts +0 -3
  252. package/src/lib/components/modal/modal-base.tsx +0 -129
  253. package/src/lib/components/modal/modal-destructive.tsx +0 -70
  254. package/src/lib/components/modal/modal.test.tsx +0 -138
  255. package/src/lib/components/modal/modal.tsx +0 -114
  256. package/src/lib/components/modal/storybook/components.tsx +0 -105
  257. package/src/lib/components/modal/storybook/modal-destructive.stories.mdx +0 -31
  258. package/src/lib/components/modal/storybook/modal.stories.mdx +0 -50
  259. package/src/lib/components/molecules/avatar/avatar-size-flags.tsx +0 -55
  260. package/src/lib/components/molecules/avatar/avatar.test.tsx +0 -114
  261. package/src/lib/components/molecules/avatar/avatar.tsx +0 -80
  262. package/src/lib/components/molecules/avatar/index.tsx +0 -1
  263. package/src/lib/components/molecules/avatar/stories/avatar.stories.mdx +0 -52
  264. package/src/lib/components/molecules/avatar/stories/components.tsx +0 -36
  265. package/src/lib/components/molecules/button/button-flags.tsx +0 -340
  266. package/src/lib/components/molecules/button/button.test.tsx +0 -77
  267. package/src/lib/components/molecules/button/button.tsx +0 -212
  268. package/src/lib/components/molecules/button/index.tsx +0 -1
  269. package/src/lib/components/molecules/button/stories/button.stories.mdx +0 -105
  270. package/src/lib/components/molecules/button/stories/components.tsx +0 -90
  271. package/src/lib/components/molecules/index.ts +0 -3
  272. package/src/lib/components/molecules/input-checkbox/index.tsx +0 -1
  273. package/src/lib/components/molecules/input-checkbox/input-checkbox.test.tsx +0 -34
  274. package/src/lib/components/molecules/input-checkbox/input-checkbox.tsx +0 -50
  275. package/src/lib/components/molecules/input-checkbox/stories/components.tsx +0 -53
  276. package/src/lib/components/molecules/input-checkbox/stories/input-checkbox.stories.mdx +0 -49
  277. package/src/lib/components/organisms/choice-list/choice-list.test.tsx +0 -36
  278. package/src/lib/components/organisms/choice-list/choice-list.tsx +0 -72
  279. package/src/lib/components/organisms/choice-list/index.tsx +0 -1
  280. package/src/lib/components/organisms/choice-list/stories/choice-list.stories.mdx +0 -57
  281. package/src/lib/components/organisms/choice-list/stories/components.tsx +0 -45
  282. package/src/lib/components/organisms/index.ts +0 -2
  283. package/src/lib/components/organisms/multi-choice-list/index.tsx +0 -1
  284. package/src/lib/components/organisms/multi-choice-list/multi-choice-list.test.tsx +0 -33
  285. package/src/lib/components/organisms/multi-choice-list/multi-choice-list.tsx +0 -53
  286. package/src/lib/components/organisms/multi-choice-list/stories/components.tsx +0 -124
  287. package/src/lib/components/organisms/multi-choice-list/stories/multi-choice-list.stories.mdx +0 -99
  288. package/src/lib/components/progress-bar/index.ts +0 -1
  289. package/src/lib/components/progress-bar/progress-bar-size-flags.tsx +0 -37
  290. package/src/lib/components/progress-bar/progress-bar.test.tsx +0 -66
  291. package/src/lib/components/progress-bar/progress-bar.tsx +0 -42
  292. package/src/lib/components/progress-bar/storybook/components.tsx +0 -62
  293. package/src/lib/components/progress-bar/storybook/progress-bar.stories.mdx +0 -43
  294. package/src/lib/components/radio-button/radio-button.tsx +0 -135
  295. package/src/lib/components/radio-button/radio.test.tsx +0 -59
  296. package/src/lib/components/radio-button/stories/components.tsx +0 -36
  297. package/src/lib/components/radio-button/stories/radio-button.stories.mdx +0 -44
  298. package/src/lib/components/range-slider/components/bar-chart.tsx +0 -50
  299. package/src/lib/components/range-slider/components/handle.tsx +0 -58
  300. package/src/lib/components/range-slider/components/rail.tsx +0 -44
  301. package/src/lib/components/range-slider/components/slider-component.tsx +0 -98
  302. package/src/lib/components/range-slider/components/slider-inputs.tsx +0 -150
  303. package/src/lib/components/range-slider/components/tick.tsx +0 -51
  304. package/src/lib/components/range-slider/components/track.tsx +0 -67
  305. package/src/lib/components/range-slider/index.tsx +0 -2
  306. package/src/lib/components/range-slider/range-slider.test.tsx +0 -185
  307. package/src/lib/components/range-slider/range-slider.tsx +0 -132
  308. package/src/lib/components/range-slider/slider.test.tsx +0 -89
  309. package/src/lib/components/range-slider/slider.tsx +0 -80
  310. package/src/lib/components/range-slider/stories/components.tsx +0 -179
  311. package/src/lib/components/range-slider/stories/range-slider.stories.mdx +0 -84
  312. package/src/lib/components/range-slider/types.ts +0 -18
  313. package/src/lib/components/select/components/menu-container.tsx +0 -69
  314. package/src/lib/components/select/components/menu-list.tsx +0 -195
  315. package/src/lib/components/select/components/menu-row.tsx +0 -43
  316. package/src/lib/components/select/components/menu.tsx +0 -151
  317. package/src/lib/components/select/components/option.tsx +0 -91
  318. package/src/lib/components/select/components/select-label.tsx +0 -10
  319. package/src/lib/components/select/components/value-component-multi.tsx +0 -40
  320. package/src/lib/components/select/components/value-component-single.tsx +0 -27
  321. package/src/lib/components/select/components/value.tsx +0 -370
  322. package/src/lib/components/select/index.tsx +0 -3
  323. package/src/lib/components/select/select.test.tsx +0 -148
  324. package/src/lib/components/select/select.tsx +0 -337
  325. package/src/lib/components/select/storybook/components.tsx +0 -999
  326. package/src/lib/components/select/storybook/radio-group.tsx +0 -157
  327. package/src/lib/components/select/storybook/select.stories.mdx +0 -172
  328. package/src/lib/components/select/types.ts +0 -149
  329. package/src/lib/components/select/utils.ts +0 -101
  330. package/src/lib/components/spinner/index.tsx +0 -1
  331. package/src/lib/components/spinner/spinner-size-flags.tsx +0 -39
  332. package/src/lib/components/spinner/spinner.test.tsx +0 -31
  333. package/src/lib/components/spinner/spinner.tsx +0 -54
  334. package/src/lib/components/spinner/stories/components.tsx +0 -39
  335. package/src/lib/components/spinner/stories/spinner.stories.mdx +0 -35
  336. package/src/lib/components/tabs/components/index.ts +0 -1
  337. package/src/lib/components/tabs/components/tab.tsx +0 -85
  338. package/src/lib/components/tabs/index.tsx +0 -1
  339. package/src/lib/components/tabs/storybook/components.tsx +0 -317
  340. package/src/lib/components/tabs/storybook/tabs.stories.mdx +0 -105
  341. package/src/lib/components/tabs/tabs.test.tsx +0 -86
  342. package/src/lib/components/tabs/tabs.tsx +0 -115
  343. package/src/lib/components/tag/components/close-button.tsx +0 -85
  344. package/src/lib/components/tag/components/index.ts +0 -2
  345. package/src/lib/components/tag/components/tag-label.tsx +0 -45
  346. package/src/lib/components/tag/index.tsx +0 -1
  347. package/src/lib/components/tag/stories/components.tsx +0 -86
  348. package/src/lib/components/tag/stories/tag.stories.mdx +0 -42
  349. package/src/lib/components/tag/tag.test.tsx +0 -36
  350. package/src/lib/components/tag/tag.tsx +0 -33
  351. package/src/lib/components/thumbnail/index.tsx +0 -1
  352. package/src/lib/components/thumbnail/stories/thumbnail.stories.mdx +0 -44
  353. package/src/lib/components/thumbnail/thumbnail-size-flags.tsx +0 -41
  354. package/src/lib/components/thumbnail/thumbnail.test.tsx +0 -51
  355. package/src/lib/components/thumbnail/thumbnail.tsx +0 -44
  356. package/src/lib/components/tooltip/index.tsx +0 -1
  357. package/src/lib/components/tooltip/stories/components.tsx +0 -224
  358. package/src/lib/components/tooltip/stories/tooltip.stories.mdx +0 -63
  359. package/src/lib/components/tooltip/tooltip.test.tsx +0 -22
  360. package/src/lib/components/tooltip/tooltip.tsx +0 -179
  361. package/src/lib/components/tree-view/components/tree-node.tsx +0 -203
  362. package/src/lib/components/tree-view/helper.tsx +0 -171
  363. package/src/lib/components/tree-view/index.ts +0 -2
  364. package/src/lib/components/tree-view/stories/components.tsx +0 -640
  365. package/src/lib/components/tree-view/stories/tree-view.stories.mdx +0 -127
  366. package/src/lib/components/tree-view/tree-view.test.tsx +0 -146
  367. package/src/lib/components/tree-view/tree-view.tsx +0 -168
  368. package/src/lib/components/tree-view/types.tsx +0 -70
  369. package/src/lib/components/typography/index.ts +0 -1
  370. package/src/lib/components/typography/storybook/components.tsx +0 -288
  371. package/src/lib/components/typography/storybook/typography.stories.mdx +0 -90
  372. package/src/lib/components/typography/typography.test.tsx +0 -97
  373. package/src/lib/components/typography/typography.tsx +0 -99
  374. package/src/lib/foundations/color-system/base-palette/base-palette.stories.tsx +0 -123
  375. package/src/lib/foundations/color-system/base-palette/base-palette.ts +0 -93
  376. package/src/lib/foundations/color-system/base-palette/index.ts +0 -1
  377. package/src/lib/foundations/color-system/color-guidelines/color-guidelines.stories.mdx +0 -85
  378. package/src/lib/foundations/color-system/color-guidelines/color-guidelines.stories.tsx +0 -231
  379. package/src/lib/foundations/color-system/color-guidelines/color-guidelines.ts +0 -160
  380. package/src/lib/foundations/color-system/color-guidelines/index.ts +0 -1
  381. package/src/lib/foundations/color-system/components/color-sample.tsx +0 -99
  382. package/src/lib/foundations/color-system/components/index.ts +0 -1
  383. package/src/lib/foundations/color-system/index.ts +0 -1
  384. package/src/lib/foundations/index.ts +0 -4
  385. package/src/lib/foundations/shadows/components.tsx +0 -59
  386. package/src/lib/foundations/shadows/index.ts +0 -1
  387. package/src/lib/foundations/shadows/shadows.stories.mdx +0 -71
  388. package/src/lib/foundations/shadows/shadows.tsx +0 -47
  389. package/src/lib/foundations/spacing/index.ts +0 -1
  390. package/src/lib/foundations/spacing/spacing-guidelines.ts +0 -37
  391. package/src/lib/foundations/spacing/spacing.stories.mdx +0 -51
  392. package/src/lib/foundations/spacing/spacing.ts +0 -18
  393. package/src/lib/foundations/typography/constants.ts +0 -25
  394. package/src/lib/foundations/typography/fonts.ts +0 -205
  395. package/src/lib/foundations/typography/index.tsx +0 -1
  396. package/src/lib/foundations/typography/text-aspect-flags.ts +0 -61
  397. package/src/lib/foundations/typography/typography.tsx +0 -102
  398. package/src/lib/helpers/generic-types.ts +0 -44
  399. package/src/lib/helpers/index.ts +0 -8
  400. package/src/lib/helpers/isReactElementOfType.test.tsx +0 -108
  401. package/src/lib/helpers/isReactElementOfType.ts +0 -42
  402. package/src/lib/helpers/nothing.tsx +0 -22
  403. package/src/lib/helpers/safe-navigation.ts +0 -57
  404. package/src/lib/helpers/slots.tsx +0 -126
  405. package/src/lib/helpers/strings.test.ts +0 -47
  406. package/src/lib/helpers/strings.ts +0 -16
  407. package/src/lib/helpers/useInputElementState.ts +0 -56
  408. package/src/lib/helpers/useKeyDown.ts +0 -17
  409. package/tsconfig.json +0 -35
  410. package/tsconfig.lib.json +0 -28
  411. package/tsconfig.spec.json +0 -21
@@ -1,84 +0,0 @@
1
- import { Canvas, Meta, Story, ArgsTable } from '@storybook/addon-docs';
2
- import { RangeSlider } from '../index'
3
- import { SliderPlayground, RangePlayground, RangeWithGraphPlayground } from './components.tsx'
4
- import { AlertBanner } from 'components/alert-banner'
5
-
6
-
7
- <Meta title="Components/RangeSlider" component={RangeSlider}/>
8
-
9
- # RangeSlider System
10
-
11
- For more details, check out the guidelines on [Figma](https://www.figma.com/file/ue1CurHfZ426o2T2l8Dk64/Edvisor-Product-Language?node-id=734%3A7378&t=FGYMPTF1ZFK1srUc-0)
12
-
13
- ## How to Use
14
-
15
- ```tsx
16
- import { Slider, RangeSlider } from '@edvisor/product-language'
17
-
18
- <Slider
19
- max={max}
20
- value={number}
21
- />
22
-
23
- <RangeSlider
24
- max={max}
25
- values={[min, max]}
26
- />
27
-
28
- ```
29
-
30
- ### Slider
31
-
32
- <SliderPlayground/>
33
-
34
- ### Range Slider
35
-
36
- <RangePlayground/>
37
-
38
-
39
- ### Range Slider With Graph
40
-
41
- <RangeWithGraphPlayground/>
42
-
43
-
44
-
45
- # API
46
-
47
- ### Slider
48
-
49
- | Prop | Type | Description |
50
- | -------------- | --------------------------------- | --------------------------------------------------- |
51
- | `min?` | `number` | `The minimum possible value (defaults to 0)` |
52
- | `max` | `number` | `The maximum possible value of the slider` |
53
- | `value` | `number` | `The max value selected` |
54
- | `prefix?` | `string` | `Prefix to show with the label / input` |
55
- | `editable?` | `boolean` | `Renders a input to allow changing the slide value` |
56
- | `onChange?` | `(value: number) => void` | `Returns the max value selected` |
57
-
58
- ### Range Slider
59
-
60
- <AlertBanner info style={{whiteSpace: 'pre-line'}}>
61
- <p>If you provide a 'data' property, the component will build Bar graph on top of the slider
62
- and use it's minimum and maximum values as a range</p>
63
- </AlertBanner>
64
-
65
- | Prop | Type | Description |
66
- | -------------- | ----------------------------------- | ---------------------------------------------------- |
67
- | `data?` | `number[]` | `List occurrences to build the Graph` |
68
- | `graphHeight?` | `number` | `The height value for the Graph, defaults to 100` |
69
- | `min?` | `number` | `The minimum possible value (defaults to 0)` |
70
- | `max?` | `number` | `The maximum possible value (defaults to 100)` |
71
- | `maxLabel?` | `string` | `The label for the max input (default to 'Max')` |
72
- | `minLabel?` | `string` | `The label for the min input (default to 'Min')` |
73
- | `values` | `number[]` | `The selected range defaults ([min, max])` |
74
- | `prefix?` | `string` | `Prefix to show with the label / input` |
75
- | `editable?` | `boolean` | `Renders a input to allow changing the slide value` |
76
- | `onChange?` | `(value: number[min, max]) => void` | `Returns the selected range` |
77
-
78
-
79
- ## Changelog
80
-
81
- ### [0.0.0]
82
- - The slider is built on top of [react-compound-slider](https://react-compound-slider.netlify.app/) lib
83
- - The Graph is built on top of [recharts](https://recharts.org/en-US/) lib
84
-
@@ -1,18 +0,0 @@
1
- import styled, { css } from 'styled-components'
2
-
3
- export enum SliderType {
4
- SLIDER,
5
- RANGE_SLIDER,
6
- }
7
-
8
- export enum ValueType {
9
- MIN,
10
- MAX,
11
- }
12
-
13
- export const FieldContainer = styled.div<{margin: string}>`
14
- ${({margin}) => margin === 'right'
15
- ? css`margin-right: auto`
16
- : css`margin-left: auto`
17
- }
18
- `
@@ -1,69 +0,0 @@
1
-
2
- import { FC } from '@helpers'
3
-
4
- import styled from 'styled-components'
5
- import { IMenuContainerProps, menuPositionType } from '../types'
6
- import { Borders, Surface, Padding } from '@foundations'
7
- import { topPosition } from '../utils'
8
-
9
- interface IMenuWrapperProps {
10
- label?: IMenuContainerProps['label'];
11
- menuHeight?: IMenuContainerProps['menuHeight'];
12
- menuPosition?: IMenuContainerProps['menuPosition'];
13
- labelPosition?: IMenuContainerProps['labelPosition'];
14
- invalid?: boolean;
15
- }
16
-
17
- const MenuWrapper = styled.div<IMenuWrapperProps>`
18
- z-index: 1;
19
- position: relative;
20
- background: ${Surface.Default.Default};
21
- top: ${(props) => topPosition(props)};
22
- box-sizing: border-box;
23
- .menu-list {
24
- box-sizing: border-box;
25
- box-shadow: ${(props) =>
26
- props.menuPosition === menuPositionType.BOTTOM
27
- ? '0px 2px 10px 0px rgba(0, 0, 0, 0.10)'
28
- : '0px -2px 10px 0px rgba(0, 0, 0, 0.10)'};
29
- border: 1px solid ${Borders.Default.Subdued};
30
- background-color: ${Surface.Default.Default};
31
- border-radius: 6px;
32
- opacity: 0;
33
- transition: opacity 0.1s ease;
34
- padding: ${Padding.xxs};
35
-
36
- &:focus {
37
- outline: none;
38
- }
39
-
40
- ::-webkit-scrollbar {
41
- width: 6px;
42
- height: 8px;
43
- }
44
-
45
- ::-webkit-scrollbar-thumb {
46
- border-radius: 4px;
47
- background: ${Surface.Neutral.Default};
48
- min-height: 50px;
49
- }
50
- }
51
- `
52
-
53
- export const MenuContainer: FC<IMenuContainerProps> = (props) => {
54
- const { onClick, children } = props
55
- const className = ['select-menu', props.className]
56
- .filter((c) => c)
57
- .join(' ')
58
-
59
- return (
60
- <MenuWrapper
61
- data-role="menu"
62
- className={className}
63
- onClick={onClick}
64
- {...props}
65
- >
66
- {children}
67
- </MenuWrapper>
68
- )
69
- }
@@ -1,195 +0,0 @@
1
- import styled from 'styled-components'
2
- import { Borders, Icons, Padding, Margin, shadowMd, Surface } from '@foundations'
3
- import { FC, is, isDefined, maybeRender, safeArray } from '@helpers'
4
- import { Heading4, Label } from 'components/typography'
5
- import { IconMinor } from 'components/icon'
6
- import { IMenuComponentProps, IOption } from '../types'
7
- import { equal } from '../utils'
8
- import { SpaceBetween } from 'components/layout'
9
- import { useRef } from 'react'
10
-
11
- const MenuListFrame = styled.div`
12
- border: 1px solid ${Borders.Default.Subdued};
13
- background-color: ${Surface.Default.Default};
14
- position: absolute;
15
- width: 100%;
16
- width: -moz-available;
17
- width: -webkit-fill-available;
18
- max-height: 184px;
19
- overflow-y: auto;
20
- overflow-x: hidden;
21
- ::-webkit-scrollbar {
22
- width: 6px;
23
- height: 8px;
24
- }
25
-
26
- ::-webkit-scrollbar-thumb {
27
- border-radius: 4px;
28
- background: ${Surface.Neutral.Default};
29
- min-height: 50px;
30
- }
31
- ${shadowMd};
32
- `
33
-
34
- const MenuRow = styled(SpaceBetween)<{active?: boolean}>`
35
- border: none;
36
- text-align: left;
37
- padding: ${Padding.s};
38
- margin: ${Margin.none} ${Margin.xxs};
39
- background-color: ${(props) =>
40
- (is(props.active)
41
- ? Surface.Selected.Default
42
- : Surface.Default.Default)
43
- };
44
- border-radius: 6px;
45
- i:first-child {
46
- align-self: start;
47
- margin-right: ${Margin.xs};
48
- }
49
- i:last-child {
50
- align-self: center;
51
- }
52
- &:first-of-type {
53
- margin-top: ${Margin.xxs};
54
- }
55
- &:last-of-type {
56
- margin-bottom: ${Margin.xxs};
57
- }
58
-
59
- &:hover {
60
- background-color: ${Surface.Default.Hover};
61
- }
62
-
63
- &:hover {
64
- background-color: ${(props) =>
65
- (is(props.active)
66
- ? Surface.Selected.Hover
67
- : Surface.Default.Hover)
68
- };
69
- }
70
-
71
- &:active {
72
- background-color: ${(props) =>
73
- (is(props.active)
74
- ? Surface.Selected.Pressed
75
- : Surface.Default.Pressed)
76
- };
77
- }
78
- `
79
-
80
- const OptionLabel = styled(Label)<{hasIcon: boolean}>`
81
- cursor: pointer;
82
- `
83
-
84
- const CheckedIcon = styled(IconMinor.Check)`
85
- svg {
86
- path {
87
- fill : ${Icons.Highlight}
88
- }
89
- }
90
- `
91
-
92
- const ValueWrapper = styled.div`
93
- width: 100%;
94
- `
95
-
96
- const TitleRow = styled(Heading4)`
97
- height: 30px;
98
- margin: ${Margin.none} ${Margin.xxs};
99
- border-bottom: 1px solid ${Borders.Default.Subdued};
100
- padding: ${Padding.s} ${Padding.none} ${Padding.none} ${Padding.s};
101
- `
102
-
103
- const Row: FC<IMenuComponentProps & {
104
- index: number,
105
- handleClick: (option: IOption) => void
106
- }> = (props) => {
107
-
108
- const {
109
- index,
110
- options = [],
111
- handleClick,
112
- } = props
113
-
114
- const hasIcon = safeArray(options)
115
- .some((option) => isDefined(option['icon']))
116
-
117
- const currentValue =
118
- Array.isArray(props.value) && is(props.multi) ? props.value : [props.value]
119
-
120
- const option = options[index]
121
-
122
- return (
123
- <MenuRow
124
- className="menu-row"
125
- center
126
- active={currentValue.some(val =>
127
- equal(val, option.value)
128
- )}
129
- onClick={() => handleClick(option)}
130
- >
131
- {
132
- maybeRender(hasIcon, option['icon'])
133
- }
134
- <ValueWrapper>
135
- <OptionLabel hasIcon={hasIcon}>
136
- {option.label}
137
- </OptionLabel>
138
- {
139
- maybeRender(option['helperText'],
140
- <OptionLabel subdued hasIcon={hasIcon}>
141
- {option['helperText']}
142
- </OptionLabel>
143
- )
144
- }
145
- </ValueWrapper>
146
- {
147
- maybeRender(currentValue.some(val =>
148
- equal(val, option.value)
149
- ), <CheckedIcon/>)
150
- }
151
- </MenuRow>
152
- )
153
- }
154
-
155
- export const MenuList: FC<IMenuComponentProps> = (props) => {
156
-
157
- // eslint-disable-next-line no-null/no-null
158
- const list = useRef<HTMLDivElement>(null)
159
-
160
- // const { open, selectedIndex, rowHeight } = props
161
-
162
- const handleClick = (option: IOption) => {
163
- const newValue = Array.isArray(props.value) && is(props.multi)
164
- ? [...props.value, option.value]
165
- : option.value
166
- props.onSelect(newValue)
167
- }
168
-
169
- /**
170
- * @TODO
171
- * This doesnt work with the styled components that RWC uses, so I'll leave comented for now
172
- *useEffect(() => {
173
- * if(is(open) && isDefined(list.current) && isDefined(selectedIndex)) {
174
- * list.current.scrollTo(0, selectedIndex * (defaultTo(rowHeight, DEFAULT_ROW_HEIGHT)+4))
175
- * }
176
- *}, [open, list, selectedIndex, rowHeight])
177
- */
178
-
179
- return (
180
- <MenuListFrame ref={list}>
181
- {
182
- maybeRender(props.menuTitle,
183
- <TitleRow>{props.menuTitle}</TitleRow>
184
- )
185
- }
186
- {(safeArray(props.options)).map((_, index) => (
187
- <Row
188
- key={index}
189
- index={index}
190
- handleClick={handleClick}
191
- {...props} />
192
- ))}
193
- </MenuListFrame>
194
- )
195
- }
@@ -1,43 +0,0 @@
1
- import { CSSProperties, memo } from 'react'
2
- import { areEqual } from 'react-window'
3
- import { OptionComponent } from './option'
4
- import { IMenuComponentProps } from '../types'
5
- import { equal } from '../utils'
6
- import { is } from '@helpers'
7
-
8
- interface IMenuRowProps {
9
- index: number;
10
- style: CSSProperties;
11
- data: IMenuComponentProps;
12
- }
13
-
14
- export const MenuRow = memo(({ index, style, data }: IMenuRowProps) => {
15
- const {
16
- options = [],
17
- labelComponent,
18
- selectedIndex,
19
- rowHeight,
20
- search,
21
- multi,
22
- onSelect
23
- } = data
24
- const option = options[index]
25
- const currentValue =
26
- Array.isArray(data.value) && is(multi) ? data.value : [data.value]
27
-
28
- return (
29
- <div style={style}>
30
- <OptionComponent
31
- option={option}
32
- labelComponent={labelComponent}
33
- height={rowHeight}
34
- active={currentValue.some(val =>
35
- equal(val, option.value)
36
- )}
37
- selected={selectedIndex === index}
38
- search={search}
39
- onSelect={onSelect}
40
- />
41
- </div>
42
- )
43
- }, areEqual)
@@ -1,151 +0,0 @@
1
- import { useEffect, useRef } from 'react'
2
- import styled from 'styled-components'
3
- import { IMenuComponentProps,
4
- IOption,
5
- DEFAULT_EMPTY_TEXT,
6
- DEFAULT_MENU_HEIGHT,
7
- DEFAULT_ROW_HEIGHT,
8
- labelPositionType,
9
- menuPositionType
10
- } from '../types'
11
- import { equal } from '../utils'
12
- import { FixedSizeList } from 'react-window'
13
- import { defaultTo, is, isDefined, maybeRender, safeArray } from '@helpers'
14
- import { Borders, Surface, Margin } from '@foundations'
15
- import { OptionItem } from './option'
16
- import { MenuContainer } from './menu-container'
17
- import { MenuRow } from './menu-row'
18
- import { useMemo } from 'react'
19
- import { SelectLabel } from './select-label'
20
-
21
- const EmptyOptionItem = styled(OptionItem)<{props: IMenuComponentProps}>`
22
- border: 1px solid ${Borders.Default.Subdued};
23
- background-color: ${Surface.Default.Default};
24
- position: absolute;
25
- margin: ${Margin.none};
26
- width: 100%;
27
- height: 54px;
28
- box-shadow: ${({ props }) =>
29
- props.menuPosition === menuPositionType.BOTTOM
30
- ? '0px 2px 10px 0px rgba(0, 0, 0, 0.10)'
31
- : '0px -2px 10px 0px rgba(0, 0, 0, 0.10)'};
32
- &:hover {
33
- background-color: ${Surface.Default.Default};
34
- }
35
- `
36
-
37
- export const Menu = (props: IMenuComponentProps) => {
38
- const {
39
- rowHeight = DEFAULT_ROW_HEIGHT,
40
- selectedIndex,
41
- open,
42
- invalid,
43
- menuHeight = DEFAULT_MENU_HEIGHT,
44
- menuPosition = menuPositionType.BOTTOM,
45
- labelPosition = labelPositionType.TOP,
46
- label,
47
- } = props
48
-
49
- const options = safeArray(props.options)
50
-
51
- type FixedSizeListType = FixedSizeList & HTMLElement
52
- // eslint-disable-next-line no-null/no-null
53
- const list = useRef<FixedSizeList>(null)
54
- // eslint-disable-next-line no-null/no-null
55
- const outerRef = useRef<FixedSizeListType>(null)
56
-
57
- const height = Math.min(
58
- Math.max(options.length * rowHeight, rowHeight) + 10, menuHeight
59
- )
60
-
61
- useEffect(() => {
62
- if (
63
- is(open) &&
64
- isDefined(list.current) &&
65
- selectedIndex !== undefined &&
66
- selectedIndex !== -1
67
- ) {
68
- list.current.scrollToItem(selectedIndex, 'center')
69
- }
70
- }, [open, selectedIndex])
71
-
72
- useEffect(() => {
73
- if (
74
- is(open) && isDefined(outerRef.current) && options.length > 0
75
- ) {
76
- outerRef.current.style.opacity = '1'
77
- }
78
- }, [open, options])
79
-
80
- const itemData = useMemo(() => {
81
- return {
82
- ...props,
83
- options,
84
- onSelect: (value: unknown, option: IOption) => {
85
- if (Array.isArray(props.value) && is(props.multi)) {
86
- const found = props.value.some((item) =>
87
- equal(item, value)
88
- )
89
- const values = found
90
- ? props.value.filter(
91
- (item) =>
92
- !equal(item, value)
93
- )
94
- : Array.from(new Set([...props.value, value]))
95
-
96
- props.onSelect(values, option)
97
- } else {
98
- props.onSelect(value, option)
99
- }
100
- }
101
- }
102
- }, [props, options])
103
-
104
- const renderList = () => {
105
- const MenuComponent = props.menuComponent
106
- const itemCount = options.length
107
-
108
- if (isDefined(MenuComponent)) {
109
- return <MenuComponent {...props} />
110
- }
111
-
112
- if (itemCount === 0) {
113
- const { emptyText } = props
114
- return (
115
- <EmptyOptionItem props={props}>
116
- <SelectLabel>
117
- <span>{defaultTo(emptyText, DEFAULT_EMPTY_TEXT)}</span>
118
- </SelectLabel>
119
- </EmptyOptionItem>
120
- )
121
- }
122
-
123
- return (
124
- <FixedSizeList
125
- className="menu-list"
126
- style={{position: 'absolute'}}
127
- ref={list}
128
- outerRef={outerRef}
129
- width="100%"
130
- height={height}
131
- itemSize={rowHeight}
132
- itemCount={itemCount}
133
- itemData={itemData}
134
- >
135
- {MenuRow}
136
- </FixedSizeList>
137
- )
138
- }
139
-
140
- return maybeRender(open,
141
- <MenuContainer
142
- invalid={invalid}
143
- label={label}
144
- menuHeight={height}
145
- menuPosition={menuPosition}
146
- labelPosition={labelPosition}
147
- >
148
- {renderList()}
149
- </MenuContainer>
150
- )
151
- }
@@ -1,91 +0,0 @@
1
- import { defaultTo, FC, is, isDefined } from '@helpers'
2
- import styled from 'styled-components'
3
- import { Label } from 'components/typography'
4
- import { Padding, Surface, Icons, Margin } from '@foundations'
5
- import { memo } from 'react'
6
- import { IOptionComponentProps, LabelComponentProps, DEFAULT_ROW_HEIGHT } from '../types'
7
- import { areEqual } from 'react-window'
8
- import { IconMinor } from 'components/icon'
9
- import { SpaceBetween } from 'components/layout'
10
-
11
- interface IOptionItemProps {
12
- active?: IOptionComponentProps['active'];
13
- selected?: IOptionComponentProps['selected'];
14
- height?: IOptionComponentProps['height'];
15
- }
16
-
17
- export const OptionItem = styled(SpaceBetween)`
18
- flex: 1;
19
- height: ${(props: IOptionItemProps) => defaultTo(props.height, DEFAULT_ROW_HEIGHT)}px;
20
- min-width: 0;
21
- cursor: pointer;
22
- box-sizing: border-box;
23
- margin: ${Margin.xxs};
24
- border-radius: 6px;
25
- background-clip: content-box;
26
- background-color: ${(props: IOptionItemProps) =>
27
- is(props.active)
28
- ? Surface.Selected.Default
29
- : is(props.selected)
30
- ? Surface.Default.Hover
31
- : Surface.Default.Default};
32
-
33
- & div {
34
- padding: ${Padding.none} ${Padding.xs};
35
- }
36
-
37
- & i:last-child {
38
- right: 8px;
39
- }
40
-
41
- &:hover {
42
- background-color: ${(props: IOptionItemProps) =>
43
- is(props.active) ? Surface.Selected.Hover : Surface.Default.Hover};
44
- }
45
-
46
- &:active {
47
- background-color: ${(props: IOptionItemProps) =>
48
- is(props.active) ? Surface.Selected.Pressed : Surface.Default.Pressed};
49
- }
50
- `
51
- const CheckedIcon = styled(IconMinor.Check)`
52
- svg {
53
- path {
54
- fill : ${Icons.Highlight}
55
- }
56
- }
57
- `
58
-
59
- export const OptionComponent = memo((props: IOptionComponentProps) => {
60
-
61
- const onClick = () => {
62
- props.onSelect(props.option.value, props.option)
63
- }
64
-
65
- const { active, selected, labelComponent, option, height } = props
66
- const SelectLabel = (isDefined(labelComponent) ? labelComponent : Label) as FC<LabelComponentProps>
67
-
68
- const className = [
69
- 'option',
70
- props.className,
71
- is(selected) ? 'selected' : '',
72
- is(active) ? 'active' : ''
73
- ].filter((v) => Boolean(v))
74
-
75
- return (
76
- <OptionItem
77
- className={className.join(' ')}
78
- data-role="option"
79
- center
80
- selected={selected}
81
- active={active}
82
- height={height}
83
- onClick={onClick}
84
- >
85
- <SelectLabel type="option" active={active} {...option}>
86
- {option.label}
87
- </SelectLabel>
88
- {is(active) && <CheckedIcon/>}
89
- </OptionItem>
90
- )
91
- }, areEqual)
@@ -1,10 +0,0 @@
1
- import styled from 'styled-components'
2
- import { Label } from 'components/typography'
3
-
4
- export const SelectLabel = styled(Label)`
5
- overflow: hidden;
6
- white-space: nowrap;
7
- text-overflow: ellipsis;
8
- user-select: none;
9
- box-sizing: border-box;
10
- `
@@ -1,40 +0,0 @@
1
- import styled from 'styled-components'
2
- import { IValueComponentMultiProps } from '../types'
3
- import { SelectLabel } from './select-label'
4
- import { Tag } from 'components/tag'
5
- import { Padding } from '@foundations'
6
- import { memo } from 'react'
7
-
8
- const TagContainer = styled(Tag)`
9
- div:first-child {
10
- min-height: auto;
11
- padding: ${Padding.none} ${Padding.none} ${Padding.none} ${Padding.xxs};
12
- }
13
- div:last-child {
14
- padding: ${Padding.none};
15
- }
16
- `
17
-
18
- const ValueComponentMulti = <T,>(props: IValueComponentMultiProps<T>) => {
19
-
20
- const { option, onRemove } = props
21
- const className = ['value-multi', props.className]
22
- .filter((c) => Boolean(c))
23
- .join(' ')
24
-
25
- return (
26
- <TagContainer
27
- className={className}
28
- closable
29
- onClick={() => {
30
- onRemove(option.value)
31
- }}
32
- >
33
- <SelectLabel default {...option}>
34
- {option.label}
35
- </SelectLabel>
36
- </TagContainer>
37
- )
38
- }
39
-
40
- export default memo(ValueComponentMulti) as typeof ValueComponentMulti