@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
@@ -0,0 +1,88 @@
1
+ import React from 'react';
2
+ import { Checkbox, Text } from '@tecsinapse/react-core';
3
+ import {
4
+ ContainerItemSelect,
5
+ StyledContainerTextLabel,
6
+ StyledSpan,
7
+ } from './styled';
8
+
9
+ interface SelectItemProps<Data, Type extends 'single' | 'multi'> {
10
+ item: Data;
11
+ type: Type;
12
+ value: Type extends 'single' ? Data | undefined : Data[];
13
+ onSelect: (
14
+ option: Type extends 'single' ? Data | undefined : Data[]
15
+ ) => never | void;
16
+ keyExtractor: (t: Data, index: number) => string;
17
+ labelExtractor: (t: Data) => string;
18
+ index: number;
19
+ }
20
+
21
+ const SelectItem = <Data, Type extends 'single' | 'multi'>({
22
+ item,
23
+ onSelect,
24
+ type,
25
+ value,
26
+ labelExtractor,
27
+ setDropDownVisible,
28
+ checkedAll,
29
+ setCheckedAll,
30
+ lenghtOptions,
31
+ }: SelectItemProps<Data, Type> & {
32
+ setDropDownVisible: (t: boolean) => void;
33
+ checkedAll: boolean;
34
+ setCheckedAll: (t: boolean) => void;
35
+ lenghtOptions: number;
36
+ }): JSX.Element => {
37
+ const isMulti = type === 'multi';
38
+ const [checked, setChecked] = React.useState<boolean>(
39
+ value !== undefined && type === 'multi' && (value as Data[]).includes(item)
40
+ );
41
+ React.useEffect(() => {
42
+ if (type === 'multi') {
43
+ checkedAll
44
+ ? setChecked(true)
45
+ : setChecked((value as Data[]).includes(item));
46
+ }
47
+ }, [checkedAll]);
48
+
49
+ const clickItem = item => {
50
+ // TS Workaround since TS won't infer the ternary operator's result type correctly
51
+ type OnSelectArg = Parameters<typeof onSelect>[0];
52
+ const key: Data = item;
53
+ if (Array.isArray(value)) {
54
+ const auxChecked = !checked;
55
+ setChecked(!checked);
56
+ if (auxChecked) {
57
+ onSelect([...value, key] as OnSelectArg);
58
+ [...value, key].length === lenghtOptions && setCheckedAll(true);
59
+ } else {
60
+ const auxArray: Data[] = value;
61
+ const indexToExclude = auxArray.indexOf(key);
62
+ auxArray.splice(indexToExclude, 1);
63
+ onSelect([...auxArray] as OnSelectArg);
64
+ setCheckedAll(false);
65
+ }
66
+ } else {
67
+ onSelect(key as OnSelectArg);
68
+ setDropDownVisible(false);
69
+ }
70
+ };
71
+
72
+ return (
73
+ <ContainerItemSelect onClick={() => clickItem(item)}>
74
+ {isMulti && (
75
+ <Checkbox checked={checked} onChange={() => clickItem(item)} />
76
+ )}
77
+ <StyledContainerTextLabel>
78
+ <Text fontWeight="bold" ellipsizeMode="tail" numberOfLines={1}>
79
+ <StyledSpan singleHighligh={type === 'single' && value === item}>
80
+ {labelExtractor(item)}
81
+ </StyledSpan>
82
+ </Text>
83
+ </StyledContainerTextLabel>
84
+ </ContainerItemSelect>
85
+ );
86
+ };
87
+
88
+ export default SelectItem;
@@ -0,0 +1 @@
1
+ export { default as ItemSelect } from './SelectItem';
@@ -0,0 +1,34 @@
1
+ import styled from '@emotion/styled';
2
+ import { StyleProps } from '@tecsinapse/react-core';
3
+
4
+ export const ContainerItemSelect = styled('div')<Partial<StyleProps>>`
5
+ padding: ${({ theme }) => `${theme.spacing.mili} ${theme.spacing.deca}`};
6
+ cursor: pointer;
7
+ &:hover {
8
+ background-color: ${({ theme }) => theme.color.primary.xlight};
9
+ }
10
+ &:hover span {
11
+ color: ${({ theme }) => theme.color.primary.medium};
12
+ }
13
+ flex-direction: row;
14
+ display: flex;
15
+ justify-content: space-between;
16
+ align-items: center;
17
+ `;
18
+
19
+ export const StyledSpan = styled('span')<
20
+ Partial<StyleProps> & { singleHighligh: boolean }
21
+ >`
22
+ color: ${({ theme, singleHighligh }) =>
23
+ singleHighligh ? theme.color.primary.medium : theme.color.secondary.xdark};
24
+ padding: ${({ theme }) => `${theme.spacing.mili} 0px`};
25
+ `;
26
+
27
+ export const StyledContainerTextLabel = styled('div')<Partial<StyleProps>>`
28
+ padding-left: ${({ theme }) => theme.spacing.mili};
29
+ width: 100%;
30
+ display: flex;
31
+ overflow: hidden;
32
+ text-overflow: ellipsis;
33
+ white-space: nowrap;
34
+ `;
@@ -0,0 +1,18 @@
1
+ export const defaultStyles = {
2
+ transition: [
3
+ 'transform 200ms ease-in-out, opacity 200ms ease-in-out, visibility 200ms ease-in-out',
4
+ ],
5
+ overflow: 'hidden',
6
+ visibility: 'hidden',
7
+ };
8
+
9
+ export const transition = {
10
+ entering: {
11
+ transform: 'translateY(-10%)',
12
+ opacity: 0,
13
+ visibility: 'hidden',
14
+ },
15
+ entered: { transform: 'translateY(0%)', opacity: 1, visibility: 'visible' },
16
+ exiting: { transform: 'translateY(0%)', opacity: 1, visibility: 'visible' },
17
+ exited: { transform: 'translateY(-10%)', opacity: 0, visibility: 'hidden' },
18
+ };
@@ -0,0 +1,32 @@
1
+ export const getDisplayValue = <Data>(
2
+ type,
3
+ value,
4
+ options,
5
+ placeholder,
6
+ keyExtractor,
7
+ labelExtractor
8
+ ): Data | Data[] => {
9
+ if (type === 'multi') {
10
+ if (value.length === 0) return placeholder;
11
+ else {
12
+ return options
13
+ .reduce(
14
+ (acc, option, index) =>
15
+ value.find(
16
+ key => keyExtractor(option, index) == keyExtractor(key, index)
17
+ )
18
+ ? acc + labelExtractor(option) + ', '
19
+ : acc,
20
+ ''
21
+ )
22
+ .slice(0, -2);
23
+ }
24
+ } else {
25
+ if (value === undefined) return placeholder;
26
+ const selectedOption = options.find(
27
+ (option, index) =>
28
+ keyExtractor(option, index) == keyExtractor(value as Data, index)
29
+ );
30
+ return selectedOption ? labelExtractor(selectedOption) : placeholder;
31
+ }
32
+ };
@@ -0,0 +1 @@
1
+ export { default as Select, SelectProps } from './Select';
@@ -0,0 +1,16 @@
1
+ import styled from '@emotion/styled';
2
+ import { StyleProps } from '@tecsinapse/react-core';
3
+
4
+ export const StyledContainer = styled('div')<Partial<StyleProps>>`
5
+ display: flex;
6
+ justify-content: center;
7
+ align-items: center;
8
+ flex-direction: column;
9
+ width: 100%;
10
+ position: relative;
11
+ `;
12
+
13
+ export const StyledInputContainer = styled('div')<Partial<StyleProps>>`
14
+ width: 100%;
15
+ z-index: ${({ theme }) => theme.zIndex.input};
16
+ `;
@@ -18,9 +18,11 @@ const Template: Story<SnackbarWebProps> = ({ open: _open, ...args }) => {
18
18
  };
