@addev-be/ui 2.5.17 → 2.6.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 (286) hide show
  1. package/assets/icons/arrow-down-1-9.svg +1 -1
  2. package/assets/icons/arrow-down-a-z.svg +1 -1
  3. package/assets/icons/arrow-up-z-a.svg +1 -1
  4. package/assets/icons/check.svg +1 -1
  5. package/assets/icons/circle-check.svg +1 -1
  6. package/assets/icons/down.svg +1 -1
  7. package/assets/icons/filter-full.svg +1 -1
  8. package/assets/icons/filter.svg +1 -1
  9. package/assets/icons/hashtag.svg +1 -1
  10. package/assets/icons/image-slash.svg +1 -1
  11. package/assets/icons/left.svg +1 -1
  12. package/assets/icons/magnifier.svg +1 -1
  13. package/assets/icons/phone.svg +1 -1
  14. package/assets/icons/right.svg +1 -1
  15. package/assets/icons/sort-calendar-ascending.svg +5 -5
  16. package/assets/icons/spinner-third.svg +1 -1
  17. package/assets/icons/table-columns.svg +1 -1
  18. package/assets/icons/table-footer-slash.svg +4 -4
  19. package/assets/icons/table-footer.svg +3 -3
  20. package/assets/icons/table.svg +1 -1
  21. package/assets/icons/up.svg +1 -1
  22. package/assets/icons/user-tie.svg +1 -1
  23. package/assets/icons/x-bar.svg +3 -3
  24. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.d.ts +14 -0
  25. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.js +77 -0
  26. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.d.ts +22 -0
  27. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.js +105 -0
  28. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.d.ts +2 -0
  29. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.js +18 -0
  30. package/dist/components/data/AdvancedRequestDataGrid/index.d.ts +2 -0
  31. package/dist/components/data/AdvancedRequestDataGrid/index.js +215 -0
  32. package/dist/components/data/AdvancedRequestDataGrid/types.d.ts +21 -0
  33. package/dist/components/data/AdvancedRequestDataGrid/types.js +2 -0
  34. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +10 -0
  35. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +173 -0
  36. package/dist/components/data/DataGrid/DataGridEditableCell.d.ts +2 -0
  37. package/dist/components/data/DataGrid/DataGridEditableCell.js +27 -0
  38. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +13 -0
  39. package/dist/components/data/DataGrid/FilterValuesScroller.js +73 -0
  40. package/dist/components/data/DataGrid/VirtualScroller.d.ts +11 -0
  41. package/dist/components/data/DataGrid/VirtualScroller.js +41 -0
  42. package/dist/components/data/DataGrid/helpers/advancedRequests.d.ts +12 -0
  43. package/dist/components/data/DataGrid/helpers/advancedRequests.js +53 -0
  44. package/dist/components/data/DataGrid/helpers.d.ts +28 -0
  45. package/dist/components/data/DataGrid/helpers.js +436 -0
  46. package/dist/components/data/SmartQueryDataGrid/helpers/columns.d.ts +20 -0
  47. package/dist/components/data/SmartQueryDataGrid/helpers/columns.js +160 -0
  48. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.d.ts +5 -0
  49. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.js +41 -0
  50. package/dist/components/data/SmartQueryDataGrid/helpers/index.d.ts +2 -0
  51. package/dist/components/data/SmartQueryDataGrid/helpers/index.js +18 -0
  52. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.d.ts +3 -0
  53. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.js +15 -0
  54. package/dist/components/data/SmartQueryDataGrid/hooks.d.ts +9 -0
  55. package/dist/components/data/SmartQueryDataGrid/hooks.js +63 -0
  56. package/dist/components/data/SmartQueryDataGrid/index.d.ts +12 -0
  57. package/dist/components/data/SmartQueryDataGrid/index.js +242 -0
  58. package/dist/components/data/SmartQueryDataGrid/types.d.ts +22 -0
  59. package/dist/components/data/SmartQueryDataGrid/types.js +2 -0
  60. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.d.ts +2 -1
  61. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.js +2 -3
  62. package/dist/components/forms/BillitIdentifier/index.d.ts +6 -0
  63. package/dist/components/forms/BillitIdentifier/index.js +71 -0
  64. package/dist/components/forms/BillitIdentifier/styles.d.ts +2 -0
  65. package/dist/components/forms/BillitIdentifier/styles.js +15 -0
  66. package/dist/components/forms/Form/FormGroup.d.ts +1 -0
  67. package/dist/components/forms/Form/FormGroup.js +2 -2
  68. package/dist/components/forms/Form/InputWithLabel.d.ts +2 -0
  69. package/dist/components/forms/Form/InputWithLabel.js +10 -0
  70. package/dist/components/forms/Form/Row.js +1 -1
  71. package/dist/components/forms/Form/Select.d.ts +3 -1
  72. package/dist/components/forms/Form/Select.js +19 -10
  73. package/dist/components/forms/Form/index.d.ts +4 -1
  74. package/dist/components/forms/Form/styles.d.ts +5 -3
  75. package/dist/components/forms/Form/styles.js +19 -14
  76. package/dist/components/forms/Form/types.d.ts +7 -0
  77. package/dist/components/forms/Form/types.js +2 -0
  78. package/dist/components/forms/styles.js +1 -1
  79. package/dist/components/ui/Card/index.d.ts +2 -1
  80. package/dist/components/ui/Card/styles.d.ts +2 -1
  81. package/dist/components/ui/Card/styles.js +2 -1
  82. package/dist/components/ui/TabsView/TabsList.d.ts +1 -0
  83. package/dist/components/ui/TabsView/TabsList.js +4 -2
  84. package/dist/components/ui/TabsView/TabsView.d.ts +3 -1
  85. package/dist/components/ui/TabsView/TabsView.js +2 -2
  86. package/dist/components/ui/TabsView/styles.js +4 -4
  87. package/dist/config/types.d.ts +11 -0
  88. package/dist/config/types.js +2 -0
  89. package/dist/helpers/react.d.ts +2 -0
  90. package/dist/helpers/react.js +8 -0
  91. package/dist/helpers/styled/index.d.ts +1 -0
  92. package/dist/helpers/styled/index.js +17 -0
  93. package/dist/hooks/useMutableState.d.ts +5 -3
  94. package/dist/hooks/useMutableState.js +9 -2
  95. package/dist/hooks/useMutableState.test.d.ts +4 -0
  96. package/dist/hooks/useMutableState.test.js +320 -0
  97. package/dist/index.d.ts +1 -0
  98. package/dist/index.js +1 -0
  99. package/dist/providers/ThemeProvider/defaultTheme.js +1 -0
  100. package/dist/providers/ThemeProvider/helpers.d.ts +1 -1
  101. package/dist/providers/ThemeProvider/index.js +1 -1
  102. package/dist/providers/ThemeProvider/types.d.ts +1 -1
  103. package/dist/services/index.js +17 -7
  104. package/dist/services/requests/userPermissions.d.ts +4 -0
  105. package/dist/services/requests/userPermissions.js +20 -0
  106. package/dist/services/sqlRequests.d.ts +1 -1
  107. package/eslint.config.js +3 -3
  108. package/package.json +11 -4
  109. package/src/Icons.tsx +138 -138
  110. package/src/components/auth/LoginForm.tsx +86 -86
  111. package/src/components/auth/LoginPage.tsx +32 -32
  112. package/src/components/auth/PasswordRecoveryForm.tsx +53 -53
  113. package/src/components/auth/PasswordResetForm.tsx +112 -112
  114. package/src/components/auth/styles.ts +14 -14
  115. package/src/components/data/DataGrid/DataGridCell.tsx +81 -81
  116. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +9 -9
  117. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -59
  118. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +182 -182
  119. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  120. package/src/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.tsx +37 -37
  121. package/src/components/data/DataGrid/DataGridEditableCell/DateEditableCell.tsx +38 -38
  122. package/src/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.tsx +71 -71
  123. package/src/components/data/DataGrid/DataGridEditableCell/TextEditableCell.tsx +37 -37
  124. package/src/components/data/DataGrid/DataGridEditableCell/index.tsx +106 -106
  125. package/src/components/data/DataGrid/DataGridEditableCell/styles.ts +35 -35
  126. package/src/components/data/DataGrid/DataGridEditableCell/types.ts +18 -18
  127. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +129 -129
  128. package/src/components/data/DataGrid/DataGridFilterMenu/helpers.ts +23 -23
  129. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +81 -81
  130. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +370 -370
  131. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +97 -97
  132. package/src/components/data/DataGrid/DataGridFooter.tsx +47 -47
  133. package/src/components/data/DataGrid/DataGridHeader.tsx +74 -74
  134. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +112 -112
  135. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +83 -83
  136. package/src/components/data/DataGrid/DataGridToolbar.tsx +134 -134
  137. package/src/components/data/DataGrid/FilterModalContent/index.tsx +137 -137
  138. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  139. package/src/components/data/DataGrid/constants.ts +6 -6
  140. package/src/components/data/DataGrid/helpers/columns.tsx +449 -449
  141. package/src/components/data/DataGrid/helpers/filters.ts +287 -287
  142. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  143. package/src/components/data/DataGrid/hooks/index.ts +29 -29
  144. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +383 -383
  145. package/src/components/data/DataGrid/hooks/useDataGridChangedRows.ts +97 -97
  146. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +174 -174
  147. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  148. package/src/components/data/DataGrid/hooks/useRefreshModal.tsx +48 -48
  149. package/src/components/data/DataGrid/index.tsx +111 -111
  150. package/src/components/data/DataGrid/styles.ts +434 -434
  151. package/src/components/data/DataGrid/types.ts +380 -380
  152. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +526 -526
  153. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  154. package/src/components/data/SqlRequestDataGrid/helpers/rows.ts +24 -24
  155. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +17 -17
  156. package/src/components/data/SqlRequestDataGrid/index.tsx +417 -417
  157. package/src/components/data/SqlRequestDataGrid/styles.ts +15 -15
  158. package/src/components/data/SqlRequestDataGrid/types.ts +74 -74
  159. package/src/components/data/SqlRequestForeignList/index.tsx +254 -254
  160. package/src/components/data/SqlRequestForeignList/styles.ts +43 -43
  161. package/src/components/data/SqlRequestForeignList/types.ts +32 -32
  162. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +108 -108
  163. package/src/components/data/SqlRequestGrid/filters/styles.ts +88 -88
  164. package/src/components/data/SqlRequestGrid/helpers/index.ts +1 -1
  165. package/src/components/data/SqlRequestGrid/helpers/sqlRequests.ts +16 -16
  166. package/src/components/data/SqlRequestGrid/index.tsx +304 -304
  167. package/src/components/data/SqlRequestGrid/styles.ts +20 -20
  168. package/src/components/data/SqlRequestGrid/types.ts +73 -73
  169. package/src/components/data/VirtualScroller/hooks.ts +71 -71
  170. package/src/components/data/VirtualScroller/index.tsx +89 -89
  171. package/src/components/data/VirtualScroller/styles.ts +57 -57
  172. package/src/components/data/VirtualScroller/types.ts +10 -10
  173. package/src/components/forms/AutoTextArea.tsx +48 -48
  174. package/src/components/forms/BillitIdentifier/index.tsx +78 -0
  175. package/src/components/forms/BillitIdentifier/styles.tsx +43 -0
  176. package/src/components/forms/Button.tsx +132 -132
  177. package/src/components/forms/Form/Checkbox.tsx +12 -12
  178. package/src/components/forms/Form/CustomSelect.tsx +86 -86
  179. package/src/components/forms/Form/FormGroup.tsx +33 -31
  180. package/src/components/forms/Form/Input.tsx +16 -16
  181. package/src/components/forms/Form/Row.tsx +28 -32
  182. package/src/components/forms/Form/Select.tsx +99 -82
  183. package/src/components/forms/Form/TextArea.tsx +17 -17
  184. package/src/components/forms/Form/index.tsx +48 -48
  185. package/src/components/forms/Form/styles.ts +148 -184
  186. package/src/components/forms/IconButton.tsx +61 -61
  187. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  188. package/src/components/forms/NumberInput.tsx +53 -53
  189. package/src/components/forms/Select.tsx +34 -34
  190. package/src/components/forms/VerticalLabel.tsx +20 -20
  191. package/src/components/forms/styles.ts +42 -42
  192. package/src/components/layout/Columns.ts +28 -28
  193. package/src/components/layout/Dropdown/index.tsx +113 -113
  194. package/src/components/layout/Dropdown/styles.ts +53 -53
  195. package/src/components/layout/Flexbox.ts +21 -21
  196. package/src/components/layout/Grid/index.tsx +8 -8
  197. package/src/components/layout/Grid/styles.ts +34 -34
  198. package/src/components/layout/Loading/index.tsx +29 -29
  199. package/src/components/layout/Loading/styles.ts +29 -29
  200. package/src/components/layout/Masonry/index.tsx +29 -29
  201. package/src/components/layout/Masonry/styles.ts +20 -20
  202. package/src/components/layout/Modal/index.tsx +51 -51
  203. package/src/components/layout/Modal/styles.ts +125 -125
  204. package/src/components/search/HighlightedText.tsx +41 -41
  205. package/src/components/search/QuickSearchBar.tsx +102 -102
  206. package/src/components/search/QuickSearchResults.tsx +86 -86
  207. package/src/components/search/styles.ts +96 -96
  208. package/src/components/search/types.ts +29 -29
  209. package/src/components/ui/Avatar/index.tsx +54 -54
  210. package/src/components/ui/Avatar/styles.ts +61 -61
  211. package/src/components/ui/Card/index.tsx +16 -14
  212. package/src/components/ui/Card/styles.ts +41 -37
  213. package/src/components/ui/ContextMenu/index.tsx +79 -79
  214. package/src/components/ui/ContextMenu/styles.ts +119 -119
  215. package/src/components/ui/Ellipsis.tsx +33 -33
  216. package/src/components/ui/Label.tsx +93 -93
  217. package/src/components/ui/Message/index.tsx +57 -57
  218. package/src/components/ui/Message/styles.ts +44 -44
  219. package/src/components/ui/TabsView/TabsList.tsx +49 -44
  220. package/src/components/ui/TabsView/TabsView.tsx +42 -38
  221. package/src/components/ui/TabsView/index.ts +3 -3
  222. package/src/components/ui/TabsView/styles.ts +84 -76
  223. package/src/components/ui/TabsView/types.ts +15 -15
  224. package/src/config/index.ts +10 -10
  225. package/src/helpers/components.ts +9 -9
  226. package/src/helpers/dates.ts +17 -17
  227. package/src/helpers/getScrollbarSize.ts +14 -14
  228. package/src/helpers/numbers.ts +63 -63
  229. package/src/helpers/responsive.ts +83 -83
  230. package/src/helpers/styled/space.ts +114 -114
  231. package/src/helpers/styled/typography.ts +25 -25
  232. package/src/helpers/text.ts +13 -13
  233. package/src/helpers/types.ts +9 -9
  234. package/src/hooks/useContainerMediaQuery.ts +7 -7
  235. package/src/hooks/useElementSize.ts +24 -24
  236. package/src/hooks/useMediaQuery.ts +9 -9
  237. package/src/hooks/useMediaQueryForWidth.ts +35 -35
  238. package/src/hooks/useMutableState.test.ts +410 -0
  239. package/src/hooks/useMutableState.ts +39 -25
  240. package/src/hooks/useShowArchived.ts +28 -28
  241. package/src/hooks/useWindowSize.ts +20 -20
  242. package/src/index.ts +103 -102
  243. package/src/providers/AuthenticationProvider/helpers.ts +3 -3
  244. package/src/providers/AuthenticationProvider/index.tsx +303 -303
  245. package/src/providers/LoadingProvider/index.tsx +47 -47
  246. package/src/providers/PortalsProvider/index.tsx +54 -54
  247. package/src/providers/PortalsProvider/styles.ts +31 -31
  248. package/src/providers/SettingsProvider/index.tsx +70 -70
  249. package/src/providers/ThemeProvider/defaultTheme.ts +471 -470
  250. package/src/providers/ThemeProvider/helpers.ts +84 -84
  251. package/src/providers/ThemeProvider/index.ts +73 -66
  252. package/src/providers/ThemeProvider/types.ts +134 -134
  253. package/src/providers/ToastProvider/index.tsx +93 -93
  254. package/src/providers/TrackingProvider/hooks.ts +14 -14
  255. package/src/providers/TrackingProvider/index.tsx +71 -71
  256. package/src/providers/UiProviders/index.tsx +76 -76
  257. package/src/providers/UiProviders/styles.ts +10 -10
  258. package/src/providers/hooks.ts +14 -14
  259. package/src/services/HttpService.ts +92 -92
  260. package/src/services/WebSocketService.ts +155 -155
  261. package/src/services/advancedRequests.ts +102 -102
  262. package/src/services/base.ts +23 -23
  263. package/src/services/globalSearch.ts +32 -32
  264. package/src/services/hooks.ts +92 -92
  265. package/src/services/requests/auth.ts +44 -44
  266. package/src/services/requests/generic.ts +62 -62
  267. package/src/services/requests/printing.ts +12 -12
  268. package/src/services/requests/tracking.ts +12 -12
  269. package/src/services/requests/userProfiles.ts +35 -35
  270. package/src/services/requests/users.ts +28 -28
  271. package/src/services/smartQueries.ts +122 -122
  272. package/src/services/sqlRequests.ts +119 -113
  273. package/src/services/types/auth.ts +98 -98
  274. package/src/services/types/base.ts +10 -10
  275. package/src/services/types/generic.ts +82 -82
  276. package/src/services/types/printing.ts +10 -10
  277. package/src/services/types/tracking.ts +29 -29
  278. package/src/services/types/userProfiles.ts +79 -79
  279. package/src/services/types/users.ts +74 -74
  280. package/src/services/updateSqlRequests.ts +32 -32
  281. package/src/styles/animations.scss +30 -30
  282. package/src/styles/index.scss +42 -42
  283. package/src/types.ts +8 -8
  284. package/src/typings.d.ts +2 -2
  285. package/tsconfig.json +18 -18
  286. package/tsconfig.tsbuildinfo +1 -1
