@addev-be/ui 0.21.3 → 0.21.4

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 (260) hide show
  1. package/dist/Icons.d.ts +11 -1
  2. package/dist/Icons.js +22 -1
  3. package/dist/components/auth/LoginForm.js +1 -1
  4. package/dist/components/auth/PasswordRecoveryForm.js +1 -1
  5. package/dist/components/auth/PasswordResetForm.js +1 -1
  6. package/dist/components/data/DataGrid/DataGridCell.d.ts +1 -1
  7. package/dist/components/data/DataGrid/DataGridCell.js +9 -9
  8. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.d.ts +2 -2
  9. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.js +1 -7
  10. package/dist/components/data/DataGrid/DataGridColumnsModal/hooks.js +3 -3
  11. package/dist/components/data/DataGrid/DataGridColumnsModal/index.js +16 -21
  12. package/dist/components/data/DataGrid/DataGridColumnsModal/styles.js +2 -2
  13. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.d.ts +2 -0
  14. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.js +23 -0
  15. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.d.ts +2 -0
  16. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.js +27 -0
  17. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.d.ts +7 -0
  18. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.js +34 -0
  19. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.d.ts +2 -0
  20. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.js +23 -0
  21. package/dist/components/data/DataGrid/DataGridEditableCell/index.d.ts +2 -0
  22. package/dist/components/data/DataGrid/DataGridEditableCell/index.js +91 -0
  23. package/dist/components/data/DataGrid/DataGridEditableCell/styles.d.ts +3 -0
  24. package/dist/components/data/DataGrid/DataGridEditableCell/styles.js +17 -0
  25. package/dist/components/data/DataGrid/DataGridEditableCell/types.d.ts +11 -0
  26. package/dist/components/data/DataGrid/DataGridEditableCell/types.js +3 -0
  27. package/dist/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.js +17 -2
  28. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.d.ts +4 -3
  29. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.js +11 -12
  30. package/dist/components/data/DataGrid/DataGridFilterMenu/index.d.ts +5 -4
  31. package/dist/components/data/DataGrid/DataGridFilterMenu/index.js +44 -41
  32. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.js +5 -5
  33. package/dist/components/data/DataGrid/DataGridFooter.js +5 -7
  34. package/dist/components/data/DataGrid/DataGridHeader.js +3 -19
  35. package/dist/components/data/DataGrid/DataGridHeaderCell.d.ts +1 -1
  36. package/dist/components/data/DataGrid/DataGridHeaderCell.js +11 -24
  37. package/dist/components/data/DataGrid/DataGridRowTemplate.d.ts +1 -1
  38. package/dist/components/data/DataGrid/DataGridRowTemplate.js +10 -9
  39. package/dist/components/data/DataGrid/DataGridToolbar.d.ts +4 -0
  40. package/dist/components/data/DataGrid/DataGridToolbar.js +131 -0
  41. package/dist/components/data/DataGrid/FilterModalContent/index.js +1 -2
  42. package/dist/components/data/DataGrid/constants.d.ts +6 -0
  43. package/dist/components/data/DataGrid/constants.js +9 -0
  44. package/dist/components/data/DataGrid/helpers/columns.d.ts +13 -12
  45. package/dist/components/data/DataGrid/helpers/columns.js +100 -130
  46. package/dist/components/data/DataGrid/hooks/index.d.ts +3 -3
  47. package/dist/components/data/DataGrid/hooks/index.js +8 -12
  48. package/dist/components/data/DataGrid/hooks/useDataGrid.js +73 -24
  49. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.d.ts +9 -0
  50. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.js +91 -0
  51. package/dist/components/data/DataGrid/hooks/useDataGridCopy.js +25 -30
  52. package/dist/components/data/DataGrid/hooks/useRefreshModal.d.ts +5 -0
  53. package/dist/components/data/DataGrid/hooks/useRefreshModal.js +25 -0
  54. package/dist/components/data/DataGrid/index.d.ts +41 -3
  55. package/dist/components/data/DataGrid/index.js +32 -5
  56. package/dist/components/data/DataGrid/styles.d.ts +16 -8
  57. package/dist/components/data/DataGrid/styles.js +65 -34
  58. package/dist/components/data/DataGrid/types.d.ts +91 -21
  59. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.d.ts +2 -0
  60. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.js +19 -0
  61. package/dist/components/data/SqlRequestDataGrid/helpers/columns.d.ts +16 -17
  62. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +235 -84
  63. package/dist/components/data/SqlRequestDataGrid/index.d.ts +2 -2
  64. package/dist/components/data/SqlRequestDataGrid/index.js +99 -74
  65. package/dist/components/data/SqlRequestDataGrid/styles.d.ts +2 -0
  66. package/dist/components/data/SqlRequestDataGrid/styles.js +14 -0
  67. package/dist/components/data/SqlRequestDataGrid/types.d.ts +13 -3
  68. package/dist/components/data/SqlRequestDataGrid/types.js +1 -0
  69. package/dist/components/data/SqlRequestForeignList/index.d.ts +4 -0
  70. package/dist/components/data/SqlRequestForeignList/index.js +132 -0
  71. package/dist/components/data/SqlRequestForeignList/styles.d.ts +9 -0
  72. package/dist/components/data/SqlRequestForeignList/styles.js +22 -0
  73. package/dist/components/data/SqlRequestForeignList/types.d.ts +22 -0
  74. package/dist/components/data/SqlRequestForeignList/types.js +2 -0
  75. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.d.ts +10 -0
  76. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.js +50 -0
  77. package/dist/components/data/SqlRequestGrid/filters/styles.d.ts +4 -0
  78. package/dist/components/data/SqlRequestGrid/filters/styles.js +17 -0
  79. package/dist/components/data/SqlRequestGrid/index.d.ts +1 -1
  80. package/dist/components/data/SqlRequestGrid/index.js +139 -50
  81. package/dist/components/data/SqlRequestGrid/styles.d.ts +0 -12
  82. package/dist/components/data/SqlRequestGrid/styles.js +4 -20
  83. package/dist/components/data/SqlRequestGrid/types.d.ts +14 -4
  84. package/dist/components/data/SqlRequestGrid/types.js +0 -1
  85. package/dist/components/data/VirtualScroller/index.d.ts +4 -3
  86. package/dist/components/data/VirtualScroller/index.js +15 -6
  87. package/dist/components/data/VirtualScroller/styles.d.ts +4 -2
  88. package/dist/components/data/VirtualScroller/styles.js +9 -7
  89. package/dist/components/data/VirtualScroller/types.js +0 -1
  90. package/dist/components/data/index.d.ts +1 -2
  91. package/dist/components/data/index.js +1 -2
  92. package/dist/components/forms/AutoTextArea.d.ts +10 -0
  93. package/dist/components/forms/AutoTextArea.js +41 -0
  94. package/dist/components/forms/Button.d.ts +11 -4
  95. package/dist/components/forms/Button.js +15 -9
  96. package/dist/components/forms/Form/Checkbox.d.ts +3 -0
  97. package/dist/components/forms/Form/Checkbox.js +33 -0
  98. package/dist/components/forms/Form/FormGroup.d.ts +11 -0
  99. package/dist/components/forms/Form/FormGroup.js +10 -0
  100. package/dist/components/forms/Form/Input.d.ts +3 -0
  101. package/dist/components/forms/Form/Input.js +33 -0
  102. package/dist/components/forms/Form/Row.d.ts +9 -0
  103. package/dist/components/forms/Form/Row.js +10 -0
  104. package/dist/components/forms/Form/Select.d.ts +13 -0
  105. package/dist/components/forms/Form/Select.js +51 -0
  106. package/dist/components/forms/Form/TextArea.d.ts +4 -0
  107. package/dist/components/forms/Form/TextArea.js +34 -0
  108. package/dist/components/forms/Form/index.d.ts +75 -0
  109. package/dist/components/forms/Form/index.js +29 -0
  110. package/dist/components/forms/Form/styles.d.ts +19 -0
  111. package/dist/components/forms/Form/styles.js +49 -0
  112. package/dist/components/forms/IconButton.d.ts +9 -4
  113. package/dist/components/forms/IconButton.js +15 -15
  114. package/dist/components/forms/NumberInput.d.ts +9 -0
  115. package/dist/components/forms/NumberInput.js +40 -0
  116. package/dist/components/forms/Select.d.ts +5 -6
  117. package/dist/components/forms/Select.js +2 -5
  118. package/dist/components/forms/index.d.ts +4 -0
  119. package/dist/components/forms/index.js +4 -0
  120. package/dist/components/forms/styles.d.ts +17 -3
  121. package/dist/components/forms/styles.js +8 -7
  122. package/dist/components/layout/Columns.d.ts +7 -0
  123. package/dist/components/layout/Columns.js +21 -0
  124. package/dist/components/layout/Dropdown/index.d.ts +1 -0
  125. package/dist/components/layout/Dropdown/index.js +24 -3
  126. package/dist/components/layout/Dropdown/styles.js +1 -1
  127. package/dist/components/layout/Flexbox.d.ts +11 -0
  128. package/dist/components/layout/Flexbox.js +26 -0
  129. package/dist/components/layout/Grid/index.d.ts +6 -0
  130. package/dist/components/layout/Grid/index.js +6 -0
  131. package/dist/components/layout/Grid/styles.d.ts +14 -0
  132. package/dist/components/layout/Grid/styles.js +29 -0
  133. package/dist/components/layout/Masonry/index.d.ts +3 -0
  134. package/dist/components/layout/Masonry/index.js +20 -0
  135. package/dist/components/layout/Masonry/styles.d.ts +5 -0
  136. package/dist/components/layout/Masonry/styles.js +17 -0
  137. package/dist/components/layout/Modal/styles.js +4 -4
  138. package/dist/components/layout/index.d.ts +5 -1
  139. package/dist/components/layout/index.js +5 -1
  140. package/dist/components/search/HighlightedText.js +9 -7
  141. package/dist/components/search/QuickSearchBar.d.ts +6 -2
  142. package/dist/components/search/QuickSearchBar.js +7 -8
  143. package/dist/components/search/styles.js +5 -5
  144. package/dist/components/search/types.d.ts +3 -0
  145. package/dist/components/ui/Avatar/index.d.ts +10 -0
  146. package/dist/components/ui/Avatar/index.js +52 -0
  147. package/dist/components/ui/Avatar/styles.d.ts +4 -0
  148. package/dist/components/ui/Avatar/styles.js +43 -0
  149. package/dist/components/ui/Card/styles.js +3 -3
  150. package/dist/components/ui/ContextMenu/styles.js +5 -5
  151. package/dist/components/ui/Ellipsis.d.ts +13 -0
  152. package/dist/components/ui/Ellipsis.js +28 -0
  153. package/dist/components/ui/Label.d.ts +10 -0
  154. package/dist/components/ui/Label.js +74 -0
  155. package/dist/components/ui/Message/index.js +1 -1
  156. package/dist/components/ui/TabsView/TabsList.d.ts +10 -0
  157. package/dist/components/ui/TabsView/TabsList.js +40 -0
  158. package/dist/components/ui/TabsView/TabsView.d.ts +9 -0
  159. package/dist/components/ui/TabsView/TabsView.js +17 -0
  160. package/dist/components/ui/TabsView/index.d.ts +3 -0
  161. package/dist/components/ui/TabsView/index.js +19 -0
  162. package/dist/components/ui/TabsView/styles.d.ts +11 -0
  163. package/dist/components/ui/TabsView/styles.js +47 -0
  164. package/dist/components/ui/TabsView/types.d.ts +10 -0
  165. package/dist/components/ui/TabsView/types.js +2 -0
  166. package/dist/components/ui/index.d.ts +4 -0
  167. package/dist/components/ui/index.js +4 -0
  168. package/dist/helpers/components.d.ts +3 -0
  169. package/dist/helpers/components.js +15 -0
  170. package/dist/helpers/index.d.ts +2 -0
  171. package/dist/helpers/index.js +2 -0
  172. package/dist/helpers/numbers.d.ts +3 -0
  173. package/dist/helpers/numbers.js +33 -1
  174. package/dist/helpers/responsive.d.ts +37 -0
  175. package/dist/helpers/responsive.js +57 -0
  176. package/dist/helpers/styled/index.d.ts +1 -0
  177. package/dist/helpers/styled/index.js +17 -0
  178. package/dist/helpers/styled/space.d.ts +39 -0
  179. package/dist/helpers/styled/space.js +90 -0
  180. package/dist/hooks/index.d.ts +5 -0
  181. package/dist/hooks/index.js +5 -0
  182. package/dist/hooks/useContainerMediaQuery.d.ts +17 -0
  183. package/dist/hooks/useContainerMediaQuery.js +10 -0
  184. package/dist/hooks/useMediaQuery.d.ts +17 -0
  185. package/dist/hooks/useMediaQuery.js +11 -0
  186. package/dist/hooks/useMediaQueryForWidth.d.ts +17 -0
  187. package/dist/hooks/useMediaQueryForWidth.js +26 -0
  188. package/dist/hooks/useMutableState.d.ts +2 -0
  189. package/dist/hooks/useMutableState.js +14 -0
  190. package/dist/hooks/useShowArchived.d.ts +6 -0
  191. package/dist/hooks/useShowArchived.js +21 -0
  192. package/dist/index.d.ts +1 -0
  193. package/dist/index.js +1 -0
  194. package/dist/providers/AuthenticationProvider/index.d.ts +1 -0
  195. package/dist/providers/AuthenticationProvider/index.js +57 -15
  196. package/dist/providers/PortalsProvider/styles.js +1 -1
  197. package/dist/providers/ThemeProvider/ThemeProvider.d.ts +1 -0
  198. package/dist/providers/ThemeProvider/ThemeProvider.js +11 -9
  199. package/dist/providers/ThemeProvider/defaultTheme.d.ts +1 -0
  200. package/dist/providers/ThemeProvider/defaultTheme.js +33 -1
  201. package/dist/providers/ThemeProvider/helpers.d.ts +12 -0
  202. package/dist/providers/ThemeProvider/helpers.js +65 -0
  203. package/dist/providers/ThemeProvider/index.d.ts +1 -0
  204. package/dist/providers/ThemeProvider/index.js +1 -0
  205. package/dist/providers/ThemeProvider/types.d.ts +4 -2
  206. package/dist/providers/TrackingProvider/hooks.d.ts +1 -0
  207. package/dist/providers/TrackingProvider/hooks.js +15 -0
  208. package/dist/providers/TrackingProvider/index.d.ts +8 -0
  209. package/dist/providers/TrackingProvider/index.js +41 -0
  210. package/dist/providers/UiProviders/index.d.ts +4 -1
  211. package/dist/providers/UiProviders/index.js +3 -2
  212. package/dist/providers/UiProviders/styles.js +1 -1
  213. package/dist/providers/index.d.ts +2 -0
  214. package/dist/providers/index.js +2 -0
  215. package/dist/services/WebSocketService.d.ts +8 -0
  216. package/dist/services/WebSocketService.js +34 -2
  217. package/dist/services/globalSearch.d.ts +6 -2
  218. package/dist/services/hooks.d.ts +10 -0
  219. package/dist/services/hooks.js +89 -2
  220. package/dist/services/index.d.ts +7 -0
  221. package/dist/services/index.js +20 -0
  222. package/dist/services/requests/generic.d.ts +29 -0
  223. package/dist/services/requests/generic.js +29 -0
  224. package/dist/services/requests/tracking.d.ts +18 -0
  225. package/dist/services/requests/tracking.js +8 -0
  226. package/dist/services/smartQueries.d.ts +51 -0
  227. package/dist/services/smartQueries.js +10 -0
  228. package/dist/services/smartRequests.d.ts +0 -0
  229. package/dist/services/smartRequests.js +1 -0
  230. package/dist/services/types/generic.d.ts +44 -0
  231. package/dist/services/types/generic.js +79 -0
  232. package/dist/services/types/tracking.d.ts +24 -0
  233. package/dist/services/types/tracking.js +47 -0
  234. package/dist/services/updateSqlRequests.d.ts +24 -0
  235. package/dist/services/updateSqlRequests.js +6 -0
  236. package/eslint.config.js +1 -1
  237. package/package.json +2 -2
  238. package/src/components/data/DataGrid/DataGridEditableCell/index.tsx +5 -5
  239. package/src/components/data/DataGrid/DataGridEditableCell/types.ts +3 -3
  240. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +0 -2
  241. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +0 -1
  242. package/src/components/data/DataGrid/DataGridFooter.tsx +0 -3
  243. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +2 -1
  244. package/src/components/data/DataGrid/FilterModalContent/index.tsx +0 -1
  245. package/src/components/data/DataGrid/helpers/columns.tsx +29 -24
  246. package/src/components/data/SqlRequestDataGrid/index.tsx +14 -8
  247. package/src/components/data/SqlRequestForeignList/index.tsx +20 -22
  248. package/src/components/data/SqlRequestForeignList/types.ts +0 -2
  249. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +0 -2
  250. package/src/components/data/SqlRequestGrid/types.ts +0 -2
  251. package/src/components/data/VirtualScroller/types.ts +0 -2
  252. package/src/components/forms/Form/Select.tsx +3 -3
  253. package/src/components/forms/IconButton.tsx +19 -9
  254. package/src/components/forms/Select.tsx +0 -1
  255. package/src/components/search/QuickSearchBar.tsx +0 -1
  256. package/src/components/ui/Label.tsx +18 -9
  257. package/src/helpers/components.ts +23 -0
  258. package/src/services/updateSqlRequests.ts +0 -2
  259. package/src/typings.d.ts +0 -2
  260. package/tsconfig.tsbuildinfo +1 -1