19
19
 
20
20
  export const Base = Template.bind({});
21
+ export const Timeout = Template.bind({});
21
22
 
22
23
  Base.args = {
23
24
  value: 'Enviado com sucesso!',
25
+ dismissable: true,
24
26
  colorVariant: 'success',
25
27
  colorTone: 'xlight',
26
28
  textProps: {
@@ -38,3 +40,25 @@ Base.args = {
38
40
  colorVariant: 'success',
39
41
  },
40
42
  };
43
+
44
+ Timeout.args = {
45
+ value: 'Falha no envio!',
46
+ dismissable: true,
47
+ timeout: 5000,
48
+ colorVariant: 'error',
49
+ colorTone: 'xlight',
50
+ textProps: {
51
+ colorVariant: 'error',
52
+ colorTone: 'medium',
53
+ },
54
+ leftIcon: {
55
+ name: 'alert-circle-outline',
56
+ type: 'material-community',
57
+ colorVariant: 'error',
58
+ colorTone: 'medium',
59
+ },
60
+ rightIcon: {
61
+ colorTone: 'medium',
62
+ colorVariant: 'error',
63
+ },
64
+ };
@@ -0,0 +1,216 @@
1
+ import React, { useState } from 'react';
2
+ import { Story } from '@storybook/react';
3
+ import {
4
+ GroupButton,
5
+ GroupButtonOption,
6
+ GroupButtonValue,
7
+ Icon,
8
+ } from '@tecsinapse/react-core';
9
+ import DataGrid from './DataGrid';
10
+ import { Input } from '../../atoms/Input';
11
+ import { Skeleton } from '../../atoms/Skeleton';
12
+ import { HeadersType } from './types';
13
+
14
+ export default {
15
+ title: 'Components/Data Grid',
16
+ component: DataGrid,
17
+ };
18
+
19
+ const options: GroupButtonValue<string>[] = [
20
+ { value: 'Filter 1' },
21
+ { value: 'Filter 2' },
22
+ ];
23
+
24
+ const ToolbarFooterComponent = React.memo(() => {
25
+ const [active, setActive] = useState<string>(options[0].value);
26
+ return (
27
+ <>
28
+ <hr
29
+ style={{
30
+ height: 1,
31
+ backgroundColor: '#C2BFBC',
32
+ border: 0,
33
+ opacity: 0.15,
34
+ margin: 0,
35
+ }}
36
+ />
37
+ <div style={{ padding: '12px 32px 6px' }}>
38
+ <GroupButton
39
+ value={active}
40
+ options={options}
41
+ renderKey={option => option}
42
+ renderOption={(option, active) => (
43
+ <GroupButtonOption active={active} description={option} />
44
+ )}
45
+ onChange={setActive}
46
+ />
47
+ </div>
48
+ </>
49
+ );
50
+ });
51
+
52
+ const ToolbarRightComponent = React.memo(() => {
53
+ return (
54
+ <Input
55
+ leftComponent={
56
+ <div style={{ margin: '0 8px' }}>
57
+ <Icon
58
+ name={'magnify'}
59
+ type={'material-community'}
60
+ colorVariant="secondary"
61
+ />
62
+ </div>
63
+ }
64
+ placeholder="Search term"
65
+ placeholderTextColor="#85807A"
66
+ />
67
+ );
68
+ });
69
+
70
+ const SkeletonPlaceholder = React.memo(() => (
71
+ <Skeleton height={55} radius="mili" animation="wave">
72
+ <div style={{ width: '100%', minWidth: 650 }} />
73
+ </Skeleton>
74
+ ));
75
+
76
+ type ExampleData = {
77
+ id: number;
78
+ name: string;
79
+ username: string;
80
+ email: string;
81
+ };
82
+
83
+ const fetchUsers = async (page = 0, rowsPerPage = 5) => {
84
+ return await fetch(
85
+ `https://jsonplaceholder.typicode.com/users?_start=${
86
+ page * rowsPerPage
87
+ }&_limit=${rowsPerPage}`,
88
+ { method: 'GET' }
89
+ );
90
+ };
91
+
92
+ const HEADERS: HeadersType<ExampleData>[] = [
93
+ { label: 'ID', render: data => data.id },
94
+ {
95
+ label: 'Name',
96
+ render: data => data.name,
97
+ sort: direction => {
98
+ alert(`sorting in: ${direction}`);
99
+ },
100
+ },
101
+ { label: 'Username', render: data => data.username },
102
+ { label: 'Email', render: data => data.email },
103
+ ];
104
+
105
+ const Template: Story = args => {
106
+ const [selected, setSelected] = React.useState<ExampleData[]>([]);
107
+ const [rowsPerPage, setRowsPerPage] = React.useState<number>(5);
108
+ const [currentPage, setCurrentPage] = React.useState<number>(0);
109
+ const [totalCount, setTotalCount] = React.useState<number>(0);
110
+ const [loading, setLoading] = React.useState<boolean>(true);
111
+ const [data, setData] = React.useState<ExampleData[]>([]);
112
+
113
+ React.useEffect(() => {
114
+ fetchUsers(currentPage, rowsPerPage)
115
+ .then(async data => {
116
+ setTotalCount(parseInt(data.headers.get('X-Total-Count') ?? '0'));
117
+ const json = await data.json();
118
+ setData(json);
119
+ })
120
+ .finally(() => setLoading(false));
121
+ }, []);
122
+
123
+ React.useEffect(() => {
124
+ setLoading(true);
125
+ fetchUsers(currentPage, rowsPerPage)
126
+ .then(async data => {
127
+ const json = await data.json();
128
+ setData(json);
129
+ })
130
+ .finally(() => setLoading(false));
131
+ }, [rowsPerPage, currentPage]);
132
+
133
+ const rowsPerPageOptions = React.useMemo(() => [5, 25, 50], []);
134
+ const rowKeyExtractor = React.useCallback(data => String(data.id), []);
135
+
136
+ return (
137
+ <DataGrid
138
+ headers={HEADERS}
139
+ data={data}
140
+ rowKeyExtractor={rowKeyExtractor}
141
+ toolbarTitle="Server Side"
142
+ toolbarRightIcons={<ToolbarRightComponent />}
143
+ toolbarFooter={<ToolbarFooterComponent />}
144
+ selectedRows={selected}
145
+ onSelectedRows={setSelected}
146
+ rowsPerPage={rowsPerPage}
147
+ rowsPerPageOptions={rowsPerPageOptions}
148
+ onRowsPerPageChange={setRowsPerPage}
149
+ page={currentPage}
150
+ onPageChange={setCurrentPage}
151
+ loading={loading}
152
+ rowsCount={totalCount}
153
+ skeletonComponent={<SkeletonPlaceholder />}
154
+ {...args}
155
+ />
156
+ );
157
+ };
158
+
159
+ export const Base = Template.bind({});
160
+
161
+ Base.args = {
162
+ selectable: true,
163
+ exportFunction: () => alert('Export handler'),
164
+ pagination: true,
165
+ };
166
+
167
+ const fetchAllUsers = async () => {
168
+ return await fetch(`https://jsonplaceholder.typicode.com/users`, {
169
+ method: 'GET',
170
+ });
171
+ };
172
+
173
+ const TemplateClient: Story = args => {
174
+ const [rowsPerPage, setRowsPerPage] = React.useState<number>(5);
175
+ const [currentPage, setCurrentPage] = React.useState<number>(0);
176
+ const [loading, setLoading] = React.useState<boolean>(true);
177
+ const [data, setData] = React.useState<ExampleData[]>([]);
178
+
179
+ React.useEffect(() => {
180
+ fetchAllUsers()
181
+ .then(async data => {
182
+ const json = await data.json();
183
+ setData(json);
184
+ })
185
+ .finally(() => setLoading(false));
186
+ }, []);
187
+
188
+ const rowKeyExtractor = React.useCallback(data => String(data.id), []);
189
+ const rowsPerPageOptions = React.useMemo(() => [5, 25, 50], []);
190
+
191
+ return (
192
+ <DataGrid
193
+ headers={HEADERS}
194
+ data={data}
195
+ rowKeyExtractor={rowKeyExtractor}
196
+ toolbarTitle="Client Side"
197
+ toolbarRightIcons={<ToolbarRightComponent />}
198
+ toolbarFooter={<ToolbarFooterComponent />}
199
+ rowsPerPage={rowsPerPage}
200
+ rowsPerPageOptions={rowsPerPageOptions}
201
+ onRowsPerPageChange={setRowsPerPage}
202
+ page={currentPage}
203
+ onPageChange={setCurrentPage}
204
+ loading={loading}
205
+ skeletonComponent={<SkeletonPlaceholder />}
206
+ {...args}
207
+ />
208
+ );
209
+ };
210
+
211
+ export const ClientSide = TemplateClient.bind({});
212
+
213
+ ClientSide.args = {
214
+ exportFunction: () => alert('Export handler'),
215
+ pagination: true,
216
+ };