@ftdata/ui 0.0.1

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 (265) hide show
  1. package/README.md +23 -0
  2. package/dist/assets/AddIcon.d.ts +3 -0
  3. package/dist/assets/AddIcon.js +35 -0
  4. package/dist/assets/ArrowLeftIcon.d.ts +2 -0
  5. package/dist/assets/ArrowLeftIcon.js +26 -0
  6. package/dist/assets/BackArrowIcon.d.ts +3 -0
  7. package/dist/assets/BackArrowIcon.js +35 -0
  8. package/dist/assets/BellIcon.d.ts +2 -0
  9. package/dist/assets/BellIcon.js +43 -0
  10. package/dist/assets/BuildingIcon.d.ts +2 -0
  11. package/dist/assets/BuildingIcon.js +15 -0
  12. package/dist/assets/BurgerMenu.d.ts +3 -0
  13. package/dist/assets/BurgerMenu.js +41 -0
  14. package/dist/assets/CancelSquareIcon.d.ts +3 -0
  15. package/dist/assets/CancelSquareIcon.js +36 -0
  16. package/dist/assets/CarretDownIcon.d.ts +3 -0
  17. package/dist/assets/CarretDownIcon.js +32 -0
  18. package/dist/assets/CavetDown.d.ts +2 -0
  19. package/dist/assets/CavetDown.js +18 -0
  20. package/dist/assets/CavetRight.d.ts +2 -0
  21. package/dist/assets/CavetRight.js +18 -0
  22. package/dist/assets/CavetUp.d.ts +2 -0
  23. package/dist/assets/CavetUp.js +18 -0
  24. package/dist/assets/CheckMarkIcon.d.ts +3 -0
  25. package/dist/assets/CheckMarkIcon.js +39 -0
  26. package/dist/assets/CheckmarkDone.d.ts +3 -0
  27. package/dist/assets/CheckmarkDone.js +27 -0
  28. package/dist/assets/CloseIcon.d.ts +2 -0
  29. package/dist/assets/CloseIcon.js +27 -0
  30. package/dist/assets/CommandIcon.d.ts +2 -0
  31. package/dist/assets/CommandIcon.js +77 -0
  32. package/dist/assets/DoneCircleIcon.d.ts +3 -0
  33. package/dist/assets/DoneCircleIcon.js +29 -0
  34. package/dist/assets/EmptyAlertDetail.d.ts +2 -0
  35. package/dist/assets/EmptyAlertDetail.js +451 -0
  36. package/dist/assets/EmptyPage.d.ts +3 -0
  37. package/dist/assets/EmptyPage.js +551 -0
  38. package/dist/assets/EyeIcon.d.ts +2 -0
  39. package/dist/assets/EyeIcon.js +35 -0
  40. package/dist/assets/FenceIcon.d.ts +2 -0
  41. package/dist/assets/FenceIcon.js +70 -0
  42. package/dist/assets/FolderCheckmark.d.ts +3 -0
  43. package/dist/assets/FolderCheckmark.js +44 -0
  44. package/dist/assets/FulltrackLogo.d.ts +3 -0
  45. package/dist/assets/FulltrackLogo.js +37 -0
  46. package/dist/assets/GlobeIcon.d.ts +2 -0
  47. package/dist/assets/GlobeIcon.js +61 -0
  48. package/dist/assets/GoogleIcon.d.ts +2 -0
  49. package/dist/assets/GoogleIcon.js +18 -0
  50. package/dist/assets/Group.js +2 -0
  51. package/dist/assets/MinusMarkIcon.d.ts +3 -0
  52. package/dist/assets/MinusMarkIcon.js +40 -0
  53. package/dist/assets/MosaicIcon.d.ts +3 -0
  54. package/dist/assets/MosaicIcon.js +41 -0
  55. package/dist/assets/NavLogo.d.ts +3 -0
  56. package/dist/assets/NavLogo.js +73 -0
  57. package/dist/assets/PinLocation.d.ts +2 -0
  58. package/dist/assets/PinLocation.js +31 -0
  59. package/dist/assets/PlusAddIcon.d.ts +2 -0
  60. package/dist/assets/PlusAddIcon.js +42 -0
  61. package/dist/assets/RefreshIcon.d.ts +2 -0
  62. package/dist/assets/RefreshIcon.js +16 -0
  63. package/dist/assets/SearchIcon.d.ts +3 -0
  64. package/dist/assets/SearchIcon.js +30 -0
  65. package/dist/assets/SendIcon.d.ts +3 -0
  66. package/dist/assets/SendIcon.js +20 -0
  67. package/dist/assets/StreetView.d.ts +2 -0
  68. package/dist/assets/StreetView.js +52 -0
  69. package/dist/assets/SwitchCheckMarkIcon.d.ts +3 -0
  70. package/dist/assets/SwitchCheckMarkIcon.js +40 -0
  71. package/dist/assets/WarningIcon.d.ts +2 -0
  72. package/dist/assets/WarningIcon.js +34 -0
  73. package/dist/assets/gif/how-to-use.js +2 -0
  74. package/dist/assets/iconMenu/SettingsIcon.d.ts +2 -0
  75. package/dist/assets/iconMenu/SettingsIcon.js +30 -0
  76. package/dist/assets/img/cover.js +2 -0
  77. package/dist/assets/img/map-sample.js +2 -0
  78. package/dist/assets/img/photo-goes-here.js +2 -0
  79. package/dist/assets/svg/chat.js +2 -0
  80. package/dist/assets/svg/colored-item.js +2 -0
  81. package/dist/assets/svg/mailbox-bro.js +2 -0
  82. package/dist/assets/svg/star-favorite.js +2 -0
  83. package/dist/assets/travolta.js +2 -0
  84. package/dist/components/Avatar/Avatar.stories.d.ts +33 -0
  85. package/dist/components/Avatar/Avatar.stories.js +177 -0
  86. package/dist/components/Avatar/index.d.ts +7 -0
  87. package/dist/components/Avatar/index.js +28 -0
  88. package/dist/components/Avatar/styles.d.ts +4 -0
  89. package/dist/components/Avatar/styles.js +37 -0
  90. package/dist/components/Avatar/utils/getAvatarColors.d.ts +6 -0
  91. package/dist/components/Avatar/utils/getAvatarColors.js +48 -0
  92. package/dist/components/Breadcrumb/Breadcrumb.stories.d.ts +17 -0
  93. package/dist/components/Breadcrumb/Breadcrumb.stories.js +51 -0
  94. package/dist/components/Breadcrumb/index.d.ts +10 -0
  95. package/dist/components/Breadcrumb/index.js +34 -0
  96. package/dist/components/Breadcrumb/styles.d.ts +9 -0
  97. package/dist/components/Breadcrumb/styles.js +43 -0
  98. package/dist/components/Button/Button.stories.d.ts +58 -0
  99. package/dist/components/Button/Button.stories.js +284 -0
  100. package/dist/components/Button/index.d.ts +26 -0
  101. package/dist/components/Button/index.js +69 -0
  102. package/dist/components/Button/modifiers.d.ts +8 -0
  103. package/dist/components/Button/modifiers.js +41 -0
  104. package/dist/components/Button/styles.d.ts +25 -0
  105. package/dist/components/Button/styles.js +111 -0
  106. package/dist/components/Checkbox/CheckMarkIcon.d.ts +3 -0
  107. package/dist/components/Checkbox/CheckMarkIcon.js +38 -0
  108. package/dist/components/Checkbox/Checkbox.stories.d.ts +35 -0
  109. package/dist/components/Checkbox/Checkbox.stories.js +101 -0
  110. package/dist/components/Checkbox/MinusMarkIcon.d.ts +3 -0
  111. package/dist/components/Checkbox/MinusMarkIcon.js +39 -0
  112. package/dist/components/Checkbox/index.d.ts +9 -0
  113. package/dist/components/Checkbox/index.js +40 -0
  114. package/dist/components/Checkbox/styles.d.ts +12 -0
  115. package/dist/components/Checkbox/styles.js +41 -0
  116. package/dist/components/Collapse/Colapse.stories.d.ts +10 -0
  117. package/dist/components/Collapse/Colapse.stories.js +108 -0
  118. package/dist/components/Collapse/index.d.ts +15 -0
  119. package/dist/components/Collapse/index.js +61 -0
  120. package/dist/components/Collapse/styles.d.ts +11 -0
  121. package/dist/components/Collapse/styles.js +23 -0
  122. package/dist/components/CustomSelect/CustomSelect.stories.d.ts +73 -0
  123. package/dist/components/CustomSelect/CustomSelect.stories.js +477 -0
  124. package/dist/components/CustomSelect/CustomSelectList/index.d.ts +10 -0
  125. package/dist/components/CustomSelect/CustomSelectList/index.js +66 -0
  126. package/dist/components/CustomSelect/CustomSelectList/style.d.ts +8 -0
  127. package/dist/components/CustomSelect/CustomSelectList/style.js +95 -0
  128. package/dist/components/CustomSelect/index.d.ts +30 -0
  129. package/dist/components/CustomSelect/index.js +193 -0
  130. package/dist/components/CustomSelect/styles.d.ts +22 -0
  131. package/dist/components/CustomSelect/styles.js +93 -0
  132. package/dist/components/DoubleList/DoubleList.stories.d.ts +13 -0
  133. package/dist/components/DoubleList/DoubleList.stories.js +82 -0
  134. package/dist/components/DoubleList/index.d.ts +9 -0
  135. package/dist/components/DoubleList/index.js +70 -0
  136. package/dist/components/DoubleList/style.d.ts +5 -0
  137. package/dist/components/DoubleList/style.js +92 -0
  138. package/dist/components/EmptyState/Empty.stories.d.ts +26 -0
  139. package/dist/components/EmptyState/Empty.stories.js +72 -0
  140. package/dist/components/EmptyState/index.d.ts +10 -0
  141. package/dist/components/EmptyState/index.js +48 -0
  142. package/dist/components/EmptyState/styles.d.ts +3 -0
  143. package/dist/components/EmptyState/styles.js +39 -0
  144. package/dist/components/Grid/Column/Column.stories.d.ts +26 -0
  145. package/dist/components/Grid/Column/Column.stories.js +335 -0
  146. package/dist/components/Grid/Column/index.d.ts +15 -0
  147. package/dist/components/Grid/Column/index.js +10 -0
  148. package/dist/components/Grid/Container/Container.stories.d.ts +11 -0
  149. package/dist/components/Grid/Container/Container.stories.js +114 -0
  150. package/dist/components/Grid/Container/index.d.ts +6 -0
  151. package/dist/components/Grid/Container/index.js +11 -0
  152. package/dist/components/Grid/Row/Row.stories.d.ts +22 -0
  153. package/dist/components/Grid/Row/Row.stories.js +248 -0
  154. package/dist/components/Grid/Row/index.d.ts +20 -0
  155. package/dist/components/Grid/Row/index.js +10 -0
  156. package/dist/components/Grid/index.d.ts +38 -0
  157. package/dist/components/Grid/index.js +121 -0
  158. package/dist/components/Grid/utils.d.ts +1 -0
  159. package/dist/components/Grid/utils.js +18 -0
  160. package/dist/components/Loading/Loading/index.d.ts +7 -0
  161. package/dist/components/Loading/Loading/index.js +9 -0
  162. package/dist/components/Loading/Loading.stories.d.ts +24 -0
  163. package/dist/components/Loading/Loading.stories.js +145 -0
  164. package/dist/components/Loading/index.d.ts +16 -0
  165. package/dist/components/Loading/index.js +98 -0
  166. package/dist/components/Menu/constants/icons.d.ts +17 -0
  167. package/dist/components/Menu/constants/icons.js +61 -0
  168. package/dist/components/Menu/helpers/createMenus.d.ts +2 -0
  169. package/dist/components/Menu/helpers/createMenus.js +20 -0
  170. package/dist/components/Menu/helpers/createSubMenus.d.ts +2 -0
  171. package/dist/components/Menu/helpers/createSubMenus.js +13 -0
  172. package/dist/components/Menu/helpers/generateColorScale.d.ts +1 -0
  173. package/dist/components/Menu/helpers/generateColorScale.js +62 -0
  174. package/dist/components/Menu/helpers/getLuminance.d.ts +1 -0
  175. package/dist/components/Menu/helpers/getLuminance.js +9 -0
  176. package/dist/components/Menu/index.d.ts +12 -0
  177. package/dist/components/Menu/index.js +108 -0
  178. package/dist/components/Menu/styles.d.ts +17 -0
  179. package/dist/components/Menu/styles.js +202 -0
  180. package/dist/components/Menu/types/IconKeysType.d.ts +2 -0
  181. package/dist/components/Menu/types/IconKeysType.js +0 -0
  182. package/dist/components/Menu/types/MenuItem.d.ts +26 -0
  183. package/dist/components/Menu/types/MenuItem.js +0 -0
  184. package/dist/components/MultiSelect/Badge/index.d.ts +6 -0
  185. package/dist/components/MultiSelect/Badge/index.js +31 -0
  186. package/dist/components/MultiSelect/Badge/styles.d.ts +1 -0
  187. package/dist/components/MultiSelect/Badge/styles.js +57 -0
  188. package/dist/components/MultiSelect/MultiSelect.stories.d.ts +61 -0
  189. package/dist/components/MultiSelect/MultiSelect.stories.js +336 -0
  190. package/dist/components/MultiSelect/MultiSelectList/index.d.ts +10 -0
  191. package/dist/components/MultiSelect/MultiSelectList/index.js +59 -0
  192. package/dist/components/MultiSelect/MultiSelectList/style.d.ts +3 -0
  193. package/dist/components/MultiSelect/MultiSelectList/style.js +82 -0
  194. package/dist/components/MultiSelect/calcTextSize.d.ts +1 -0
  195. package/dist/components/MultiSelect/calcTextSize.js +10 -0
  196. package/dist/components/MultiSelect/index.d.ts +24 -0
  197. package/dist/components/MultiSelect/index.js +284 -0
  198. package/dist/components/MultiSelect/styles.d.ts +24 -0
  199. package/dist/components/MultiSelect/styles.js +165 -0
  200. package/dist/components/Radio/Radio.stories.d.ts +18 -0
  201. package/dist/components/Radio/Radio.stories.js +30 -0
  202. package/dist/components/Radio/index.d.ts +7 -0
  203. package/dist/components/Radio/index.js +27 -0
  204. package/dist/components/Radio/story.d.ts +5 -0
  205. package/dist/components/Radio/story.js +47 -0
  206. package/dist/components/Radio/styles.d.ts +8 -0
  207. package/dist/components/Radio/styles.js +43 -0
  208. package/dist/components/StateAlert/StateAlert.stories.d.ts +46 -0
  209. package/dist/components/StateAlert/StateAlert.stories.js +189 -0
  210. package/dist/components/StateAlert/index.d.ts +22 -0
  211. package/dist/components/StateAlert/index.js +56 -0
  212. package/dist/components/StateAlert/styles.d.ts +7 -0
  213. package/dist/components/StateAlert/styles.js +124 -0
  214. package/dist/components/Switch/Switch.stories.d.ts +26 -0
  215. package/dist/components/Switch/Switch.stories.js +81 -0
  216. package/dist/components/Switch/index.d.ts +8 -0
  217. package/dist/components/Switch/index.js +26 -0
  218. package/dist/components/Switch/styles.d.ts +15 -0
  219. package/dist/components/Switch/styles.js +33 -0
  220. package/dist/components/Text/Paragraph/Paragraph.stories.d.ts +29 -0
  221. package/dist/components/Text/Paragraph/Paragraph.stories.js +124 -0
  222. package/dist/components/Text/Title/Title.stories.d.ts +41 -0
  223. package/dist/components/Text/Title/Title.stories.js +106 -0
  224. package/dist/components/Text/index.d.ts +3 -0
  225. package/dist/components/Text/index.js +17 -0
  226. package/dist/components/Text/styles.d.ts +23 -0
  227. package/dist/components/Text/styles.js +70 -0
  228. package/dist/components/TextArea/Textarea.stories.d.ts +33 -0
  229. package/dist/components/TextArea/Textarea.stories.js +65 -0
  230. package/dist/components/TextArea/index.d.ts +10 -0
  231. package/dist/components/TextArea/index.js +39 -0
  232. package/dist/components/TextArea/styles.d.ts +18 -0
  233. package/dist/components/TextArea/styles.js +88 -0
  234. package/dist/components/TooltipWrapper/Tooltip.stories.d.ts +21 -0
  235. package/dist/components/TooltipWrapper/Tooltip.stories.js +54 -0
  236. package/dist/components/TooltipWrapper/index.d.ts +20 -0
  237. package/dist/components/TooltipWrapper/index.js +56 -0
  238. package/dist/components/TooltipWrapper/styles.d.ts +6 -0
  239. package/dist/components/TooltipWrapper/styles.js +20 -0
  240. package/dist/components/Tooltips/Tooltips.stories.d.ts +25 -0
  241. package/dist/components/Tooltips/Tooltips.stories.js +139 -0
  242. package/dist/components/Tooltips/index.d.ts +8 -0
  243. package/dist/components/Tooltips/index.js +28 -0
  244. package/dist/components/Tooltips/styles.d.ts +5 -0
  245. package/dist/components/Tooltips/styles.js +37 -0
  246. package/dist/components/UserMenu/UserMenu.stories.d.ts +26 -0
  247. package/dist/components/UserMenu/UserMenu.stories.js +174 -0
  248. package/dist/components/UserMenu/index.d.ts +19 -0
  249. package/dist/components/UserMenu/index.js +64 -0
  250. package/dist/components/UserMenu/style.d.ts +2 -0
  251. package/dist/components/UserMenu/style.js +44 -0
  252. package/dist/index.d.ts +3 -0
  253. package/dist/index.js +3 -0
  254. package/dist/static/image/cover.png +0 -0
  255. package/dist/static/image/how-to-use.gif +0 -0
  256. package/dist/static/image/map-sample.png +0 -0
  257. package/dist/static/image/photo-goes-here.png +0 -0
  258. package/dist/static/image/travolta.jpg +0 -0
  259. package/dist/static/svg/Group.svg +5 -0
  260. package/dist/static/svg/chat.svg +10 -0
  261. package/dist/static/svg/colored-item.svg +9 -0
  262. package/dist/static/svg/mailbox-bro.svg +102 -0
  263. package/dist/static/svg/star-favorite.svg +3 -0
  264. package/dist/style/_reset.css +205 -0
  265. package/package.json +43 -0
