@tecsinapse/react-web-kit 1.23.7 → 2.0.0

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 (381) hide show
  1. package/dist/cjs/components/atoms/Accordion/Accordion.js +34 -37
  2. package/dist/cjs/components/atoms/Accordion/Accordion.js.map +1 -1
  3. package/dist/cjs/components/atoms/Accordion/animations.js +0 -2
  4. package/dist/cjs/components/atoms/Accordion/animations.js.map +1 -1
  5. package/dist/cjs/components/atoms/Accordion/styled.js +4 -10
  6. package/dist/cjs/components/atoms/Accordion/styled.js.map +1 -1
  7. package/dist/cjs/components/atoms/Badge/Badge.js +8 -12
  8. package/dist/cjs/components/atoms/Badge/Badge.js.map +1 -1
  9. package/dist/cjs/components/atoms/Button/Button.d.ts +1 -1
  10. package/dist/cjs/components/atoms/Button/Button.js +17 -17
  11. package/dist/cjs/components/atoms/Button/Button.js.map +1 -1
  12. package/dist/cjs/components/atoms/Button/hooks/useMouseHover.js +0 -2
  13. package/dist/cjs/components/atoms/Button/hooks/useMouseHover.js.map +1 -1
  14. package/dist/cjs/components/atoms/Button/hooks/useMousePressed.js +0 -2
  15. package/dist/cjs/components/atoms/Button/hooks/useMousePressed.js.map +1 -1
  16. package/dist/cjs/components/atoms/Button/styled.js +1 -7
  17. package/dist/cjs/components/atoms/Button/styled.js.map +1 -1
  18. package/dist/cjs/components/atoms/Dropdown/index.js +9 -14
  19. package/dist/cjs/components/atoms/Dropdown/index.js.map +1 -1
  20. package/dist/cjs/components/atoms/Dropdown/styled.js +1 -7
  21. package/dist/cjs/components/atoms/Dropdown/styled.js.map +1 -1
  22. package/dist/cjs/components/atoms/Input/Input.d.ts +1 -1
  23. package/dist/cjs/components/atoms/Input/Input.js +34 -36
  24. package/dist/cjs/components/atoms/Input/Input.js.map +1 -1
  25. package/dist/cjs/components/atoms/Input/styled.js +1 -7
  26. package/dist/cjs/components/atoms/Input/styled.js.map +1 -1
  27. package/dist/cjs/components/atoms/InputMask/InputMask.d.ts +1 -1
  28. package/dist/cjs/components/atoms/InputMask/InputMask.js +34 -36
  29. package/dist/cjs/components/atoms/InputMask/InputMask.js.map +1 -1
  30. package/dist/cjs/components/atoms/InputMask/styled.js +1 -7
  31. package/dist/cjs/components/atoms/InputMask/styled.js.map +1 -1
  32. package/dist/cjs/components/atoms/Modal/Modal.js +11 -18
  33. package/dist/cjs/components/atoms/Modal/Modal.js.map +1 -1
  34. package/dist/cjs/components/atoms/Modal/animations.js +0 -2
  35. package/dist/cjs/components/atoms/Modal/animations.js.map +1 -1
  36. package/dist/cjs/components/atoms/Modal/styled.js +1 -7
  37. package/dist/cjs/components/atoms/Modal/styled.js.map +1 -1
  38. package/dist/cjs/components/atoms/Overlay/Overlay.d.ts +3 -2
  39. package/dist/cjs/components/atoms/Overlay/Overlay.js +12 -15
  40. package/dist/cjs/components/atoms/Overlay/Overlay.js.map +1 -1
  41. package/dist/cjs/components/atoms/Overlay/animations.js +0 -2
  42. package/dist/cjs/components/atoms/Overlay/animations.js.map +1 -1
  43. package/dist/cjs/components/atoms/Overlay/styled.js +1 -7
  44. package/dist/cjs/components/atoms/Overlay/styled.js.map +1 -1
  45. package/dist/cjs/components/atoms/Skeleton/Skeleton.js +19 -15
  46. package/dist/cjs/components/atoms/Skeleton/Skeleton.js.map +1 -1
  47. package/dist/cjs/components/atoms/Skeleton/styled.js +1 -7
  48. package/dist/cjs/components/atoms/Skeleton/styled.js.map +1 -1
  49. package/dist/cjs/components/atoms/Switch/Switch.js +19 -21
  50. package/dist/cjs/components/atoms/Switch/Switch.js.map +1 -1
  51. package/dist/cjs/components/atoms/Switch/styled.js +2 -8
  52. package/dist/cjs/components/atoms/Switch/styled.js.map +1 -1
  53. package/dist/cjs/components/atoms/Table/Body/TBody.js +1 -7
  54. package/dist/cjs/components/atoms/Table/Body/TBody.js.map +1 -1
  55. package/dist/cjs/components/atoms/Table/Cell/Td.js +1 -7
  56. package/dist/cjs/components/atoms/Table/Cell/Td.js.map +1 -1
  57. package/dist/cjs/components/atoms/Table/Cell/styled.js +1 -7
  58. package/dist/cjs/components/atoms/Table/Cell/styled.js.map +1 -1
  59. package/dist/cjs/components/atoms/Table/Container/TableContainer.js +1 -7
  60. package/dist/cjs/components/atoms/Table/Container/TableContainer.js.map +1 -1
  61. package/dist/cjs/components/atoms/Table/Container/styled.js +1 -7
  62. package/dist/cjs/components/atoms/Table/Container/styled.js.map +1 -1
  63. package/dist/cjs/components/atoms/Table/Footer/TFoot.js +1 -7
  64. package/dist/cjs/components/atoms/Table/Footer/TFoot.js.map +1 -1
  65. package/dist/cjs/components/atoms/Table/Footer/styled.js +1 -7
  66. package/dist/cjs/components/atoms/Table/Footer/styled.js.map +1 -1
  67. package/dist/cjs/components/atoms/Table/Header/THead.js +1 -9
  68. package/dist/cjs/components/atoms/Table/Header/THead.js.map +1 -1
  69. package/dist/cjs/components/atoms/Table/Header/Th.js +1 -7
  70. package/dist/cjs/components/atoms/Table/Header/Th.js.map +1 -1
  71. package/dist/cjs/components/atoms/Table/Header/styled.js +3 -9
  72. package/dist/cjs/components/atoms/Table/Header/styled.js.map +1 -1
  73. package/dist/cjs/components/atoms/Table/Row/Tr.js +1 -7
  74. package/dist/cjs/components/atoms/Table/Row/Tr.js.map +1 -1
  75. package/dist/cjs/components/atoms/Table/Row/styled.js +1 -7
  76. package/dist/cjs/components/atoms/Table/Row/styled.js.map +1 -1
  77. package/dist/cjs/components/atoms/Table/Table.js +1 -7
  78. package/dist/cjs/components/atoms/Table/Table.js.map +1 -1
  79. package/dist/cjs/components/atoms/Table/Toolbar/TableToolbar.js +1 -10
  80. package/dist/cjs/components/atoms/Table/Toolbar/TableToolbar.js.map +1 -1
  81. package/dist/cjs/components/atoms/Table/Toolbar/styled.js +1 -7
  82. package/dist/cjs/components/atoms/Table/Toolbar/styled.js.map +1 -1
  83. package/dist/cjs/components/atoms/Table/styled.js +1 -7
  84. package/dist/cjs/components/atoms/Table/styled.js.map +1 -1
  85. package/dist/cjs/components/atoms/Tag/Tag.js +19 -16
  86. package/dist/cjs/components/atoms/Tag/Tag.js.map +1 -1
  87. package/dist/cjs/components/atoms/Tooltip/Tooltip.d.ts +2 -2
  88. package/dist/cjs/components/atoms/Tooltip/Tooltip.js +21 -19
  89. package/dist/cjs/components/atoms/Tooltip/Tooltip.js.map +1 -1
  90. package/dist/cjs/components/atoms/Tooltip/styled.js +2 -8
  91. package/dist/cjs/components/atoms/Tooltip/styled.js.map +1 -1
  92. package/dist/cjs/components/molecules/Breadcrumbs/BreadcrumbItem/BreadcrumbItem.js +9 -16
  93. package/dist/cjs/components/molecules/Breadcrumbs/BreadcrumbItem/BreadcrumbItem.js.map +1 -1
  94. package/dist/cjs/components/molecules/Breadcrumbs/BreadcrumbItem/styled.js +2 -8
  95. package/dist/cjs/components/molecules/Breadcrumbs/BreadcrumbItem/styled.js.map +1 -1
  96. package/dist/cjs/components/molecules/Breadcrumbs/Breadcrumbs.d.ts +1 -1
  97. package/dist/cjs/components/molecules/Breadcrumbs/Breadcrumbs.js +11 -14
  98. package/dist/cjs/components/molecules/Breadcrumbs/Breadcrumbs.js.map +1 -1
  99. package/dist/cjs/components/molecules/Breadcrumbs/styled.js +1 -7
  100. package/dist/cjs/components/molecules/Breadcrumbs/styled.js.map +1 -1
  101. package/dist/cjs/components/molecules/DatePicker/DatePicker.d.ts +2 -1
  102. package/dist/cjs/components/molecules/DatePicker/DatePicker.js +81 -84
  103. package/dist/cjs/components/molecules/DatePicker/DatePicker.js.map +1 -1
  104. package/dist/cjs/components/molecules/DatePicker/Modal.d.ts +1 -0
  105. package/dist/cjs/components/molecules/DatePicker/styled.d.ts +1 -1
  106. package/dist/cjs/components/molecules/DateTimePicker/DateTimePicker.d.ts +1 -1
  107. package/dist/cjs/components/molecules/DateTimePicker/DateTimePicker.js +9 -15
  108. package/dist/cjs/components/molecules/DateTimePicker/DateTimePicker.js.map +1 -1
  109. package/dist/cjs/components/molecules/DateTimePicker/styled.d.ts +1 -1
  110. package/dist/cjs/components/molecules/Drawer/Drawer.d.ts +1 -1
  111. package/dist/cjs/components/molecules/Drawer/Drawer.js +11 -19
  112. package/dist/cjs/components/molecules/Drawer/Drawer.js.map +1 -1
  113. package/dist/cjs/components/molecules/Drawer/animations.js +0 -2
  114. package/dist/cjs/components/molecules/Drawer/animations.js.map +1 -1
  115. package/dist/cjs/components/molecules/Drawer/styled.js +1 -7
  116. package/dist/cjs/components/molecules/Drawer/styled.js.map +1 -1
  117. package/dist/cjs/components/molecules/Grid/Grid.d.ts +1 -1
  118. package/dist/cjs/components/molecules/Grid/Grid.js +35 -27
  119. package/dist/cjs/components/molecules/Grid/Grid.js.map +1 -1
  120. package/dist/cjs/components/molecules/Grid/Item/Item.d.ts +2 -2
  121. package/dist/cjs/components/molecules/Grid/Item/Item.js +3 -10
  122. package/dist/cjs/components/molecules/Grid/Item/Item.js.map +1 -1
  123. package/dist/cjs/components/molecules/Grid/Item/functions.js +0 -2
  124. package/dist/cjs/components/molecules/Grid/Item/functions.js.map +1 -1
  125. package/dist/cjs/components/molecules/IconTextButton/IconTextButton.d.ts +1 -1
  126. package/dist/cjs/components/molecules/IconTextButton/IconTextButton.js +40 -29
  127. package/dist/cjs/components/molecules/IconTextButton/IconTextButton.js.map +1 -1
  128. package/dist/cjs/components/molecules/IconTextButton/TextComponent.js +11 -11
  129. package/dist/cjs/components/molecules/IconTextButton/TextComponent.js.map +1 -1
  130. package/dist/cjs/components/molecules/IconTextButton/hooks/useIconTextButton.js.map +1 -1
  131. package/dist/cjs/components/molecules/IconTextButton/styled.js +1 -7
  132. package/dist/cjs/components/molecules/IconTextButton/styled.js.map +1 -1
  133. package/dist/cjs/components/molecules/InputPassword/InputPassword.d.ts +1 -1
  134. package/dist/cjs/components/molecules/InputPassword/InputPassword.js +17 -15
  135. package/dist/cjs/components/molecules/InputPassword/InputPassword.js.map +1 -1
  136. package/dist/cjs/components/molecules/LabeledSwitch/LabelComponent.js +11 -13
  137. package/dist/cjs/components/molecules/LabeledSwitch/LabelComponent.js.map +1 -1
  138. package/dist/cjs/components/molecules/LabeledSwitch/LabeledSwitch.d.ts +1 -1
  139. package/dist/cjs/components/molecules/LabeledSwitch/LabeledSwitch.js +31 -26
  140. package/dist/cjs/components/molecules/LabeledSwitch/LabeledSwitch.js.map +1 -1
  141. package/dist/cjs/components/molecules/LabeledSwitch/styled.js +2 -9
  142. package/dist/cjs/components/molecules/LabeledSwitch/styled.js.map +1 -1
  143. package/dist/cjs/components/molecules/Masonry/Masonry.d.ts +3 -2
  144. package/dist/cjs/components/molecules/Masonry/Masonry.js +5 -17
  145. package/dist/cjs/components/molecules/Masonry/Masonry.js.map +1 -1
  146. package/dist/cjs/components/molecules/Masonry/styled.js +3 -9
  147. package/dist/cjs/components/molecules/Masonry/styled.js.map +1 -1
  148. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuBlock.js +14 -23
  149. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuBlock.js.map +1 -1
  150. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.js +16 -25
  151. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.js.map +1 -1
  152. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.js +1 -13
  153. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.js.map +1 -1
  154. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/styled.js +2 -8
  155. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/styled.js.map +1 -1
  156. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/styled.js +2 -8
  157. package/dist/cjs/components/molecules/Menubar/MenuBlock/MenuItem/styled.js.map +1 -1
  158. package/dist/cjs/components/molecules/Menubar/MenuBlock/styled.js +5 -11
  159. package/dist/cjs/components/molecules/Menubar/MenuBlock/styled.js.map +1 -1
  160. package/dist/cjs/components/molecules/Menubar/Menubar.js +45 -59
  161. package/dist/cjs/components/molecules/Menubar/Menubar.js.map +1 -1
  162. package/dist/cjs/components/molecules/Menubar/MostUsed/MostUsed.js +20 -24
  163. package/dist/cjs/components/molecules/Menubar/MostUsed/MostUsed.js.map +1 -1
  164. package/dist/cjs/components/molecules/Menubar/MostUsed/styled.js +2 -9
  165. package/dist/cjs/components/molecules/Menubar/MostUsed/styled.js.map +1 -1
  166. package/dist/cjs/components/molecules/Menubar/SearchResultItem/SearchResultItem.js +10 -18
  167. package/dist/cjs/components/molecules/Menubar/SearchResultItem/SearchResultItem.js.map +1 -1
  168. package/dist/cjs/components/molecules/Menubar/SearchResultItem/styled.js +2 -9
  169. package/dist/cjs/components/molecules/Menubar/SearchResultItem/styled.js.map +1 -1
  170. package/dist/cjs/components/molecules/Menubar/SearchResultItem/utils.js +1 -10
  171. package/dist/cjs/components/molecules/Menubar/SearchResultItem/utils.js.map +1 -1
  172. package/dist/cjs/components/molecules/Menubar/animations.js +0 -2
  173. package/dist/cjs/components/molecules/Menubar/animations.js.map +1 -1
  174. package/dist/cjs/components/molecules/Menubar/styled.js +8 -15
  175. package/dist/cjs/components/molecules/Menubar/styled.js.map +1 -1
  176. package/dist/cjs/components/molecules/Menubar/types.d.ts +3 -3
  177. package/dist/cjs/components/molecules/Menubar/utils.js +0 -2
  178. package/dist/cjs/components/molecules/Menubar/utils.js.map +1 -1
  179. package/dist/cjs/components/molecules/Select/Dropdown/Dropdown.d.ts +1 -0
  180. package/dist/cjs/components/molecules/Select/Dropdown/Dropdown.js +55 -46
  181. package/dist/cjs/components/molecules/Select/Dropdown/Dropdown.js.map +1 -1
  182. package/dist/cjs/components/molecules/Select/Dropdown/components/SearchInput.js +20 -18
  183. package/dist/cjs/components/molecules/Select/Dropdown/components/SearchInput.js.map +1 -1
  184. package/dist/cjs/components/molecules/Select/Dropdown/styled.js +7 -13
  185. package/dist/cjs/components/molecules/Select/Dropdown/styled.js.map +1 -1
  186. package/dist/cjs/components/molecules/Select/Select.js +32 -42
  187. package/dist/cjs/components/molecules/Select/Select.js.map +1 -1
  188. package/dist/cjs/components/molecules/Select/SelectItem/SelectItem.d.ts +1 -0
  189. package/dist/cjs/components/molecules/Select/SelectItem/SelectItem.js +6 -21
  190. package/dist/cjs/components/molecules/Select/SelectItem/SelectItem.js.map +1 -1
  191. package/dist/cjs/components/molecules/Select/SelectItem/styled.js +3 -9
  192. package/dist/cjs/components/molecules/Select/SelectItem/styled.js.map +1 -1
  193. package/dist/cjs/components/molecules/Select/animations.js +0 -2
  194. package/dist/cjs/components/molecules/Select/animations.js.map +1 -1
  195. package/dist/cjs/components/molecules/Select/functions.js +0 -2
  196. package/dist/cjs/components/molecules/Select/functions.js.map +1 -1
  197. package/dist/cjs/components/molecules/Select/styled.js +11 -15
  198. package/dist/cjs/components/molecules/Select/styled.js.map +1 -1
  199. package/dist/cjs/components/molecules/Snackbar/Snackbar.js +1 -11
  200. package/dist/cjs/components/molecules/Snackbar/Snackbar.js.map +1 -1
  201. package/dist/cjs/components/molecules/Snackbar/styled.js +1 -7
  202. package/dist/cjs/components/molecules/Snackbar/styled.js.map +1 -1
  203. package/dist/cjs/components/molecules/TextArea/TextArea.d.ts +1 -1
  204. package/dist/cjs/components/molecules/TextArea/TextArea.js +42 -39
  205. package/dist/cjs/components/molecules/TextArea/TextArea.js.map +1 -1
  206. package/dist/cjs/components/molecules/TextArea/styled.js +1 -7
  207. package/dist/cjs/components/molecules/TextArea/styled.js.map +1 -1
  208. package/dist/cjs/components/organisms/DataGrid/DataGrid.d.ts +1 -1
  209. package/dist/cjs/components/organisms/DataGrid/DataGrid.js +50 -57
  210. package/dist/cjs/components/organisms/DataGrid/DataGrid.js.map +1 -1
  211. package/dist/cjs/components/organisms/DataGrid/Footer/Footer.js +57 -49
  212. package/dist/cjs/components/organisms/DataGrid/Footer/Footer.js.map +1 -1
  213. package/dist/cjs/components/organisms/DataGrid/Footer/styled.d.ts +0 -6
  214. package/dist/cjs/components/organisms/DataGrid/Footer/styled.js +11 -18
  215. package/dist/cjs/components/organisms/DataGrid/Footer/styled.js.map +1 -1
  216. package/dist/cjs/components/organisms/DataGrid/Header/Header.d.ts +1 -0
  217. package/dist/cjs/components/organisms/DataGrid/Header/Header.js +25 -24
  218. package/dist/cjs/components/organisms/DataGrid/Header/Header.js.map +1 -1
  219. package/dist/cjs/components/organisms/DataGrid/Header/styled.js +1 -7
  220. package/dist/cjs/components/organisms/DataGrid/Header/styled.js.map +1 -1
  221. package/dist/cjs/components/organisms/DataGrid/Header/utils.js +0 -2
  222. package/dist/cjs/components/organisms/DataGrid/Header/utils.js.map +1 -1
  223. package/dist/cjs/components/organisms/DataGrid/Row/Row.d.ts +1 -1
  224. package/dist/cjs/components/organisms/DataGrid/Row/Row.js +8 -13
  225. package/dist/cjs/components/organisms/DataGrid/Row/Row.js.map +1 -1
  226. package/dist/cjs/components/organisms/DataGrid/styled.js +1 -7
  227. package/dist/cjs/components/organisms/DataGrid/styled.js.map +1 -1
  228. package/dist/cjs/components/organisms/DataGrid/types.d.ts +2 -2
  229. package/dist/cjs/components/organisms/DataGrid/utils.js +0 -2
  230. package/dist/cjs/components/organisms/DataGrid/utils.js.map +1 -1
  231. package/dist/cjs/hooks/useBreakpoints.d.ts +1 -1
  232. package/dist/cjs/hooks/useBreakpoints.js +0 -2
  233. package/dist/cjs/hooks/useBreakpoints.js.map +1 -1
  234. package/dist/cjs/hooks/useClickAwayListener.js +1 -7
  235. package/dist/cjs/hooks/useClickAwayListener.js.map +1 -1
  236. package/dist/cjs/hooks/useWindowSize.d.ts +1 -1
  237. package/dist/cjs/hooks/useWindowSize.js +2 -8
  238. package/dist/cjs/hooks/useWindowSize.js.map +1 -1
  239. package/dist/cjs/index.js +0 -2
  240. package/dist/cjs/index.js.map +1 -1
  241. package/dist/esm/components/atoms/Accordion/Accordion.js +29 -28
  242. package/dist/esm/components/atoms/Accordion/Accordion.js.map +1 -1
  243. package/dist/esm/components/atoms/Badge/Badge.js +8 -8
  244. package/dist/esm/components/atoms/Badge/Badge.js.map +1 -1
  245. package/dist/esm/components/atoms/Button/Button.d.ts +1 -1
  246. package/dist/esm/components/atoms/Button/Button.js +17 -13
  247. package/dist/esm/components/atoms/Button/Button.js.map +1 -1
  248. package/dist/esm/components/atoms/Button/styled.js.map +1 -1
  249. package/dist/esm/components/atoms/Dropdown/index.js +8 -7
  250. package/dist/esm/components/atoms/Dropdown/index.js.map +1 -1
  251. package/dist/esm/components/atoms/Input/Input.d.ts +1 -1
  252. package/dist/esm/components/atoms/Input/Input.js +33 -31
  253. package/dist/esm/components/atoms/Input/Input.js.map +1 -1
  254. package/dist/esm/components/atoms/InputMask/InputMask.d.ts +1 -1
  255. package/dist/esm/components/atoms/InputMask/InputMask.js +33 -31
  256. package/dist/esm/components/atoms/InputMask/InputMask.js.map +1 -1
  257. package/dist/esm/components/atoms/Modal/Modal.js +11 -14
  258. package/dist/esm/components/atoms/Modal/Modal.js.map +1 -1
  259. package/dist/esm/components/atoms/Overlay/Overlay.d.ts +3 -2
  260. package/dist/esm/components/atoms/Overlay/Overlay.js +12 -11
  261. package/dist/esm/components/atoms/Overlay/Overlay.js.map +1 -1
  262. package/dist/esm/components/atoms/Overlay/styled.js.map +1 -1
  263. package/dist/esm/components/atoms/Skeleton/Skeleton.js +19 -11
  264. package/dist/esm/components/atoms/Skeleton/Skeleton.js.map +1 -1
  265. package/dist/esm/components/atoms/Skeleton/styled.js.map +1 -1
  266. package/dist/esm/components/atoms/Switch/Switch.js +19 -17
  267. package/dist/esm/components/atoms/Switch/Switch.js.map +1 -1
  268. package/dist/esm/components/atoms/Table/Body/TBody.js +1 -3
  269. package/dist/esm/components/atoms/Table/Body/TBody.js.map +1 -1
  270. package/dist/esm/components/atoms/Table/Cell/Td.js +1 -3
  271. package/dist/esm/components/atoms/Table/Cell/Td.js.map +1 -1
  272. package/dist/esm/components/atoms/Table/Container/TableContainer.js +1 -3
  273. package/dist/esm/components/atoms/Table/Container/TableContainer.js.map +1 -1
  274. package/dist/esm/components/atoms/Table/Footer/TFoot.js +1 -3
  275. package/dist/esm/components/atoms/Table/Footer/TFoot.js.map +1 -1
  276. package/dist/esm/components/atoms/Table/Header/THead.js +1 -5
  277. package/dist/esm/components/atoms/Table/Header/THead.js.map +1 -1
  278. package/dist/esm/components/atoms/Table/Header/Th.js +1 -3
  279. package/dist/esm/components/atoms/Table/Header/Th.js.map +1 -1
  280. package/dist/esm/components/atoms/Table/Row/Tr.js +1 -3
  281. package/dist/esm/components/atoms/Table/Row/Tr.js.map +1 -1
  282. package/dist/esm/components/atoms/Table/Table.js +1 -3
  283. package/dist/esm/components/atoms/Table/Table.js.map +1 -1
  284. package/dist/esm/components/atoms/Table/Toolbar/TableToolbar.js +1 -6
  285. package/dist/esm/components/atoms/Table/Toolbar/TableToolbar.js.map +1 -1
  286. package/dist/esm/components/atoms/Tag/Tag.js +19 -12
  287. package/dist/esm/components/atoms/Tag/Tag.js.map +1 -1
  288. package/dist/esm/components/atoms/Tooltip/Tooltip.d.ts +2 -2
  289. package/dist/esm/components/atoms/Tooltip/Tooltip.js +18 -12
  290. package/dist/esm/components/atoms/Tooltip/Tooltip.js.map +1 -1
  291. package/dist/esm/components/molecules/Breadcrumbs/BreadcrumbItem/BreadcrumbItem.js +9 -12
  292. package/dist/esm/components/molecules/Breadcrumbs/BreadcrumbItem/BreadcrumbItem.js.map +1 -1
  293. package/dist/esm/components/molecules/Breadcrumbs/Breadcrumbs.d.ts +1 -1
  294. package/dist/esm/components/molecules/Breadcrumbs/Breadcrumbs.js +11 -10
  295. package/dist/esm/components/molecules/Breadcrumbs/Breadcrumbs.js.map +1 -1
  296. package/dist/esm/components/molecules/DatePicker/DatePicker.d.ts +2 -1
  297. package/dist/esm/components/molecules/DatePicker/DatePicker.js +81 -78
  298. package/dist/esm/components/molecules/DatePicker/DatePicker.js.map +1 -1
  299. package/dist/esm/components/molecules/DatePicker/Modal.d.ts +1 -0
  300. package/dist/esm/components/molecules/DatePicker/styled.d.ts +1 -1
  301. package/dist/esm/components/molecules/DateTimePicker/DateTimePicker.d.ts +1 -1
  302. package/dist/esm/components/molecules/DateTimePicker/DateTimePicker.js +9 -9
  303. package/dist/esm/components/molecules/DateTimePicker/DateTimePicker.js.map +1 -1
  304. package/dist/esm/components/molecules/DateTimePicker/styled.d.ts +1 -1
  305. package/dist/esm/components/molecules/Drawer/Drawer.d.ts +1 -1
  306. package/dist/esm/components/molecules/Drawer/Drawer.js +11 -15
  307. package/dist/esm/components/molecules/Drawer/Drawer.js.map +1 -1
  308. package/dist/esm/components/molecules/Grid/Grid.d.ts +1 -1
  309. package/dist/esm/components/molecules/Grid/Grid.js +35 -23
  310. package/dist/esm/components/molecules/Grid/Grid.js.map +1 -1
  311. package/dist/esm/components/molecules/Grid/Item/Item.d.ts +2 -2
  312. package/dist/esm/components/molecules/Grid/Item/Item.js +1 -4
  313. package/dist/esm/components/molecules/Grid/Item/Item.js.map +1 -1
  314. package/dist/esm/components/molecules/IconTextButton/IconTextButton.d.ts +1 -1
  315. package/dist/esm/components/molecules/IconTextButton/IconTextButton.js +40 -25
  316. package/dist/esm/components/molecules/IconTextButton/IconTextButton.js.map +1 -1
  317. package/dist/esm/components/molecules/IconTextButton/TextComponent.js +10 -6
  318. package/dist/esm/components/molecules/IconTextButton/TextComponent.js.map +1 -1
  319. package/dist/esm/components/molecules/IconTextButton/hooks/useIconTextButton.js.map +1 -1
  320. package/dist/esm/components/molecules/InputPassword/InputPassword.d.ts +1 -1
  321. package/dist/esm/components/molecules/InputPassword/InputPassword.js +16 -10
  322. package/dist/esm/components/molecules/InputPassword/InputPassword.js.map +1 -1
  323. package/dist/esm/components/molecules/LabeledSwitch/LabelComponent.js +10 -8
  324. package/dist/esm/components/molecules/LabeledSwitch/LabelComponent.js.map +1 -1
  325. package/dist/esm/components/molecules/LabeledSwitch/LabeledSwitch.d.ts +1 -1
  326. package/dist/esm/components/molecules/LabeledSwitch/LabeledSwitch.js +31 -22
  327. package/dist/esm/components/molecules/LabeledSwitch/LabeledSwitch.js.map +1 -1
  328. package/dist/esm/components/molecules/Masonry/Masonry.d.ts +3 -2
  329. package/dist/esm/components/molecules/Masonry/Masonry.js +2 -10
  330. package/dist/esm/components/molecules/Masonry/Masonry.js.map +1 -1
  331. package/dist/esm/components/molecules/Masonry/styled.js.map +1 -1
  332. package/dist/esm/components/molecules/Menubar/MenuBlock/MenuBlock.js +13 -18
  333. package/dist/esm/components/molecules/Menubar/MenuBlock/MenuBlock.js.map +1 -1
  334. package/dist/esm/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.js +15 -20
  335. package/dist/esm/components/molecules/Menubar/MenuBlock/MenuItem/MenuItem.js.map +1 -1
  336. package/dist/esm/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.js +1 -9
  337. package/dist/esm/components/molecules/Menubar/MenuBlock/MenuItem/SubMenuBlock/SubMenuBlock.js.map +1 -1
  338. package/dist/esm/components/molecules/Menubar/Menubar.js +40 -50
  339. package/dist/esm/components/molecules/Menubar/Menubar.js.map +1 -1
  340. package/dist/esm/components/molecules/Menubar/MostUsed/MostUsed.js +19 -19
  341. package/dist/esm/components/molecules/Menubar/MostUsed/MostUsed.js.map +1 -1
  342. package/dist/esm/components/molecules/Menubar/SearchResultItem/SearchResultItem.js +10 -14
  343. package/dist/esm/components/molecules/Menubar/SearchResultItem/SearchResultItem.js.map +1 -1
  344. package/dist/esm/components/molecules/Menubar/SearchResultItem/utils.js +1 -4
  345. package/dist/esm/components/molecules/Menubar/SearchResultItem/utils.js.map +1 -1
  346. package/dist/esm/components/molecules/Menubar/animations.js.map +1 -1
  347. package/dist/esm/components/molecules/Menubar/types.d.ts +3 -3
  348. package/dist/esm/components/molecules/Select/Dropdown/Dropdown.d.ts +1 -0
  349. package/dist/esm/components/molecules/Select/Dropdown/Dropdown.js +50 -37
  350. package/dist/esm/components/molecules/Select/Dropdown/Dropdown.js.map +1 -1
  351. package/dist/esm/components/molecules/Select/Dropdown/components/SearchInput.js +19 -13
  352. package/dist/esm/components/molecules/Select/Dropdown/components/SearchInput.js.map +1 -1
  353. package/dist/esm/components/molecules/Select/Select.js +27 -33
  354. package/dist/esm/components/molecules/Select/Select.js.map +1 -1
  355. package/dist/esm/components/molecules/Select/SelectItem/SelectItem.d.ts +1 -0
  356. package/dist/esm/components/molecules/Select/SelectItem/SelectItem.js +1 -12
  357. package/dist/esm/components/molecules/Select/SelectItem/SelectItem.js.map +1 -1
  358. package/dist/esm/components/molecules/Select/styled.js +9 -6
  359. package/dist/esm/components/molecules/Select/styled.js.map +1 -1
  360. package/dist/esm/components/molecules/Snackbar/Snackbar.js +1 -7
  361. package/dist/esm/components/molecules/Snackbar/Snackbar.js.map +1 -1
  362. package/dist/esm/components/molecules/TextArea/TextArea.d.ts +1 -1
  363. package/dist/esm/components/molecules/TextArea/TextArea.js +42 -35
  364. package/dist/esm/components/molecules/TextArea/TextArea.js.map +1 -1
  365. package/dist/esm/components/molecules/TextArea/styled.js.map +1 -1
  366. package/dist/esm/components/organisms/DataGrid/DataGrid.d.ts +1 -1
  367. package/dist/esm/components/organisms/DataGrid/DataGrid.js +47 -50
  368. package/dist/esm/components/organisms/DataGrid/DataGrid.js.map +1 -1
  369. package/dist/esm/components/organisms/DataGrid/Footer/Footer.js +55 -43
  370. package/dist/esm/components/organisms/DataGrid/Footer/Footer.js.map +1 -1
  371. package/dist/esm/components/organisms/DataGrid/Footer/styled.d.ts +0 -6
  372. package/dist/esm/components/organisms/DataGrid/Header/Header.d.ts +1 -0
  373. package/dist/esm/components/organisms/DataGrid/Header/Header.js +24 -19
  374. package/dist/esm/components/organisms/DataGrid/Header/Header.js.map +1 -1
  375. package/dist/esm/components/organisms/DataGrid/Row/Row.d.ts +1 -1
  376. package/dist/esm/components/organisms/DataGrid/Row/Row.js +7 -8
  377. package/dist/esm/components/organisms/DataGrid/Row/Row.js.map +1 -1
  378. package/dist/esm/components/organisms/DataGrid/types.d.ts +2 -2
  379. package/dist/esm/hooks/useBreakpoints.d.ts +1 -1
  380. package/dist/esm/hooks/useWindowSize.d.ts +1 -1
  381. package/package.json +11 -10