@@ -0,0 +1,320 @@
1
+ "use strict";
2
+ /**
3
+ * @vitest-environment jsdom
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ var react_1 = require("@testing-library/react");
7
+ var vitest_1 = require("vitest");
8
+ var useMutableState_1 = require("./useMutableState");
9
+ (0, vitest_1.describe)('isDispatchFunction', function () {
10
+ (0, vitest_1.it)('should return true for functions', function () {
11
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
12
+ var fn = function (state) { return state; };
13
+ (0, vitest_1.expect)((0, useMutableState_1.isDispatchFunction)(fn)).toBe(true);
14
+ });
15
+ (0, vitest_1.it)('should return false for objects', function () {
16
+ (0, vitest_1.expect)((0, useMutableState_1.isDispatchFunction)({ key: 'value' })).toBe(false);
17
+ });
18
+ (0, vitest_1.it)('should return false for primitives', function () {
19
+ (0, vitest_1.expect)((0, useMutableState_1.isDispatchFunction)('string')).toBe(false);
20
+ (0, vitest_1.expect)((0, useMutableState_1.isDispatchFunction)(123)).toBe(false);
21
+ (0, vitest_1.expect)((0, useMutableState_1.isDispatchFunction)(null)).toBe(false);
22
+ (0, vitest_1.expect)((0, useMutableState_1.isDispatchFunction)(undefined)).toBe(false);
23
+ });
24
+ });
25
+ (0, vitest_1.describe)('useMutableState', function () {
26
+ (0, vitest_1.describe)('initialization', function () {
27
+ (0, vitest_1.it)('should initialize with default value', function () {
28
+ var result = (0, react_1.renderHook)(function () {
29
+ return (0, useMutableState_1.useMutableState)({ name: 'John', age: 30 });
30
+ }).result;
31
+ var state = result.current[0];
32
+ (0, vitest_1.expect)(state).toEqual({ name: 'John', age: 30 });
33
+ });
34
+ (0, vitest_1.it)('should initialize with empty object when no value is provided', function () {
35
+ var result = (0, react_1.renderHook)(function () { return (0, useMutableState_1.useMutableState)(); }).result;
36
+ var state = result.current[0];
37
+ (0, vitest_1.expect)(state).toEqual({});
38
+ });
39
+ (0, vitest_1.it)('should initialize with function result', function () {
40
+ var result = (0, react_1.renderHook)(function () {
41
+ return (0, useMutableState_1.useMutableState)(function () { return ({ count: 0, items: [] }); });
42
+ }).result;
43
+ var state = result.current[0];
44
+ (0, vitest_1.expect)(state).toEqual({ count: 0, items: [] });
45
+ });
46
+ (0, vitest_1.it)('should return tuple with three elements', function () {
47
+ var result = (0, react_1.renderHook)(function () { return (0, useMutableState_1.useMutableState)({ value: 1 }); }).result;
48
+ (0, vitest_1.expect)(result.current).toHaveLength(3);
49
+ (0, vitest_1.expect)(typeof result.current[0]).toBe('object');
50
+ (0, vitest_1.expect)(typeof result.current[1]).toBe('function');
51
+ (0, vitest_1.expect)(typeof result.current[2]).toBe('function');
52
+ });
53
+ });
54
+ (0, vitest_1.describe)('setValue (full state update)', function () {
55
+ (0, vitest_1.it)('should update entire state with new value', function () {
56
+ var result = (0, react_1.renderHook)(function () {
57
+ return (0, useMutableState_1.useMutableState)({ name: 'John', age: 30 });
58
+ }).result;
59
+ (0, react_1.act)(function () {
60
+ var _a = result.current, setValue = _a[1];
61
+ setValue({ name: 'Jane', age: 25 });
62
+ });
63
+ (0, vitest_1.expect)(result.current[0]).toEqual({ name: 'Jane', age: 25 });
64
+ });
65
+ (0, vitest_1.it)('should update state using function', function () {
66
+ var result = (0, react_1.renderHook)(function () { return (0, useMutableState_1.useMutableState)({ count: 0 }); }).result;
67
+ (0, react_1.act)(function () {
68
+ var _a = result.current, setValue = _a[1];
69
+ setValue(function (prev) { return ({ count: prev.count + 1 }); });
70
+ });
71
+ (0, vitest_1.expect)(result.current[0]).toEqual({ count: 1 });
72
+ });
73
+ (0, vitest_1.it)('should replace entire state object', function () {
74
+ var result = (0, react_1.renderHook)(function () {
75
+ return (0, useMutableState_1.useMutableState)({ name: 'John', age: 30, city: 'Paris' });
76
+ }).result;
77
+ (0, react_1.act)(function () {
78
+ var _a = result.current, setValue = _a[1];
79
+ setValue({ name: 'Jane', age: 22, city: 'London' });
80
+ });
81
+ (0, vitest_1.expect)(result.current[0]).toEqual({
82
+ name: 'Jane',
83
+ age: 22,
84
+ city: 'London',
85
+ });
86
+ });
87
+ });
88
+ (0, vitest_1.describe)('setPartialValue (partial state update)', function () {
89
+ (0, vitest_1.it)('should merge partial object with existing state', function () {
90
+ var result = (0, react_1.renderHook)(function () {
91
+ return (0, useMutableState_1.useMutableState)({ name: 'John', age: 30, city: 'Paris' });
92
+ }).result;
93
+ (0, react_1.act)(function () {
94
+ var _a = result.current, setPartialValue = _a[2];
95
+ setPartialValue({ age: 31 });
96
+ });
97
+ (0, vitest_1.expect)(result.current[0]).toEqual({
98
+ name: 'John',
99
+ age: 31,
100
+ city: 'Paris',
101
+ });
102
+ });
103
+ (0, vitest_1.it)('should merge partial object using function', function () {
104
+ var result = (0, react_1.renderHook)(function () {
105
+ return (0, useMutableState_1.useMutableState)({ count: 0, total: 100 });
106
+ }).result;
107
+ (0, react_1.act)(function () {
108
+ var _a = result.current, setPartialValue = _a[2];
109
+ setPartialValue(function (state) { return ({ count: state.count + 5 }); });
110
+ });
111
+ (0, vitest_1.expect)(result.current[0]).toEqual({ count: 5, total: 100 });
112
+ });
113
+ (0, vitest_1.it)('should handle deep nested objects', function () {
114
+ var result = (0, react_1.renderHook)(function () {
115
+ return (0, useMutableState_1.useMutableState)({
116
+ user: {
117
+ name: 'John',
118
+ address: {
119
+ city: 'Paris',
120
+ country: 'France',
121
+ },
122
+ },
123
+ settings: {
124
+ theme: 'dark',
125
+ },
126
+ });
127
+ }).result;
128
+ (0, react_1.act)(function () {
129
+ var _a = result.current, setPartialValue = _a[2];
130
+ setPartialValue({
131
+ user: {
132
+ address: {
133
+ city: 'Lyon',
134
+ },
135
+ },
136
+ });
137
+ });
138
+ (0, vitest_1.expect)(result.current[0]).toEqual({
139
+ user: {
140
+ name: 'John',
141
+ address: {
142
+ city: 'Lyon',
143
+ country: 'France',
144
+ },
145
+ },
146
+ settings: {
147
+ theme: 'dark',
148
+ },
149
+ });
150
+ });
151
+ (0, vitest_1.it)('should add new properties to state', function () {
152
+ var result = (0, react_1.renderHook)(function () {
153
+ return (0, useMutableState_1.useMutableState)({ name: 'John' });
154
+ }).result;
155
+ (0, react_1.act)(function () {
156
+ var _a = result.current, setPartialValue = _a[2];
157
+ setPartialValue({ age: 30 });
158
+ });
159
+ (0, vitest_1.expect)(result.current[0]).toEqual({ name: 'John', age: 30 });
160
+ });
161
+ (0, vitest_1.it)('should handle multiple consecutive updates', function () {
162
+ var result = (0, react_1.renderHook)(function () {
163
+ return (0, useMutableState_1.useMutableState)({ count: 0, value: 10 });
164
+ }).result;
165
+ (0, react_1.act)(function () {
166
+ var _a = result.current, setPartialValue = _a[2];
167
+ setPartialValue({ count: 1 });
168
+ setPartialValue({ value: 20 });
169
+ setPartialValue({ count: 2 });
170
+ });
171
+ (0, vitest_1.expect)(result.current[0]).toEqual({ count: 2, value: 20 });
172
+ });
173
+ (0, vitest_1.it)('should handle empty partial object', function () {
174
+ var result = (0, react_1.renderHook)(function () {
175
+ return (0, useMutableState_1.useMutableState)({ name: 'John', age: 30 });
176
+ }).result;
177
+ (0, react_1.act)(function () {
178
+ var _a = result.current, setPartialValue = _a[2];
179
+ setPartialValue({});
180
+ });
181
+ (0, vitest_1.expect)(result.current[0]).toEqual({ name: 'John', age: 30 });
182
+ });
183
+ (0, vitest_1.it)('should preserve arrays correctly', function () {
184
+ var result = (0, react_1.renderHook)(function () {
185
+ return (0, useMutableState_1.useMutableState)({ items: [1, 2, 3], count: 0 });
186
+ }).result;
187
+ (0, react_1.act)(function () {
188
+ var _a = result.current, setPartialValue = _a[2];
189
+ setPartialValue({ count: 5 });
190
+ });
191
+ (0, vitest_1.expect)(result.current[0]).toEqual({ items: [1, 2, 3], count: 5 });
192
+ });
193
+ (0, vitest_1.it)('should update arrays when provided', function () {
194
+ var result = (0, react_1.renderHook)(function () {
195
+ return (0, useMutableState_1.useMutableState)({ items: [1, 2, 3], count: 0 });
196
+ }).result;
197
+ (0, react_1.act)(function () {
198
+ var _a = result.current, setPartialValue = _a[2];
199
+ setPartialValue({ items: [4, 5, 6] });
200
+ });
201
+ (0, vitest_1.expect)(result.current[0]).toEqual({ items: [4, 5, 6], count: 0 });
202
+ });
203
+ });
204
+ (0, vitest_1.describe)('referential stability', function () {
205
+ (0, vitest_1.it)('should maintain stable setPartialValue reference', function () {
206
+ var _a = (0, react_1.renderHook)(function () {
207
+ return (0, useMutableState_1.useMutableState)({ count: 0 });
208
+ }), result = _a.result, rerender = _a.rerender;
209
+ var _b = result.current, firstSetPartial = _b[2];
210
+ (0, react_1.act)(function () {
211
+ var _a = result.current, setValue = _a[1];
212
+ setValue({ count: 1 });
213
+ });
214
+ rerender();
215
+ var _c = result.current, secondSetPartial = _c[2];
216
+ (0, vitest_1.expect)(firstSetPartial).toBe(secondSetPartial);
217
+ });
218
+ (0, vitest_1.it)('should trigger new reference when state changes', function () {
219
+ var _a = (0, react_1.renderHook)(function () {
220
+ return (0, useMutableState_1.useMutableState)({ count: 0 });
221
+ }), result = _a.result, rerender = _a.rerender;
222
+ var firstState = result.current[0];
223
+ (0, react_1.act)(function () {
224
+ var _a = result.current, setPartialValue = _a[2];
225
+ setPartialValue({ count: 1 });
226
+ });
227
+ rerender();
228
+ var secondState = result.current[0];
229
+ (0, vitest_1.expect)(firstState).not.toBe(secondState);
230
+ });
231
+ });
232
+ (0, vitest_1.describe)('complex types', function () {
233
+ (0, vitest_1.it)('should handle complex nested types', function () {
234
+ var initialState = {
235
+ id: 1,
236
+ user: {
237
+ name: 'John',
238
+ email: 'john@example.com',
239
+ preferences: {
240
+ notifications: true,
241
+ theme: 'dark',
242
+ },
243
+ },
244
+ items: ['item1', 'item2'],
245
+ };
246
+ var result = (0, react_1.renderHook)(function () { return (0, useMutableState_1.useMutableState)(initialState); }).result;
247
+ (0, react_1.act)(function () {
248
+ var _a = result.current, setPartialValue = _a[2];
249
+ setPartialValue({
250
+ user: {
251
+ preferences: {
252
+ theme: 'light',
253
+ },
254
+ },
255
+ metadata: { lastUpdated: Date.now() },
256
+ });
257
+ });
258
+ var state = result.current[0];
259
+ (0, vitest_1.expect)(state.user.name).toBe('John');
260
+ (0, vitest_1.expect)(state.user.email).toBe('john@example.com');
261
+ (0, vitest_1.expect)(state.user.preferences.notifications).toBe(true);
262
+ (0, vitest_1.expect)(state.user.preferences.theme).toBe('light');
263
+ (0, vitest_1.expect)(state.metadata).toBeDefined();
264
+ (0, vitest_1.expect)(state.items).toEqual(['item1', 'item2']);
265
+ });
266
+ });
267
+ (0, vitest_1.describe)('edge cases', function () {
268
+ (0, vitest_1.it)('should handle null values', function () {
269
+ var result = (0, react_1.renderHook)(function () {
270
+ return (0, useMutableState_1.useMutableState)({ value: 'test' });
271
+ }).result;
272
+ (0, react_1.act)(function () {
273
+ var _a = result.current, setPartialValue = _a[2];
274
+ setPartialValue({ value: null });
275
+ });
276
+ (0, vitest_1.expect)(result.current[0]).toEqual({ value: null });
277
+ });
278
+ (0, vitest_1.it)('should handle undefined values', function () {
279
+ var result = (0, react_1.renderHook)(function () {
280
+ return (0, useMutableState_1.useMutableState)({ value: 'test' });
281
+ }).result;
282
+ (0, react_1.act)(function () {
283
+ var _a = result.current, setPartialValue = _a[2];
284
+ setPartialValue({ value: undefined });
285
+ });
286
+ // defaultsDeep doesn't override with undefined, so original value remains
287
+ (0, vitest_1.expect)(result.current[0].value).toBe('test');
288
+ });
289
+ (0, vitest_1.it)('should handle state with boolean false', function () {
290
+ var result = (0, react_1.renderHook)(function () {
291
+ return (0, useMutableState_1.useMutableState)({ isActive: true, isEnabled: true });
292
+ }).result;
293
+ (0, react_1.act)(function () {
294
+ var _a = result.current, setPartialValue = _a[2];
295
+ setPartialValue({ isActive: false });
296
+ });
297
+ (0, vitest_1.expect)(result.current[0]).toEqual({ isActive: false, isEnabled: true });
298
+ });
299
+ (0, vitest_1.it)('should handle state with number zero', function () {
300
+ var result = (0, react_1.renderHook)(function () {
301
+ return (0, useMutableState_1.useMutableState)({ count: 10, total: 100 });
302
+ }).result;
303
+ (0, react_1.act)(function () {
304
+ var _a = result.current, setPartialValue = _a[2];
305
+ setPartialValue({ count: 0 });
306
+ });
307
+ (0, vitest_1.expect)(result.current[0]).toEqual({ count: 0, total: 100 });
308
+ });
309
+ (0, vitest_1.it)('should handle state with empty string', function () {
310
+ var result = (0, react_1.renderHook)(function () {
311
+ return (0, useMutableState_1.useMutableState)({ name: 'John', description: 'Test' });
312
+ }).result;
313
+ (0, react_1.act)(function () {
314
+ var _a = result.current, setPartialValue = _a[2];
315
+ setPartialValue({ name: '' });
316
+ });
317
+ (0, vitest_1.expect)(result.current[0]).toEqual({ name: '', description: 'Test' });
318
+ });
319
+ });
320
+ });
package/dist/index.d.ts CHANGED
@@ -15,6 +15,7 @@ export * from './components/data/SqlRequestForeignList';
15
15
  export * from './components/data/VirtualScroller';
16
16
  export * from './components/data/VirtualScroller/types';
17
17
  export * from './components/forms/AutoTextArea';
18
+ export * from './components/forms/BillitIdentifier';
18
19
  export * from './components/forms/Button';
19
20
  export * from './components/forms/Select';
20
21
  export * from './components/forms/IconButton';
package/dist/index.js CHANGED
@@ -31,6 +31,7 @@ __exportStar(require("./components/data/SqlRequestForeignList"), exports);
31
31
  __exportStar(require("./components/data/VirtualScroller"), exports);
32
32
  __exportStar(require("./components/data/VirtualScroller/types"), exports);
33
33
  __exportStar(require("./components/forms/AutoTextArea"), exports);
34
+ __exportStar(require("./components/forms/BillitIdentifier"), exports);
34
35
  __exportStar(require("./components/forms/Button"), exports);
35
36
  __exportStar(require("./components/forms/Select"), exports);
36
37
  __exportStar(require("./components/forms/IconButton"), exports);
@@ -365,6 +365,7 @@ exports.defaultTheme = {
365
365
  sans: "'Montserrat', Helvetica, Arial, Verdana, sans-serif",
366
366
  serif: "Georgia, Cambria, 'Times New Roman', Times, serif",
367
367
  mono: "Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace",
368
+ input: "'Montserrat', Helvetica, Arial, Verdana, sans-serif",
368
369
  },
369
370
  weights: {
370
371
  light: '200',
@@ -3,7 +3,7 @@ import { DeepPartial } from '../../types';
3
3
  export declare const extendTheme: (base: Theme, override?: DeepPartial<Theme>) => Theme;
4
4
  export declare const extendDefaultTheme: (override?: DeepPartial<Theme>) => Theme;
5
5
  export declare const extendDefaultDarkTheme: (override?: DeepPartial<Theme>) => Theme;
6
- export declare const getColor: (colorWithIntensity: ThemeColorWithIntensity) => ThemeColor;
6
+ export declare const getColor: (colorWithIntensity: ThemeColor | ThemeColorWithIntensity) => ThemeColor;
7
7
  export declare const getIntensity: (colorWithIntensity: ThemeColorWithIntensity) => ThemeColorIntensity;
8
8
  export declare const isThemeColorWithIntensity: (color: ThemeColor | ThemeColorWithIntensity) => color is ThemeColorWithIntensity;
9
9
  export declare const getColorWithIntensity: (color: ThemeColor | ThemeColorWithIntensity, defaultIntensity?: ThemeColorIntensity) => ThemeColorWithIntensity;
@@ -35,7 +35,7 @@ var getThemeColorsCss = function (colors, darkMode) {
35
35
  })
36
36
  .join('');
37
37
  };
38
- exports.ThemeProvider = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: contents;\n ", "\n\n a, a:visited {\n color: var(--color-primary-500);\n }\n a:active,\n a:hover {\n color: var(--color-primary-700);\n }\n"], ["\n display: contents;\n ", "\n\n a, a:visited {\n color: var(--color-primary-500);\n }\n a:active,\n a:hover {\n color: var(--color-primary-700);\n }\n"])), function (_a) {
38
+ exports.ThemeProvider = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: contents;\n ", "\n\n font-family: var(--font-sans);\n font-size: var(--text-base);\n font-weight: var(--weight-normal);\n color: var(--color-text-800);\n background-color: var(--color-base-0);\n\n a,\n a:visited {\n color: var(--color-primary-500);\n }\n a:active,\n a:hover {\n color: var(--color-primary-700);\n }\n"], ["\n display: contents;\n ", "\n\n font-family: var(--font-sans);\n font-size: var(--text-base);\n font-weight: var(--weight-normal);\n color: var(--color-text-800);\n background-color: var(--color-base-0);\n\n a,\n a:visited {\n color: var(--color-primary-500);\n }\n a:active,\n a:hover {\n color: var(--color-primary-700);\n }\n"])), function (_a) {
39
39
  var _b = _a.$theme, $theme = _b === void 0 ? {} : _b, $darkTheme = _a.$darkTheme, $darkMode = _a.$darkMode;
40
40
  var theme = $darkMode ? $darkTheme !== null && $darkTheme !== void 0 ? $darkTheme : $theme : $theme;
41
41
  var darkMode = !$darkTheme && $darkMode;
@@ -7,7 +7,7 @@ export type ThemeColor = ThemeRawColor | ThemePredefinedColor;
7
7
  export type ThemeColorReference = ThemeColor | ThemeColorDefinition;
8
8
  export type ThemeColorWithIntensity = `${ThemeColor}-${ThemeColorIntensity}`;
9
9
  export type ThemeTextSize = 'xs' | 'sm' | 'base' | 'lg' | 'xl' | '2xl' | '3xl' | '4xl' | '5xl' | '6xl';
10
- export type ThemeFontFamily = 'sans' | 'serif' | 'mono';
10
+ export type ThemeFontFamily = 'sans' | 'serif' | 'mono' | 'input';
11
11
  export type ThemeFontWeight = 'light' | 'normal' | 'bold';
12
12
  export type ThemeSpace = '0' | '0_5' | '1' | '1_5' | '2' | '3' | '4' | '5' | '6' | '8' | '10' | '12' | '14' | '16' | '20' | '24' | '32' | '40' | '48' | '56' | '64' | '72' | '80' | '96' | '128';
13
13
  export type ThemeSpaceWithNegative = ThemeSpace | `-${ThemeSpace}`;
@@ -18,13 +18,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
18
18
  var __exportStar = (this && this.__exportStar) || function(m, exports) {
19
19
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
20
20
  };
21
- var __importStar = (this && this.__importStar) || function (mod) {
22
- if (mod && mod.__esModule) return mod;
23
- var result = {};
24
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
25
- __setModuleDefault(result, mod);
26
- return result;
27
- };
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
28
38
  Object.defineProperty(exports, "__esModule", { value: true });
29
39
  exports.SmartQueries = void 0;
30
40
  __exportStar(require("./WebSocketService"), exports);
@@ -0,0 +1,4 @@
1
+ export declare const useGetUserPermissionRequestHandler: () => (data: GetUserPermissionRequestDTO) => Promise<GetUserPermissionResponseDTO>;
2
+ export declare const useGetAllUserPermissionsRequestHandler: () => (data: GetAllUserPermissionsRequestDTO) => Promise<GetAllUserPermissionsResponseDTO>;
3
+ export declare const useSaveUserPermissionRequestHandler: () => (data: SaveUserPermissionRequestDTO) => Promise<SaveUserPermissionResponseDTO>;
4
+ export declare const useDeleteUserPermissionRequestHandler: () => (data: DeleteUserPermissionRequestDTO) => Promise<DeleteUserPermissionResponseDTO>;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useDeleteUserPermissionRequestHandler = exports.useSaveUserPermissionRequestHandler = exports.useGetAllUserPermissionsRequestHandler = exports.useGetUserPermissionRequestHandler = void 0;
4
+ var hooks_1 = require("../hooks");
5
+ var useGetUserPermissionRequestHandler = function () {
6
+ return (0, hooks_1.useLoadingRequestHandler)('GetUserPermission');
7
+ };
8
+ exports.useGetUserPermissionRequestHandler = useGetUserPermissionRequestHandler;
9
+ var useGetAllUserPermissionsRequestHandler = function () {
10
+ return (0, hooks_1.useLoadingRequestHandler)('GetAllUserPermissions');
11
+ };
12
+ exports.useGetAllUserPermissionsRequestHandler = useGetAllUserPermissionsRequestHandler;
13
+ var useSaveUserPermissionRequestHandler = function () {
14
+ return (0, hooks_1.useLoadingRequestHandler)('SaveUserPermission');
15
+ };
16
+ exports.useSaveUserPermissionRequestHandler = useSaveUserPermissionRequestHandler;
17
+ var useDeleteUserPermissionRequestHandler = function () {
18
+ return (0, hooks_1.useLoadingRequestHandler)('DeleteUserPermission');
19
+ };
20
+ exports.useDeleteUserPermissionRequestHandler = useDeleteUserPermissionRequestHandler;
@@ -9,7 +9,7 @@ export type FieldDTO<T extends string = string> = {
9
9
  };
10
10
  export type ConditionDTO = {
11
11
  field: string;
12
- operator: 'lessThan' | 'lessThanOrEqual' | 'lessThanOrEquals' | 'equals' | 'notEquals' | 'greaterThanOrEqual' | 'greaterThanOrEquals' | 'greaterThan' | 'like' | 'contains' | 'notContains' | 'startsWith' | 'endsWith' | 'notLike' | 'inRange' | 'between' | 'isNull' | 'isNotNull' | 'inArray' | 'in' | 'not' | 'and' | 'or';
12
+ operator: 'isLessThan' | 'isLessThanOrEqual' | 'isLessThanOrEquals' | 'lessThan' | 'lessThanOrEqual' | 'lessThanOrEquals' | 'equals' | 'notEquals' | 'isGreaterThanOrEqual' | 'isGreaterThanOrEquals' | 'isGreaterThan' | 'greaterThanOrEqual' | 'greaterThanOrEquals' | 'greaterThan' | 'like' | 'contains' | 'notContains' | 'startsWith' | 'endsWith' | 'notLike' | 'inRange' | 'between' | 'isNull' | 'isNotNull' | 'inArray' | 'in' | 'not' | 'and' | 'or';
13
13
  value?: string | number | boolean | null | (string | number | boolean | null)[];
14
14
  children?: ConditionDTO[];
15
15
  type?: SqlRequestGridColumn<unknown>['type'];
package/eslint.config.js CHANGED
@@ -1,3 +1,3 @@
1
- import { eslintReactConfig } from '@addev-be/framework-utils/eslint/react.config.mjs';
2
-
3
- export default [...eslintReactConfig, { ignores: ['dist'] }];
1
+ import { eslintReactConfig } from '@addev-be/framework-utils/eslint/react.config.mjs';
2
+
3
+ export default [...eslintReactConfig, { ignores: ['dist'] }];
package/package.json CHANGED
@@ -1,12 +1,13 @@
1
1
  {
2
2
  "name": "@addev-be/ui",
3
- "version": "2.5.17",
3
+ "version": "2.6.0",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "watch": "tsc -b --watch",
7
7
  "build": "tsc -b",
8
8
  "lint": "eslint .",
9
- "publish": "yarn npm publish"
9
+ "publish": "yarn npm publish",
10
+ "test": "vitest"
10
11
  },
11
12
  "types": "src/index.ts",
12
13
  "exports": {
@@ -20,7 +21,11 @@
20
21
  "update-version": "../../node/update-version.mjs"
21
22
  },
22
23
  "devDependencies": {
23
- "@addev-be/framework-utils": "^2.5.17",
24
+ "@addev-be/framework-utils": "^2.6.0",
25
+ "@testing-library/dom": "^10.4.1",
26
+ "@testing-library/react": "^16.3.0",
27
+ "@testing-library/react-hooks": "^8.0.1",
28
+ "@types/jsdom": "^27",
24
29
  "@types/lodash": "^4.17.20",
25
30
  "@types/react": "^19.1.13",
26
31
  "@types/react-dom": "^19.1.9",
@@ -28,7 +33,9 @@
28
33
  "@vitejs/plugin-react-swc": "^4.1.0",
29
34
  "eslint": "^9.36.0",
30
35
  "globals": "^16.4.0",
31
- "typescript": "^5.9.2"
36
+ "jsdom": "^27.3.0",
37
+ "typescript": "^5.9.2",
38
+ "vitest": "^4.0.15"
32
39
  },
33
40
  "peerDependencies": {
34
41
  "react": "^18.3.1",