@tecsinapse/react-web-kit 1.3.2 → 1.6.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 (337) hide show
  1. package/CHANGELOG.md +98 -0
  2. package/dist/components/atoms/Accordion/Accordion.d.ts +9 -0
  3. package/dist/components/atoms/Accordion/Accordion.js +85 -0
  4. package/dist/components/atoms/Accordion/Accordion.js.map +1 -0
  5. package/dist/components/atoms/Accordion/animations.d.ts +41 -0
  6. package/dist/components/atoms/Accordion/animations.js +65 -0
  7. package/dist/components/atoms/Accordion/animations.js.map +1 -0
  8. package/dist/components/atoms/Accordion/index.d.ts +1 -0
  9. package/dist/components/atoms/Accordion/index.js +24 -0
  10. package/dist/components/atoms/Accordion/index.js.map +1 -0
  11. package/dist/components/atoms/Accordion/styled.d.ts +8 -0
  12. package/dist/components/atoms/Accordion/styled.js +53 -0
  13. package/dist/components/atoms/Accordion/styled.js.map +1 -0
  14. package/dist/components/atoms/Badge/index.js +2 -2
  15. package/dist/components/atoms/Button/index.js +2 -2
  16. package/dist/components/atoms/Button/styled.js +14 -5
  17. package/dist/components/atoms/Button/styled.js.map +1 -1
  18. package/dist/components/atoms/Input/index.js +2 -2
  19. package/dist/components/atoms/Modal/Modal.d.ts +8 -0
  20. package/dist/components/atoms/Modal/Modal.js +43 -0
  21. package/dist/components/atoms/Modal/Modal.js.map +1 -0
  22. package/dist/components/atoms/Modal/animations.d.ts +23 -0
  23. package/dist/components/atoms/Modal/animations.js +32 -0
  24. package/dist/components/atoms/Modal/animations.js.map +1 -0
  25. package/dist/components/atoms/Modal/index.d.ts +1 -0
  26. package/dist/components/atoms/Modal/index.js +24 -0
  27. package/dist/components/atoms/Modal/index.js.map +1 -0
  28. package/dist/components/atoms/Modal/styled.d.ts +2 -0
  29. package/dist/components/atoms/Modal/styled.js +39 -0
  30. package/dist/components/atoms/Modal/styled.js.map +1 -0
  31. package/dist/components/atoms/Overlay/Overlay.d.ts +10 -0
  32. package/dist/components/atoms/Overlay/Overlay.js +40 -0
  33. package/dist/components/atoms/Overlay/Overlay.js.map +1 -0
  34. package/dist/components/atoms/Overlay/animations.d.ts +18 -0
  35. package/dist/components/atoms/Overlay/animations.js +27 -0
  36. package/dist/components/atoms/Overlay/animations.js.map +1 -0
  37. package/dist/components/atoms/Overlay/index.d.ts +1 -0
  38. package/dist/components/atoms/Overlay/index.js +16 -0
  39. package/dist/components/atoms/Overlay/index.js.map +1 -0
  40. package/dist/components/atoms/Overlay/styled.d.ts +2 -0
  41. package/dist/components/atoms/Overlay/styled.js +36 -0
  42. package/dist/components/atoms/Overlay/styled.js.map +1 -0
  43. package/dist/components/atoms/Skeleton/Skeleton.d.ts +10 -0
  44. package/dist/components/atoms/Skeleton/Skeleton.js +35 -0
  45. package/dist/components/atoms/Skeleton/Skeleton.js.map +1 -0
  46. package/dist/components/atoms/Skeleton/index.d.ts +1 -0
  47. package/dist/components/atoms/Skeleton/index.js +24 -0
  48. package/dist/components/atoms/Skeleton/index.js.map +1 -0
  49. package/dist/components/atoms/Skeleton/styled.d.ts +5 -0
  50. package/dist/components/atoms/Skeleton/styled.js +79 -0
  51. package/dist/components/atoms/Skeleton/styled.js.map +1 -0
  52. package/dist/components/atoms/Table/Body/TBody.d.ts +3 -0
  53. package/dist/components/atoms/Table/Body/TBody.js +22 -0
  54. package/dist/components/atoms/Table/Body/TBody.js.map +1 -0
  55. package/dist/components/atoms/Table/Body/index.d.ts +1 -0
  56. package/dist/components/atoms/Table/Body/index.js +16 -0
  57. package/dist/components/atoms/Table/Body/index.js.map +1 -0
  58. package/dist/components/atoms/Table/Cell/Td.d.ts +3 -0
  59. package/dist/components/atoms/Table/Cell/Td.js +23 -0
  60. package/dist/components/atoms/Table/Cell/Td.js.map +1 -0
  61. package/dist/components/atoms/Table/Cell/index.d.ts +1 -0
  62. package/dist/components/atoms/Table/Cell/index.js +16 -0
  63. package/dist/components/atoms/Table/Cell/index.js.map +1 -0
  64. package/dist/components/atoms/Table/Cell/styled.d.ts +2 -0
  65. package/dist/components/atoms/Table/Cell/styled.js +34 -0
  66. package/dist/components/atoms/Table/Cell/styled.js.map +1 -0
  67. package/dist/components/atoms/Table/Container/TableContainer.d.ts +3 -0
  68. package/dist/components/atoms/Table/Container/TableContainer.js +23 -0
  69. package/dist/components/atoms/Table/Container/TableContainer.js.map +1 -0
  70. package/dist/components/atoms/Table/Container/index.d.ts +1 -0
  71. package/dist/components/atoms/Table/Container/index.js +16 -0
  72. package/dist/components/atoms/Table/Container/index.js.map +1 -0
  73. package/dist/components/atoms/Table/Container/styled.d.ts +2 -0
  74. package/dist/components/atoms/Table/Container/styled.js +30 -0
  75. package/dist/components/atoms/Table/Container/styled.js.map +1 -0
  76. package/dist/components/atoms/Table/Footer/TFoot.d.ts +3 -0
  77. package/dist/components/atoms/Table/Footer/TFoot.js +24 -0
  78. package/dist/components/atoms/Table/Footer/TFoot.js.map +1 -0
  79. package/dist/components/atoms/Table/Footer/index.d.ts +1 -0
  80. package/dist/components/atoms/Table/Footer/index.js +16 -0
  81. package/dist/components/atoms/Table/Footer/index.js.map +1 -0
  82. package/dist/components/atoms/Table/Footer/styled.d.ts +5 -0
  83. package/dist/components/atoms/Table/Footer/styled.js +19 -0
  84. package/dist/components/atoms/Table/Footer/styled.js.map +1 -0
  85. package/dist/components/atoms/Table/Header/THead.d.ts +3 -0
  86. package/dist/components/atoms/Table/Header/THead.js +27 -0
  87. package/dist/components/atoms/Table/Header/THead.js.map +1 -0
  88. package/dist/components/atoms/Table/Header/Th.d.ts +3 -0
  89. package/dist/components/atoms/Table/Header/Th.js +24 -0
  90. package/dist/components/atoms/Table/Header/Th.js.map +1 -0
  91. package/dist/components/atoms/Table/Header/index.d.ts +2 -0
  92. package/dist/components/atoms/Table/Header/index.js +24 -0
  93. package/dist/components/atoms/Table/Header/index.js.map +1 -0
  94. package/dist/components/atoms/Table/Header/styled.d.ts +4 -0
  95. package/dist/components/atoms/Table/Header/styled.js +54 -0
  96. package/dist/components/atoms/Table/Header/styled.js.map +1 -0
  97. package/dist/components/atoms/Table/Row/Tr.d.ts +3 -0
  98. package/dist/components/atoms/Table/Row/Tr.js +24 -0
  99. package/dist/components/atoms/Table/Row/Tr.js.map +1 -0
  100. package/dist/components/atoms/Table/Row/index.d.ts +1 -0
  101. package/dist/components/atoms/Table/Row/index.js +16 -0
  102. package/dist/components/atoms/Table/Row/index.js.map +1 -0
  103. package/dist/components/atoms/Table/Row/styled.d.ts +2 -0
  104. package/dist/components/atoms/Table/Row/styled.js +24 -0
  105. package/dist/components/atoms/Table/Row/styled.js.map +1 -0
  106. package/dist/components/atoms/Table/Table.d.ts +3 -0
  107. package/dist/components/atoms/Table/Table.js +24 -0
  108. package/dist/components/atoms/Table/Table.js.map +1 -0
  109. package/dist/components/atoms/Table/Toolbar/TableToolbar.d.ts +8 -0
  110. package/dist/components/atoms/Table/Toolbar/TableToolbar.js +30 -0
  111. package/dist/components/atoms/Table/Toolbar/TableToolbar.js.map +1 -0
  112. package/dist/components/atoms/Table/Toolbar/index.d.ts +1 -0
  113. package/dist/components/atoms/Table/Toolbar/index.js +24 -0
  114. package/dist/components/atoms/Table/Toolbar/index.js.map +1 -0
  115. package/dist/components/atoms/Table/Toolbar/styled.d.ts +5 -0
  116. package/dist/components/atoms/Table/Toolbar/styled.js +19 -0
  117. package/dist/components/atoms/Table/Toolbar/styled.js.map +1 -0
  118. package/dist/components/atoms/Table/index.d.ts +8 -0
  119. package/dist/components/atoms/Table/index.js +84 -0
  120. package/dist/components/atoms/Table/index.js.map +1 -0
  121. package/dist/components/atoms/Table/styled.d.ts +2 -0
  122. package/dist/components/atoms/Table/styled.js +20 -0
  123. package/dist/components/atoms/Table/styled.js.map +1 -0
  124. package/dist/components/atoms/Tag/index.js +2 -2
  125. package/dist/components/molecules/Breadcrumbs/BreadcrumbItem/index.js +2 -2
  126. package/dist/components/molecules/Breadcrumbs/index.js +2 -2
  127. package/dist/components/molecules/Drawer/Drawer.js +33 -3
  128. package/dist/components/molecules/Drawer/Drawer.js.map +1 -1
  129. package/dist/components/molecules/Drawer/animations.d.ts +42 -0
  130. package/dist/components/molecules/Drawer/animations.js +77 -0
  131. package/dist/components/molecules/Drawer/animations.js.map +1 -0
  132. package/dist/components/molecules/Drawer/index.js +2 -2
  133. package/dist/components/molecules/Drawer/styled.d.ts +0 -1
  134. package/dist/components/molecules/Drawer/styled.js +4 -19
  135. package/dist/components/molecules/Drawer/styled.js.map +1 -1
  136. package/dist/components/molecules/InputPassword/InputPassword.js +2 -2
  137. package/dist/components/molecules/InputPassword/index.js +2 -2
  138. package/dist/components/molecules/Menubar/MenuBlock/MenuBlock.d.ts +4 -3
  139. package/dist/components/molecules/Menubar/MenuBlock/MenuBlock.js +14 -5
  140. package/dist/components/molecules/Menubar/MenuBlock/MenuBlock.js.map +1 -1
  141. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.d.ts +1 -0
  142. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.js +6 -3
  143. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.js.map +1 -1
  144. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.d.ts +1 -0
  145. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.js +4 -2
  146. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.js.map +1 -1
  147. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/styled.js +3 -0
  148. package/dist/components/molecules/Menubar/MenuBlock/MenuItem/styled.js.map +1 -1
  149. package/dist/components/molecules/Menubar/Menubar.d.ts +3 -2
  150. package/dist/components/molecules/Menubar/Menubar.js +33 -21
  151. package/dist/components/molecules/Menubar/Menubar.js.map +1 -1
  152. package/dist/components/molecules/Menubar/MostUsed/MostUsed.d.ts +3 -2
  153. package/dist/components/molecules/Menubar/MostUsed/MostUsed.js +6 -3
  154. package/dist/components/molecules/Menubar/MostUsed/MostUsed.js.map +1 -1
  155. package/dist/components/molecules/Menubar/animations.d.ts +4 -0
  156. package/dist/components/molecules/Menubar/animations.js +63 -0
  157. package/dist/components/molecules/Menubar/animations.js.map +1 -0
  158. package/dist/components/molecules/Menubar/index.js +2 -2
  159. package/dist/components/molecules/Menubar/styled.js +14 -1
  160. package/dist/components/molecules/Menubar/styled.js.map +1 -1
  161. package/dist/components/molecules/Menubar/types.js +4 -0
  162. package/dist/components/molecules/Select/Dropdown/Dropdown.d.ts +7 -0
  163. package/dist/components/molecules/Select/Dropdown/Dropdown.js +90 -0
  164. package/dist/components/molecules/Select/Dropdown/Dropdown.js.map +1 -0
  165. package/dist/components/molecules/Select/Dropdown/index.d.ts +1 -0
  166. package/dist/components/molecules/Select/Dropdown/index.js +16 -0
  167. package/dist/components/molecules/Select/Dropdown/index.js.map +1 -0
  168. package/dist/components/molecules/Select/Dropdown/styled.d.ts +13 -0
  169. package/dist/components/molecules/Select/Dropdown/styled.js +113 -0
  170. package/dist/components/molecules/Select/Dropdown/styled.js.map +1 -0
  171. package/dist/components/molecules/Select/Select.d.ts +15 -0
  172. package/dist/components/molecules/Select/Select.js +85 -0
  173. package/dist/components/molecules/Select/Select.js.map +1 -0
  174. package/dist/components/molecules/Select/SelectItem/SelectItem.d.ts +16 -0
  175. package/dist/components/molecules/Select/SelectItem/SelectItem.js +76 -0
  176. package/dist/components/molecules/Select/SelectItem/SelectItem.js.map +1 -0
  177. package/dist/components/molecules/Select/SelectItem/index.d.ts +1 -0
  178. package/dist/components/molecules/Select/SelectItem/index.js +16 -0
  179. package/dist/components/molecules/Select/SelectItem/index.js.map +1 -0
  180. package/dist/components/molecules/Select/SelectItem/styled.d.ts +4 -0
  181. package/dist/components/molecules/Select/SelectItem/styled.js +54 -0
  182. package/dist/components/molecules/Select/SelectItem/styled.js.map +1 -0
  183. package/dist/components/molecules/Select/animations.d.ts +27 -0
  184. package/dist/components/molecules/Select/animations.js +36 -0
  185. package/dist/components/molecules/Select/animations.js.map +1 -0
  186. package/dist/components/molecules/Select/functions.d.ts +1 -0
  187. package/dist/components/molecules/Select/functions.js +21 -0
  188. package/dist/components/molecules/Select/functions.js.map +1 -0
  189. package/dist/components/molecules/Select/index.d.ts +1 -0
  190. package/dist/components/molecules/Select/index.js +24 -0
  191. package/dist/components/molecules/Select/index.js.map +1 -0
  192. package/dist/components/molecules/Select/styled.d.ts +3 -0
  193. package/dist/components/molecules/Select/styled.js +28 -0
  194. package/dist/components/molecules/Select/styled.js.map +1 -0
  195. package/dist/components/molecules/Snackbar/index.js +2 -2
  196. package/dist/components/molecules/Snackbar/styled.js +2 -2
  197. package/dist/components/organisms/DataGrid/DataGrid.d.ts +28 -0
  198. package/dist/components/organisms/DataGrid/DataGrid.js +121 -0
  199. package/dist/components/organisms/DataGrid/DataGrid.js.map +1 -0
  200. package/dist/components/organisms/DataGrid/Footer/Footer.d.ts +15 -0
  201. package/dist/components/organisms/DataGrid/Footer/Footer.js +107 -0
  202. package/dist/components/organisms/DataGrid/Footer/Footer.js.map +1 -0
  203. package/dist/components/organisms/DataGrid/Footer/index.d.ts +1 -0
  204. package/dist/components/organisms/DataGrid/Footer/index.js +16 -0
  205. package/dist/components/organisms/DataGrid/Footer/index.js.map +1 -0
  206. package/dist/components/organisms/DataGrid/Footer/styled.d.ts +35 -0
  207. package/dist/components/organisms/DataGrid/Footer/styled.js +91 -0
  208. package/dist/components/organisms/DataGrid/Footer/styled.js.map +1 -0
  209. package/dist/components/organisms/DataGrid/Header/Header.d.ts +12 -0
  210. package/dist/components/organisms/DataGrid/Header/Header.js +88 -0
  211. package/dist/components/organisms/DataGrid/Header/Header.js.map +1 -0
  212. package/dist/components/organisms/DataGrid/Header/index.d.ts +1 -0
  213. package/dist/components/organisms/DataGrid/Header/index.js +16 -0
  214. package/dist/components/organisms/DataGrid/Header/index.js.map +1 -0
  215. package/dist/components/organisms/DataGrid/Header/styled.d.ts +1 -0
  216. package/dist/components/organisms/DataGrid/Header/styled.js +23 -0
  217. package/dist/components/organisms/DataGrid/Header/styled.js.map +1 -0
  218. package/dist/components/organisms/DataGrid/Header/utils.d.ts +10 -0
  219. package/dist/components/organisms/DataGrid/Header/utils.js +30 -0
  220. package/dist/components/organisms/DataGrid/Header/utils.js.map +1 -0
  221. package/dist/components/organisms/DataGrid/Row/Row.d.ts +10 -0
  222. package/dist/components/organisms/DataGrid/Row/Row.js +42 -0
  223. package/dist/components/organisms/DataGrid/Row/Row.js.map +1 -0
  224. package/dist/components/organisms/DataGrid/Row/index.d.ts +1 -0
  225. package/dist/components/organisms/DataGrid/Row/index.js +16 -0
  226. package/dist/components/organisms/DataGrid/Row/index.js.map +1 -0
  227. package/dist/components/organisms/DataGrid/index.d.ts +2 -0
  228. package/dist/components/organisms/DataGrid/index.js +42 -0
  229. package/dist/components/organisms/DataGrid/index.js.map +1 -0
  230. package/dist/components/organisms/DataGrid/styled.d.ts +1 -0
  231. package/dist/components/organisms/DataGrid/styled.js +23 -0
  232. package/dist/components/organisms/DataGrid/styled.js.map +1 -0
  233. package/dist/components/organisms/DataGrid/types.d.ts +7 -0
  234. package/dist/components/organisms/DataGrid/types.js +6 -0
  235. package/dist/components/organisms/DataGrid/types.js.map +1 -0
  236. package/dist/components/organisms/DataGrid/utils.d.ts +2 -0
  237. package/dist/components/organisms/DataGrid/utils.js +18 -0
  238. package/dist/components/organisms/DataGrid/utils.js.map +1 -0
  239. package/dist/hooks/index.d.ts +1 -0
  240. package/dist/hooks/index.js +14 -0
  241. package/dist/hooks/index.js.map +1 -0
  242. package/dist/hooks/useClickAwayListener.d.ts +2 -0
  243. package/dist/hooks/useClickAwayListener.js +28 -0
  244. package/dist/hooks/useClickAwayListener.js.map +1 -0
  245. package/dist/index.d.ts +6 -0
  246. package/dist/index.js +104 -3
  247. package/dist/index.js.map +1 -1
  248. package/package.json +7 -6
  249. package/src/components/atoms/Accordion/Accordion.stories.tsx +35 -0
  250. package/src/components/atoms/Accordion/Accordion.tsx +99 -0
  251. package/src/components/atoms/Accordion/animations.ts +51 -0
  252. package/src/components/atoms/Accordion/index.ts +1 -0
  253. package/src/components/atoms/Accordion/styled.ts +35 -0
  254. package/src/components/atoms/Button/styled.ts +11 -1
  255. package/src/components/atoms/Modal/Modal.stories.tsx +55 -0
  256. package/src/components/atoms/Modal/Modal.tsx +34 -0
  257. package/src/components/atoms/Modal/animations.ts +12 -0
  258. package/src/components/atoms/Modal/index.ts +1 -0
  259. package/src/components/atoms/Modal/styled.ts +17 -0
  260. package/src/components/atoms/Overlay/Overlay.tsx +40 -0
  261. package/src/components/atoms/Overlay/animations.ts +11 -0
  262. package/src/components/atoms/Overlay/index.ts +1 -0
  263. package/src/components/atoms/Overlay/styled.ts +20 -0
  264. package/src/components/atoms/Skeleton/Skeleton.stories.tsx +15 -0
  265. package/src/components/atoms/Skeleton/Skeleton.tsx +37 -0
  266. package/src/components/atoms/Skeleton/index.ts +1 -0
  267. package/src/components/atoms/Skeleton/styled.ts +68 -0
  268. package/src/components/atoms/Table/Body/TBody.tsx +10 -0
  269. package/src/components/atoms/Table/Body/index.ts +1 -0
  270. package/src/components/atoms/Table/Cell/Td.tsx +11 -0
  271. package/src/components/atoms/Table/Cell/index.ts +1 -0
  272. package/src/components/atoms/Table/Cell/styled.ts +12 -0
  273. package/src/components/atoms/Table/Container/TableContainer.tsx +11 -0
  274. package/src/components/atoms/Table/Container/index.ts +1 -0
  275. package/src/components/atoms/Table/Container/styled.ts +10 -0
  276. package/src/components/atoms/Table/Footer/TFoot.tsx +11 -0
  277. package/src/components/atoms/Table/Footer/index.ts +1 -0
  278. package/src/components/atoms/Table/Footer/styled.ts +8 -0
  279. package/src/components/atoms/Table/Header/THead.tsx +21 -0
  280. package/src/components/atoms/Table/Header/Th.tsx +10 -0
  281. package/src/components/atoms/Table/Header/index.ts +2 -0
  282. package/src/components/atoms/Table/Header/styled.ts +30 -0
  283. package/src/components/atoms/Table/Row/Tr.tsx +11 -0
  284. package/src/components/atoms/Table/Row/index.ts +1 -0
  285. package/src/components/atoms/Table/Row/styled.ts +8 -0
  286. package/src/components/atoms/Table/Table.stories.tsx +96 -0
  287. package/src/components/atoms/Table/Table.tsx +11 -0
  288. package/src/components/atoms/Table/Toolbar/TableToolbar.tsx +31 -0
  289. package/src/components/atoms/Table/Toolbar/index.ts +1 -0
  290. package/src/components/atoms/Table/Toolbar/styled.ts +8 -0
  291. package/src/components/atoms/Table/index.ts +8 -0
  292. package/src/components/atoms/Table/styled.ts +9 -0
  293. package/src/components/molecules/Drawer/Drawer.stories.tsx +19 -21
  294. package/src/components/molecules/Drawer/Drawer.tsx +34 -6
  295. package/src/components/molecules/Drawer/animations.ts +50 -0
  296. package/src/components/molecules/Drawer/styled.ts +3 -12
  297. package/src/components/molecules/InputPassword/InputPassword.stories.tsx +1 -1
  298. package/src/components/molecules/Menubar/MenuBlock/MenuBlock.tsx +38 -31
  299. package/src/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.tsx +4 -2
  300. package/src/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.tsx +3 -2
  301. package/src/components/molecules/Menubar/MenuBlock/MenuItem/styled.ts +3 -0
  302. package/src/components/molecules/Menubar/Menubar.stories.tsx +20 -13
  303. package/src/components/molecules/Menubar/Menubar.tsx +65 -51
  304. package/src/components/molecules/Menubar/MostUsed/MostUsed.tsx +4 -2
  305. package/src/components/molecules/Menubar/animations.ts +64 -0
  306. package/src/components/molecules/Menubar/styled.ts +8 -1
  307. package/src/components/molecules/Select/Dropdown/Dropdown.tsx +106 -0
  308. package/src/components/molecules/Select/Dropdown/index.ts +1 -0
  309. package/src/components/molecules/Select/Dropdown/styled.ts +77 -0
  310. package/src/components/molecules/Select/Select.stories.tsx +108 -0
  311. package/src/components/molecules/Select/Select.tsx +92 -0
  312. package/src/components/molecules/Select/SelectItem/SelectItem.tsx +88 -0
  313. package/src/components/molecules/Select/SelectItem/index.ts +1 -0
  314. package/src/components/molecules/Select/SelectItem/styled.ts +34 -0
  315. package/src/components/molecules/Select/animations.ts +18 -0
  316. package/src/components/molecules/Select/functions.ts +32 -0
  317. package/src/components/molecules/Select/index.ts +1 -0
  318. package/src/components/molecules/Select/styled.ts +16 -0
  319. package/src/components/molecules/Snackbar/Snackbar.stories.tsx +24 -0
  320. package/src/components/organisms/DataGrid/DatGrid.stories.tsx +216 -0
  321. package/src/components/organisms/DataGrid/DataGrid.tsx +183 -0
  322. package/src/components/organisms/DataGrid/Footer/Footer.tsx +137 -0
  323. package/src/components/organisms/DataGrid/Footer/index.ts +1 -0
  324. package/src/components/organisms/DataGrid/Footer/styled.ts +59 -0
  325. package/src/components/organisms/DataGrid/Header/Header.tsx +111 -0
  326. package/src/components/organisms/DataGrid/Header/index.ts +1 -0
  327. package/src/components/organisms/DataGrid/Header/styled.ts +10 -0
  328. package/src/components/organisms/DataGrid/Header/utils.ts +28 -0
  329. package/src/components/organisms/DataGrid/Row/Row.tsx +33 -0
  330. package/src/components/organisms/DataGrid/Row/index.ts +1 -0
  331. package/src/components/organisms/DataGrid/index.ts +2 -0
  332. package/src/components/organisms/DataGrid/styled.ts +10 -0
  333. package/src/components/organisms/DataGrid/types.ts +11 -0
  334. package/src/components/organisms/DataGrid/utils.ts +15 -0
  335. package/src/hooks/index.ts +1 -0
  336. package/src/hooks/useClickAwayListener.ts +18 -0
  337. package/src/index.ts +10 -0