package/dist/Icons.d.ts CHANGED
@@ -1,4 +1,6 @@
1
1
  import { FC, SVGProps } from 'react';
2
+ import AngleLeftIcon from '../assets/icons/angle-left.svg?react';
3
+ import AngleRightIcon from '../assets/icons/angle-right.svg?react';
2
4
  import ArrowDown19Icon from '../assets/icons/arrow-down-1-9.svg?react';
3
5
  import ArrowDownAZIcon from '../assets/icons/arrow-down-a-z.svg?react';
4
6
  import ArrowDownBigSmallIcon from '../assets/icons/arrow-down-big-small.svg?react';
@@ -7,8 +9,11 @@ import ArrowUpBigSmallIcon from '../assets/icons/arrow-up-big-small.svg?react';
7
9
  import ArrowUpZAIcon from '../assets/icons/arrow-up-z-a.svg?react';
8
10
  import ArrowsRotateIcon from '../assets/icons/arrows-rotate.svg?react';
9
11
  import ArrowsUpDownIcon from '../assets/icons/arrows-up-down.svg?react';
12
+ import BarsIcon from '../assets/icons/bars.svg?react';
10
13
  import CheckIcon from '../assets/icons/check.svg?react';
11
14
  import ChevronDownIcon from '../assets/icons/chevron-down.svg?react';