@@ -0,0 +1,336 @@
1
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ import { useState } from "react";
3
+ import index from "./index.js";
4
+ const meta = {
5
+ title: "DESIGN COMPONENTS/MultiSelect",
6
+ component: index,
7
+ tags: [
8
+ "autodocs"
9
+ ],
10
+ parameters: {
11
+ layout: "centered"
12
+ },
13
+ decorators: [
14
+ (Story)=>/*#__PURE__*/ jsx("div", {
15
+ style: {
16
+ width: "402px",
17
+ height: "402px",
18
+ display: "flex"
19
+ },
20
+ children: /*#__PURE__*/ jsx(Story, {})
21
+ })
22
+ ],
23
+ argTypes: {
24
+ translation: {
25
+ description: "Recebe a fun\xe7\xe3o de tradu\xe7\xe3o do i18n"
26
+ },
27
+ placeholder: {
28
+ description: "Recebe o placeholder do input."
29
+ },
30
+ name: {
31
+ description: "Recebe a propriedade name para a label e para o input."
32
+ },
33
+ options: {
34
+ description: "Recebe as op\xe7\xf5es que ir\xe3o aparecer na listagem.",
35
+ table: {
36
+ type: {
37
+ summary: "IMultiSelectOption[] ({ value: string, label: string }[])"
38
+ }
39
+ }
40
+ },
41
+ onChangeItems: {
42
+ description: "Recebe uma fun\xe7\xe3o para controlar o estado de op\xe7\xf5es selecionadas quando elas mudarem."
43
+ },
44
+ optional: {
45
+ description: "Recebe um texto descrevendo que \xe9 opcional."
46
+ },
47
+ required: {
48
+ description: "Define se esse campo \xe9 obrigat\xf3rio."
49
+ },
50
+ selectAll: {
51
+ description: "Define se a op\xe7\xe3o de selecionar todos est\xe1 dispon\xedvel ou n\xe3o."
52
+ },
53
+ isLoading: {
54
+ description: "Coloca a lista em estado de loading."
55
+ },
56
+ isError: {
57
+ description: "Define se o campo est\xe1 preeenchido incorretamente."
58
+ },
59
+ isSuccess: {
60
+ description: "Define se o campo est\xe1 preeenchido corretamente."
61
+ },
62
+ maxItems: {
63
+ description: "Define um limite de sele\xe7\xf5es."
64
+ }
65
+ }
66
+ };
67
+ const MultiSelect_stories = meta;
68
+ const mockTranslate = (key)=>{
69
+ switch(key){
70
+ case "all_were_selected":
71
+ return "Todos foram Selecionados.";
72
+ case "remove_all":
73
+ return "Remover todos";
74
+ case "select_all":
75
+ return "Selecionar todos";
76
+ case "no_data_was_found":
77
+ return "Nenhum dado foi encontrado.";
78
+ case "the_selection_limit_has_been_reached":
79
+ return "O limite de sele\xe7\xf5es foi atingido.";
80
+ case "no_data_is_available":
81
+ return "Nenhum dado dispon\xedvel.";
82
+ default:
83
+ return key;
84
+ }
85
+ };
86
+ const mockOptions = [
87
+ {
88
+ value: "xs",
89
+ label: "Extra Pequeno"
90
+ },
91
+ {
92
+ value: "s",
93
+ label: "Pequeno"
94
+ },
95
+ {
96
+ value: "m",
97
+ label: "M\xe9dio"
98
+ },
99
+ {
100
+ value: "l",
101
+ label: "Grande"
102
+ },
103
+ {
104
+ value: "xl",
105
+ label: "Extra Grande"
106
+ },
107
+ {
108
+ value: "xxl",
109
+ label: "Extra Extra Grande"
110
+ },
111
+ {
112
+ value: "2xl",
113
+ label: "2X Grande"
114
+ },
115
+ {
116
+ value: "3xl",
117
+ label: "3X Grande"
118
+ },
119
+ {
120
+ value: "one-size",
121
+ label: "Tamanho \xdanico"
122
+ },
123
+ {
124
+ value: "custom",
125
+ label: "Tamanho Personalizado"
126
+ },
127
+ {
128
+ value: "not-applicable",
129
+ label: "N\xe3o Aplic\xe1vel"
130
+ }
131
+ ];
132
+ const mockManyOptions = [
133
+ {
134
+ value: "xxs",
135
+ label: "Extra Extra Pequeno"
136
+ },
137
+ ...mockOptions,
138
+ {
139
+ value: "padrao",
140
+ label: "Padr\xe3o"
141
+ }
142
+ ];
143
+ const Default = {
144
+ args: {
145
+ placeholder: "Selecione ...",
146
+ options: mockOptions,
147
+ translation: mockTranslate,
148
+ label: "Default"
149
+ }
150
+ };
151
+ const Label = {
152
+ args: {
153
+ placeholder: "Selecione ...",
154
+ options: mockOptions,
155
+ helpText: "",
156
+ label: "Label",
157
+ translation: mockTranslate
158
+ }
159
+ };
160
+ const SelectAll = {
161
+ args: {
162
+ placeholder: "Selecione ...",
163
+ options: mockOptions,
164
+ helpText: "",
165
+ label: "Label",
166
+ translation: mockTranslate,
167
+ selectAll: true
168
+ }
169
+ };
170
+ const MaxItems = {
171
+ args: {
172
+ placeholder: "Selecione ...",
173
+ options: mockOptions,
174
+ helpText: "",
175
+ label: "Label",
176
+ translation: mockTranslate,
177
+ maxItems: 5
178
+ }
179
+ };
180
+ const ManyOptions = {
181
+ args: {
182
+ placeholder: "Selecione ...",
183
+ options: mockManyOptions,
184
+ helpText: "",
185
+ label: "Label",
186
+ translation: mockTranslate
187
+ }
188
+ };
189
+ const Optional = {
190
+ args: {
191
+ placeholder: "Selecione ...",
192
+ options: mockOptions,
193
+ helpText: "",
194
+ label: "Opcional",
195
+ optional: "(opcional)",
196
+ translation: mockTranslate
197
+ }
198
+ };
199
+ const Required = {
200
+ args: {
201
+ placeholder: "Selecione ...",
202
+ options: mockOptions,
203
+ helpText: "",
204
+ label: "Obrigat\xf3rio",
205
+ translation: mockTranslate,
206
+ required: true
207
+ }
208
+ };
209
+ const HelpText = {
210
+ args: {
211
+ placeholder: "Selecione ...",
212
+ options: mockOptions,
213
+ helpText: "texto de ajuda",
214
+ label: "Texto de Ajuda",
215
+ translation: mockTranslate
216
+ }
217
+ };
218
+ const Loading = {
219
+ args: {
220
+ placeholder: "Selecione ...",
221
+ options: mockOptions,
222
+ helpText: "",
223
+ label: "Loading",
224
+ translation: mockTranslate,
225
+ isLoading: true
226
+ }
227
+ };
228
+ const Success = {
229
+ args: {
230
+ placeholder: "Selecione ...",
231
+ options: mockOptions,
232
+ helpText: "mensagem de sucesso",
233
+ label: "Sucesso",
234
+ translation: mockTranslate,
235
+ isSuccess: true
236
+ }
237
+ };
238
+ const Error = {
239
+ args: {
240
+ placeholder: "Selecione ...",
241
+ options: mockOptions,
242
+ helpText: "Mensagem de erro",
243
+ label: "Erro",
244
+ translation: mockTranslate,
245
+ optional: "",
246
+ isError: true
247
+ }
248
+ };
249
+ const Value = {
250
+ args: {
251
+ placeholder: "Selecione ...",
252
+ options: mockOptions,
253
+ helpText: "Alguns dados j\xe1 foram selecionados",
254
+ label: "Value",
255
+ translation: mockTranslate,
256
+ optional: "",
257
+ value: mockOptions.slice(0, 8)
258
+ }
259
+ };
260
+ const onChangeItems = {
261
+ render: ()=>{
262
+ const [selected, setSelected] = useState([]);
263
+ const handleChangeSeleceted = (options)=>{
264
+ setSelected(options);
265
+ };
266
+ return /*#__PURE__*/ jsxs("div", {
267
+ style: {
268
+ display: "flex",
269
+ flexDirection: "column",
270
+ width: "100%",
271
+ gap: "3rem"
272
+ },
273
+ children: [
274
+ /*#__PURE__*/ jsxs("div", {
275
+ children: [
276
+ /*#__PURE__*/ jsxs("h2", {
277
+ style: {
278
+ fontWeight: "500",
279
+ marginBottom: "1rem",
280
+ color: "#26333B"
281
+ },
282
+ children: [
283
+ "Selecionados:",
284
+ " "
285
+ ]
286
+ }),
287
+ /*#__PURE__*/ jsx("div", {
288
+ style: {
289
+ display: "flex",
290
+ gap: "0.5rem",
291
+ flexWrap: "wrap"
292
+ },
293
+ children: selected.length ? /*#__PURE__*/ jsxs(Fragment, {
294
+ children: [
295
+ " ",
296
+ selected.map((op)=>/*#__PURE__*/ jsx("span", {
297
+ style: {
298
+ padding: "0.25rem",
299
+ background: "#FF5656",
300
+ fontSize: "12px",
301
+ lineHeight: "12px",
302
+ borderRadius: "4px",
303
+ color: "#F5F5F5",
304
+ fontWeight: "600"
305
+ },
306
+ children: op.label
307
+ }, op.value))
308
+ ]
309
+ }) : /*#__PURE__*/ jsx("span", {
310
+ style: {
311
+ padding: "0.25rem",
312
+ background: "#FF5656",
313
+ fontSize: "12px",
314
+ lineHeight: "12px",
315
+ borderRadius: "4px",
316
+ color: "#F5F5F5",
317
+ fontWeight: "600"
318
+ },
319
+ children: "Nenhum Selecionado"
320
+ })
321
+ })
322
+ ]
323
+ }),
324
+ /*#__PURE__*/ jsx(index, {
325
+ options: mockOptions,
326
+ placeholder: "Selecione os tamanhos",
327
+ onChangeItems: handleChangeSeleceted,
328
+ translation: mockTranslate,
329
+ label: "Tamanho",
330
+ selectAll: true
331
+ })
332
+ ]
333
+ });
334
+ }
335
+ };
336
+ export { Default, Error, HelpText, Label, Loading, ManyOptions, MaxItems, Optional, Required, SelectAll, Success, Value, MultiSelect_stories as default, onChangeItems };
@@ -0,0 +1,10 @@
1
+ import { IMultiSelectOption } from "..";
2
+ interface MultiSelectProps {
3
+ onClickOption?: (event: React.MouseEvent<HTMLDivElement>, option: IMultiSelectOption) => void;
4
+ options: IMultiSelectOption[];
5
+ isLoading?: boolean;
6
+ addAll?: (event: React.MouseEvent<HTMLDivElement>) => void;
7
+ translation: (key: string) => string;
8
+ }
9
+ export default function MultiSelect({ options, onClickOption, isLoading, addAll, translation, }: MultiSelectProps): import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -0,0 +1,59 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { FixedSizeList } from "react-window";
3
+ import { LoadingContainer, OptionContainer, SelectDropdown } from "./style.js";
4
+ import Loading from "../../Loading/Loading/index.js";
5
+ const renderRow = ({ data, index, style, onClickOption, addAll })=>{
6
+ const option = data[index];
7
+ const hasSelectAll = "__select_all" === option.value;
8
+ const handleClick = (event)=>{
9
+ if (hasSelectAll) {
10
+ if (addAll) addAll(event);
11
+ return;
12
+ }
13
+ onClickOption?.(event, option);
14
+ };
15
+ return /*#__PURE__*/ jsx(OptionContainer, {
16
+ style: style,
17
+ onClick: handleClick,
18
+ className: hasSelectAll ? "__select_all" : "",
19
+ children: /*#__PURE__*/ jsx("span", {
20
+ children: option.label
21
+ })
22
+ });
23
+ };
24
+ function MultiSelect({ options, onClickOption, isLoading, addAll, translation }) {
25
+ const selectAll = {
26
+ value: "__select_all",
27
+ label: translation("select_all")
28
+ };
29
+ const newOptions = addAll ? [
30
+ selectAll,
31
+ ...options
32
+ ] : options;
33
+ const OPTION_SIZE = 36;
34
+ const optionLength = newOptions.length;
35
+ const height = OPTION_SIZE * (0 === optionLength ? 1 : optionLength >= 7 ? 7 : optionLength);
36
+ return /*#__PURE__*/ jsx(SelectDropdown, {
37
+ children: isLoading ? /*#__PURE__*/ jsx(LoadingContainer, {
38
+ children: /*#__PURE__*/ jsx(Loading, {
39
+ size: "lg",
40
+ variant: "light"
41
+ })
42
+ }) : /*#__PURE__*/ jsx(FixedSizeList, {
43
+ itemCount: newOptions.length,
44
+ itemData: newOptions,
45
+ itemSize: 36,
46
+ height: height,
47
+ width: "100%",
48
+ itemKey: (index)=>newOptions[index].value || index,
49
+ children: ({ index, style, data })=>renderRow({
50
+ data,
51
+ index,
52
+ style,
53
+ onClickOption,
54
+ addAll
55
+ })
56
+ })
57
+ });
58
+ }
59
+ export { MultiSelect as default };
@@ -0,0 +1,3 @@
1
+ export declare const SelectDropdown: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
2
+ export declare const OptionContainer: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
3
+ export declare const LoadingContainer: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
@@ -0,0 +1,82 @@
1
+ import styled_components from "styled-components";
2
+ import { COLOR_ACCENT_MEDIUM, COLOR_NEUTRAL_DARKER, COLOR_NEUTRAL_DAY, COLOR_NEUTRAL_DUSK, COLOR_NEUTRAL_LIGHTER, FONT_FAMILY_01, FONT_WEIGHT_BOLD, FONT_WEIGHT_MEDIUM } from "@ftdata/f-tokens";
3
+ const SelectDropdown = styled_components.div`
4
+ background-color: ${COLOR_NEUTRAL_DAY};
5
+ border-radius: 0.25rem;
6
+ box-shadow: 0px 2px 4px rgba(107, 117, 124, 0.32);
7
+ color: ${COLOR_NEUTRAL_DUSK};
8
+ position: absolute;
9
+ top: calc(100% + 0.5rem);
10
+ right: 0;
11
+ width: 100%;
12
+ height: auto;
13
+ z-index: 3;
14
+
15
+ & > div {
16
+ border-radius: 0.25rem;
17
+ }
18
+
19
+ *::-webkit-scrollbar-track {
20
+ background-color: #f4f4f4;
21
+ border-radius: 0 0.25rem 0.25rem 0;
22
+ }
23
+
24
+ *::-webkit-scrollbar {
25
+ width: 10px;
26
+ background: #f4f4f4;
27
+ border-radius: 0 0.25rem 0.25rem 0;
28
+ }
29
+
30
+ *::-webkit-scrollbar-thumb {
31
+ border-radius: 10px;
32
+ background: #d5d8da;
33
+ }
34
+
35
+ .__select_all {
36
+ span {
37
+ color: ${COLOR_ACCENT_MEDIUM};
38
+ font-weight: ${FONT_WEIGHT_BOLD};
39
+ }
40
+
41
+ &:hover {
42
+ span {
43
+ color: ${COLOR_ACCENT_MEDIUM};
44
+ }
45
+ }
46
+ }
47
+ `;
48
+ const OptionContainer = styled_components.div`
49
+ background-color: ${COLOR_NEUTRAL_DAY};
50
+ box-sizing: border-box;
51
+ cursor: pointer;
52
+ display: flex;
53
+ gap: 0.5rem;
54
+ padding: 0.5rem 1rem;
55
+ width: 100%;
56
+
57
+ &:hover {
58
+ background-color: ${COLOR_NEUTRAL_LIGHTER};
59
+
60
+ span {
61
+ color: ${COLOR_NEUTRAL_DUSK};
62
+ }
63
+ }
64
+
65
+ span {
66
+ max-width: 80%;
67
+ color: ${COLOR_NEUTRAL_DARKER};
68
+ font-size: 0.875rem;
69
+ line-height: 1.25rem;
70
+ font-family: ${FONT_FAMILY_01};
71
+ font-weight: ${FONT_WEIGHT_MEDIUM};
72
+ white-space: nowrap;
73
+ overflow: hidden;
74
+ text-overflow: ellipsis;
75
+ }
76
+ `;
77
+ const LoadingContainer = styled_components.div`
78
+ background-color: ${COLOR_NEUTRAL_DAY};
79
+ height: 10rem;
80
+ width: 100%;
81
+ `;
82
+ export { LoadingContainer, OptionContainer, SelectDropdown };
@@ -0,0 +1 @@
1
+ export default function calcTextSize(text: string, textStyle: string, unit: "px" | "rem"): number;
@@ -0,0 +1,10 @@
1
+ function calcTextSize(text, textStyle, unit) {
2
+ const canvas = document.createElement("canvas");
3
+ const ctx = canvas.getContext("2d");
4
+ if (!ctx) return 0;
5
+ ctx.font = textStyle;
6
+ const size = ctx.measureText(text).width;
7
+ if ("rem" === unit) return size / 16;
8
+ return size;
9
+ }
10
+ export { calcTextSize as default };
@@ -0,0 +1,24 @@
1
+ import { InputHTMLAttributes } from "react";
2
+ export interface IMultiSelectOption {
3
+ value: string;
4
+ label: string;
5
+ }
6
+ interface MultiSelectProps extends Omit<InputHTMLAttributes<HTMLInputElement>, "value"> {
7
+ helpText?: string;
8
+ label?: string;
9
+ name?: string;
10
+ onChangeItems?: (options: IMultiSelectOption[]) => void;
11
+ options: IMultiSelectOption[];
12
+ optional?: string;
13
+ required?: boolean;
14
+ selectAll?: boolean;
15
+ placeholder: string;
16
+ isLoading?: boolean;
17
+ isError?: boolean;
18
+ isSuccess?: boolean;
19
+ maxItems?: number;
20
+ translation: (key: string) => string;
21
+ value?: IMultiSelectOption[];
22
+ }
23
+ export default function MultiSelect({ helpText, label, isLoading, name, onChangeItems, optional, options, required, maxItems, placeholder, selectAll, isError, value, isSuccess, translation, ...rest }: MultiSelectProps): import("react/jsx-runtime").JSX.Element;
24
+ export {};