@@ -6,9 +6,10 @@ import { MostUsedType } from '../types';
6
6
  interface MostUsedProps {
7
7
  data: MostUsedType[];
8
8
  label: string;
9
+ toggle: () => void;
9
10
  }
10
11
 
11
- const MostUsed: React.FC<MostUsedProps> = ({ data, label }) => {
12
+ const MostUsed: React.FC<MostUsedProps> = ({ data, label, toggle }) => {
12
13
  const noTextDecoration = { textDecoration: 'none' };
13
14
 
14
15
  return (
@@ -28,6 +29,7 @@ const MostUsed: React.FC<MostUsedProps> = ({ data, label }) => {
28
29
  {...props}
29
30
  style={noTextDecoration}
30
31
  key={`${title}-${category}`}
32
+ onClick={toggle}
31
33
  >
32
34
  <StyledCard elevated key={`${title}-${category}`}>
33
35
  <Text fontWeight="bold" colorVariant="primary">
@@ -49,4 +51,4 @@ const MostUsed: React.FC<MostUsedProps> = ({ data, label }) => {
49
51
  );
50
52
  };
51
53
 
52
- export default MostUsed;
54
+ export default React.memo(MostUsed);
@@ -0,0 +1,64 @@
1
+ import { CSSProperties } from 'react';
2
+ import { TransitionStatus } from 'react-transition-group';
3
+
4
+ const getDefaultInputContainerStyles = {
5
+ transitionDuration: '250ms',
6
+ transitionProperty: 'opacity scale transform',
7
+ transitionTimingFunction: 'ease-in-out',
8
+ };
9
+
10
+ const getDefaultContainerOpenMenuStyles = {
11
+ transitionDuration: '250ms',
12
+ transitionProperty: 'opacity scale transform',
13
+ transitionTimingFunction: 'ease-in-out',
14
+ };
15
+
16
+ const getInputContainerTransform = {
17
+ entered: {
18
+ transform: 'scale(1, 1) translateY(0px)',
19
+ },
20
+ entering: {
21
+ opacity: 0.5,
22
+ transform: 'scale(0.99, 0.99) translateY(-5px)',
23
+ },
24
+ exited: {
25
+ opacity: 0,
26
+ transform: 'scale(0.99, 0.99) translateY(-50px)',
27
+ },
28
+ exiting: {
29
+ opacity: 0.5,
30
+ transform: 'scale(0.99, 0.99) translateY(-5px)',
31
+ },
32
+ };
33
+
34
+ const getContainerOpenMenuTransform = {
35
+ entered: {
36
+ transform: 'scale(1, 1) translateY(0px) ',
37
+ },
38
+ entering: {
39
+ opacity: 0.95,
40
+ transform: 'scale(0.99, 0.99) translateY(0px)',
41
+ },
42
+ exited: {
43
+ opacity: 0,
44
+ transform: 'scale(0.99, 0.99) translateY(-600px)',
45
+ },
46
+ exiting: {
47
+ opacity: 0.95,
48
+ transform: 'scale(0.99, 0.99) translateY(0px)',
49
+ },
50
+ };
51
+
52
+ export const getInputContainerStyles = (
53
+ state: TransitionStatus
54
+ ): CSSProperties => ({
55
+ ...getDefaultInputContainerStyles,
56
+ ...getInputContainerTransform[state],
57
+ });
58
+
59
+ export const getContainerOpenMenuStyles = (
60
+ state: TransitionStatus
61
+ ): CSSProperties => ({
62
+ ...getDefaultContainerOpenMenuStyles,
63
+ ...getContainerOpenMenuTransform[state],
64
+ });
@@ -12,6 +12,8 @@ export const StyledIconInput = webStyled('div')<Partial<StyleProps>>`
12
12
  `;
13
13
 
14
14
  export const StyledMenuBar = webStyled('div')<Partial<StyleProps>>`
15
+ position: relative;
16
+ z-index: ${({ theme }) => theme.zIndex.absolute};
15
17
  background-color: ${({ theme }) => theme.miscellaneous.surfaceColor};
16
18
  display: flex;
17
19
  flex-direction: row;
@@ -27,6 +29,9 @@ export const StyledMenuButton = nativeStyled(Button)<Partial<StyleProps>>`
27
29
  padding-bottom: calc(${({ theme }) => theme.spacing.centi} + 2px);
28
30
  padding-left: calc(${({ theme }) => theme.spacing.centi} + 2px);
29
31
  margin-right: ${({ theme }) => theme.spacing.kilo};
32
+ & * {
33
+ user-select: none;
34
+ }
30
35
  `;
31
36
 
32
37
  export const StyledContainerOpenMenu = webStyled('div')<Partial<StyleProps>>`
@@ -35,7 +40,9 @@ export const StyledContainerOpenMenu = webStyled('div')<Partial<StyleProps>>`
35
40
  theme.miscellaneous.shadow,
36
41
  0.08
37
42
  )}`};
38
- background-color: ${({ theme }) => theme.miscellaneous.surfaceColor};
43
+ background-color: ${({ theme }) => theme.miscellaneous.surfaceColor};
44
+ border-bottom-left-radius: ${({ theme }) => theme.borderRadius.mili};
45
+ border-bottom-right-radius: ${({ theme }) => theme.borderRadius.mili};
39
46
  box-shadow: 0px 2px 8px ${({ theme }) =>
40
47
  hex2rgba(theme.miscellaneous.shadow, 0.08)};
41
48
  padding-right: 8vw;
@@ -0,0 +1,106 @@
1
+ import React, { CSSProperties } from 'react';
2
+ import {
3
+ Checkbox,
4
+ Text,
5
+ Icon,
6
+ useDebouncedState,
7
+ } from '@tecsinapse/react-core';
8
+ import { Input } from '../../../atoms/Input';
9
+ import { ItemSelect } from '../SelectItem';
10
+ import { SelectProps } from '../Select';
11
+ import {
12
+ SearchBarContainer,
13
+ StyledContainerCheckAll,
14
+ StyledContainerDropdown,
15
+ StyledContainerTextLabel,
16
+ StyledSpan,
17
+ StyledTest,
18
+ } from './styled';
19
+
20
+ const Dropdown = <Data, Type extends 'single' | 'multi'>({
21
+ options,
22
+ onSearch,
23
+ type,
24
+ hideSearchBar,
25
+ onSelect,
26
+ value,
27
+ keyExtractor,
28
+ labelExtractor,
29
+ setDropDownVisible,
30
+ style,
31
+ }: SelectProps<Data, Type> & {
32
+ setDropDownVisible: (t: boolean) => void;
33
+ style: CSSProperties;
34
+ }): JSX.Element => {
35
+ const [searchArg, setSearchArg] = useDebouncedState<string>('', onSearch);
36
+ const lengthOptions = options.length;
37
+
38
+ const [checkedAll, setCheckedAll] = React.useState<boolean>(
39
+ type === 'multi' && (value as Data[])?.length === lengthOptions
40
+ );
41
+
42
+ const onClickCheckAll = () => {
43
+ const items = options.map(option => option);
44
+ setCheckedAll(!checkedAll);
45
+ const aux = !checkedAll;
46
+ type OnSelectArg = Parameters<typeof onSelect>[0];
47
+ const auxArray: Data[] = [];
48
+ !aux ? onSelect(auxArray as OnSelectArg) : onSelect(items as OnSelectArg);
49
+ };
50
+
51
+ return (
52
+ <StyledContainerDropdown lengthOptions={lengthOptions} style={style}>
53
+ {type === 'multi' && (
54
+ <StyledContainerCheckAll
55
+ onClick={hideSearchBar ? onClickCheckAll : undefined}
56
+ >
57
+ <Checkbox checked={checkedAll} onChange={onClickCheckAll} />
58
+ {!hideSearchBar ? (
59
+ <SearchBarContainer>
60
+ <Input
61
+ style={{ width: '100%' }}
62
+ placeholder="Busque a opção desejada"
63
+ value={searchArg}
64
+ leftComponent={
65
+ <Icon
66
+ name="magnify"
67
+ type="material-community"
68
+ size="centi"
69
+ style={{ marginHorizontal: 12 }}
70
+ />
71
+ }
72
+ onChange={text => setSearchArg(text)}
73
+ />
74
+ </SearchBarContainer>
75
+ ) : (
76
+ <StyledContainerTextLabel>
77
+ <Text fontWeight="bold">
78
+ <StyledSpan>Selecionar todos</StyledSpan>
79
+ </Text>
80
+ </StyledContainerTextLabel>
81
+ )}
82
+ </StyledContainerCheckAll>
83
+ )}
84
+ <StyledTest lenghtOptions={options.length}>
85
+ {options.map((item, index) => (
86
+ <ItemSelect
87
+ type={type}
88
+ key={index}
89
+ item={item}
90
+ onSelect={onSelect}
91
+ value={value}
92
+ keyExtractor={keyExtractor}
93
+ index={index}
94
+ labelExtractor={labelExtractor}
95
+ setDropDownVisible={setDropDownVisible}
96
+ checkedAll={checkedAll}
97
+ setCheckedAll={setCheckedAll}
98
+ lenghtOptions={options.length}
99
+ />
100
+ ))}
101
+ </StyledTest>
102
+ </StyledContainerDropdown>
103
+ );
104
+ };
105
+
106
+ export default Dropdown;
@@ -0,0 +1 @@
1
+ export { default as Dropdown } from './Dropdown';
@@ -0,0 +1,77 @@
1
+ import styled from '@emotion/styled';
2
+ import { hex2rgba, StyleProps } from '@tecsinapse/react-core';
3
+ import { SelectProps } from '../Select';
4
+
5
+ export const StyledContainerDropdown = styled('div')<
6
+ Partial<StyleProps & SelectProps<any, any> & { lengthOptions: number }>
7
+ >`
8
+ width: 100%;
9
+ background-color: ${({ theme }: StyleProps) =>
10
+ theme.miscellaneous.surfaceColor};
11
+ border-radius: ${({ theme }: StyleProps) => theme.borderRadius.mili};
12
+ box-shadow: 0px 2px 8px
13
+ ${({ theme }: StyleProps) => hex2rgba(theme.miscellaneous.shadow, 0.08)};
14
+ margin-top: ${({ theme }: StyleProps) => theme.spacing.centi};
15
+ top: 100%;
16
+ position: absolute;
17
+ padding-top: ${({
18
+ theme,
19
+ hideSearchBar,
20
+ }: StyleProps & Partial<SelectProps<any, any>>) =>
21
+ !hideSearchBar ? `${theme.spacing.deca}` : '0px'};
22
+ padding-bottom: ${({ theme }: StyleProps) => theme.spacing.mili};
23
+ z-index: ${({ theme }: StyleProps) => theme.zIndex.default};
24
+ `;
25
+
26
+ export const StyledTest = styled('div')<
27
+ Partial<StyleProps & SelectProps<any, any> & { lenghtOptions: number }>
28
+ >`
29
+ max-height: 250px;
30
+ top: 100%;
31
+ overflow-y: ${({
32
+ lenghtOptions = 0,
33
+ }: Partial<{ lenghtOptions: number } & StyleProps>) =>
34
+ lenghtOptions > 5 ? 'scroll' : 'hidden'};
35
+ ::-webkit-scrollbar {
36
+ width: 8px;
37
+ }
38
+ ::-webkit-scrollbar-thumb {
39
+ border-radius: ${({ theme }: StyleProps) => theme.borderRadius.centi};
40
+ background-color: ${({ theme }: StyleProps) => theme.color.secondary.light};
41
+ }
42
+ ::-webkit-scrollbar-thumb:hover {
43
+ background-color: ${({ theme }: StyleProps) => theme.color.primary.light};
44
+ },
45
+ `;
46
+
47
+ export const SearchBarContainer = styled('div')<Partial<StyleProps>>`
48
+ padding-left: ${({ theme }) => theme.spacing.mili};
49
+ width: 100%;
50
+ `;
51
+
52
+ export const StyledContainerCheckAll = styled('div')<Partial<StyleProps>>`
53
+ padding: ${({ theme }) => `${theme.spacing.mili} ${theme.spacing.deca}`};
54
+ flex-direction: row;
55
+ display: flex;
56
+ justify-content: flex-start;
57
+ align-items: center;
58
+ cursor: pointer;
59
+ &:hover {
60
+ background-color: ${({ theme }) => theme.color.primary.xlight};
61
+ }
62
+ &:hover span {
63
+ color: ${({ theme }) => theme.color.primary.medium};
64
+ }
65
+ `;
66
+
67
+ export const StyledSpan = styled('span')<Partial<StyleProps>>`
68
+ color: ${({ theme }) => theme.color.primary.medium};
69
+ padding: ${({ theme }) => `${theme.spacing.mili} 0px`};
70
+ `;
71
+
72
+ export const StyledContainerTextLabel = styled('div')<Partial<StyleProps>>`
73
+ padding-left: ${({ theme }) => theme.spacing.mili};
74
+ width: 100%;
75
+ display: flex;
76
+ overflow: hidden;
77
+ `;
@@ -0,0 +1,108 @@
1
+ import { Story } from '@storybook/react';
2
+ import React, { useState } from 'react';
3
+
4
+ import { default as Select, SelectProps } from './Select';
5
+ import styled from '@emotion/styled';
6
+
7
+ export default {
8
+ title: 'Components/Select',
9
+ component: Select,
10
+ };
11
+
12
+ type Option = {
13
+ label: string;
14
+ value: string;
15
+ };
16
+
17
+ const OPTIONS_EXAMPLE: Option[] = [
18
+ { label: 'Label 1', value: 'value1' },
19
+ { label: 'Label 2', value: 'value2' },
20
+ { label: 'Label 3', value: 'value3' },
21
+ { label: 'Label 4', value: 'value4' },
22
+ { label: 'Label 5', value: 'value5' },
23
+ { label: 'Label 6', value: 'value6' },
24
+ ];
25
+
26
+ const TemplateSingle: Story<SelectProps<Option, 'single'>> = args => {
27
+ const [singleValue, setSingleValue] = useState(undefined);
28
+
29
+ const handleSelectSingleValue = key => setSingleValue(key);
30
+
31
+ const handleSearch = React.useCallback((searchArg: string) => {
32
+ console.log(searchArg);
33
+ }, []);
34
+
35
+ return (
36
+ <Container>
37
+ <ContainerSelect>
38
+ <Select
39
+ {...args}
40
+ value={singleValue}
41
+ type="single"
42
+ onSelect={handleSelectSingleValue}
43
+ labelExtractor={item => item.label}
44
+ keyExtractor={item => String(item.value)}
45
+ onSearch={handleSearch}
46
+ />
47
+ </ContainerSelect>
48
+ </Container>
49
+ );
50
+ };
51
+
52
+ export const Single = TemplateSingle.bind({});
53
+
54
+ Single.args = {
55
+ placeholder: 'Placeholder do select',
56
+ label: 'Label',
57
+ options: OPTIONS_EXAMPLE,
58
+ hideSearchBar: false,
59
+ };
60
+
61
+ const TemplateMulti: Story<SelectProps<Option, 'multi'>> = args => {
62
+ const [multiValue, setMultiValue] = useState([]);
63
+
64
+ const handleSelectMultipleValues = keys => setMultiValue(keys);
65
+
66
+ const handleSearch = React.useCallback((searchArg: string) => {
67
+ console.log(searchArg);
68
+ }, []);
69
+
70
+ return (
71
+ <Container>
72
+ <ContainerSelect>
73
+ <Select
74
+ {...args}
75
+ value={multiValue}
76
+ type="multi"
77
+ onSelect={handleSelectMultipleValues}
78
+ labelExtractor={item => item.label}
79
+ keyExtractor={item => String(item.value)}
80
+ onSearch={handleSearch}
81
+ />
82
+ </ContainerSelect>
83
+ </Container>
84
+ );
85
+ };
86
+
87
+ export const Multi = TemplateMulti.bind({});
88
+
89
+ Multi.args = {
90
+ placeholder: 'Placeholder do select',
91
+ label: 'Label',
92
+ options: OPTIONS_EXAMPLE,
93
+ hideSearchBar: false,
94
+ };
95
+
96
+ const Container = styled('div')`
97
+ width: 100%;
98
+ height: 100%;
99
+ display: flex;
100
+ align-items: center;
101
+ justify-content: center;
102
+ flex-direction: column;
103
+ `;
104
+
105
+ const ContainerSelect = styled('div')`
106
+ display: flex;
107
+ width: 400px;
108
+ `;
@@ -0,0 +1,92 @@
1
+ import React from 'react';
2
+ import { Icon, PressableInputContainer, Text } from '@tecsinapse/react-core';
3
+ import { useClickAwayListener } from '../../../hooks';
4
+ import { StyledContainer, StyledInputContainer } from './styled';
5
+ import { Dropdown } from './Dropdown';
6
+ import { getDisplayValue } from './functions';
7
+ import { Transition } from 'react-transition-group';
8
+ import { defaultStyles, transition } from './animations';
9
+
10
+ export interface SelectProps<Data, Type extends 'single' | 'multi'> {
11
+ options: Data[];
12
+ onSelect: (
13
+ option: Type extends 'single' ? Data | undefined : Data[]
14
+ ) => never | void;
15
+ value: Type extends 'single' ? Data | undefined : Data[];
16
+ type: Type;
17
+ keyExtractor: (t: Data, index?: number) => string;
18
+ labelExtractor: (t: Data) => string;
19
+ placeholder?: string;
20
+ onSearch?: (searchArg: string) => void | never;
21
+ searchBarPlaceholder?: string;
22
+ hideSearchBar?: boolean;
23
+ label?: string;
24
+ }
25
+
26
+ export const Select = <Data, Type extends 'single' | 'multi'>({
27
+ value,
28
+ options,
29
+ keyExtractor,
30
+ onSelect,
31
+ type,
32
+ labelExtractor,
33
+ placeholder,
34
+ onSearch,
35
+ hideSearchBar = true,
36
+ label,
37
+ ...rest
38
+ }: SelectProps<Data, Type>): JSX.Element => {
39
+ const [dropDownVisible, setDropDownVisible] = React.useState<boolean>(false);
40
+ const refDropDown = React.useRef(null);
41
+ useClickAwayListener(refDropDown, setDropDownVisible);
42
+
43
+ const displayValue = getDisplayValue<Data>(
44
+ type,
45
+ value,
46
+ options,
47
+ placeholder,
48
+ keyExtractor,
49
+ labelExtractor
50
+ );
51
+
52
+ return (
53
+ <StyledContainer ref={refDropDown}>
54
+ <StyledInputContainer>
55
+ <PressableInputContainer
56
+ label={label}
57
+ {...rest}
58
+ onPress={() => setDropDownVisible(!dropDownVisible)}
59
+ rightComponent={
60
+ <Icon
61
+ name="chevron-down"
62
+ type="material-community"
63
+ size="centi"
64
+ style={{ marginRight: 12 }}
65
+ />
66
+ }
67
+ >
68
+ <Text ellipsizeMode="tail" numberOfLines={1}>
69
+ {displayValue}
70
+ </Text>
71
+ </PressableInputContainer>
72
+ </StyledInputContainer>
73
+ <Transition in={dropDownVisible} timeout={300}>
74
+ {state => (
75
+ <Dropdown
76
+ options={options}
77
+ onSelect={onSelect}
78
+ value={value}
79
+ type={type}
80
+ keyExtractor={keyExtractor}
81
+ labelExtractor={labelExtractor}
82
+ hideSearchBar={hideSearchBar}
83
+ style={{ ...defaultStyles, ...transition[state] }}
84
+ setDropDownVisible={setDropDownVisible}
85
+ />
86
+ )}
87
+ </Transition>
88
+ </StyledContainer>
89
+ );
90
+ };
91
+
92
+ export default Select;