15
+ import ChevronLeftIcon from '../assets/icons/chevron-left.svg?react';
16
+ import ChevronRightIcon from '../assets/icons/chevron-right.svg?react';
12
17
  import CircleCheckIcon from '../assets/icons/circle-check.svg?react';
13
18
  import CircleInfoIcon from '../assets/icons/circle-info.svg?react';
14
19
  import CircleXMarkIcon from '../assets/icons/circle-xmark.svg?react';
@@ -18,6 +23,7 @@ import EllipsisIcon from '../assets/icons/ellipsis.svg?react';
18
23
  import FilterFullIcon from '../assets/icons/filter-full.svg?react';
19
24
  import FilterIcon from '../assets/icons/filter.svg?react';
20
25
  import FilterSlashIcon from '../assets/icons/filter-slash.svg?react';
26
+ import FloppyDiskIcon from '../assets/icons/floppy-disk.svg?react';
21
27
  import HashtagIcon from '../assets/icons/hashtag.svg?react';
22
28
  import ImageSlashIcon from '../assets/icons/image-slash.svg?react';
23
29
  import LeftIcon from '../assets/icons/left.svg?react';
@@ -34,10 +40,13 @@ import TableFooterIcon from '../assets/icons/table-footer.svg?react';
34
40
  import TableFooterSlashIcon from '../assets/icons/table-footer-slash.svg?react';
35
41
  import TableIcon from '../assets/icons/table.svg?react';
36
42
  import TallyIcon from '../assets/icons/tally.svg?react';
43
+ import TrashCanIcon from '../assets/icons/trash-can.svg?react';
37
44
  import TriangleExclamationIcon from '../assets/icons/triangle-exclamation.svg?react';
38
45
  import UpIcon from '../assets/icons/up.svg?react';
39
46
  import UserTieIcon from '../assets/icons/user-tie.svg?react';
40
47
  import XBarIcon from '../assets/icons/x-bar.svg?react';
48
+ import XMarkIcon from '../assets/icons/xmark.svg?react';
49
+ import XMarkLargeIcon from '../assets/icons/xmark-large.svg?react';
41
50
  type IconFCProps = SVGProps<SVGSVGElement>;
42
51
  export type IconFC = FC<IconFCProps>;
43
52
  type AnimatedIconProps = {
@@ -46,4 +55,5 @@ type AnimatedIconProps = {
46
55
  };
47
56
  export declare const AnimatedIcon: FC<AnimatedIconProps & IconFCProps>;
48
57
  export declare const LoadingIcon: FC<IconFCProps>;
49
- export { ArrowDown19Icon, ArrowDownAZIcon, ArrowDownBigSmallIcon, ArrowsRotateIcon, ArrowsUpDownIcon, ArrowUp91Icon, ArrowUpBigSmallIcon, ArrowUpZAIcon, CheckIcon, ChevronDownIcon, CircleXMarkIcon, CopyIcon, DownIcon, EllipsisIcon, FilterFullIcon, FilterIcon, FilterSlashIcon, HashtagIcon, ImageSlashIcon, LeftIcon, MagnifierIcon, PhoneIcon, PlusIcon, RightIcon, SigmaIcon, SortCalendarAscendingIcon, SortCalendarDescendingIcon, SpinnerIcon, TableColumnsIcon, TableFooterIcon, TableFooterSlashIcon, TableIcon, TallyIcon, UpIcon, UserTieIcon, XBarIcon, CircleCheckIcon, CircleInfoIcon, TriangleExclamationIcon, };
58
+ export declare const BlankIcon: FC<IconFCProps>;
59
+ export { AngleLeftIcon, AngleRightIcon, ArrowDown19Icon, ArrowDownAZIcon, ArrowDownBigSmallIcon, ArrowsRotateIcon, ArrowsUpDownIcon, ArrowUp91Icon, ArrowUpBigSmallIcon, ArrowUpZAIcon, BarsIcon, CheckIcon, ChevronDownIcon, ChevronLeftIcon, ChevronRightIcon, CircleCheckIcon, CircleInfoIcon, CircleXMarkIcon, CopyIcon, DownIcon, EllipsisIcon, FilterFullIcon, FilterIcon, FilterSlashIcon, FloppyDiskIcon, HashtagIcon, ImageSlashIcon, LeftIcon, MagnifierIcon, PhoneIcon, PlusIcon, RightIcon, SigmaIcon, SortCalendarAscendingIcon, SortCalendarDescendingIcon, SpinnerIcon, TableColumnsIcon, TableFooterIcon, TableFooterSlashIcon, TableIcon, TallyIcon, TrashCanIcon, TriangleExclamationIcon, UpIcon, UserTieIcon, XBarIcon, XMarkIcon, XMarkLargeIcon, };
package/dist/Icons.js CHANGED
@@ -25,9 +25,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
25
25
  return (mod && mod.__esModule) ? mod : { "default": mod };
26
26
  };
27
27
  Object.defineProperty(exports, "__esModule", { value: true });
28
- exports.TriangleExclamationIcon = exports.CircleInfoIcon = exports.CircleCheckIcon = exports.XBarIcon = exports.UserTieIcon = exports.UpIcon = exports.TallyIcon = exports.TableIcon = exports.TableFooterSlashIcon = exports.TableFooterIcon = exports.TableColumnsIcon = exports.SpinnerIcon = exports.SortCalendarDescendingIcon = exports.SortCalendarAscendingIcon = exports.SigmaIcon = exports.RightIcon = exports.PlusIcon = exports.PhoneIcon = exports.MagnifierIcon = exports.LeftIcon = exports.ImageSlashIcon = exports.HashtagIcon = exports.FilterSlashIcon = exports.FilterIcon = exports.FilterFullIcon = exports.EllipsisIcon = exports.DownIcon = exports.CopyIcon = exports.CircleXMarkIcon = exports.ChevronDownIcon = exports.CheckIcon = exports.ArrowUpZAIcon = exports.ArrowUpBigSmallIcon = exports.ArrowUp91Icon = exports.ArrowsUpDownIcon = exports.ArrowsRotateIcon = exports.ArrowDownBigSmallIcon = exports.ArrowDownAZIcon = exports.ArrowDown19Icon = exports.LoadingIcon = exports.AnimatedIcon = void 0;
28
+ exports.XMarkIcon = exports.XBarIcon = exports.UserTieIcon = exports.UpIcon = exports.TriangleExclamationIcon = exports.TrashCanIcon = exports.TallyIcon = exports.TableIcon = exports.TableFooterSlashIcon = exports.TableFooterIcon = exports.TableColumnsIcon = exports.SpinnerIcon = exports.SortCalendarDescendingIcon = exports.SortCalendarAscendingIcon = exports.SigmaIcon = exports.RightIcon = exports.PlusIcon = exports.PhoneIcon = exports.MagnifierIcon = exports.LeftIcon = exports.ImageSlashIcon = exports.HashtagIcon = exports.FloppyDiskIcon = exports.FilterSlashIcon = exports.FilterIcon = exports.FilterFullIcon = exports.EllipsisIcon = exports.DownIcon = exports.CopyIcon = exports.CircleXMarkIcon = exports.CircleInfoIcon = exports.CircleCheckIcon = exports.ChevronRightIcon = exports.ChevronLeftIcon = exports.ChevronDownIcon = exports.CheckIcon = exports.BarsIcon = exports.ArrowUpZAIcon = exports.ArrowUpBigSmallIcon = exports.ArrowUp91Icon = exports.ArrowsUpDownIcon = exports.ArrowsRotateIcon = exports.ArrowDownBigSmallIcon = exports.ArrowDownAZIcon = exports.ArrowDown19Icon = exports.AngleRightIcon = exports.AngleLeftIcon = exports.BlankIcon = exports.LoadingIcon = exports.AnimatedIcon = void 0;
29
+ exports.XMarkLargeIcon = void 0;
29
30
  var jsx_runtime_1 = require("react/jsx-runtime");
30
31
  var react_1 = require("react");
32
+ var angle_left_svg_react_1 = __importDefault(require("../assets/icons/angle-left.svg?react"));
33
+ exports.AngleLeftIcon = angle_left_svg_react_1.default;
34
+ var angle_right_svg_react_1 = __importDefault(require("../assets/icons/angle-right.svg?react"));
35
+ exports.AngleRightIcon = angle_right_svg_react_1.default;
31
36
  var arrow_down_1_9_svg_react_1 = __importDefault(require("../assets/icons/arrow-down-1-9.svg?react"));
32
37
  exports.ArrowDown19Icon = arrow_down_1_9_svg_react_1.default;
33
38
  var arrow_down_a_z_svg_react_1 = __importDefault(require("../assets/icons/arrow-down-a-z.svg?react"));