@@ -1 +1 @@
1
- {"version":3,"file":"Select.js","sources":["../../../../../src/components/molecules/Select/Select.tsx"],"sourcesContent":["import {\n PressableInputContainer,\n Text,\n TextProps,\n} from '@tecsinapse/react-core';\nimport React, { useEffect, useState } from 'react';\nimport { Transition } from 'react-transition-group';\nimport { useClickAwayListener } from '../../../hooks';\nimport { defaultStyles, transition } from './animations';\nimport { Dropdown } from './Dropdown';\nimport { getDisplayValue } from './functions';\nimport {\n RightComponent,\n StyledContainer,\n StyledInputContainer,\n} from './styled';\n\nexport interface SelectProps<Data, Type extends 'single' | 'multi'>\n extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> {\n options: ((searchInput?: string) => Promise<Data[]>) | Data[];\n onSelect: (\n option: Type extends 'single' ? Data | undefined : Data[]\n ) => never | void;\n value: Type extends 'single' ? Data | undefined : Data[];\n type: Type;\n keyExtractor: (t: Data, index?: number) => string;\n labelExtractor: (t: Data) => string;\n placeholder?: string;\n onSearch?:\n | ((searchArg: string) => void)\n | ((searchInput?: string) => Promise<Data[]>)\n | never;\n searchBarPlaceholder?: string;\n hideSearchBar?: boolean;\n selectAllLabel?: string;\n disabled?: boolean;\n label?: string;\n anchor?: 'top' | 'bottom';\n displayTextProps?: TextProps;\n}\n\n/** NOTE: For better performance, you should memoize options and handlers */\nconst Select = <Data, Type extends 'single' | 'multi'>({\n value,\n options,\n keyExtractor,\n onSelect,\n type,\n labelExtractor,\n placeholder,\n onSearch,\n searchBarPlaceholder = 'Busque a opção desejada',\n hideSearchBar = true,\n label,\n disabled = false,\n anchor = 'bottom',\n displayTextProps,\n selectAllLabel = 'Selecionar todos',\n ...rest\n}: SelectProps<Data, Type>): JSX.Element => {\n const [dropDownVisible, setDropDownVisible] = React.useState<boolean>(false);\n const [selectOptions, setSelectOptions] = useState<Data[]>([]);\n const refDropDown = React.useRef(null);\n useClickAwayListener(refDropDown, setDropDownVisible);\n\n useEffect(() => {\n if (typeof options !== 'function') {\n setSelectOptions(options);\n }\n }, [options]);\n\n // TODO: Add Skeleton to modal height when loading is true\n\n const onlyLabel = label && !placeholder;\n const hasValue =\n type === 'single' ? !!value : ((value || []) as []).length > 0;\n const _placeholder = onlyLabel ? label : placeholder;\n const _label = hasValue ? label : undefined;\n\n const displayValue = getDisplayValue<Data>(\n type,\n value,\n selectOptions,\n _placeholder,\n keyExtractor,\n labelExtractor\n );\n\n const handleLazyFocus = React.useCallback(async () => {\n if (!dropDownVisible && typeof options === 'function') {\n try {\n const result = await options();\n if (result) {\n setSelectOptions(result ?? []);\n }\n } catch (e) {\n // TODO: Catch error\n }\n }\n }, [options, setSelectOptions, dropDownVisible]);\n\n const handleOnSearch = React.useCallback(\n async (searchInput: string | undefined) => {\n if (searchInput !== undefined && onSearch && dropDownVisible) {\n try {\n //TODO: Remove code duplicated below (Select in react-native-kit)\n const result = await onSearch(searchInput);\n if (result) {\n if (type === 'single') {\n if (\n value &&\n !result.find(\n v => keyExtractor(value as Data) === keyExtractor(v)\n )\n ) {\n setSelectOptions([value as Data, ...result]);\n } else setSelectOptions(result);\n } else {\n if ((value as Data[]).length > 0) {\n const selectedValues =\n (value as Data[]).filter(\n v =>\n !result.find(\n current =>\n keyExtractor(v as Data) === keyExtractor(current)\n )\n ) || [];\n setSelectOptions([...selectedValues, ...result]);\n } else {\n setSelectOptions(result);\n }\n }\n }\n } catch (e) {\n // TODO: Catch error\n }\n }\n },\n [onSearch, value, keyExtractor, dropDownVisible, setSelectOptions]\n );\n\n const handlePressInput = async () => {\n await handleLazyFocus();\n };\n\n const onPress = React.useCallback(\n () => setDropDownVisible(prev => !prev),\n [setDropDownVisible]\n );\n\n return (\n <StyledContainer ref={refDropDown} {...rest}>\n <StyledInputContainer onFocus={handlePressInput}>\n <PressableInputContainer\n label={_label}\n onPress={onPress}\n disabled={disabled}\n rightComponent={RightComponent}\n >\n <Text\n {...displayTextProps}\n ellipsizeMode=\"tail\"\n numberOfLines={1}\n fontWeight={'bold'}\n >\n {displayValue}\n </Text>\n </PressableInputContainer>\n </StyledInputContainer>\n <Transition in={dropDownVisible} timeout={300}>\n {state => (\n <Dropdown\n options={selectOptions ?? []}\n onSelect={onSelect}\n value={value}\n type={type}\n keyExtractor={keyExtractor}\n labelExtractor={labelExtractor}\n hideSearchBar={hideSearchBar}\n searchBarPlaceholder={searchBarPlaceholder}\n onSearch={handleOnSearch}\n style={{ ...defaultStyles, ...transition[anchor][state] }}\n setDropDownVisible={setDropDownVisible}\n anchor={anchor}\n selectAllLabel={selectAllLabel}\n />\n )}\n </Transition>\n </StyledContainer>\n );\n};\n\nexport default Select;\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Select.js","sources":["../../../../../src/components/molecules/Select/Select.tsx"],"sourcesContent":["import {\n PressableInputContainer,\n Text,\n TextProps,\n} from '@tecsinapse/react-core';\nimport React, { useEffect, useState } from 'react';\nimport { Transition } from 'react-transition-group';\nimport { useClickAwayListener } from '../../../hooks';\nimport { defaultStyles, transition } from './animations';\nimport { Dropdown } from './Dropdown';\nimport { getDisplayValue } from './functions';\nimport {\n RightComponent,\n StyledContainer,\n StyledInputContainer,\n} from './styled';\n\nexport interface SelectProps<Data, Type extends 'single' | 'multi'>\n extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> {\n options: ((searchInput?: string) => Promise<Data[]>) | Data[];\n onSelect: (\n option: Type extends 'single' ? Data | undefined : Data[]\n ) => never | void;\n value: Type extends 'single' ? Data | undefined : Data[];\n type: Type;\n keyExtractor: (t: Data, index?: number) => string;\n labelExtractor: (t: Data) => string;\n placeholder?: string;\n onSearch?:\n | ((searchArg: string) => void)\n | ((searchInput?: string) => Promise<Data[]>)\n | never;\n searchBarPlaceholder?: string;\n hideSearchBar?: boolean;\n selectAllLabel?: string;\n disabled?: boolean;\n label?: string;\n anchor?: 'top' | 'bottom';\n displayTextProps?: TextProps;\n}\n\n/** NOTE: For better performance, you should memoize options and handlers */\nconst Select = <Data, Type extends 'single' | 'multi'>({\n value,\n options,\n keyExtractor,\n onSelect,\n type,\n labelExtractor,\n placeholder,\n onSearch,\n searchBarPlaceholder = 'Busque a opção desejada',\n hideSearchBar = true,\n label,\n disabled = false,\n anchor = 'bottom',\n displayTextProps,\n selectAllLabel = 'Selecionar todos',\n ...rest\n}: SelectProps<Data, Type>): JSX.Element => {\n const [dropDownVisible, setDropDownVisible] = React.useState<boolean>(false);\n const [selectOptions, setSelectOptions] = useState<Data[]>([]);\n const refDropDown = React.useRef(null);\n useClickAwayListener(refDropDown, setDropDownVisible);\n\n useEffect(() => {\n if (typeof options !== 'function') {\n setSelectOptions(options);\n }\n }, [options]);\n\n // TODO: Add Skeleton to modal height when loading is true\n\n const onlyLabel = label && !placeholder;\n const hasValue =\n type === 'single' ? !!value : ((value || []) as []).length > 0;\n const _placeholder = onlyLabel ? label : placeholder;\n const _label = hasValue ? label : undefined;\n\n const displayValue = getDisplayValue<Data>(\n type,\n value,\n selectOptions,\n _placeholder,\n keyExtractor,\n labelExtractor\n );\n\n const handleLazyFocus = React.useCallback(async () => {\n if (!dropDownVisible && typeof options === 'function') {\n try {\n const result = await options();\n if (result) {\n setSelectOptions(result ?? []);\n }\n } catch (e) {\n // TODO: Catch error\n }\n }\n }, [options, setSelectOptions, dropDownVisible]);\n\n const handleOnSearch = React.useCallback(\n async (searchInput: string | undefined) => {\n if (searchInput !== undefined && onSearch && dropDownVisible) {\n try {\n //TODO: Remove code duplicated below (Select in react-native-kit)\n const result = await onSearch(searchInput);\n if (result) {\n if (type === 'single') {\n if (\n value &&\n !result.find(\n v => keyExtractor(value as Data) === keyExtractor(v)\n )\n ) {\n setSelectOptions([value as Data, ...result]);\n } else setSelectOptions(result);\n } else {\n if ((value as Data[]).length > 0) {\n const selectedValues =\n (value as Data[]).filter(\n v =>\n !result.find(\n current =>\n keyExtractor(v as Data) === keyExtractor(current)\n )\n ) || [];\n setSelectOptions([...selectedValues, ...result]);\n } else {\n setSelectOptions(result);\n }\n }\n }\n } catch (e) {\n // TODO: Catch error\n }\n }\n },\n [onSearch, value, keyExtractor, dropDownVisible, setSelectOptions]\n );\n\n const handlePressInput = async () => {\n await handleLazyFocus();\n };\n\n const onPress = React.useCallback(\n () => setDropDownVisible(prev => !prev),\n [setDropDownVisible]\n );\n //TODO: when component is wrapper by GridITem and Text of label has prop \"numberOfLines={1}\", this component incresing witht based on options selects, breaking layout of Grid, we must fix this problem.\n return (\n <StyledContainer ref={refDropDown} {...rest}>\n <StyledInputContainer onFocus={handlePressInput}>\n <PressableInputContainer\n label={_label}\n onPress={onPress}\n disabled={disabled}\n rightComponent={RightComponent}\n >\n <Text {...displayTextProps} fontWeight={'bold'}>\n {displayValue}\n </Text>\n </PressableInputContainer>\n </StyledInputContainer>\n <Transition in={dropDownVisible} timeout={300}>\n {state => (\n <Dropdown\n options={selectOptions ?? []}\n onSelect={onSelect}\n value={value}\n type={type}\n keyExtractor={keyExtractor}\n labelExtractor={labelExtractor}\n hideSearchBar={hideSearchBar}\n searchBarPlaceholder={searchBarPlaceholder}\n onSearch={handleOnSearch}\n style={{ ...defaultStyles, ...transition[anchor][state] }}\n setDropDownVisible={setDropDownVisible}\n anchor={anchor}\n selectAllLabel={selectAllLabel}\n />\n )}\n </Transition>\n </StyledContainer>\n );\n};\n\nexport default Select;\n"],"names":[],"mappings":"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"}
@@ -1,3 +1,4 @@
1
+ /// <reference types="react" />
1
2
  interface SelectItemProps<Data, Type extends 'single' | 'multi'> {
2
3
  item: Data;
3
4
  type: Type;
@@ -60,18 +60,7 @@ const SelectItem = ({
60
60
  },
61
61
  [onSelect, setDropDownVisible, setCheckedAll, setChecked, checked]
62
62
  );
63
- return /* @__PURE__ */ React.createElement(ContainerItemSelect, {
64
- onClick: () => clickItem(item, value)
65
- }, isMulti && /* @__PURE__ */ React.createElement(Checkbox, {
66
- checked,
67
- onChange: () => clickItem(item, value)
68
- }), /* @__PURE__ */ React.createElement(StyledContainerTextLabel, null, /* @__PURE__ */ React.createElement(Text, {
69
- fontWeight: "bold",
70
- ellipsizeMode: "tail",
71
- numberOfLines: 1
72
- }, /* @__PURE__ */ React.createElement(StyledSpan, {
73
- singleHighligh: type === "single" && value === item
74
- }, labelExtractor(item)))));
63
+ return /* @__PURE__ */ React.createElement(ContainerItemSelect, { onClick: () => clickItem(item, value) }, isMulti && /* @__PURE__ */ React.createElement(Checkbox, { checked, onChange: () => clickItem(item, value) }), /* @__PURE__ */ React.createElement(StyledContainerTextLabel, null, /* @__PURE__ */ React.createElement(Text, { fontWeight: "bold", ellipsizeMode: "tail", numberOfLines: 1 }, /* @__PURE__ */ React.createElement(StyledSpan, { singleHighligh: type === "single" && value === item }, labelExtractor(item)))));
75
64
  };
76
65
  var ItemSelect = React.memo(SelectItem);
77
66
 
@@ -1 +1 @@
1
- {"version":3,"file":"SelectItem.js","sources":["../../../../../../src/components/molecules/Select/SelectItem/SelectItem.tsx"],"sourcesContent":["import React from 'react';\nimport { Checkbox, Text } from '@tecsinapse/react-core';\nimport {\n ContainerItemSelect,\n StyledContainerTextLabel,\n StyledSpan,\n} from './styled';\n\ninterface SelectItemProps<Data, Type extends 'single' | 'multi'> {\n item: Data;\n type: Type;\n value: Type extends 'single' ? Data | undefined : Data[];\n onSelect: (\n option: Type extends 'single' ? Data | undefined : Data[]\n ) => never | void;\n keyExtractor: (t: Data, index?: number) => string;\n labelExtractor: (t: Data) => string;\n index: number;\n}\n\nconst SelectItem = <Data, Type extends 'single' | 'multi'>({\n item,\n onSelect,\n type,\n value,\n labelExtractor,\n setDropDownVisible,\n checkedAll,\n setCheckedAll,\n lenghtOptions,\n keyExtractor,\n}: SelectItemProps<Data, Type> & {\n setDropDownVisible: (t: boolean) => void;\n checkedAll: boolean;\n setCheckedAll: (t: boolean) => void;\n lenghtOptions: number;\n}): JSX.Element => {\n const isMulti = type === 'multi';\n const [checked, setChecked] = React.useState<boolean>(\n value !== undefined &&\n type === 'multi' &&\n (value as Data[]).find(\n data => keyExtractor(data) === keyExtractor(item)\n ) !== undefined\n );\n\n React.useEffect(() => {\n if (\n !checked &&\n value !== undefined &&\n ((type === 'multi' &&\n (value as Data[]).find(\n data => keyExtractor(data) === keyExtractor(item)\n )) ||\n (type === 'single' &&\n keyExtractor(value as Data) === keyExtractor(item)))\n )\n setChecked(true);\n }, [value, keyExtractor, type]);\n\n React.useEffect(() => {\n if (type === 'multi') {\n checkedAll\n ? setChecked(true)\n : setChecked(\n (value as Data[]).find(\n data => keyExtractor(data) === keyExtractor(item)\n ) !== undefined\n );\n }\n }, [checkedAll]);\n\n const clickItem = React.useCallback(\n (item, _value) => {\n // TS Workaround since TS won't infer the ternary operator's result type correctly\n type OnSelectArg = Parameters<typeof onSelect>[0];\n const key: Data = item;\n if (Array.isArray(_value)) {\n const auxChecked = !checked;\n setChecked(!checked);\n if (auxChecked) {\n onSelect([..._value, key] as OnSelectArg);\n [..._value, key].length === lenghtOptions && setCheckedAll(true);\n } else {\n const auxArray: Data[] = [..._value];\n const indexToExclude = auxArray.findIndex(\n data => keyExtractor(data) === keyExtractor(key)\n );\n auxArray.splice(indexToExclude, 1);\n onSelect([...auxArray] as OnSelectArg);\n setCheckedAll(false);\n }\n } else {\n onSelect(key as OnSelectArg);\n setDropDownVisible(false);\n }\n },\n [onSelect, setDropDownVisible, setCheckedAll, setChecked, checked]\n );\n\n return (\n <ContainerItemSelect onClick={() => clickItem(item, value)}>\n {isMulti && (\n <Checkbox checked={checked} onChange={() => clickItem(item, value)} />\n )}\n <StyledContainerTextLabel>\n <Text fontWeight=\"bold\" ellipsizeMode=\"tail\" numberOfLines={1}>\n <StyledSpan singleHighligh={type === 'single' && value === item}>\n {labelExtractor(item)}\n </StyledSpan>\n </Text>\n </StyledContainerTextLabel>\n </ContainerItemSelect>\n );\n};\n\nexport default React.memo(SelectItem) as typeof SelectItem;\n"],"names":["item"],"mappings":"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"}
1
+ {"version":3,"file":"SelectItem.js","sources":["../../../../../../src/components/molecules/Select/SelectItem/SelectItem.tsx"],"sourcesContent":["import React from 'react';\nimport { Checkbox, Text } from '@tecsinapse/react-core';\nimport {\n ContainerItemSelect,\n StyledContainerTextLabel,\n StyledSpan,\n} from './styled';\n\ninterface SelectItemProps<Data, Type extends 'single' | 'multi'> {\n item: Data;\n type: Type;\n value: Type extends 'single' ? Data | undefined : Data[];\n onSelect: (\n option: Type extends 'single' ? Data | undefined : Data[]\n ) => never | void;\n keyExtractor: (t: Data, index?: number) => string;\n labelExtractor: (t: Data) => string;\n index: number;\n}\n\nconst SelectItem = <Data, Type extends 'single' | 'multi'>({\n item,\n onSelect,\n type,\n value,\n labelExtractor,\n setDropDownVisible,\n checkedAll,\n setCheckedAll,\n lenghtOptions,\n keyExtractor,\n}: SelectItemProps<Data, Type> & {\n setDropDownVisible: (t: boolean) => void;\n checkedAll: boolean;\n setCheckedAll: (t: boolean) => void;\n lenghtOptions: number;\n}): JSX.Element => {\n const isMulti = type === 'multi';\n const [checked, setChecked] = React.useState<boolean>(\n value !== undefined &&\n type === 'multi' &&\n (value as Data[]).find(\n data => keyExtractor(data) === keyExtractor(item)\n ) !== undefined\n );\n\n React.useEffect(() => {\n if (\n !checked &&\n value !== undefined &&\n ((type === 'multi' &&\n (value as Data[]).find(\n data => keyExtractor(data) === keyExtractor(item)\n )) ||\n (type === 'single' &&\n keyExtractor(value as Data) === keyExtractor(item)))\n )\n setChecked(true);\n }, [value, keyExtractor, type]);\n\n React.useEffect(() => {\n if (type === 'multi') {\n checkedAll\n ? setChecked(true)\n : setChecked(\n (value as Data[]).find(\n data => keyExtractor(data) === keyExtractor(item)\n ) !== undefined\n );\n }\n }, [checkedAll]);\n\n const clickItem = React.useCallback(\n (item, _value) => {\n // TS Workaround since TS won't infer the ternary operator's result type correctly\n type OnSelectArg = Parameters<typeof onSelect>[0];\n const key: Data = item;\n if (Array.isArray(_value)) {\n const auxChecked = !checked;\n setChecked(!checked);\n if (auxChecked) {\n onSelect([..._value, key] as OnSelectArg);\n [..._value, key].length === lenghtOptions && setCheckedAll(true);\n } else {\n const auxArray: Data[] = [..._value];\n const indexToExclude = auxArray.findIndex(\n data => keyExtractor(data) === keyExtractor(key)\n );\n auxArray.splice(indexToExclude, 1);\n onSelect([...auxArray] as OnSelectArg);\n setCheckedAll(false);\n }\n } else {\n onSelect(key as OnSelectArg);\n setDropDownVisible(false);\n }\n },\n [onSelect, setDropDownVisible, setCheckedAll, setChecked, checked]\n );\n\n return (\n <ContainerItemSelect onClick={() => clickItem(item, value)}>\n {isMulti && (\n <Checkbox checked={checked} onChange={() => clickItem(item, value)} />\n )}\n <StyledContainerTextLabel>\n <Text fontWeight=\"bold\" ellipsizeMode=\"tail\" numberOfLines={1}>\n <StyledSpan singleHighligh={type === 'single' && value === item}>\n {labelExtractor(item)}\n </StyledSpan>\n </Text>\n </StyledContainerTextLabel>\n </ContainerItemSelect>\n );\n};\n\nexport default React.memo(SelectItem) as typeof SelectItem;\n"],"names":["item"],"mappings":"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"}
@@ -13,12 +13,15 @@ const StyledContainer = styled("div")`
13
13
  const StyledInputContainer = styled("div")`
14
14
  width: 100%;
15
15
  `;
16
- const RightComponent = /* @__PURE__ */ React.createElement(Icon, {
17
- name: "chevron-down",
18
- type: "material-community",
19
- size: "centi",
20
- style: { marginRight: 12 }
21
- });
16
+ const RightComponent = /* @__PURE__ */ React.createElement(
17
+ Icon,
18
+ {
19
+ name: "chevron-down",
20
+ type: "material-community",
21
+ size: "centi",
22
+ style: { marginRight: 12 }
23
+ }
24
+ );
22
25
 
23
26
  export { RightComponent, StyledContainer, StyledInputContainer };
24
27
  //# sourceMappingURL=styled.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"styled.js","sources":["../../../../../src/components/molecules/Select/styled.tsx"],"sourcesContent":["import styled from '@emotion/styled';\nimport { Icon, StyleProps } from '@tecsinapse/react-core';\nimport React from 'react';\n\nexport const StyledContainer = styled('div')<Partial<StyleProps>>`\n display: flex;\n justify-content: center;\n align-items: center;\n flex-direction: column;\n width: 100%;\n position: relative;\n`;\n\nexport const StyledInputContainer = styled('div')<Partial<StyleProps>>`\n width: 100%;\n`;\n\nexport const RightComponent = (\n <Icon\n name=\"chevron-down\"\n type=\"material-community\"\n size=\"centi\"\n style={{ marginRight: 12 }}\n />\n);\n"],"names":[],"mappings":";;;;AAIa,MAAA,eAAA,GAAkB,OAAO,KAAK,CAAA,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAAA;AAS9B,MAAA,oBAAA,GAAuB,OAAO,KAAK,CAAA,CAAA;AAAA;AAAA,EAAA;AAIzC,MAAM,iCACV,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA;AAAA,EACC,IAAK,EAAA,cAAA;AAAA,EACL,IAAK,EAAA,oBAAA;AAAA,EACL,IAAK,EAAA,OAAA;AAAA,EACL,KAAA,EAAO,EAAE,WAAA,EAAa,EAAG,EAAA;AAAA,CAC3B;;;;"}
1
+ {"version":3,"file":"styled.js","sources":["../../../../../src/components/molecules/Select/styled.tsx"],"sourcesContent":["import styled from '@emotion/styled';\nimport { Icon, StyleProps } from '@tecsinapse/react-core';\nimport React from 'react';\n\nexport const StyledContainer = styled('div')<Partial<StyleProps>>`\n display: flex;\n justify-content: center;\n align-items: center;\n flex-direction: column;\n width: 100%;\n position: relative;\n`;\n\nexport const StyledInputContainer = styled('div')<Partial<StyleProps>>`\n width: 100%;\n`;\n\nexport const RightComponent = (\n <Icon\n name=\"chevron-down\"\n type=\"material-community\"\n size=\"centi\"\n style={{ marginRight: 12 }}\n />\n);\n"],"names":[],"mappings":";;;;AAIa,MAAA,eAAA,GAAkB,OAAO,KAAK,CAAA,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAAA;AAS9B,MAAA,oBAAA,GAAuB,OAAO,KAAK,CAAA,CAAA;AAAA;AAAA,EAAA;AAIzC,MAAM,cACX,mBAAA,KAAA,CAAA,aAAA;AAAA,EAAC,IAAA;AAAA,EAAA;AAAA,IACC,IAAK,EAAA,cAAA;AAAA,IACL,IAAK,EAAA,oBAAA;AAAA,IACL,IAAK,EAAA,OAAA;AAAA,IACL,KAAA,EAAO,EAAE,WAAA,EAAa,EAAG,EAAA;AAAA,GAAA;AAC3B;;;;"}
@@ -7,13 +7,7 @@ const Snackbar = ({
7
7
  textProps = { colorVariant: "primary", colorTone: "medium" },
8
8
  ...rest
9
9
  }) => {
10
- return /* @__PURE__ */ React.createElement(SnackbarStyled, {
11
- ...rest
12
- }, /* @__PURE__ */ React.createElement(Text, {
13
- ...textProps,
14
- fontWeight: "bold",
15
- typography: "base"
16
- }, value));
10
+ return /* @__PURE__ */ React.createElement(SnackbarStyled, { ...rest, showProgressBar: false }, /* @__PURE__ */ React.createElement(Text, { ...textProps, fontWeight: "bold", typography: "base" }, value));
17
11
  };
18
12
 
19
13
  export { Snackbar as default };
@@ -1 +1 @@
1
- {"version":3,"file":"Snackbar.js","sources":["../../../../../src/components/molecules/Snackbar/Snackbar.tsx"],"sourcesContent":["import React from 'react';\nimport {\n SnackbarProps as SnackPropsCore,\n Text,\n TextProps,\n} from '@tecsinapse/react-core';\nimport { SnackbarStyled } from './styled';\n\nexport interface SnackbarWebProps extends Omit<SnackPropsCore, 'children'> {\n value: string;\n textProps?: TextProps;\n}\n\nconst Snackbar: React.FC<SnackbarWebProps> = ({\n value,\n textProps = { colorVariant: 'primary', colorTone: 'medium' },\n ...rest\n}) => {\n return (\n <SnackbarStyled {...rest}>\n <Text {...textProps} fontWeight=\"bold\" typography=\"base\">\n {value}\n </Text>\n </SnackbarStyled>\n );\n};\n\nexport default Snackbar;\n"],"names":[],"mappings":";;;;AAaA,MAAM,WAAuC,CAAC;AAAA,EAC5C,KAAA;AAAA,EACA,SAAY,GAAA,EAAE,YAAc,EAAA,SAAA,EAAW,WAAW,QAAS,EAAA;AAAA,EACxD,GAAA,IAAA;AACL,CAAM,KAAA;AACJ,EAAA,uBACG,KAAA,CAAA,aAAA,CAAA,cAAA,EAAA;AAAA,IAAgB,GAAG,IAAA;AAAA,GAAA,kBACjB,KAAA,CAAA,aAAA,CAAA,IAAA,EAAA;AAAA,IAAM,GAAG,SAAA;AAAA,IAAW,UAAW,EAAA,MAAA;AAAA,IAAO,UAAW,EAAA,MAAA;AAAA,GAAA,EAC/C,KACH,CACF,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"Snackbar.js","sources":["../../../../../src/components/molecules/Snackbar/Snackbar.tsx"],"sourcesContent":["import React from 'react';\nimport {\n SnackbarProps as SnackPropsCore,\n Text,\n TextProps,\n} from '@tecsinapse/react-core';\nimport { SnackbarStyled } from './styled';\n\nexport interface SnackbarWebProps extends Omit<SnackPropsCore, 'children'> {\n value: string;\n textProps?: TextProps;\n}\n\nconst Snackbar: React.FC<SnackbarWebProps> = ({\n value,\n textProps = { colorVariant: 'primary', colorTone: 'medium' },\n ...rest\n}) => {\n return (\n <SnackbarStyled {...rest} showProgressBar={false}>\n <Text {...textProps} fontWeight=\"bold\" typography=\"base\">\n {value}\n </Text>\n </SnackbarStyled>\n );\n};\n\nexport default Snackbar;\n"],"names":[],"mappings":";;;;AAaA,MAAM,WAAuC,CAAC;AAAA,EAC5C,KAAA;AAAA,EACA,SAAY,GAAA,EAAE,YAAc,EAAA,SAAA,EAAW,WAAW,QAAS,EAAA;AAAA,EAC3D,GAAG,IAAA;AACL,CAAM,KAAA;AACJ,EAAA,uBACG,KAAA,CAAA,aAAA,CAAA,cAAA,EAAA,EAAgB,GAAG,IAAA,EAAM,iBAAiB,KACzC,EAAA,kBAAA,KAAA,CAAA,aAAA,CAAC,IAAM,EAAA,EAAA,GAAG,WAAW,UAAW,EAAA,MAAA,EAAO,UAAW,EAAA,MAAA,EAAA,EAC/C,KACH,CACF,CAAA,CAAA;AAEJ;;;;"}
@@ -1,5 +1,5 @@
1
1
  import { FC } from 'react';
2
2
  import { TextAreaProps as ITACore } from '@tecsinapse/react-core';
3
- export declare type TextAreaProps = Omit<ITACore, 'TextComponent' | 'focused'>;
3
+ export type TextAreaProps = Omit<ITACore, 'TextComponent' | 'focused'>;
4
4
  declare const TextArea: FC<TextAreaProps>;
5
5
  export default TextArea;
@@ -33,41 +33,48 @@ const TextArea = ({
33
33
  onBlur,
34
34
  !disabled
35
35
  );
36
- return /* @__PURE__ */ React.createElement(TextArea$1, {
37
- label,
38
- labelColor,
39
- labelColorVariant,
40
- labelColorTone,
41
- labelTypography,
42
- labelStack,
43
- labelWeight,
44
- LabelComponent: Text,
45
- leftComponent,
46
- rightComponent,
47
- borderColor,
48
- borderColorGradation,
49
- inputContainerStyle,
50
- focused,
51
- disabled,
52
- variant,
53
- value,
54
- hintComponent,
55
- hint,
56
- style,
57
- TextComponent: Text,
58
- maxLength
59
- }, /* @__PURE__ */ React.createElement(StyledWebInput, {
60
- ...rest,
61
- fontStack: inputFontStack,
62
- fontWeight: inputFontWeight,
63
- disabled,
64
- onFocus: handleFocus,
65
- onBlur: handleBlur,
66
- textAlignVertical: "top",
67
- multiline: true,
68
- value,
69
- maxLength
70
- }));
36
+ return /* @__PURE__ */ React.createElement(
37
+ TextArea$1,
38
+ {
39
+ label,
40
+ labelColor,
41
+ labelColorVariant,
42
+ labelColorTone,
43
+ labelTypography,
44
+ labelStack,
45
+ labelWeight,
46
+ LabelComponent: Text,
47
+ leftComponent,
48
+ rightComponent,
49
+ borderColor,
50
+ borderColorGradation,
51
+ inputContainerStyle,
52
+ focused,
53
+ disabled,
54
+ variant,
55
+ value,
56
+ hintComponent,
57
+ hint,
58
+ style,
59
+ TextComponent: Text,
60
+ maxLength
61
+ },
62
+ /* @__PURE__ */ React.createElement(
63
+ StyledWebInput,
64
+ {
65
+ ...rest,
66
+ fontStack: inputFontStack,
67
+ fontWeight: inputFontWeight,
68
+ disabled,
69
+ onFocus: handleFocus,
70
+ onBlur: handleBlur,
71
+ textAlignVertical: "top",
72
+ multiline: true,
73
+ value,
74
+ maxLength
75
+ }
76
+ )
77
+ );
71
78
  };
72
79
 
73
80
  export { TextArea as default };
@@ -1 +1 @@
1
- {"version":3,"file":"TextArea.js","sources":["../../../../../src/components/molecules/TextArea/TextArea.tsx"],"sourcesContent":["import React, { FC } from 'react';\nimport {\n useInputFocus,\n TextAreaProps as ITACore,\n TextArea as TACore,\n Text,\n} from '@tecsinapse/react-core';\nimport { StyledWebInput } from './styled';\n\nexport type TextAreaProps = Omit<ITACore, 'TextComponent' | 'focused'>;\n\nconst TextArea: FC<TextAreaProps> = ({\n label,\n labelColor,\n labelColorVariant,\n labelColorTone,\n labelTypography,\n labelStack,\n labelWeight,\n leftComponent,\n rightComponent,\n disabled,\n style,\n borderColor,\n borderColorGradation,\n inputFontStack = 'default',\n inputFontWeight = 'bold',\n inputContainerStyle,\n variant = 'default',\n hintComponent,\n hint,\n onFocus,\n onBlur,\n value,\n maxLength,\n ...rest\n}) => {\n const { focused, handleBlur, handleFocus } = useInputFocus(\n onFocus,\n onBlur,\n !disabled\n );\n\n return (\n <TACore\n label={label}\n labelColor={labelColor}\n labelColorVariant={labelColorVariant}\n labelColorTone={labelColorTone}\n labelTypography={labelTypography}\n labelStack={labelStack}\n labelWeight={labelWeight}\n LabelComponent={Text}\n leftComponent={leftComponent}\n rightComponent={rightComponent}\n borderColor={borderColor}\n borderColorGradation={borderColorGradation}\n inputContainerStyle={inputContainerStyle}\n focused={focused}\n disabled={disabled}\n variant={variant}\n value={value}\n hintComponent={hintComponent}\n hint={hint}\n style={style}\n TextComponent={Text}\n maxLength={maxLength}\n >\n <StyledWebInput\n {...rest}\n fontStack={inputFontStack}\n fontWeight={inputFontWeight}\n disabled={disabled}\n onFocus={handleFocus}\n onBlur={handleBlur}\n textAlignVertical={'top'}\n multiline\n value={value}\n maxLength={maxLength}\n />\n </TACore>\n );\n};\n\nexport default TextArea;\n"],"names":["TACore"],"mappings":";;;;AAWA,MAAM,WAA8B,CAAC;AAAA,EACnC,KAAA;AAAA,EACA,UAAA;AAAA,EACA,iBAAA;AAAA,EACA,cAAA;AAAA,EACA,eAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA,aAAA;AAAA,EACA,cAAA;AAAA,EACA,QAAA;AAAA,EACA,KAAA;AAAA,EACA,WAAA;AAAA,EACA,oBAAA;AAAA,EACA,cAAiB,GAAA,SAAA;AAAA,EACjB,eAAkB,GAAA,MAAA;AAAA,EAClB,mBAAA;AAAA,EACA,OAAU,GAAA,SAAA;AAAA,EACV,aAAA;AAAA,EACA,IAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,KAAA;AAAA,EACA,SAAA;AAAA,EACG,GAAA,IAAA;AACL,CAAM,KAAA;AACJ,EAAA,MAAM,EAAE,OAAA,EAAS,UAAY,EAAA,WAAA,EAAgB,GAAA,aAAA;AAAA,IAC3C,OAAA;AAAA,IACA,MAAA;AAAA,IACA,CAAC,QAAA;AAAA,GACH,CAAA;AAEA,EAAA,uBACG,KAAA,CAAA,aAAA,CAAAA,UAAA,EAAA;AAAA,IACC,KAAA;AAAA,IACA,UAAA;AAAA,IACA,iBAAA;AAAA,IACA,cAAA;AAAA,IACA,eAAA;AAAA,IACA,UAAA;AAAA,IACA,WAAA;AAAA,IACA,cAAgB,EAAA,IAAA;AAAA,IAChB,aAAA;AAAA,IACA,cAAA;AAAA,IACA,WAAA;AAAA,IACA,oBAAA;AAAA,IACA,mBAAA;AAAA,IACA,OAAA;AAAA,IACA,QAAA;AAAA,IACA,OAAA;AAAA,IACA,KAAA;AAAA,IACA,aAAA;AAAA,IACA,IAAA;AAAA,IACA,KAAA;AAAA,IACA,aAAe,EAAA,IAAA;AAAA,IACf,SAAA;AAAA,GAAA,kBAEC,KAAA,CAAA,aAAA,CAAA,cAAA,EAAA;AAAA,IACE,GAAG,IAAA;AAAA,IACJ,SAAW,EAAA,cAAA;AAAA,IACX,UAAY,EAAA,eAAA;AAAA,IACZ,QAAA;AAAA,IACA,OAAS,EAAA,WAAA;AAAA,IACT,MAAQ,EAAA,UAAA;AAAA,IACR,iBAAmB,EAAA,KAAA;AAAA,IACnB,SAAS,EAAA,IAAA;AAAA,IACT,KAAA;AAAA,IACA,SAAA;AAAA,GACF,CACF,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"TextArea.js","sources":["../../../../../src/components/molecules/TextArea/TextArea.tsx"],"sourcesContent":["import React, { FC } from 'react';\nimport {\n useInputFocus,\n TextAreaProps as ITACore,\n TextArea as TACore,\n Text,\n} from '@tecsinapse/react-core';\nimport { StyledWebInput } from './styled';\n\nexport type TextAreaProps = Omit<ITACore, 'TextComponent' | 'focused'>;\n\nconst TextArea: FC<TextAreaProps> = ({\n label,\n labelColor,\n labelColorVariant,\n labelColorTone,\n labelTypography,\n labelStack,\n labelWeight,\n leftComponent,\n rightComponent,\n disabled,\n style,\n borderColor,\n borderColorGradation,\n inputFontStack = 'default',\n inputFontWeight = 'bold',\n inputContainerStyle,\n variant = 'default',\n hintComponent,\n hint,\n onFocus,\n onBlur,\n value,\n maxLength,\n ...rest\n}) => {\n const { focused, handleBlur, handleFocus } = useInputFocus(\n onFocus,\n onBlur,\n !disabled\n );\n\n return (\n <TACore\n label={label}\n labelColor={labelColor}\n labelColorVariant={labelColorVariant}\n labelColorTone={labelColorTone}\n labelTypography={labelTypography}\n labelStack={labelStack}\n labelWeight={labelWeight}\n LabelComponent={Text}\n leftComponent={leftComponent}\n rightComponent={rightComponent}\n borderColor={borderColor}\n borderColorGradation={borderColorGradation}\n inputContainerStyle={inputContainerStyle}\n focused={focused}\n disabled={disabled}\n variant={variant}\n value={value}\n hintComponent={hintComponent}\n hint={hint}\n style={style}\n TextComponent={Text}\n maxLength={maxLength}\n >\n <StyledWebInput\n {...rest}\n fontStack={inputFontStack}\n fontWeight={inputFontWeight}\n disabled={disabled}\n onFocus={handleFocus}\n onBlur={handleBlur}\n textAlignVertical={'top'}\n multiline\n value={value}\n maxLength={maxLength}\n />\n </TACore>\n );\n};\n\nexport default TextArea;\n"],"names":["TACore"],"mappings":";;;;AAWA,MAAM,WAA8B,CAAC;AAAA,EACnC,KAAA;AAAA,EACA,UAAA;AAAA,EACA,iBAAA;AAAA,EACA,cAAA;AAAA,EACA,eAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA,aAAA;AAAA,EACA,cAAA;AAAA,EACA,QAAA;AAAA,EACA,KAAA;AAAA,EACA,WAAA;AAAA,EACA,oBAAA;AAAA,EACA,cAAiB,GAAA,SAAA;AAAA,EACjB,eAAkB,GAAA,MAAA;AAAA,EAClB,mBAAA;AAAA,EACA,OAAU,GAAA,SAAA;AAAA,EACV,aAAA;AAAA,EACA,IAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,KAAA;AAAA,EACA,SAAA;AAAA,EACA,GAAG,IAAA;AACL,CAAM,KAAA;AACJ,EAAA,MAAM,EAAE,OAAA,EAAS,UAAY,EAAA,WAAA,EAAgB,GAAA,aAAA;AAAA,IAC3C,OAAA;AAAA,IACA,MAAA;AAAA,IACA,CAAC,QAAA;AAAA,GACH,CAAA;AAEA,EACE,uBAAA,KAAA,CAAA,aAAA;AAAA,IAACA,UAAA;AAAA,IAAA;AAAA,MACC,KAAA;AAAA,MACA,UAAA;AAAA,MACA,iBAAA;AAAA,MACA,cAAA;AAAA,MACA,eAAA;AAAA,MACA,UAAA;AAAA,MACA,WAAA;AAAA,MACA,cAAgB,EAAA,IAAA;AAAA,MAChB,aAAA;AAAA,MACA,cAAA;AAAA,MACA,WAAA;AAAA,MACA,oBAAA;AAAA,MACA,mBAAA;AAAA,MACA,OAAA;AAAA,MACA,QAAA;AAAA,MACA,OAAA;AAAA,MACA,KAAA;AAAA,MACA,aAAA;AAAA,MACA,IAAA;AAAA,MACA,KAAA;AAAA,MACA,aAAe,EAAA,IAAA;AAAA,MACf,SAAA;AAAA,KAAA;AAAA,oBAEA,KAAA,CAAA,aAAA;AAAA,MAAC,cAAA;AAAA,MAAA;AAAA,QACE,GAAG,IAAA;AAAA,QACJ,SAAW,EAAA,cAAA;AAAA,QACX,UAAY,EAAA,eAAA;AAAA,QACZ,QAAA;AAAA,QACA,OAAS,EAAA,WAAA;AAAA,QACT,MAAQ,EAAA,UAAA;AAAA,QACR,iBAAmB,EAAA,KAAA;AAAA,QACnB,SAAS,EAAA,IAAA;AAAA,QACT,KAAA;AAAA,QACA,SAAA;AAAA,OAAA;AAAA,KACF;AAAA,GACF,CAAA;AAEJ;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"styled.js","sources":["../../../../../src/components/molecules/TextArea/styled.ts"],"sourcesContent":["import styled from '@emotion/native';\nimport {\n FontStackType,\n FontWeightType,\n StyleProps,\n TextAreaInputBase,\n} from '@tecsinapse/react-core';\nimport { TextAreaProps } from './TextArea';\n\ninterface Font {\n fontStack?: FontStackType;\n fontWeight?: FontWeightType;\n}\n\nexport const StyledWebInput = styled(TextAreaInputBase)<\n Font & Partial<TextAreaProps> & Partial<StyleProps>\n>`\n font-weight: ${({ theme, fontWeight = 'regular' }) =>\n theme.font.weight[fontWeight]};\n font-family: ${({ theme, fontStack = 'default' }) =>\n `'${theme.font.stack[fontStack]}'`};\n outline-width: 0;\n`;\n"],"names":["styled"],"mappings":";;;AAca,MAAA,cAAA,GAAiBA,aAAO,iBAAiB,CAAA,CAAA;AAAA,eAGrC,EAAA,CAAC,EAAE,KAAO,EAAA,UAAA,GAAa,WACpC,KAAA,KAAA,CAAM,KAAK,MAAO,CAAA,UAAA,CAAA,CAAA;AAAA,eACL,EAAA,CAAC,EAAE,KAAO,EAAA,SAAA,GAAY,WACnC,KAAA,CAAA,CAAA,EAAI,KAAM,CAAA,IAAA,CAAK,KAAM,CAAA,SAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA;AAAA;;;;"}
1
+ {"version":3,"file":"styled.js","sources":["../../../../../src/components/molecules/TextArea/styled.ts"],"sourcesContent":["import styled from '@emotion/native';\nimport {\n FontStackType,\n FontWeightType,\n StyleProps,\n TextAreaInputBase,\n} from '@tecsinapse/react-core';\nimport { TextAreaProps } from './TextArea';\n\ninterface Font {\n fontStack?: FontStackType;\n fontWeight?: FontWeightType;\n}\n\nexport const StyledWebInput = styled(TextAreaInputBase)<\n Font & Partial<TextAreaProps> & Partial<StyleProps>\n>`\n font-weight: ${({ theme, fontWeight = 'regular' }) =>\n theme.font.weight[fontWeight]};\n font-family: ${({ theme, fontStack = 'default' }) =>\n `'${theme.font.stack[fontStack]}'`};\n outline-width: 0;\n`;\n"],"names":["styled"],"mappings":";;;AAca,MAAA,cAAA,GAAiBA,aAAO,iBAAiB,CAAA,CAAA;AAAA,eAGrC,EAAA,CAAC,EAAE,KAAO,EAAA,UAAA,GAAa,WACpC,KAAA,KAAA,CAAM,IAAK,CAAA,MAAA,CAAO,UAAU,CAAA,CAAA;AAAA,eACf,EAAA,CAAC,EAAE,KAAA,EAAO,SAAY,GAAA,SAAA,OACnC,CAAI,CAAA,EAAA,KAAA,CAAM,IAAK,CAAA,KAAA,CAAM,SAAS,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA;AAAA;;;;"}
@@ -25,5 +25,5 @@ export interface DataGridProps<Data> extends React.HTMLAttributes<HTMLDivElement
25
25
  emptyPlaceholder?: React.ReactNode;
26
26
  exportComponent?: React.ReactNode;
27
27
  }
28
- declare const DataGrid: <Data>({ headers, data, rowKeyExtractor, toolbarTitle, toolbarFooter, toolbarRightIcons, selectable, selectedRows, onSelectedRows, pagination, rowsPerPage, onRowsPerPageChange, rowsPerPageOptions, rowsPerPageLabel, exportLabel, exportFunction, rowsCount, page, onPageChange, loading, skeletonComponent, emptyPlaceholder, exportComponent, ...rest }: DataGridProps<Data>) => JSX.Element;
28
+ declare const DataGrid: <Data>({ headers, data, rowKeyExtractor, toolbarTitle, toolbarFooter, toolbarRightIcons, selectable, selectedRows, onSelectedRows, pagination, rowsPerPage, onRowsPerPageChange, rowsPerPageOptions: _rowsPerPageOptions, rowsPerPageLabel: _rowsPerPageLabel, exportLabel, exportFunction, rowsCount, page, onPageChange, loading, skeletonComponent, emptyPlaceholder, exportComponent, ...rest }: DataGridProps<Data>) => JSX.Element;
29
29
  export default DataGrid;
@@ -67,58 +67,55 @@ const DataGrid = ({
67
67
  },
68
68
  [onSelectedRows, rowKeyExtractor]
69
69
  );
70
- return /* @__PURE__ */ React.createElement(TableContainer, {
71
- ...rest
72
- }, /* @__PURE__ */ React.createElement(TableToolbar, {
73
- title: toolbarTitle,
74
- rightIcons: toolbarRightIcons,
75
- footer: toolbarFooter
76
- }), /* @__PURE__ */ React.createElement(Table, null, /* @__PURE__ */ React.createElement(Header, {
77
- selectable,
78
- headers,
79
- data,
80
- rowsCount: rowsCount ?? data.length,
81
- rowKeyExtractor,
82
- selectedRows,
83
- onSelected: onSelectedRows
84
- }), !loading ? /* @__PURE__ */ React.createElement(TBody, null, data.length > 0 ? getData(data, rowsCount, page, rowsPerPage, pagination).map(
85
- (item) => /* @__PURE__ */ React.createElement(Row, {
86
- key: rowKeyExtractor(item),
87
- rowKeyExtractor,
88
- handleSelect,
70
+ return /* @__PURE__ */ React.createElement(TableContainer, { ...rest }, /* @__PURE__ */ React.createElement(
71
+ TableToolbar,
72
+ {
73
+ title: toolbarTitle,
74
+ rightIcons: toolbarRightIcons,
75
+ footer: toolbarFooter
76
+ }
77
+ ), /* @__PURE__ */ React.createElement(Table, null, /* @__PURE__ */ React.createElement(
78
+ Header,
79
+ {
89
80
  selectable,
90
81
  headers,
91
- data: item,
92
- checked: selectedRows?.some(
93
- (sel) => rowKeyExtractor(sel) === rowKeyExtractor(item)
94
- )
95
- })
96
- ) : /* @__PURE__ */ React.createElement("tr", null, /* @__PURE__ */ React.createElement("td", {
97
- colSpan: 99
98
- }, emptyPlaceholder))) : /* @__PURE__ */ React.createElement(TBody, null, [...Array(rowsPerPage).keys()].map((idx) => /* @__PURE__ */ React.createElement(Tr, {
99
- key: `skeleton-${idx}`
100
- }, /* @__PURE__ */ React.createElement(Td, {
101
- colSpan: 99,
102
- style: { padding: 0 }
103
- }, skeletonComponent ?? /* @__PURE__ */ React.createElement(Skeleton, {
104
- height: 55,
105
- radius: "mili",
106
- animation: "wave"
107
- }, /* @__PURE__ */ React.createElement("div", {
108
- style: { width: "100%" }
109
- })))))), (Number(rowsCount) > 0 || data.length > 0) && /* @__PURE__ */ React.createElement(Footer, {
110
- exportFunction,
111
- exportLabel,
112
- rowsPerPageLabel,
113
- rowsPerPage,
114
- onRowsPerPageChange,
115
- rowsPerPageOptions,
116
- rowsCount: rowsCount ?? data.length,
117
- page,
118
- onPageChange,
119
- pagination,
120
- exportComponent
121
- })));
82
+ data,
83
+ rowsCount: rowsCount ?? data.length,
84
+ rowKeyExtractor,
85
+ selectedRows,
86
+ onSelected: onSelectedRows
87
+ }
88
+ ), !loading ? /* @__PURE__ */ React.createElement(TBody, null, data.length > 0 ? getData(data, rowsCount, page, rowsPerPage, pagination).map(
89
+ (item) => /* @__PURE__ */ React.createElement(
90
+ Row,
91
+ {
92
+ key: rowKeyExtractor(item),
93
+ rowKeyExtractor,
94
+ handleSelect,
95
+ selectable,
96
+ headers,
97
+ data: item,
98
+ checked: selectedRows?.some(
99
+ (sel) => rowKeyExtractor(sel) === rowKeyExtractor(item)
100
+ )
101
+ }
102
+ )
103
+ ) : /* @__PURE__ */ React.createElement("tr", null, /* @__PURE__ */ React.createElement("td", { colSpan: 99 }, emptyPlaceholder))) : /* @__PURE__ */ React.createElement(TBody, null, [...Array(rowsPerPage).keys()].map((idx) => /* @__PURE__ */ React.createElement(Tr, { key: `skeleton-${idx}` }, /* @__PURE__ */ React.createElement(Td, { colSpan: 99, style: { padding: 0 } }, skeletonComponent ?? /* @__PURE__ */ React.createElement(Skeleton, { height: 55, radius: "mili", animation: "wave" }, /* @__PURE__ */ React.createElement("div", { style: { width: "100%" } })))))), (Number(rowsCount) > 0 || data.length > 0) && /* @__PURE__ */ React.createElement(
104
+ Footer,
105
+ {
106
+ exportFunction,
107
+ exportLabel,
108
+ rowsPerPageLabel,
109
+ rowsPerPage,
110
+ onRowsPerPageChange,
111
+ rowsPerPageOptions,
112
+ rowsCount: rowsCount ?? data.length,
113
+ page,
114
+ onPageChange,
115
+ pagination,
116
+ exportComponent
117
+ }
118
+ )));
122
119
  };
123
120
 
124
121
  export { DataGrid as default };
@@ -1 +1 @@
1
- {"version":3,"file":"DataGrid.js","sources":["../../../../../src/components/organisms/DataGrid/DataGrid.tsx"],"sourcesContent":["import React from 'react';\nimport {\n Table,\n TableToolbar,\n TableContainer,\n Tr,\n Td,\n TBody,\n} from '../../atoms/Table';\nimport { Header } from './Header';\nimport { Row } from './Row';\nimport { HeadersType } from './types';\nimport { Footer } from './Footer';\nimport { Skeleton } from '../../atoms/Skeleton';\nimport { getData, removeElement } from './utils';\n\nexport interface DataGridProps<Data>\n extends React.HTMLAttributes<HTMLDivElement> {\n headers: HeadersType<Data>[];\n data: Data[];\n /** Unique identifier for row data */\n rowKeyExtractor: (data: Data) => string;\n toolbarRightIcons?: React.ReactNode;\n toolbarFooter?: React.ReactNode;\n toolbarTitle: string;\n /** Enable rows selection */\n selectable?: boolean;\n /** Selected items */\n selectedRows?: Data[];\n /** Selection handler */\n onSelectedRows?: (data: Data[] | ((prevState: Data[]) => Data[])) => void;\n /** Shows pagination controls */\n pagination?: boolean;\n /** Results per page */\n rowsPerPage?: number;\n /** Results per page handler */\n onRowsPerPageChange?: (value: number) => void;\n rowsPerPageOptions?: number[];\n rowsPerPageLabel?: (value: number) => string;\n /** Export button label */\n exportLabel?: string;\n exportFunction?: () => void;\n /** Total data elements. Only specify this property if your data is server-side */\n rowsCount?: number;\n /** Current page. Always start in 0 */\n page?: number;\n /** Current page handler */\n onPageChange?: (page: number) => void;\n /** Loading state. The amount of skeleton rows is based on current rowsPerPage */\n loading?: boolean;\n /** Custom skeleton component for better visual */\n skeletonComponent?: React.ReactNode;\n /** Empty state placeholder */\n emptyPlaceholder?: React.ReactNode;\n /** Export component, use if default button with label is not ideal. This prop, not receive \"exportLabel\" and \"exportFunction\" */\n exportComponent?: React.ReactNode;\n}\n\n/** Note: Consider memoizing functions for a better performance */\nconst DataGrid = <Data,>({\n headers,\n data,\n rowKeyExtractor,\n toolbarTitle,\n toolbarFooter,\n toolbarRightIcons,\n selectable = false,\n selectedRows = [],\n onSelectedRows,\n pagination = false,\n rowsPerPage = 10,\n onRowsPerPageChange,\n rowsPerPageOptions: _rowsPerPageOptions,\n rowsPerPageLabel: _rowsPerPageLabel,\n exportLabel = 'Exportar',\n exportFunction,\n rowsCount,\n page = 0,\n onPageChange,\n loading = false,\n skeletonComponent,\n emptyPlaceholder,\n exportComponent,\n ...rest\n}: DataGridProps<Data>): JSX.Element => {\n if (selectable && (!selectedRows || !onSelectedRows)) {\n throw new Error(\n '[DataGrid] You should specify selection handlers (selectedRows, onSelectedRows)'\n );\n }\n\n const rowsPerPageLabel = React.useCallback(\n value =>\n _rowsPerPageLabel\n ? _rowsPerPageLabel(value)\n : `Exibir por página: ${value} itens`,\n [_rowsPerPageLabel]\n );\n const rowsPerPageOptions = React.useMemo(\n () => _rowsPerPageOptions ?? [10, 25, 50],\n [_rowsPerPageOptions]\n );\n\n const handleSelect = React.useCallback(\n (current, checked) => {\n if (checked) {\n onSelectedRows?.(prevState => [...prevState, current]);\n return;\n }\n\n onSelectedRows?.(prevState => {\n const idx = prevState.findIndex(\n el => rowKeyExtractor(el) === rowKeyExtractor(current)\n );\n return [...removeElement(prevState, idx)];\n });\n },\n [onSelectedRows, rowKeyExtractor]\n );\n\n return (\n <TableContainer {...rest}>\n <TableToolbar\n title={toolbarTitle}\n rightIcons={toolbarRightIcons}\n footer={toolbarFooter}\n />\n <Table>\n <Header\n selectable={selectable}\n headers={headers}\n data={data}\n rowsCount={rowsCount ?? data.length}\n rowKeyExtractor={rowKeyExtractor}\n selectedRows={selectedRows}\n onSelected={onSelectedRows}\n />\n\n {!loading ? (\n <TBody>\n {data.length > 0 ? (\n getData(data, rowsCount, page, rowsPerPage, pagination).map(\n item => (\n <Row\n key={rowKeyExtractor(item)}\n rowKeyExtractor={rowKeyExtractor}\n handleSelect={handleSelect}\n selectable={selectable}\n headers={headers}\n data={item}\n checked={selectedRows?.some(\n sel => rowKeyExtractor(sel) === rowKeyExtractor(item)\n )}\n />\n )\n )\n ) : (\n <tr>\n <td colSpan={99}>{emptyPlaceholder}</td>\n </tr>\n )}\n </TBody>\n ) : (\n <TBody>\n {[...Array(rowsPerPage).keys()].map(idx => (\n <Tr key={`skeleton-${idx}`}>\n <Td colSpan={99} style={{ padding: 0 }}>\n {skeletonComponent ?? (\n <Skeleton height={55} radius=\"mili\" animation=\"wave\">\n <div style={{ width: '100%' }} />\n </Skeleton>\n )}\n </Td>\n </Tr>\n ))}\n </TBody>\n )}\n\n {(Number(rowsCount) > 0 || data.length > 0) && (\n <Footer\n exportFunction={exportFunction}\n exportLabel={exportLabel}\n rowsPerPageLabel={rowsPerPageLabel}\n rowsPerPage={rowsPerPage}\n onRowsPerPageChange={onRowsPerPageChange}\n rowsPerPageOptions={rowsPerPageOptions}\n rowsCount={rowsCount ?? data.length}\n page={page}\n onPageChange={onPageChange}\n pagination={pagination}\n exportComponent={exportComponent}\n />\n )}\n </Table>\n </TableContainer>\n );\n};\n\nexport default DataGrid;\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"DataGrid.js","sources":["../../../../../src/components/organisms/DataGrid/DataGrid.tsx"],"sourcesContent":["import React from 'react';\nimport {\n Table,\n TableToolbar,\n TableContainer,\n Tr,\n Td,\n TBody,\n} from '../../atoms/Table';\nimport { Header } from './Header';\nimport { Row } from './Row';\nimport { HeadersType } from './types';\nimport { Footer } from './Footer';\nimport { Skeleton } from '../../atoms/Skeleton';\nimport { getData, removeElement } from './utils';\n\nexport interface DataGridProps<Data>\n extends React.HTMLAttributes<HTMLDivElement> {\n headers: HeadersType<Data>[];\n data: Data[];\n /** Unique identifier for row data */\n rowKeyExtractor: (data: Data) => string;\n toolbarRightIcons?: React.ReactNode;\n toolbarFooter?: React.ReactNode;\n toolbarTitle: string;\n /** Enable rows selection */\n selectable?: boolean;\n /** Selected items */\n selectedRows?: Data[];\n /** Selection handler */\n onSelectedRows?: (data: Data[] | ((prevState: Data[]) => Data[])) => void;\n /** Shows pagination controls */\n pagination?: boolean;\n /** Results per page */\n rowsPerPage?: number;\n /** Results per page handler */\n onRowsPerPageChange?: (value: number) => void;\n rowsPerPageOptions?: number[];\n rowsPerPageLabel?: (value: number) => string;\n /** Export button label */\n exportLabel?: string;\n exportFunction?: () => void;\n /** Total data elements. Only specify this property if your data is server-side */\n rowsCount?: number;\n /** Current page. Always start in 0 */\n page?: number;\n /** Current page handler */\n onPageChange?: (page: number) => void;\n /** Loading state. The amount of skeleton rows is based on current rowsPerPage */\n loading?: boolean;\n /** Custom skeleton component for better visual */\n skeletonComponent?: React.ReactNode;\n /** Empty state placeholder */\n emptyPlaceholder?: React.ReactNode;\n /** Export component, use if default button with label is not ideal. This prop, not receive \"exportLabel\" and \"exportFunction\" */\n exportComponent?: React.ReactNode;\n}\n\n/** Note: Consider memoizing functions for a better performance */\nconst DataGrid = <Data,>({\n headers,\n data,\n rowKeyExtractor,\n toolbarTitle,\n toolbarFooter,\n toolbarRightIcons,\n selectable = false,\n selectedRows = [],\n onSelectedRows,\n pagination = false,\n rowsPerPage = 10,\n onRowsPerPageChange,\n rowsPerPageOptions: _rowsPerPageOptions,\n rowsPerPageLabel: _rowsPerPageLabel,\n exportLabel = 'Exportar',\n exportFunction,\n rowsCount,\n page = 0,\n onPageChange,\n loading = false,\n skeletonComponent,\n emptyPlaceholder,\n exportComponent,\n ...rest\n}: DataGridProps<Data>): JSX.Element => {\n if (selectable && (!selectedRows || !onSelectedRows)) {\n throw new Error(\n '[DataGrid] You should specify selection handlers (selectedRows, onSelectedRows)'\n );\n }\n\n const rowsPerPageLabel = React.useCallback(\n value =>\n _rowsPerPageLabel\n ? _rowsPerPageLabel(value)\n : `Exibir por página: ${value} itens`,\n [_rowsPerPageLabel]\n );\n const rowsPerPageOptions = React.useMemo(\n () => _rowsPerPageOptions ?? [10, 25, 50],\n [_rowsPerPageOptions]\n );\n\n const handleSelect = React.useCallback(\n (current, checked) => {\n if (checked) {\n onSelectedRows?.(prevState => [...prevState, current]);\n return;\n }\n\n onSelectedRows?.(prevState => {\n const idx = prevState.findIndex(\n el => rowKeyExtractor(el) === rowKeyExtractor(current)\n );\n return [...removeElement(prevState, idx)];\n });\n },\n [onSelectedRows, rowKeyExtractor]\n );\n\n return (\n <TableContainer {...rest}>\n <TableToolbar\n title={toolbarTitle}\n rightIcons={toolbarRightIcons}\n footer={toolbarFooter}\n />\n <Table>\n <Header\n selectable={selectable}\n headers={headers}\n data={data}\n rowsCount={rowsCount ?? data.length}\n rowKeyExtractor={rowKeyExtractor}\n selectedRows={selectedRows}\n onSelected={onSelectedRows}\n />\n\n {!loading ? (\n <TBody>\n {data.length > 0 ? (\n getData(data, rowsCount, page, rowsPerPage, pagination).map(\n item => (\n <Row\n key={rowKeyExtractor(item)}\n rowKeyExtractor={rowKeyExtractor}\n handleSelect={handleSelect}\n selectable={selectable}\n headers={headers}\n data={item}\n checked={selectedRows?.some(\n sel => rowKeyExtractor(sel) === rowKeyExtractor(item)\n )}\n />\n )\n )\n ) : (\n <tr>\n <td colSpan={99}>{emptyPlaceholder}</td>\n </tr>\n )}\n </TBody>\n ) : (\n <TBody>\n {[...Array(rowsPerPage).keys()].map(idx => (\n <Tr key={`skeleton-${idx}`}>\n <Td colSpan={99} style={{ padding: 0 }}>\n {skeletonComponent ?? (\n <Skeleton height={55} radius=\"mili\" animation=\"wave\">\n <div style={{ width: '100%' }} />\n </Skeleton>\n )}\n </Td>\n </Tr>\n ))}\n </TBody>\n )}\n\n {(Number(rowsCount) > 0 || data.length > 0) && (\n <Footer\n exportFunction={exportFunction}\n exportLabel={exportLabel}\n rowsPerPageLabel={rowsPerPageLabel}\n rowsPerPage={rowsPerPage}\n onRowsPerPageChange={onRowsPerPageChange}\n rowsPerPageOptions={rowsPerPageOptions}\n rowsCount={rowsCount ?? data.length}\n page={page}\n onPageChange={onPageChange}\n pagination={pagination}\n exportComponent={exportComponent}\n />\n )}\n </Table>\n </TableContainer>\n );\n};\n\nexport default DataGrid;\n"],"names":[],"mappings":"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"}
@@ -51,51 +51,63 @@ const Footer = ({
51
51
  );
52
52
  const currentInitItem = page * rowsPerPage + 1;
53
53
  const currentFinalItem = (page + 1) * rowsPerPage > rowsCount ? rowsCount : (page + 1) * rowsPerPage;
54
- return /* @__PURE__ */ React.createElement(TFoot, null, /* @__PURE__ */ React.createElement(Tr, null, /* @__PURE__ */ React.createElement(TdFooterStyled, {
55
- colSpan: 99
56
- }, /* @__PURE__ */ React.createElement(FooterContainer, null, /* @__PURE__ */ React.createElement(FooterContainerStart, null, pagination && /* @__PURE__ */ React.createElement(SelectContainer, null, /* @__PURE__ */ React.createElement(Select, {
57
- options: rowsPerPageOptions,
58
- onSelect: handleRowsPerPage,
59
- value: rowsPerPage,
60
- type: "single",
61
- keyExtractor: (value) => String(value),
62
- labelExtractor: rowsPerPageLabel,
63
- anchor: "top"
64
- })), exportComponent && !exportFunction && /* @__PURE__ */ React.createElement(React.Fragment, null, exportComponent), exportFunction && /* @__PURE__ */ React.createElement(HoveredText, null, /* @__PURE__ */ React.createElement(Button, {
65
- variant: "outlined",
66
- onPress: () => exportFunction()
67
- }, /* @__PURE__ */ React.createElement(Text, {
68
- fontColor: "orange",
69
- fontWeight: "bold"
70
- }, exportLabel)))), pagination && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(TextPagination, {
71
- fontWeight: "bold",
72
- fontColor: "medium"
73
- }, `Exibindo ${currentInitItem} a ${currentFinalItem} de ${rowsCount} registros`), /* @__PURE__ */ React.createElement(FooterContainerEnd, null, /* @__PURE__ */ React.createElement(NavigationButton, {
74
- onPress: () => onPageChange?.(page - 1),
75
- disabled: page === 0
76
- }, /* @__PURE__ */ React.createElement(Icon, {
77
- name: "chevron-left",
78
- type: "material-community",
79
- fontColor: "light"
80
- })), /* @__PURE__ */ React.createElement(PagesContainer, null, [...Array(Math.ceil(rowsCount / rowsPerPage)).keys()].slice(
54
+ return /* @__PURE__ */ React.createElement(TFoot, null, /* @__PURE__ */ React.createElement(Tr, null, /* @__PURE__ */ React.createElement(TdFooterStyled, { colSpan: 99 }, /* @__PURE__ */ React.createElement(FooterContainer, null, /* @__PURE__ */ React.createElement(FooterContainerStart, null, pagination && /* @__PURE__ */ React.createElement(SelectContainer, null, /* @__PURE__ */ React.createElement(
55
+ Select,
56
+ {
57
+ options: rowsPerPageOptions,
58
+ onSelect: handleRowsPerPage,
59
+ value: rowsPerPage,
60
+ type: "single",
61
+ keyExtractor: (value) => String(value),
62
+ labelExtractor: rowsPerPageLabel,
63
+ anchor: "top"
64
+ }
65
+ )), exportComponent && !exportFunction && /* @__PURE__ */ React.createElement(React.Fragment, null, exportComponent), exportFunction && /* @__PURE__ */ React.createElement(HoveredText, null, /* @__PURE__ */ React.createElement(Button, { variant: "outlined", onPress: () => exportFunction() }, /* @__PURE__ */ React.createElement(Text, { fontColor: "orange", fontWeight: "bold" }, exportLabel)))), pagination && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
66
+ TextPagination,
67
+ {
68
+ fontWeight: "bold",
69
+ fontColor: "medium"
70
+ },
71
+ `Exibindo ${currentInitItem} a ${currentFinalItem} de ${rowsCount} registros`
72
+ ), /* @__PURE__ */ React.createElement(FooterContainerEnd, null, /* @__PURE__ */ React.createElement(
73
+ NavigationButton,
74
+ {
75
+ onPress: () => onPageChange?.(page - 1),
76
+ disabled: page === 0
77
+ },
78
+ /* @__PURE__ */ React.createElement(
79
+ Icon,
80
+ {
81
+ name: "chevron-left",
82
+ type: "material-community",
83
+ fontColor: "light"
84
+ }
85
+ )
86
+ ), /* @__PURE__ */ React.createElement(PagesContainer, null, [...Array(Math.ceil(rowsCount / rowsPerPage)).keys()].slice(
81
87
  getPaginationSlice().start,
82
88
  getPaginationSlice().end
83
- ).map((value) => /* @__PURE__ */ React.createElement(HoveredText, {
84
- key: `page-${value}`
85
- }, /* @__PURE__ */ React.createElement(PageButton, {
86
- variant: page === value ? "outlined" : "text",
87
- onPress: () => onPageChange?.(value)
88
- }, /* @__PURE__ */ React.createElement(Text, {
89
- fontColor: "medium",
90
- fontWeight: "bold"
91
- }, value + 1))))), /* @__PURE__ */ React.createElement(NavigationButton, {
92
- onPress: () => onPageChange?.(page + 1),
93
- disabled: page === Math.ceil(rowsCount / rowsPerPage) - 1
94
- }, /* @__PURE__ */ React.createElement(Icon, {
95
- name: "chevron-right",
96
- type: "material-community",
97
- fontColor: "light"
98
- }))))))));
89
+ ).map((value) => /* @__PURE__ */ React.createElement(HoveredText, { key: `page-${value}` }, /* @__PURE__ */ React.createElement(
90
+ PageButton,
91
+ {
92
+ variant: page === value ? "outlined" : "text",
93
+ onPress: () => onPageChange?.(value)
94
+ },
95
+ /* @__PURE__ */ React.createElement(Text, { fontColor: "medium", fontWeight: "bold" }, value + 1)
96
+ )))), /* @__PURE__ */ React.createElement(
97
+ NavigationButton,
98
+ {
99
+ onPress: () => onPageChange?.(page + 1),
100
+ disabled: page === Math.ceil(rowsCount / rowsPerPage) - 1
101
+ },
102
+ /* @__PURE__ */ React.createElement(
103
+ Icon,
104
+ {
105
+ name: "chevron-right",
106
+ type: "material-community",
107
+ fontColor: "light"
108
+ }
109
+ )
110
+ )))))));
99
111
  };
100
112
  var Footer$1 = React.memo(Footer);
101
113