@@ -44,10 +49,16 @@ var arrows_rotate_svg_react_1 = __importDefault(require("../assets/icons/arrows-
44
49
  exports.ArrowsRotateIcon = arrows_rotate_svg_react_1.default;
45
50
  var arrows_up_down_svg_react_1 = __importDefault(require("../assets/icons/arrows-up-down.svg?react"));
46
51
  exports.ArrowsUpDownIcon = arrows_up_down_svg_react_1.default;
52
+ var bars_svg_react_1 = __importDefault(require("../assets/icons/bars.svg?react"));
53
+ exports.BarsIcon = bars_svg_react_1.default;
47
54
  var check_svg_react_1 = __importDefault(require("../assets/icons/check.svg?react"));
48
55
  exports.CheckIcon = check_svg_react_1.default;
49
56
  var chevron_down_svg_react_1 = __importDefault(require("../assets/icons/chevron-down.svg?react"));
50
57
  exports.ChevronDownIcon = chevron_down_svg_react_1.default;
58
+ var chevron_left_svg_react_1 = __importDefault(require("../assets/icons/chevron-left.svg?react"));
59
+ exports.ChevronLeftIcon = chevron_left_svg_react_1.default;
60
+ var chevron_right_svg_react_1 = __importDefault(require("../assets/icons/chevron-right.svg?react"));
61
+ exports.ChevronRightIcon = chevron_right_svg_react_1.default;
51
62
  var circle_check_svg_react_1 = __importDefault(require("../assets/icons/circle-check.svg?react"));
52
63
  exports.CircleCheckIcon = circle_check_svg_react_1.default;
53
64
  var circle_info_svg_react_1 = __importDefault(require("../assets/icons/circle-info.svg?react"));
@@ -66,6 +77,8 @@ var filter_svg_react_1 = __importDefault(require("../assets/icons/filter.svg?rea
66
77
  exports.FilterIcon = filter_svg_react_1.default;
67
78
  var filter_slash_svg_react_1 = __importDefault(require("../assets/icons/filter-slash.svg?react"));
68
79
  exports.FilterSlashIcon = filter_slash_svg_react_1.default;
80
+ var floppy_disk_svg_react_1 = __importDefault(require("../assets/icons/floppy-disk.svg?react"));
81
+ exports.FloppyDiskIcon = floppy_disk_svg_react_1.default;
69
82
  var hashtag_svg_react_1 = __importDefault(require("../assets/icons/hashtag.svg?react"));
70
83
  exports.HashtagIcon = hashtag_svg_react_1.default;
71
84
  var image_slash_svg_react_1 = __importDefault(require("../assets/icons/image-slash.svg?react"));
@@ -98,6 +111,8 @@ var table_svg_react_1 = __importDefault(require("../assets/icons/table.svg?react
98
111
  exports.TableIcon = table_svg_react_1.default;
99
112
  var tally_svg_react_1 = __importDefault(require("../assets/icons/tally.svg?react"));
100
113
  exports.TallyIcon = tally_svg_react_1.default;
114
+ var trash_can_svg_react_1 = __importDefault(require("../assets/icons/trash-can.svg?react"));
115
+ exports.TrashCanIcon = trash_can_svg_react_1.default;
101
116
  var triangle_exclamation_svg_react_1 = __importDefault(require("../assets/icons/triangle-exclamation.svg?react"));
102
117
  exports.TriangleExclamationIcon = triangle_exclamation_svg_react_1.default;
103
118
  var up_svg_react_1 = __importDefault(require("../assets/icons/up.svg?react"));
@@ -106,6 +121,10 @@ var user_tie_svg_react_1 = __importDefault(require("../assets/icons/user-tie.svg
106
121
  exports.UserTieIcon = user_tie_svg_react_1.default;
107
122
  var x_bar_svg_react_1 = __importDefault(require("../assets/icons/x-bar.svg?react"));
108
123
  exports.XBarIcon = x_bar_svg_react_1.default;
124
+ var xmark_svg_react_1 = __importDefault(require("../assets/icons/xmark.svg?react"));
125
+ exports.XMarkIcon = xmark_svg_react_1.default;
126
+ var xmark_large_svg_react_1 = __importDefault(require("../assets/icons/xmark-large.svg?react"));
127
+ exports.XMarkLargeIcon = xmark_large_svg_react_1.default;
109
128
  var AnimatedIcon = function (_a) {
110
129
  var icons = _a.icons, _b = _a.speed, speed = _b === void 0 ? 150 : _b, props = __rest(_a, ["icons", "speed"]);
111
130
  var _c = (0, react_1.useState)(0), currentIcon = _c[0], setCurrentIcon = _c[1];
@@ -126,3 +145,5 @@ var LoadingIcon = function (_a) {
126
145
  return ((0, jsx_runtime_1.jsx)(spinner_third_svg_react_1.default, __assign({ className: "animate-spin ".concat(className) }, props)));
127
146
  };
128
147
  exports.LoadingIcon = LoadingIcon;
148
+ var BlankIcon = function (props) { return ((0, jsx_runtime_1.jsx)("svg", __assign({ xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24" }, props))); };
149
+ exports.BlankIcon = BlankIcon;
@@ -43,6 +43,6 @@ var LoginForm = function () {
43
43
  }, []);
44
44
  if (isLoading)
45
45
  return (0, jsx_runtime_1.jsx)("div", { children: "Chargement..." });
46
- return ((0, jsx_runtime_1.jsx)(ui_1.Card, { children: (0, jsx_runtime_1.jsxs)(styles_1.FormContainer, { children: [(0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Adresse e-mail / Nom d'utilisateur", children: (0, jsx_runtime_1.jsx)(forms_1.Input, { ref: usernameInputRef, type: "email", autoComplete: "email", required: true, value: username, onChange: function (e) { return setUsername(e.target.value); } }) }), (0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Mot de passe", children: (0, jsx_runtime_1.jsx)(forms_1.Input, { ref: passwordInputRef, type: "password", autoComplete: "current-password", required: true, value: password, onChange: function (e) { return setPassword(e.target.value); } }) }), error && (0, jsx_runtime_1.jsx)(ui_1.Message, { type: "error", children: error }), (0, jsx_runtime_1.jsx)(forms_1.Button, { color: "primary", onClick: onLoginClicked, children: "Se connecter" }), (0, jsx_runtime_1.jsx)(react_router_dom_1.Link, { to: "/recover", children: "Mot de passe oubli\u00E9 ?" })] }) }));
46
+ return ((0, jsx_runtime_1.jsx)(ui_1.Card, { children: (0, jsx_runtime_1.jsxs)(styles_1.FormContainer, { children: [(0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Adresse e-mail / Nom d'utilisateur", children: (0, jsx_runtime_1.jsx)(forms_1.Input, { ref: usernameInputRef, type: "email", autoComplete: "email", required: true, value: username, onChange: function (e) { return setUsername(e.target.value); } }) }), (0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Mot de passe", children: (0, jsx_runtime_1.jsx)(forms_1.Input, { ref: passwordInputRef, type: "password", autoComplete: "current-password", required: true, value: password, onChange: function (e) { return setPassword(e.target.value); } }) }), error && (0, jsx_runtime_1.jsx)(ui_1.Message, { type: "error", children: error }), (0, jsx_runtime_1.jsx)(forms_1.Button, { "$color": "primary", onClick: onLoginClicked, children: "Se connecter" }), (0, jsx_runtime_1.jsx)(react_router_dom_1.Link, { to: "/recover", children: "Mot de passe oubli\u00E9 ?" })] }) }));
47
47
  };
48
48
  exports.LoginForm = LoginForm;
@@ -19,6 +19,6 @@ var PasswordRecoveryForm = function () {
19
19
  setIsSubmitted(true);
20
20
  });
21
21
  }, [email, sendRecoveryKey]);
22
- return ((0, jsx_runtime_1.jsx)(ui_1.Card, { children: (0, jsx_runtime_1.jsx)(styles_1.FormContainer, { children: isSubmitted ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(Message_1.Message, { type: "success", children: "Un e-mail de r\u00E9initialisation de mot de passe vous a \u00E9t\u00E9 envoy\u00E9." }), (0, jsx_runtime_1.jsx)(react_router_dom_1.Link, { to: "/", children: "Retour" })] })) : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Adresse e-mail", children: (0, jsx_runtime_1.jsx)(forms_1.Input, { type: "email", autoComplete: "email", required: true, value: email, onChange: function (e) { return setEmail(e.target.value); } }) }), (0, jsx_runtime_1.jsx)(forms_1.Button, { color: "primary", onClick: onSubmitClicked, children: "Envoyer un lien de r\u00E9cup\u00E9ration" })] })) }) }));
22
+ return ((0, jsx_runtime_1.jsx)(ui_1.Card, { children: (0, jsx_runtime_1.jsx)(styles_1.FormContainer, { children: isSubmitted ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(Message_1.Message, { type: "success", children: "Un e-mail de r\u00E9initialisation de mot de passe vous a \u00E9t\u00E9 envoy\u00E9." }), (0, jsx_runtime_1.jsx)(react_router_dom_1.Link, { to: "/", children: "Retour" })] })) : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Adresse e-mail", children: (0, jsx_runtime_1.jsx)(forms_1.Input, { type: "email", autoComplete: "email", required: true, value: email, onChange: function (e) { return setEmail(e.target.value); } }) }), (0, jsx_runtime_1.jsx)(forms_1.Button, { "$color": "primary", onClick: onSubmitClicked, children: "Envoyer un lien de r\u00E9cup\u00E9ration" })] })) }) }));
23
23
  };
24
24
  exports.PasswordRecoveryForm = PasswordRecoveryForm;
@@ -51,6 +51,6 @@ var PasswordResetForm = function () {
51
51
  return null;
52
52
  }
53
53
  }, [keyStatus, status]);
54
- return ((0, jsx_runtime_1.jsx)(ui_1.Card, { children: (0, jsx_runtime_1.jsxs)(styles_1.FormContainer, { children: [content !== null && content !== void 0 ? content : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Nouveau mot de passe", children: (0, jsx_runtime_1.jsx)(ui_1.Input, { type: "password", autoComplete: "current-password", required: true, value: password1, onChange: function (e) { return setPassword1(e.target.value); } }) }), (0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Confirmation du mot de passe", children: (0, jsx_runtime_1.jsx)(ui_1.Input, { type: "password", autoComplete: "current-password", required: true, value: password2, onChange: function (e) { return setPassword2(e.target.value); } }) }), error && ((0, jsx_runtime_1.jsx)(Message_1.Message, { className: "mt-4", type: "error", children: error })), (0, jsx_runtime_1.jsx)(ui_1.Button, { color: "primary", onClick: onSubmitClicked, children: "R\u00E9initialiser le mot de passe" })] })), (0, jsx_runtime_1.jsx)(react_router_dom_1.Link, { to: "/", children: "Retour" })] }) }));
54
+ return ((0, jsx_runtime_1.jsx)(ui_1.Card, { children: (0, jsx_runtime_1.jsxs)(styles_1.FormContainer, { children: [content !== null && content !== void 0 ? content : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Nouveau mot de passe", children: (0, jsx_runtime_1.jsx)(ui_1.Input, { type: "password", autoComplete: "current-password", required: true, value: password1, onChange: function (e) { return setPassword1(e.target.value); } }) }), (0, jsx_runtime_1.jsx)(VerticalLabel_1.StackedLabel, { label: "Confirmation du mot de passe", children: (0, jsx_runtime_1.jsx)(ui_1.Input, { type: "password", autoComplete: "current-password", required: true, value: password2, onChange: function (e) { return setPassword2(e.target.value); } }) }), error && ((0, jsx_runtime_1.jsx)(Message_1.Message, { className: "mt-4", type: "error", children: error })), (0, jsx_runtime_1.jsx)(ui_1.Button, { "$color": "primary", onClick: onSubmitClicked, children: "R\u00E9initialiser le mot de passe" })] })), (0, jsx_runtime_1.jsx)(react_router_dom_1.Link, { to: "/", children: "Retour" })] }) }));
55
55
  };
56
56
  exports.PasswordResetForm = PasswordResetForm;
@@ -1,2 +1,2 @@
1
1
  import { DataGridCellProps } from './types';
2
- export declare const DataGridCell: <R>({ row, rowIndex, columnKey, columnIndex, column, context, style, }: DataGridCellProps<R>) => import("react/jsx-runtime").JSX.Element;
2
+ export declare const DataGridCell: <R, T>({ row, rowIndex, columnKey, columnIndex, column, context, style, }: DataGridCellProps<R, T>) => import("react/jsx-runtime").JSX.Element;
@@ -26,22 +26,22 @@ Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.DataGridCell = void 0;
27
27
  var jsx_runtime_1 = require("react/jsx-runtime");
28
28
  /* eslint-disable @typescript-eslint/no-explicit-any */
29
- /* eslint-disable @typescript-eslint/no-unnecessary-type-constraint */
30
29
  var styles = __importStar(require("./styles"));
31
30
  var react_1 = require("react");
32
31
  var DataGridEditableCell_1 = require("./DataGridEditableCell");
33
32
  var hooks_1 = require("./hooks");
34
- var defaultRender = function (row, col) {
35
- var value = col.propertyName ? row[col.propertyName] : '';
36
- return !value ? '' : String(value);
37
- };
33
+ var defaultRender = function (value) { return (!value ? '' : String(value)); };
38
34
  var DataGridCell = function (_a) {
39
35
  var _b, _c;
40
36
  var row = _a.row, rowIndex = _a.rowIndex, columnKey = _a.columnKey, columnIndex = _a.columnIndex, column = _a.column, context = _a.context, style = _a.style;
41
- var _d = (0, hooks_1.useDataGridContext)(context), name = _d.name, editable = _d.editable, _e = _d.editingCell, editingCell = _e === void 0 ? [-1, -1] : _e, setEditingCell = _d.setEditingCell, onRowDoubleClick = _d.onRowDoubleClick;
42
- var isEditable = !!editable && !!column.editable && column.type && column.getter;
37
+ var _d = (0, hooks_1.useDataGridContext)(context), name = _d.name, editable = _d.editable, _e = _d.editingCell, editingCell = _e === void 0 ? [-1, -1] : _e, setEditingCell = _d.setEditingCell, onRowDoubleClick = _d.onRowDoubleClick, userSelect = _d.userSelect;
38
+ var isEditable = !!editable &&
39
+ 'editable' in column &&
40
+ !!column.editable &&
41
+ !!column.editComponent;
43
42
  var isEditing = isEditable && editingCell[0] === rowIndex && editingCell[1] === columnIndex;
44
43
  var DataGridCellComponent = (_b = column.component) !== null && _b !== void 0 ? _b : styles.DataGridCell;
44
+ var value = (0, react_1.useMemo)(function () { return column.getter(row); }, [column, row]);
45
45
  var onDoubleClick = (0, react_1.useCallback)(function (e) {
46
46
  e.stopPropagation();
47
47
  e.preventDefault();
@@ -52,8 +52,8 @@ var DataGridCell = function (_a) {
52
52
  onRowDoubleClick === null || onRowDoubleClick === void 0 ? void 0 : onRowDoubleClick(row, e);
53
53
  }, [columnIndex, isEditable, onRowDoubleClick, row, rowIndex, setEditingCell]);
54
54
  if (isEditing) {
55
- return ((0, jsx_runtime_1.jsx)(DataGridEditableCell_1.DataGridEditableCell, { row: row, rowIndex: rowIndex, columnKey: columnKey, columnIndex: columnIndex, column: column, context: context }, "".concat(name, "-").concat(rowIndex, "-").concat(columnIndex)));
55
+ return ((0, jsx_runtime_1.jsx)(DataGridEditableCell_1.DataGridEditableCell, { row: row, rowIndex: rowIndex, columnKey: columnKey, columnIndex: columnIndex, column: column, context: context, userSelect: userSelect }, "".concat(name, "-").concat(rowIndex, "-").concat(columnIndex)));
56
56
  }
57
- return ((0, jsx_runtime_1.jsx)(DataGridCellComponent, { onDoubleClick: onDoubleClick, style: style, children: ((_c = column.render) !== null && _c !== void 0 ? _c : defaultRender)(row, column) }, "".concat(name, "-").concat(rowIndex, "-").concat(columnIndex)));
57
+ return ((0, jsx_runtime_1.jsx)(DataGridCellComponent, { onDoubleClick: onDoubleClick, style: style, "$userSelect": userSelect, "$color": column.color, "$textAlign": column.textAlign, children: ((_c = column.render) !== null && _c !== void 0 ? _c : defaultRender)(value, row, column) }, "".concat(name, "-").concat(rowIndex, "-").concat(columnIndex)));
58
58
  };
59
59
  exports.DataGridCell = DataGridCell;
@@ -1,2 +1,2 @@
1
- import { DataGridColumnKeyValuePair, DataGridColumns } from '../types';
2
- export declare const normalizeColumnsOrders: <R>(columns: DataGridColumns<R> | DataGridColumnKeyValuePair<R>[]) => DataGridColumnKeyValuePair<R>[];
1
+ import { DataGridColumns } from '../types';
2
+ export declare const normalizeColumnsOrders: <R>(columns: DataGridColumns<R>) => DataGridColumns<R>;
@@ -13,12 +13,6 @@ var __assign = (this && this.__assign) || function () {
13
13
  Object.defineProperty(exports, "__esModule", { value: true });
14
14
  exports.normalizeColumnsOrders = void 0;
15
15
  var normalizeColumnsOrders = function (columns) {
16
- return (Array.isArray(columns) ? columns : Object.entries(columns)).map(function (_a, index) {
17
- var key = _a[0], column = _a[1];
18
- return [
19
- key,
20
- __assign(__assign({}, column), { order: index }),
21
- ];
22
- });
16
+ return columns.map(function (column, index) { return (__assign(__assign({}, column), { order: index })); });
23
17
  };
24
18
  exports.normalizeColumnsOrders = normalizeColumnsOrders;
@@ -2,11 +2,11 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.useDataGridColumnsModal = void 0;
4
4
  var jsx_runtime_1 = require("react/jsx-runtime");
5
+ var lodash_1 = require("lodash");
5
6
  var react_1 = require("react");
6
7
  var forms_1 = require("../../../forms");
7
8
  var _1 = require(".");
8
9
  var Modal_1 = require("../../../layout/Modal");
9
- var lodash_1 = require("lodash");
10
10
  var useDataGridColumnsModal = function (context) {
11
11
  var _a = (0, react_1.useState)(false), isVisible = _a[0], setIsVisible = _a[1];
12
12
  var _b = (0, react_1.useContext)(context), columns = _b.columns, setSettings = _b.setSettings, saveSettings = _b.saveSettings;
@@ -19,7 +19,7 @@ var useDataGridColumnsModal = function (context) {
19
19
  setIsVisible(false);
20
20
  }, []);
21
21
  var onApplyClicked = (0, react_1.useCallback)(function () {
22
- var newSettings = (0, lodash_1.mapValues)(currentColumns, function (col) {
22
+ var newSettings = (0, lodash_1.mapValues)((0, lodash_1.keyBy)(currentColumns, 'key'), function (col) {
23
23
  var _a, _b;
24
24
  return ({
25
25
  order: (_a = col.order) !== null && _a !== void 0 ? _a : 0,
@@ -31,7 +31,7 @@ var useDataGridColumnsModal = function (context) {
31
31
  closeModal();
32
32
  }, [currentColumns, closeModal, saveSettings, setSettings]);
33
33
  var modal = (0, react_1.useMemo)(function () {
34
- return isVisible ? ((0, jsx_runtime_1.jsxs)(Modal_1.Modal, { "$width": 600, "$height": 400, children: [(0, jsx_runtime_1.jsx)(Modal_1.Modal.Header, { children: "Param\u00E8tres des colonnes" }), (0, jsx_runtime_1.jsx)(Modal_1.Modal.Content, { children: (0, jsx_runtime_1.jsx)(_1.DataGridColumnsEditor, { columns: currentColumns, onColumnsChanged: setCurrentColumns }) }), (0, jsx_runtime_1.jsxs)(Modal_1.Modal.Footer, { children: [(0, jsx_runtime_1.jsx)(forms_1.Button, { onClick: closeModal, children: "Annuler" }), (0, jsx_runtime_1.jsx)(forms_1.Button, { color: "primary", style: { marginLeft: 'auto' }, onClick: onApplyClicked, children: "Appliquer" })] })] })) : null;
34
+ return isVisible ? ((0, jsx_runtime_1.jsxs)(Modal_1.Modal, { "$width": 600, "$height": 400, children: [(0, jsx_runtime_1.jsx)(Modal_1.Modal.Header, { children: "Param\u00E8tres des colonnes" }), (0, jsx_runtime_1.jsx)(Modal_1.Modal.Content, { children: (0, jsx_runtime_1.jsx)(_1.DataGridColumnsEditor, { columns: currentColumns, onColumnsChanged: setCurrentColumns }) }), (0, jsx_runtime_1.jsxs)(Modal_1.Modal.Footer, { children: [(0, jsx_runtime_1.jsx)(forms_1.Button, { onClick: closeModal, children: "Annuler" }), (0, jsx_runtime_1.jsx)(forms_1.Button, { "$color": "primary", style: { marginLeft: 'auto' }, onClick: onApplyClicked, children: "Appliquer" })] })] })) : null;
35
35
  }, [closeModal, currentColumns, isVisible, onApplyClicked]);
36
36
  return { openModal: openModal, closeModal: closeModal, modal: modal };
37
37
  };
@@ -62,19 +62,16 @@ var DataGridColumnItem = function (_a) {
62
62
  exports.DataGridColumnItem = DataGridColumnItem;
63
63
  var DataGridColumnsEditor = function (_a) {
64
64
  var columns = _a.columns, onColumnsChanged = _a.onColumnsChanged;
65
+ console.log('DataGridColumnsEditor columns:', columns);
65
66
  var _b = (0, hooks_1.useVisibleAndHiddenColumns)(columns), visibleColumns = _b[0], hiddenColumns = _b[1];
66
- var sortedVisibleColumnsEntries = (0, helpers_1.normalizeColumnsOrders)(lodash_1.default.sortBy(Object.entries(visibleColumns), function (_a) {
67
- var _b;
68
- var col = _a[1];
69
- return (_b = col.order) !== null && _b !== void 0 ? _b : 0;
70
- }));
67
+ var sortedVisibleColumnsEntries = (0, helpers_1.normalizeColumnsOrders)(lodash_1.default.sortBy(visibleColumns, function (col) { var _a; return (_a = col.order) !== null && _a !== void 0 ? _a : 0; }));
71
68
  var onUpButtonClicked = (0, react_1.useCallback)(function (index) {
72
69
  if (index > 0) {
73
70
  var newArray_1 = (0, helpers_1.normalizeColumnsOrders)(__spreadArray(__spreadArray(__spreadArray([], sortedVisibleColumnsEntries.slice(0, index - 1), true), [
74
71
  sortedVisibleColumnsEntries[index],
75
72
  sortedVisibleColumnsEntries[index - 1]
76
73
  ], false), sortedVisibleColumnsEntries.slice(index + 1), true));
77
- onColumnsChanged(function () { return (__assign(__assign({}, Object.fromEntries(newArray_1)), hiddenColumns)); });
74
+ onColumnsChanged(function () { return __spreadArray(__spreadArray([], newArray_1, true), hiddenColumns, true); });
78
75
  }
79
76
  }, [hiddenColumns, onColumnsChanged, sortedVisibleColumnsEntries]);
80
77
  var onDownButtonClicked = (0, react_1.useCallback)(function (index) {
@@ -83,29 +80,27 @@ var DataGridColumnsEditor = function (_a) {
83
80
  sortedVisibleColumnsEntries[index + 1],
84
81
  sortedVisibleColumnsEntries[index]
85
82
  ], false), sortedVisibleColumnsEntries.slice(index + 2), true));
86
- onColumnsChanged(function () { return (__assign(__assign({}, Object.fromEntries(newArray_2)), hiddenColumns)); });
83
+ onColumnsChanged(function () { return __spreadArray(__spreadArray([], newArray_2, true), hiddenColumns, true); });
87
84
  }
88
85
  }, [hiddenColumns, onColumnsChanged, sortedVisibleColumnsEntries]);
89
86
  var onHideButtonClicked = (0, react_1.useCallback)(function (columnKey) {
90
87
  onColumnsChanged(function (prev) {
91
- var _a;
92
- return (__assign(__assign({}, prev), (_a = {}, _a[columnKey] = __assign(__assign({}, prev[columnKey]), { order: -1 }), _a)));
88
+ return prev.map(function (column) {
89
+ return column.key === columnKey
90
+ ? __assign(__assign({}, column), { order: -1 }) : column;
91
+ });
93
92
  });
94
93
  }, [onColumnsChanged]);
95
94
  var onShowButtonClicked = (0, react_1.useCallback)(function (columnKey) {
96
95
  onColumnsChanged(function (prev) {
97
- var _a;
98
- return (__assign(__assign({}, prev), (_a = {}, _a[columnKey] = __assign(__assign({}, hiddenColumns[columnKey]), { order: Object.keys(prev).length }), _a)));
96
+ return prev.map(function (column) {
97
+ return column.key === columnKey
98
+ ? __assign(__assign({}, column), { order: Object.keys(prev).length }) : column;
99
+ });
99
100
  });
100
- }, [hiddenColumns, onColumnsChanged]);
101
- return ((0, jsx_runtime_1.jsxs)(styles.Container, { children: [(0, jsx_runtime_1.jsxs)(styles.Panel, { children: [(0, jsx_runtime_1.jsx)(styles.Title, { children: "Colonnes visibles" }), (0, jsx_runtime_1.jsx)(styles.ColumnsList, { children: sortedVisibleColumnsEntries.map(function (_a, index) {
102
- var key = _a[0], column = _a[1];
103
- return ((0, jsx_runtime_1.jsx)(exports.DataGridColumnItem, { columnKey: key, columnIndex: index, column: column, visible: true, onUpButtonClicked: index > 0 ? onUpButtonClicked : undefined, onDownButtonClicked: index < sortedVisibleColumnsEntries.length - 1
104
- ? onDownButtonClicked
105
- : undefined, onVisibleButtonClicked: onHideButtonClicked }, key));
106
- }) })] }), (0, jsx_runtime_1.jsxs)(styles.Panel, { children: [(0, jsx_runtime_1.jsx)(styles.Title, { children: "Colonnes masqu\u00E9es" }), (0, jsx_runtime_1.jsx)(styles.ColumnsList, { children: Object.entries(hiddenColumns).map(function (_a, index) {
107
- var key = _a[0], column = _a[1];
108
- return ((0, jsx_runtime_1.jsx)(exports.DataGridColumnItem, { columnKey: key, columnIndex: index, column: column, visible: false, onVisibleButtonClicked: onShowButtonClicked }, key));
109
- }) })] })] }));
101
+ }, [onColumnsChanged]);
102
+ return ((0, jsx_runtime_1.jsxs)(styles.Container, { children: [(0, jsx_runtime_1.jsxs)(styles.Panel, { children: [(0, jsx_runtime_1.jsx)(styles.Title, { children: "Colonnes visibles" }), (0, jsx_runtime_1.jsx)(styles.ColumnsList, { children: sortedVisibleColumnsEntries.map(function (column, index) { return ((0, jsx_runtime_1.jsx)(exports.DataGridColumnItem, { columnKey: column.key, columnIndex: index, column: column, visible: true, onUpButtonClicked: index > 0 ? onUpButtonClicked : undefined, onDownButtonClicked: index < sortedVisibleColumnsEntries.length - 1
103
+ ? onDownButtonClicked
104
+ : undefined, onVisibleButtonClicked: onHideButtonClicked }, column.key)); }) })] }), (0, jsx_runtime_1.jsxs)(styles.Panel, { children: [(0, jsx_runtime_1.jsx)(styles.Title, { children: "Colonnes masqu\u00E9es" }), (0, jsx_runtime_1.jsx)(styles.ColumnsList, { children: hiddenColumns.map(function (column, index) { return ((0, jsx_runtime_1.jsx)(exports.DataGridColumnItem, { columnKey: column.key, columnIndex: index, column: column, visible: false, onVisibleButtonClicked: onShowButtonClicked }, column.key)); }) })] })] }));
110
105
  };
111
106
  exports.DataGridColumnsEditor = DataGridColumnsEditor;
@@ -40,10 +40,10 @@ exports.Title = styled_components_1.default.div.attrs({
40
40
  })(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n margin: 0;\n margin-bottom: var(--space-2);\n font-weight: bold;\n"], ["\n margin: 0;\n margin-bottom: var(--space-2);\n font-weight: bold;\n"])));
41
41
  exports.ColumnsList = styled_components_1.default.ul.attrs({
42
42
  className: 'DataGridColumnsModal-ColumnsList',
43
- })(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n display: flex;\n flex-direction: column;\n flex: 1;\n overflow: auto;\n border: 1px solid var(--color-neutral-200);\n margin: 0;\n background-color: var(--color-neutral-50);\n\n & > li:not(:last-child) {\n border-bottom: 1px solid var(--color-neutral-100);\n }\n"], ["\n display: flex;\n flex-direction: column;\n flex: 1;\n overflow: auto;\n border: 1px solid var(--color-neutral-200);\n margin: 0;\n background-color: var(--color-neutral-50);\n\n & > li:not(:last-child) {\n border-bottom: 1px solid var(--color-neutral-100);\n }\n"])));
43
+ })(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n display: flex;\n flex-direction: column;\n flex: 1;\n overflow: auto;\n border: 1px solid var(--color-base-200);\n margin: 0;\n background-color: var(--color-base-50);\n\n & > li:not(:last-child) {\n border-bottom: 1px solid var(--color-base-100);\n }\n"], ["\n display: flex;\n flex-direction: column;\n flex: 1;\n overflow: auto;\n border: 1px solid var(--color-base-200);\n margin: 0;\n background-color: var(--color-base-50);\n\n & > li:not(:last-child) {\n border-bottom: 1px solid var(--color-base-100);\n }\n"])));
44
44
  exports.ColumnItem = styled_components_1.default.li.attrs({
45
45
  className: 'DataGridColumnsModal-ColumnItem',
46
- })(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n padding: var(--space-1);\n transition: background-color 0.2s;\n cursor: pointer;\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: var(--space-2);\n\n span {\n flex: 1;\n }\n\n button {\n display: none;\n padding: var(--space-1);\n width: var(--space-6);\n height: var(--space-6);\n border-radius: var(--rounded-full);\n background-color: var(--color-neutral-200);\n border: none;\n align-items: center;\n justify-content: center;\n }\n\n &:hover {\n background-color: var(--color-neutral-100);\n button {\n display: flex;\n background-color: var(--color-neutral-300);\n }\n }\n"], ["\n padding: var(--space-1);\n transition: background-color 0.2s;\n cursor: pointer;\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: var(--space-2);\n\n span {\n flex: 1;\n }\n\n button {\n display: none;\n padding: var(--space-1);\n width: var(--space-6);\n height: var(--space-6);\n border-radius: var(--rounded-full);\n background-color: var(--color-neutral-200);\n border: none;\n align-items: center;\n justify-content: center;\n }\n\n &:hover {\n background-color: var(--color-neutral-100);\n button {\n display: flex;\n background-color: var(--color-neutral-300);\n }\n }\n"])));
46
+ })(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n padding: var(--space-1);\n transition: background-color 0.2s;\n cursor: pointer;\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: var(--space-2);\n\n span {\n flex: 1;\n }\n\n button {\n display: none;\n padding: var(--space-1);\n width: var(--space-6);\n height: var(--space-6);\n border-radius: var(--rounded-full);\n background-color: var(--color-base-200);\n border: none;\n align-items: center;\n justify-content: center;\n }\n\n &:hover {\n background-color: var(--color-base-100);\n button {\n display: flex;\n background-color: var(--color-base-300);\n }\n }\n"], ["\n padding: var(--space-1);\n transition: background-color 0.2s;\n cursor: pointer;\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: var(--space-2);\n\n span {\n flex: 1;\n }\n\n button {\n display: none;\n padding: var(--space-1);\n width: var(--space-6);\n height: var(--space-6);\n border-radius: var(--rounded-full);\n background-color: var(--color-base-200);\n border: none;\n align-items: center;\n justify-content: center;\n }\n\n &:hover {\n background-color: var(--color-base-100);\n button {\n display: flex;\n background-color: var(--color-base-300);\n }\n }\n"])));
47
47
  exports.Buttons = styled_components_1.default.div.attrs({
48
48
  className: 'DataGridColumnsModal-Buttons',
49
49
  })(templateObject_8 || (templateObject_8 = __makeTemplateObject(["\n display: flex;\n gap: var(--space-1);\n height: var(--space-6);\n ", "\n\n svg {\n width: var(--space-4);\n height: var(--space-4);\n }\n"], ["\n display: flex;\n gap: var(--space-1);\n height: var(--space-6);\n ", "\n\n svg {\n width: var(--space-4);\n height: var(--space-4);\n }\n"])), function (_a) {
@@ -0,0 +1,2 @@
1
+ import { DataGridEditableCellProps } from './types';
2
+ export declare const CheckboxEditableCell: <R>(props: DataGridEditableCellProps<R, boolean> & import("react").RefAttributes<HTMLInputElement>) => import("react").JSX.Element | null;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CheckboxEditableCell = void 0;
4
+ var jsx_runtime_1 = require("react/jsx-runtime");
5
+ var react_1 = require("react");
6
+ var CheckboxEditableCellInner = function (_a, ref) {
7
+ var value = _a.value, onChange = _a.onChange, onClose = _a.onClose;
8
+ var onBlur = (0, react_1.useCallback)(function () {
9
+ onClose(true);
10
+ }, [onClose]);
11
+ var onKeyDown = (0, react_1.useCallback)(function (e) {
12
+ if (e.key === 'Enter') {
13
+ e.preventDefault();
14
+ onClose(true);
15
+ }
16
+ else if (e.key === 'Escape') {
17
+ e.preventDefault();
18
+ onClose(false);
19
+ }
20
+ }, [onClose]);
21
+ return ((0, jsx_runtime_1.jsx)("input", { ref: ref, type: "checkbox", checked: value, onChange: function (e) { return onChange(e.target.checked); }, onBlur: onBlur, onKeyDown: onKeyDown }));
22
+ };
23
+ exports.CheckboxEditableCell = (0, react_1.forwardRef)(CheckboxEditableCellInner);
@@ -0,0 +1,2 @@
1
+ import { DataGridEditableCellProps } from './types';
2
+ export declare const DateEditableCell: <R>(props: DataGridEditableCellProps<R, string> & import("react").RefAttributes<HTMLInputElement>) => import("react").JSX.Element | null;
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.DateEditableCell = void 0;
7
+ var jsx_runtime_1 = require("react/jsx-runtime");
8
+ var react_1 = require("react");
9
+ var moment_1 = __importDefault(require("moment"));
10
+ var DateEditableCellInner = function (_a, ref) {
11
+ var value = _a.value, onChange = _a.onChange, onClose = _a.onClose;
12
+ var onBlur = (0, react_1.useCallback)(function () {
13
+ onClose(true);
14
+ }, [onClose]);
15
+ var onKeyDown = (0, react_1.useCallback)(function (e) {
16
+ if (e.key === 'Enter') {
17
+ e.preventDefault();
18
+ onClose(true);
19
+ }
20
+ else if (e.key === 'Escape') {
21
+ e.preventDefault();
22
+ onClose(false);
23
+ }
24
+ }, [onClose]);
25
+ return ((0, jsx_runtime_1.jsx)("input", { ref: ref, type: "date", value: (0, moment_1.default)(value).format('YYYY-MM-DD'), onChange: function (e) { return onChange(e.target.value); }, onBlur: onBlur, onKeyDown: onKeyDown }));
26
+ };
27
+ exports.DateEditableCell = (0, react_1.forwardRef)(DateEditableCellInner);
@@ -0,0 +1,7 @@
1
+ import { DataGridEditableCellProps } from './types';
2
+ export declare const NumberEditableCell: <R>(props: DataGridEditableCellProps<R, number> & {
3
+ decimals?: number;
4
+ currency?: string | ((row: R) => string);
5
+ prefix?: string;
6
+ suffix?: string;
7
+ } & import("react").RefAttributes<HTMLElement>) => import("react").JSX.Element | null;
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NumberEditableCell = void 0;
4
+ var jsx_runtime_1 = require("react/jsx-runtime");
5
+ var react_1 = require("react");
6
+ var numbers_1 = require("../../../../helpers/numbers");
7
+ var react_number_format_1 = require("react-number-format");
8
+ var NumberEditableCellInner = function (_a, ref) {
9
+ var _b = _a.decimals, decimals = _b === void 0 ? 0 : _b, currency = _a.currency, prefixFromProps = _a.prefix, suffixFromProps = _a.suffix, row = _a.row, value = _a.value, onChange = _a.onChange, onClose = _a.onClose;
10
+ var currencyName = typeof currency === 'function' ? currency(row) : currency;
11
+ var _c = currencyName
12
+ ? (0, numbers_1.getCurrencySymbol)(currencyName)
13
+ : [undefined, undefined], prefixFromCurrency = _c[0], suffixFromCurrency = _c[1];
14
+ var prefix = prefixFromProps || prefixFromCurrency;
15
+ var suffix = suffixFromProps || suffixFromCurrency;
16
+ var onBlur = (0, react_1.useCallback)(function () {
17
+ onClose(true);
18
+ }, [onClose]);
19
+ var onKeyDown = (0, react_1.useCallback)(function (e) {
20
+ if (e.key === 'Enter') {
21
+ e.preventDefault();
22
+ onClose(true);
23
+ }
24
+ else if (e.key === 'Escape') {
25
+ e.preventDefault();
26
+ onClose(false);
27
+ }
28
+ }, [onClose]);
29
+ return ((0, jsx_runtime_1.jsx)(react_number_format_1.NumericFormat, { getInputRef: ref, value: Number(value), onChange: function (e) {
30
+ console.log('e:', e);
31
+ onChange((0, numbers_1.parseNumber)(e.target.value));
32
+ }, onBlur: onBlur, onKeyDown: onKeyDown, decimalSeparator: numbers_1.decimalSeparator, decimalScale: decimals, fixedDecimalScale: !!decimals, prefix: prefix ? prefix + ' ' : undefined, suffix: suffix ? ' ' + suffix : undefined }));
33
+ };
34
+ exports.NumberEditableCell = (0, react_1.forwardRef)(NumberEditableCellInner);
@@ -0,0 +1,2 @@
1
+ import { DataGridEditableCellProps } from './types';
2
+ export declare const TextEditableCell: <R>(props: DataGridEditableCellProps<R, string> & import("react").RefAttributes<HTMLInputElement>) => import("react").JSX.Element | null;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TextEditableCell = void 0;
4
+ var jsx_runtime_1 = require("react/jsx-runtime");
5
+ var react_1 = require("react");
6
+ var TextEditableCellInner = function (_a, ref) {
7
+ var value = _a.value, onChange = _a.onChange, onClose = _a.onClose;
8
+ var onBlur = (0, react_1.useCallback)(function () {
9
+ onClose(true);
10
+ }, [onClose]);
11
+ var onKeyDown = (0, react_1.useCallback)(function (e) {
12
+ if (e.key === 'Enter') {
13
+ e.preventDefault();
14
+ onClose(true);
15
+ }
16
+ else if (e.key === 'Escape') {
17
+ e.preventDefault();
18
+ onClose(false);
19
+ }
20
+ }, [onClose]);
21
+ return ((0, jsx_runtime_1.jsx)("input", { ref: ref, type: "text", value: String(value), onChange: function (e) { return onChange(e.target.value); }, onBlur: onBlur, onKeyDown: onKeyDown }));
22
+ };
23
+ exports.TextEditableCell = (0, react_1.forwardRef)(TextEditableCellInner);
@@ -0,0 +1,2 @@
1
+ import { EditableDataGridCellProps } from '../types';
2
+ export declare const DataGridEditableCell: <R, T>({ row, columnKey, column, context, }: EditableDataGridCellProps<R, T>) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
14
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
15
+ if (ar || !(i in from)) {
16
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
17
+ ar[i] = from[i];
18
+ }
19
+ }
20
+ return to.concat(ar || Array.prototype.slice.call(from));
21
+ };
22
+ Object.defineProperty(exports, "__esModule", { value: true });
23
+ exports.DataGridEditableCell = void 0;
24
+ var jsx_runtime_1 = require("react/jsx-runtime");
25
+ var react_1 = require("react");
26
+ var styles_1 = require("./styles");
27
+ var hooks_1 = require("../hooks");
28
+ var DataGridEditableCell = function (_a) {
29
+ var row = _a.row, columnKey = _a.columnKey, column = _a.column, context = _a.context;
30
+ var _b = (0, hooks_1.useDataGridContext)(context), setEditingCell = _b.setEditingCell, setRows = _b.setRows, editRow = _b.editRow, rows = _b.rows, rowKeyGetter = _b.rowKeyGetter;
31
+ var initialValue = (0, react_1.useMemo)(function () { return column.getter(row); }, [column, row]);
32
+ var _c = (0, react_1.useState)(initialValue), value = _c[0], setValue = _c[1];
33
+ var inputRef = (0, react_1.useRef)(null);
34
+ var rowKey = rowKeyGetter(row);
35
+ var defaultItemToPartialRow = (0, react_1.useCallback)(function (key, row, newValue) {
36
+ var _a;
37
+ return (_a = { Id: key }, _a[columnKey] = newValue, _a);
38
+ }, [columnKey]);
39
+ var partialRowGetter = ('itemToPartialRow' in column && column.itemToPartialRow) ||
40
+ defaultItemToPartialRow;
41
+ var save = (0, react_1.useCallback)(function () {
42
+ var rowIndex = rows.findIndex(function (r) { return rowKeyGetter(r) === rowKey; });
43
+ // If row is found
44
+ if (rowIndex >= 0) {
45
+ // Update the row with the new value
46
+ var partialRow = partialRowGetter(rowKey, row, value);
47
+ var newRow_1 = __assign(__assign({}, row), partialRow);
48
+ // Update the edited rows state
49
+ editRow(partialRow);
50
+ // Update the rows
51
+ setRows === null || setRows === void 0 ? void 0 : setRows(function (oldRows) {
52
+ var newRows = __spreadArray([], oldRows, true);
53
+ newRows[rowIndex] = newRow_1;
54
+ return newRows;
55
+ });
56
+ }
57
+ }, [
58
+ editRow,
59
+ partialRowGetter,
60
+ row,
61
+ rowKey,
62
+ rowKeyGetter,
63
+ rows,
64
+ setRows,
65
+ value,
66
+ ]);
67
+ var onClose = (0, react_1.useCallback)(function (shouldSave, nextEditingCell) {
68
+ if (nextEditingCell === void 0) { nextEditingCell = [-1, -1]; }
69
+ if (shouldSave && value !== initialValue) {
70
+ save();
71
+ }
72
+ setEditingCell(nextEditingCell);
73
+ }, [initialValue, save, setEditingCell, value]);
74
+ (0, react_1.useEffect)(function () {
75
+ if (inputRef.current) {
76
+ inputRef.current.focus();
77
+ if (inputRef.current instanceof HTMLInputElement) {
78
+ inputRef.current.select();
79
+ }
80
+ }
81
+ }, [inputRef]);
82
+ var input = (0, react_1.useMemo)(function () {
83
+ if (!('editable' in column) || !column.editable || !column.editComponent) {
84
+ return null;
85
+ }
86
+ var EditComponent = column.editComponent;
87
+ return ((0, jsx_runtime_1.jsx)(EditComponent, { row: row, ref: inputRef, value: value, onChange: setValue, onClose: onClose, context: context }));
88
+ }, [column, context, onClose, row, value]);
89
+ return ((0, jsx_runtime_1.jsx)(styles_1.EditableCellContainer, { "$textAlign": column.textAlign, children: input }, columnKey));
90
+ };
91
+ exports.DataGridEditableCell = DataGridEditableCell;
@@ -0,0 +1,3 @@
1
+ export declare const EditableCellContainer: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {
2
+ $textAlign?: "left" | "right" | "center";
3
+ }>> & string;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.EditableCellContainer = void 0;
11
+ var styles_1 = require("../styles");
12
+ var styled_components_1 = __importDefault(require("styled-components"));
13
+ exports.EditableCellContainer = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n position: relative;\n ", "\n padding: 1px 4px 0px 4px;\n overflow: visible;\n background-color: var(--color-base-0);\n\n & input,\n & select {\n position: absolute;\n inset: 0;\n z-index: 10;\n\n font-size: inherit;\n font-family: inherit;\n font-weight: inherit;\n text-align: ", ";\n\n border: 1px solid var(--color-base-300);\n padding: var(--space-1) var(--space-2);\n\n color: var(--color-text-800);\n &::placeholder {\n color: var(--color-text-400);\n }\n\n border: none;\n outline: none;\n }\n"], ["\n position: relative;\n ", "\n padding: 1px 4px 0px 4px;\n overflow: visible;\n background-color: var(--color-base-0);\n\n & input,\n & select {\n position: absolute;\n inset: 0;\n z-index: 10;\n\n font-size: inherit;\n font-family: inherit;\n font-weight: inherit;\n text-align: ", ";\n\n border: 1px solid var(--color-base-300);\n padding: var(--space-1) var(--space-2);\n\n color: var(--color-text-800);\n &::placeholder {\n color: var(--color-text-400);\n }\n\n border: none;\n outline: none;\n }\n"])), styles_1.dataGridCellCss, function (_a) {
14
+ var _b = _a.$textAlign, $textAlign = _b === void 0 ? 'left' : _b;
15
+ return $textAlign;
16
+ });
17
+ var templateObject_1;