@sqrzro/ui 4.0.0-alpha.6 → 4.0.0-alpha.61

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 (295) hide show
  1. package/dist/components/buttons/ActionButton/index.d.ts +8 -6
  2. package/dist/components/buttons/ActionButton/index.js +3 -27
  3. package/dist/components/buttons/Button/index.d.ts +7 -6
  4. package/dist/components/buttons/Button/index.js +9 -19
  5. package/dist/components/collections/Collection/index.d.ts +7 -3
  6. package/dist/components/collections/Collection/index.js +9 -7
  7. package/dist/components/collections/DataTable/index.d.ts +14 -0
  8. package/dist/components/collections/DataTable/index.js +14 -0
  9. package/dist/components/collections/DefinitionList/index.d.ts +13 -0
  10. package/dist/components/collections/DefinitionList/index.js +13 -0
  11. package/dist/components/collections/EmptyMessage/index.d.ts +1 -1
  12. package/dist/components/collections/EmptyMessage/index.js +6 -4
  13. package/dist/components/collections/EmptyMessageAction/index.d.ts +2 -2
  14. package/dist/components/collections/EmptyMessageAction/index.js +1 -1
  15. package/dist/components/collections/List/index.d.ts +6 -3
  16. package/dist/components/collections/List/index.js +2 -2
  17. package/dist/components/collections/ListClientComponent/index.d.ts +7 -4
  18. package/dist/components/collections/ListClientComponent/index.js +8 -5
  19. package/dist/components/collections/ListItem/index.d.ts +10 -3
  20. package/dist/components/collections/ListItem/index.js +15 -23
  21. package/dist/components/collections/ListItemMenu/index.d.ts +8 -0
  22. package/dist/components/collections/ListItemMenu/index.js +7 -0
  23. package/dist/components/collections/ListItemMeta/index.d.ts +6 -4
  24. package/dist/components/collections/ListItemMeta/index.js +13 -17
  25. package/dist/components/collections/ListItemSecondary/index.d.ts +5 -3
  26. package/dist/components/collections/ListItemSecondary/index.js +12 -8
  27. package/dist/components/collections/Pagination/index.d.ts +1 -1
  28. package/dist/components/collections/Pagination/index.js +6 -7
  29. package/dist/components/collections/PaginationLink/index.d.ts +9 -0
  30. package/dist/components/collections/PaginationLink/index.js +9 -0
  31. package/dist/components/collections/Table/index.d.ts +3 -4
  32. package/dist/components/collections/Table/index.js +2 -8
  33. package/dist/components/collections/TableClientComponent/index.d.ts +7 -6
  34. package/dist/components/collections/TableClientComponent/index.js +11 -26
  35. package/dist/components/collections/TableRow/index.d.ts +13 -0
  36. package/dist/components/collections/TableRow/index.js +15 -0
  37. package/dist/components/collections/interfaces.d.ts +41 -34
  38. package/dist/components/collections/lang.js +1 -1
  39. package/dist/components/collections/utility/is-paginated.d.ts +1 -1
  40. package/dist/components/collections/utility/is-right-aligned.d.ts +3 -0
  41. package/dist/components/collections/utility/is-right-aligned.js +11 -0
  42. package/dist/components/collections/utility/normalize-href.d.ts +2 -0
  43. package/dist/components/collections/utility/normalize-href.js +8 -0
  44. package/dist/components/collections/utility/render-cell.d.ts +5 -0
  45. package/dist/components/collections/utility/render-cell.js +33 -0
  46. package/dist/components/elements/Badge/index.d.ts +12 -0
  47. package/dist/components/elements/Badge/index.js +9 -0
  48. package/dist/components/elements/ContentLink/index.d.ts +4 -0
  49. package/dist/components/elements/ContentLink/index.js +7 -0
  50. package/dist/components/elements/InfoPanel/index.d.ts +11 -0
  51. package/dist/components/elements/InfoPanel/index.js +9 -0
  52. package/dist/components/{utility → elements}/Link/index.d.ts +3 -2
  53. package/dist/components/{utility → elements}/Link/index.js +10 -9
  54. package/dist/components/elements/Menu/index.d.ts +19 -0
  55. package/dist/components/elements/Menu/index.js +17 -0
  56. package/dist/components/elements/MenuItem/index.d.ts +9 -0
  57. package/dist/components/elements/MenuItem/index.js +12 -0
  58. package/dist/components/elements/Page/index.d.ts +19 -0
  59. package/dist/components/elements/Page/index.js +18 -0
  60. package/dist/components/elements/Reference/index.d.ts +9 -0
  61. package/dist/components/elements/Reference/index.js +16 -0
  62. package/dist/components/elements/Summary/index.d.ts +13 -0
  63. package/dist/components/elements/Summary/index.js +22 -0
  64. package/dist/components/errors/AppError/index.d.ts +19 -0
  65. package/dist/components/errors/AppError/index.js +9 -0
  66. package/dist/components/errors/AppForbiddenError/index.d.ts +7 -0
  67. package/dist/components/errors/AppForbiddenError/index.js +6 -0
  68. package/dist/components/errors/AppNotFoundError/index.d.ts +7 -0
  69. package/dist/components/errors/AppNotFoundError/index.js +6 -0
  70. package/dist/components/errors/AppServerError/index.d.ts +8 -0
  71. package/dist/components/errors/AppServerError/index.js +17 -0
  72. package/dist/components/index.d.ts +35 -6
  73. package/dist/components/index.js +17 -3
  74. package/dist/components/modals/ConfirmModal/index.d.ts +5 -3
  75. package/dist/components/modals/ConfirmModal/index.js +3 -3
  76. package/dist/components/modals/Modal/index.d.ts +4 -4
  77. package/dist/components/modals/Modal/index.js +3 -3
  78. package/dist/components/modals/ModalActions/index.d.ts +3 -3
  79. package/dist/components/modals/ModalActions/index.js +4 -3
  80. package/dist/components/utility/Action/index.d.ts +11 -0
  81. package/dist/components/utility/Action/index.js +48 -0
  82. package/dist/components/utility/ActionList/index.d.ts +5 -5
  83. package/dist/components/utility/ActionList/index.js +5 -3
  84. package/dist/components/utility/AppBody/index.d.ts +5 -0
  85. package/dist/components/utility/AppBody/index.js +9 -0
  86. package/dist/components/utility/Calendar/index.d.ts +32 -0
  87. package/dist/components/utility/Calendar/index.js +66 -0
  88. package/dist/components/utility/CalendarDay/index.d.ts +11 -0
  89. package/dist/components/utility/CalendarDay/index.js +22 -0
  90. package/dist/components/utility/Confirmable/index.d.ts +9 -0
  91. package/dist/components/utility/Confirmable/index.js +14 -0
  92. package/dist/components/utility/Container/index.d.ts +1 -1
  93. package/dist/components/utility/Container/index.js +2 -2
  94. package/dist/components/utility/Loader/index.d.ts +1 -1
  95. package/dist/components/utility/Loader/index.js +5 -4
  96. package/dist/components/utility/Popover/index.d.ts +1 -1
  97. package/dist/components/utility/Popover/index.js +5 -5
  98. package/dist/components/utility/Toast/index.d.ts +2 -2
  99. package/dist/components/utility/Toast/index.js +6 -4
  100. package/dist/components/utility/Toaster/index.js +5 -5
  101. package/dist/filters/components/FilterBar/index.d.ts +5 -2
  102. package/dist/filters/components/FilterBarClientComponent/index.d.ts +2 -4
  103. package/dist/filters/components/FilterBarClientComponent/index.js +3 -43
  104. package/dist/filters/components/FilterClearButton/index.d.ts +7 -2
  105. package/dist/filters/components/FilterClearButton/index.js +8 -4
  106. package/dist/filters/components/FilterControl/index.d.ts +1 -1
  107. package/dist/filters/components/FilterControl/index.js +11 -4
  108. package/dist/filters/components/FilterItem/index.d.ts +2 -1
  109. package/dist/filters/components/FilterItem/index.js +3 -7
  110. package/dist/filters/components/FilterPanel/index.d.ts +1 -1
  111. package/dist/filters/{utility/filter.d.ts → filter.d.ts} +1 -1
  112. package/dist/filters/{utility/filter.js → filter.js} +8 -8
  113. package/dist/filters/filters/BooleanFilter/index.js +1 -1
  114. package/dist/filters/filters/CalendarFilter/index.js +3 -2
  115. package/dist/filters/filters/DateFilter/index.d.ts +1 -1
  116. package/dist/filters/filters/DateFilter/index.js +9 -4
  117. package/dist/filters/filters/DropdownFilter/index.js +1 -1
  118. package/dist/filters/filters/Filter/index.d.ts +5 -4
  119. package/dist/filters/filters/Filter/index.js +7 -7
  120. package/dist/filters/filters/SearchFilter/index.d.ts +7 -2
  121. package/dist/filters/filters/SearchFilter/index.js +8 -8
  122. package/dist/filters/filters/interfaces.d.ts +0 -2
  123. package/dist/filters/index.d.ts +2 -1
  124. package/dist/filters/index.js +2 -1
  125. package/dist/filters/interfaces.d.ts +2 -2
  126. package/dist/filters/utility/render-value.js +5 -5
  127. package/dist/forms/components/Autocomplete/index.d.ts +2 -2
  128. package/dist/forms/components/Autocomplete/index.js +3 -3
  129. package/dist/forms/components/AutocompleteList/index.d.ts +7 -0
  130. package/dist/forms/components/AutocompleteList/index.js +15 -0
  131. package/dist/forms/components/BaseCalendarInput/index.d.ts +11 -0
  132. package/dist/forms/components/BaseCalendarInput/index.js +22 -0
  133. package/dist/forms/components/CSVInput/index.d.ts +11 -0
  134. package/dist/forms/components/CSVInput/index.js +32 -0
  135. package/dist/forms/components/CalendarInput/index.d.ts +6 -0
  136. package/dist/forms/components/CalendarInput/index.js +14 -0
  137. package/dist/forms/components/ColorInput/index.d.ts +16 -0
  138. package/dist/forms/components/ColorInput/index.js +14 -0
  139. package/dist/forms/components/Dropdown/index.d.ts +1 -1
  140. package/dist/forms/components/Dropdown/index.js +9 -8
  141. package/dist/forms/components/DropdownItem/index.d.ts +9 -0
  142. package/dist/forms/components/DropdownItem/index.js +9 -0
  143. package/dist/forms/components/DropdownList/index.d.ts +1 -1
  144. package/dist/forms/components/DropdownList/index.js +7 -11
  145. package/dist/forms/components/EditableForm/index.d.ts +3 -3
  146. package/dist/forms/components/EditableForm/index.js +9 -9
  147. package/dist/forms/components/EditableFormField/index.d.ts +1 -1
  148. package/dist/forms/components/EditableFormField/index.js +3 -3
  149. package/dist/forms/components/EditableFormFields/index.d.ts +6 -0
  150. package/dist/forms/components/EditableFormFields/index.js +22 -1
  151. package/dist/forms/components/Form/index.d.ts +4 -2
  152. package/dist/forms/components/Form/index.js +7 -6
  153. package/dist/forms/components/FormError/index.d.ts +2 -2
  154. package/dist/forms/components/FormError/index.js +7 -5
  155. package/dist/forms/components/FormField/index.d.ts +7 -5
  156. package/dist/forms/components/FormField/index.js +15 -7
  157. package/dist/forms/components/FormFields/index.d.ts +19 -2
  158. package/dist/forms/components/FormFields/index.js +38 -2
  159. package/dist/forms/components/FormLabel/index.d.ts +1 -1
  160. package/dist/forms/components/FormLabel/index.js +4 -3
  161. package/dist/forms/components/ModalForm/index.d.ts +3 -2
  162. package/dist/forms/components/ModalForm/index.js +4 -3
  163. package/dist/forms/components/NumberInput/index.d.ts +1 -1
  164. package/dist/forms/components/PasswordComplexity/index.d.ts +16 -0
  165. package/dist/forms/components/PasswordComplexity/index.js +14 -0
  166. package/dist/forms/components/PasswordComplexityItem/index.d.ts +8 -0
  167. package/dist/forms/components/PasswordComplexityItem/index.js +10 -0
  168. package/dist/forms/components/PasswordInput/index.d.ts +1 -1
  169. package/dist/forms/components/PasswordInput/index.js +6 -6
  170. package/dist/forms/components/PointsInput/index.d.ts +5 -0
  171. package/dist/forms/components/{MoneyInput → PointsInput}/index.js +3 -3
  172. package/dist/forms/components/RangeCalendarInput/index.d.ts +6 -0
  173. package/dist/forms/components/RangeCalendarInput/index.js +14 -0
  174. package/dist/forms/components/StaticTextInput/index.d.ts +2 -2
  175. package/dist/forms/components/StaticTextInput/index.js +6 -7
  176. package/dist/forms/components/Switch/index.d.ts +9 -3
  177. package/dist/forms/components/Switch/index.js +7 -5
  178. package/dist/forms/components/TextArea/index.d.ts +14 -0
  179. package/dist/forms/components/TextArea/index.js +15 -0
  180. package/dist/forms/components/TextInput/index.d.ts +1 -1
  181. package/dist/forms/components/TextInput/index.js +5 -4
  182. package/dist/forms/hooks/useAutocomplete.d.ts +8 -6
  183. package/dist/forms/hooks/useAutocomplete.js +4 -4
  184. package/dist/forms/hooks/useDropdown.d.ts +5 -7
  185. package/dist/forms/hooks/useDropdown.js +5 -5
  186. package/dist/forms/hooks/useEditableDropdown.d.ts +4 -0
  187. package/dist/forms/hooks/useEditableDropdown.js +6 -0
  188. package/dist/forms/hooks/useEditableForm.js +8 -1
  189. package/dist/forms/hooks/useForm.d.ts +6 -7
  190. package/dist/forms/hooks/useForm.js +25 -27
  191. package/dist/forms/hooks/useModalForm.d.ts +2 -2
  192. package/dist/forms/hooks/useModalForm.js +8 -1
  193. package/dist/forms/index.d.ts +22 -6
  194. package/dist/forms/index.js +9 -4
  195. package/dist/forms/interfaces.d.ts +1 -1
  196. package/dist/forms/utility/extract-input-props.js +1 -0
  197. package/dist/forms/utility/format-date-value.d.ts +2 -0
  198. package/dist/forms/utility/format-date-value.js +13 -0
  199. package/dist/forms/utility/format-file-size.d.ts +2 -0
  200. package/dist/forms/utility/format-file-size.js +11 -0
  201. package/dist/hooks/index.d.ts +3 -0
  202. package/dist/hooks/index.js +3 -0
  203. package/dist/hooks/useConfirmable.d.ts +21 -0
  204. package/dist/hooks/useConfirmable.js +58 -0
  205. package/dist/hooks/useDownload.d.ts +2 -0
  206. package/dist/hooks/useDownload.js +18 -0
  207. package/dist/hooks/usePopover.d.ts +12 -0
  208. package/dist/hooks/usePopover.js +24 -0
  209. package/dist/hooks/useSelected.d.ts +12 -0
  210. package/dist/hooks/useSelected.js +35 -0
  211. package/dist/hooks/useServerAction.d.ts +10 -0
  212. package/dist/hooks/useServerAction.js +17 -0
  213. package/dist/hooks/useSuccess.d.ts +10 -0
  214. package/dist/hooks/useSuccess.js +22 -0
  215. package/dist/mail/Mail/index.d.ts +8 -0
  216. package/dist/mail/Mail/index.js +106 -0
  217. package/dist/mail/MailBlock/index.d.ts +5 -0
  218. package/dist/mail/MailBlock/index.js +5 -0
  219. package/dist/mail/MailButton/index.d.ts +8 -0
  220. package/dist/mail/MailButton/index.js +28 -0
  221. package/dist/mail/MailTable/index.d.ts +9 -0
  222. package/dist/mail/MailTable/index.js +7 -0
  223. package/dist/mail/index.d.ts +8 -0
  224. package/dist/mail/index.js +4 -0
  225. package/dist/mail/utility/convert-to-datauri.d.ts +2 -0
  226. package/dist/mail/utility/convert-to-datauri.js +16 -0
  227. package/dist/mail/utility/get-mail-config.d.ts +4 -0
  228. package/dist/mail/utility/get-mail-config.js +34 -0
  229. package/dist/mail/utility/interfaces.d.ts +23 -0
  230. package/dist/navigation/components/AppNavigation/index.d.ts +3 -1
  231. package/dist/navigation/components/AppNavigation/index.js +4 -4
  232. package/dist/navigation/components/AppNavigationItem/index.d.ts +5 -3
  233. package/dist/navigation/components/AppNavigationItem/index.js +16 -7
  234. package/dist/navigation/components/Tabs/index.js +1 -4
  235. package/dist/navigation/hooks/useNavigation.d.ts +3 -3
  236. package/dist/navigation/hooks/useNavigation.js +5 -5
  237. package/dist/styles/classnames/config.d.ts +91 -0
  238. package/dist/styles/classnames/config.js +1 -0
  239. package/dist/styles/classnames/interfaces.d.ts +56 -0
  240. package/dist/styles/classnames/interfaces.js +1 -0
  241. package/dist/styles/classnames/utility/apply-sizes.d.ts +3 -0
  242. package/dist/styles/classnames/utility/apply-sizes.js +21 -0
  243. package/dist/styles/classnames/utility/apply-variants.d.ts +3 -0
  244. package/dist/styles/classnames/utility/apply-variants.js +26 -0
  245. package/dist/styles/classnames/utility/is-classname-object.d.ts +3 -0
  246. package/dist/styles/classnames/utility/is-classname-object.js +7 -0
  247. package/dist/styles/classnames/utility/parse-classnames.d.ts +6 -0
  248. package/dist/styles/classnames/utility/parse-classnames.js +33 -0
  249. package/dist/styles/context.d.ts +28 -0
  250. package/dist/styles/context.js +19 -0
  251. package/dist/styles/icons/config.d.ts +22 -0
  252. package/dist/styles/icons/config.js +1 -0
  253. package/dist/styles/icons/interfaces.d.ts +4 -0
  254. package/dist/styles/icons/interfaces.js +1 -0
  255. package/dist/styles/index.d.ts +6 -2
  256. package/dist/styles/index.js +2 -1
  257. package/dist/styles/styles.css +60 -0
  258. package/dist/utility/compare-dates.d.ts +2 -0
  259. package/dist/utility/compare-dates.js +13 -0
  260. package/dist/utility/get-date-state.d.ts +8 -0
  261. package/dist/utility/get-date-state.js +63 -0
  262. package/dist/utility/get-days.d.ts +2 -0
  263. package/dist/utility/get-days.js +5 -0
  264. package/dist/utility/get-weeks.d.ts +2 -0
  265. package/dist/utility/get-weeks.js +31 -0
  266. package/dist/utility/index.d.ts +1 -1
  267. package/dist/utility/interfaces.d.ts +33 -17
  268. package/dist/utility/is-data-object-array.d.ts +3 -0
  269. package/dist/utility/is-data-object-array.js +5 -0
  270. package/dist/utility/is-data-object.d.ts +3 -0
  271. package/dist/utility/is-data-object.js +4 -0
  272. package/package.json +31 -19
  273. package/dist/components/buttons/ConfirmableButton/index.d.ts +0 -7
  274. package/dist/components/buttons/ConfirmableButton/index.js +0 -13
  275. package/dist/components/collections/utility/filter-columns.d.ts +0 -3
  276. package/dist/components/collections/utility/filter-columns.js +0 -8
  277. package/dist/components/collections/utility/get-selected-from-search-params.d.ts +0 -2
  278. package/dist/components/collections/utility/get-selected-from-search-params.js +0 -5
  279. package/dist/components/collections/utility/set-selected-to-search-params.d.ts +0 -2
  280. package/dist/components/collections/utility/set-selected-to-search-params.js +0 -4
  281. package/dist/components/utility/ClassNames/index.d.ts +0 -6
  282. package/dist/components/utility/ClassNames/index.js +0 -7
  283. package/dist/components/utility/Page/index.d.ts +0 -18
  284. package/dist/components/utility/Page/index.js +0 -34
  285. package/dist/components/utility/RootLayout/index.d.ts +0 -12
  286. package/dist/components/utility/RootLayout/index.js +0 -14
  287. package/dist/forms/components/MoneyInput/index.d.ts +0 -5
  288. package/dist/styles/config.d.ts +0 -64
  289. package/dist/styles/config.js +0 -43
  290. package/dist/styles/icons.d.ts +0 -15
  291. package/dist/styles/icons.js +0 -7
  292. package/dist/styles/interfaces.d.ts +0 -41
  293. /package/dist/{styles → mail/utility}/interfaces.js +0 -0
  294. /package/dist/styles/{tw.d.ts → classnames/utility/tw.d.ts} +0 -0
  295. /package/dist/styles/{tw.js → classnames/utility/tw.js} +0 -0
@@ -1,14 +1,14 @@
1
1
  'use client';
2
2
  import { useEffect, useState } from 'react';
3
- function useDropdown({ deps, fn }) {
4
- const [data, setData] = useState([]);
3
+ function useDropdown(props, { deps, fn }) {
4
+ const [options, setOptions] = useState([]);
5
5
  async function getData() {
6
- const response = await (deps ? fn(...deps) : fn());
7
- setData(response);
6
+ const response = await fn(...(deps ?? []));
7
+ setOptions(response);
8
8
  }
9
9
  useEffect(() => {
10
10
  void getData();
11
11
  }, deps || []);
12
- return { data };
12
+ return { ...props, options };
13
13
  }
14
14
  export default useDropdown;
@@ -0,0 +1,4 @@
1
+ import { EditableDropdownFormFieldProps } from '../components/EditableFormFields';
2
+ import { UseDropdownArgs } from './useDropdown';
3
+ declare function useEditableDropdown<T extends string, U extends unknown[] = unknown[]>(props: EditableDropdownFormFieldProps<T>, args: UseDropdownArgs<T, U>): EditableDropdownFormFieldProps<T>;
4
+ export default useEditableDropdown;
@@ -0,0 +1,6 @@
1
+ 'use client';
2
+ import useDropdown from './useDropdown';
3
+ function useEditableDropdown(props, args) {
4
+ return useDropdown(props, args);
5
+ }
6
+ export default useEditableDropdown;
@@ -26,7 +26,14 @@ function useEditableForm({ defaultStatus, onCancel, onEdit, onSuccess, title, ..
26
26
  ...useFormReturn,
27
27
  actionProps: { status, setStatus },
28
28
  fieldProps: editableFieldProps,
29
- formProps: { formProps: useFormReturn.formProps, onCancel, onEdit, status, setStatus, title },
29
+ formProps: {
30
+ formProps: useFormReturn.formProps,
31
+ onCancel,
32
+ onEdit,
33
+ status,
34
+ setStatus,
35
+ title,
36
+ },
30
37
  status,
31
38
  setStatus,
32
39
  };
@@ -1,4 +1,5 @@
1
1
  import type { Default, InputEvent } from '../../forms/interfaces';
2
+ import type { UseSuccessArgs } from '../../hooks/useSuccess';
2
3
  import type { FormProps } from '../components/Form';
3
4
  interface AwaitedFormResponse<M> {
4
5
  data: M | null;
@@ -11,7 +12,7 @@ export interface FieldPropsReturn<Request, K extends keyof Request = keyof Reque
11
12
  isDisabled?: boolean;
12
13
  label?: string;
13
14
  name: string;
14
- onChange: (event: InputEvent<Request[K]>) => void;
15
+ onFieldChange: (event: InputEvent<Request[K]>) => void;
15
16
  value: Request[K];
16
17
  }
17
18
  export interface ToastsArgs {
@@ -19,14 +20,11 @@ export interface ToastsArgs {
19
20
  success?: string | false;
20
21
  validation?: string | false;
21
22
  }
22
- export interface UseFormArgs<Request, Response> {
23
+ export interface UseFormArgs<Request, Response> extends UseSuccessArgs<Response> {
23
24
  defaults?: Default<Request>;
24
25
  onError?: (message: string) => void;
25
26
  onSubmit?: (formData: Request) => FormResponse<Response>;
26
- onSuccess?: (response: Response) => Promise<void> | void;
27
- onValidation?: (errors: Record<string, string>) => void;
28
- redirectOnSuccess?: string | false | ((response: Response) => string | false);
29
- refreshOnSuccess?: boolean;
27
+ onValidation?: (errors: Record<string, string>, uncaughtErrors?: Record<string, string>) => void;
30
28
  toasts?: ToastsArgs | false;
31
29
  }
32
30
  export interface UseFormReturn<Request> {
@@ -37,9 +35,10 @@ export interface UseFormReturn<Request> {
37
35
  isLoading: boolean;
38
36
  resetForm: () => void;
39
37
  setErrors: (errors: Record<string, string> | null) => void;
40
- setFormData: (key: keyof Request, value: Request[keyof Request]) => void;
38
+ setFormData: <K extends keyof Request>(key: K, value: Request[K]) => void;
41
39
  submitForm: () => void;
42
40
  }
41
+ export declare const DEFAULT_TOAST_MESSAGES: Record<keyof ToastsArgs, string>;
43
42
  /**
44
43
  * ## Overview
45
44
  *
@@ -1,10 +1,10 @@
1
1
  'use client';
2
2
  import { useRef, useState, useTransition } from 'react';
3
3
  import { formatTitle } from '@sqrzro/utility';
4
- import { useRouter } from 'next/navigation';
5
4
  import useDeepCompareEffect from 'use-deep-compare-effect';
5
+ import useSuccess from '../../hooks/useSuccess';
6
6
  import useToast from '../../hooks/useToast';
7
- const DEFAULT_TOAST_MESSAGES = {
7
+ export const DEFAULT_TOAST_MESSAGES = {
8
8
  server: 'There was a problem submitting your request. Please try again later.',
9
9
  success: 'Your request was submitted successfully.',
10
10
  validation: 'There was a problem with your submission. Please check the form and try again.',
@@ -120,10 +120,12 @@ function getToastMessage(key, toasts) {
120
120
  * handling additional form events or integrating with different server APIs.
121
121
  */
122
122
  function useForm({ defaults = {}, onError, onSubmit, onSuccess, onValidation, redirectOnSuccess, refreshOnSuccess, toasts, }) {
123
- const innerRef = useRef(null);
124
- const router = useRouter();
125
- const [isLoading, startTransition] = useTransition();
123
+ const ref = useRef(null);
124
+ const usedFields = useRef(new Set());
125
+ const { handleSuccess } = useSuccess({ onSuccess, redirectOnSuccess, refreshOnSuccess });
126
+ const [isLoading] = useTransition();
126
127
  const [errors, setErrors] = useState(null);
128
+ const [uncaughtErrors, setUncaughtErrors] = useState(null);
127
129
  const [data, setData] = useState(defaults);
128
130
  const { toastError, toastSuccess } = useToast();
129
131
  function setFormData(key, value) {
@@ -132,28 +134,21 @@ function useForm({ defaults = {}, onError, onSubmit, onSuccess, onValidation, re
132
134
  function handleChange(event) {
133
135
  setData((prev) => ({ ...prev, [event.target.name]: event.target.value }));
134
136
  }
135
- async function handleSuccess(response) {
136
- await onSuccess?.(response);
137
- if (redirectOnSuccess) {
138
- const redirect = typeof redirectOnSuccess === 'function'
139
- ? redirectOnSuccess(response)
140
- : redirectOnSuccess;
141
- if (redirect) {
142
- router.push(redirect);
143
- }
144
- }
145
- if (refreshOnSuccess) {
146
- router.refresh();
147
- }
137
+ async function handleFormSuccess(response) {
138
+ await handleSuccess(response);
148
139
  toastSuccess(getToastMessage('success', toasts));
149
140
  }
150
- function handleError(message) {
141
+ function handleFormError(message) {
151
142
  onError?.(message);
152
143
  toastError(getToastMessage('server', toasts));
153
144
  }
154
- function handleValidation(messages) {
155
- onValidation?.(messages);
145
+ function handleFormValidation(messages) {
146
+ const uncaughtMessages = Object.keys(messages)
147
+ .filter((key) => !usedFields.current.has(key))
148
+ .reduce((acc, key) => ({ ...acc, [key]: messages[key] }), {});
149
+ onValidation?.(messages, uncaughtMessages);
156
150
  setErrors(messages);
151
+ setUncaughtErrors(uncaughtMessages);
157
152
  toastError(getToastMessage('validation', toasts));
158
153
  }
159
154
  async function handleSubmit() {
@@ -163,21 +158,22 @@ function useForm({ defaults = {}, onError, onSubmit, onSuccess, onValidation, re
163
158
  setErrors(null);
164
159
  const fnReturn = await onSubmit(data);
165
160
  if (fnReturn.error) {
166
- return handleError(fnReturn.error);
161
+ return handleFormError(fnReturn.error);
167
162
  }
168
163
  if (fnReturn.validation) {
169
- return handleValidation(fnReturn.validation);
164
+ return handleFormValidation(fnReturn.validation);
170
165
  }
171
- if (fnReturn.data) {
172
- return handleSuccess(fnReturn.data);
166
+ if (fnReturn.data !== null) {
167
+ return handleFormSuccess(fnReturn.data);
173
168
  }
174
169
  }
175
170
  function fieldProps(name, label) {
171
+ usedFields.current.add(name);
176
172
  return {
177
173
  error: getErrorsForField(errors, name),
178
174
  label: getLabel(name, label),
179
175
  name: name,
180
- onChange: handleChange,
176
+ onFieldChange: handleChange,
181
177
  value: data[name],
182
178
  };
183
179
  }
@@ -196,13 +192,15 @@ function useForm({ defaults = {}, onError, onSubmit, onSuccess, onValidation, re
196
192
  formData: data,
197
193
  formProps: {
198
194
  action: handleSubmit,
195
+ ref,
196
+ uncaughtErrors,
199
197
  },
200
198
  isLoading,
201
199
  resetForm,
202
200
  setErrors,
203
201
  setFormData,
204
202
  submitForm: () => {
205
- setTimeout(() => innerRef.current?.requestSubmit(), 1);
203
+ setTimeout(() => ref.current?.requestSubmit(), 1);
206
204
  },
207
205
  };
208
206
  }
@@ -1,8 +1,8 @@
1
- import type { Action } from '../../utility/interfaces';
1
+ import type { SimpleActionObject } from '../../utility/interfaces';
2
2
  import type { ModalFormProps } from '../components/ModalForm';
3
3
  import type { UseFormArgs, UseFormReturn } from './useForm';
4
4
  export interface UseModalFormArgs<Request, Response> extends UseFormArgs<Request, Response> {
5
- actions?: Action[];
5
+ actions?: SimpleActionObject[];
6
6
  icon?: React.ReactNode;
7
7
  submitLabel?: string;
8
8
  title?: string;
@@ -1,8 +1,10 @@
1
1
  'use client';
2
+ import { useState } from 'react';
2
3
  import { useRouter } from 'next/navigation';
3
4
  import useSearchParamsHref from '../../hooks/useSearchParamsHref';
4
- import useForm from './useForm';
5
+ import useForm, { DEFAULT_TOAST_MESSAGES } from './useForm';
5
6
  function useModalForm({ actions, icon, submitLabel, title, ...useFormArgs }) {
7
+ const [serverError, setServerError] = useState(null);
6
8
  const { setSearchParamsHref } = useSearchParamsHref();
7
9
  const router = useRouter();
8
10
  function handleSuccess(response) {
@@ -14,6 +16,10 @@ function useModalForm({ actions, icon, submitLabel, title, ...useFormArgs }) {
14
16
  }
15
17
  const useFormReturn = useForm({
16
18
  ...useFormArgs,
19
+ onError: (message) => {
20
+ setServerError(DEFAULT_TOAST_MESSAGES.server);
21
+ useFormArgs.onError?.(message);
22
+ },
17
23
  onSuccess: handleSuccess,
18
24
  toasts: false,
19
25
  });
@@ -22,6 +28,7 @@ function useModalForm({ actions, icon, submitLabel, title, ...useFormArgs }) {
22
28
  formProps: {
23
29
  formProps: useFormReturn.formProps,
24
30
  modalProps: { actions, icon, title },
31
+ serverError,
25
32
  submitLabel,
26
33
  },
27
34
  };
@@ -1,6 +1,8 @@
1
1
  export * from './interfaces';
2
2
  export type { AutocompleteProps } from './components/Autocomplete';
3
3
  export { default as Autocomplete } from './components/Autocomplete';
4
+ export type { CSVInputClassNames, CSVInputProps } from './components/CSVInput';
5
+ export { default as CSVInput } from './components/CSVInput';
4
6
  export type { DropdownClassNames, DropdownProps } from './components/Dropdown';
5
7
  export { default as Dropdown } from './components/Dropdown';
6
8
  export type { EditableFormClassNames, EditableFormProps } from './components/EditableForm';
@@ -9,26 +11,40 @@ export type { EditableFormFieldProps } from './components/EditableFormField';
9
11
  export { default as EditableFormField } from './components/EditableFormField';
10
12
  export type { FormClassNames, FormProps } from './components/Form';
11
13
  export { default as Form } from './components/Form';
14
+ export type { FormErrorProps } from './components/FormError';
15
+ export { default as FormError } from './components/FormError';
12
16
  export type { FormFieldClassNames, FormFieldProps } from './components/FormField';
13
17
  export { default as FormField } from './components/FormField';
14
18
  export type { FormSubmitProps } from './components/FormSubmit';
15
19
  export { default as FormSubmit } from './components/FormSubmit';
16
20
  export type { ModalFormProps } from './components/ModalForm';
17
21
  export { default as ModalForm } from './components/ModalForm';
18
- export type { MoneyInputProps } from './components/MoneyInput';
19
- export { default as MoneyInput } from './components/MoneyInput';
22
+ export type { PasswordComplexityProps } from './components/PasswordComplexity';
23
+ export { default as PasswordComplexity } from './components/PasswordComplexity';
20
24
  export type { NumberInputProps } from './components/NumberInput';
21
25
  export { default as NumberInput } from './components/NumberInput';
22
26
  export type { PasswordInputClassNames, PasswordInputProps } from './components/PasswordInput';
23
27
  export { default as PasswordInput } from './components/PasswordInput';
28
+ export type { PointsInputProps } from './components/PointsInput';
29
+ export { default as PointsInput } from './components/PointsInput';
30
+ export type { StaticTextInputClassNames, StaticTextInputProps } from './components/StaticTextInput';
31
+ export { default as StaticTextInput } from './components/StaticTextInput';
32
+ export type { TextAreaClassNames, TextAreaProps } from './components/TextArea';
33
+ export { default as TextArea } from './components/TextArea';
24
34
  export type { TextInputClassNames, TextInputProps } from './components/TextInput';
25
35
  export { default as TextInput } from './components/TextInput';
26
- export type { EditableDropdownFormFieldProps, EditableTextFormFieldProps, } from './components/EditableFormFields';
27
- export { EditableDropdownFormField, EditableTextFormField } from './components/EditableFormFields';
28
- export type { AutocompleteFormFieldProps, DropdownFormFieldProps, MoneyFormFieldProps, NumberFormFieldProps, PasswordFormFieldProps, TextFormFieldProps, } from './components/FormFields';
29
- export { AutocompleteFormField, DropdownFormField, MoneyFormField, NumberFormField, PasswordFormField, TextFormField, } from './components/FormFields';
36
+ export type * from './components/EditableFormFields';
37
+ export * from './components/EditableFormFields';
38
+ export type * from './components/FormFields';
39
+ export * from './components/FormFields';
40
+ export type { UseAutocompleteArgs, UseAutocompleteReturn } from './hooks/useAutocomplete';
30
41
  export { default as useAutocomplete } from './hooks/useAutocomplete';
42
+ export type { UseDropdownArgs } from './hooks/useDropdown';
31
43
  export { default as useDropdown } from './hooks/useDropdown';
44
+ export { default as useEditableDropdown } from './hooks/useEditableDropdown';
45
+ export type { UseEditableFormArgs, UseEditableFormReturn } from './hooks/useEditableForm';
32
46
  export { default as useEditableForm } from './hooks/useEditableForm';
47
+ export type { UseFormArgs, UseFormReturn } from './hooks/useForm';
33
48
  export { default as useForm } from './hooks/useForm';
49
+ export type { UseModalFormArgs, UseModalFormReturn } from './hooks/useModalForm';
34
50
  export { default as useModalForm } from './hooks/useModalForm';
@@ -1,21 +1,26 @@
1
1
  export * from './interfaces';
2
2
  export { default as Autocomplete } from './components/Autocomplete';
3
+ export { default as CSVInput } from './components/CSVInput';
3
4
  export { default as Dropdown } from './components/Dropdown';
4
5
  export { default as EditableForm } from './components/EditableForm';
5
6
  export { default as EditableFormField } from './components/EditableFormField';
6
7
  export { default as Form } from './components/Form';
8
+ export { default as FormError } from './components/FormError';
7
9
  export { default as FormField } from './components/FormField';
8
10
  export { default as FormSubmit } from './components/FormSubmit';
9
11
  export { default as ModalForm } from './components/ModalForm';
10
- export { default as MoneyInput } from './components/MoneyInput';
12
+ export { default as PasswordComplexity } from './components/PasswordComplexity';
11
13
  export { default as NumberInput } from './components/NumberInput';
12
14
  export { default as PasswordInput } from './components/PasswordInput';
15
+ export { default as PointsInput } from './components/PointsInput';
16
+ export { default as StaticTextInput } from './components/StaticTextInput';
17
+ export { default as TextArea } from './components/TextArea';
13
18
  export { default as TextInput } from './components/TextInput';
14
- export { EditableDropdownFormField, EditableTextFormField } from './components/EditableFormFields';
15
- export { AutocompleteFormField, DropdownFormField, MoneyFormField, NumberFormField, PasswordFormField, TextFormField, } from './components/FormFields';
16
- // Hooks
19
+ export * from './components/EditableFormFields';
20
+ export * from './components/FormFields';
17
21
  export { default as useAutocomplete } from './hooks/useAutocomplete';
18
22
  export { default as useDropdown } from './hooks/useDropdown';
23
+ export { default as useEditableDropdown } from './hooks/useEditableDropdown';
19
24
  export { default as useEditableForm } from './hooks/useEditableForm';
20
25
  export { default as useForm } from './hooks/useForm';
21
26
  export { default as useModalForm } from './hooks/useModalForm';
@@ -7,7 +7,7 @@ export interface DropdownObject<T = string> {
7
7
  $data?: Record<string, string>;
8
8
  details?: string | null;
9
9
  isDisabled?: boolean;
10
- label: string;
10
+ label: React.ReactNode;
11
11
  value: T;
12
12
  }
13
13
  export type EditingStatus = 'CANCELLED' | 'EDITING' | 'SAVED';
@@ -13,6 +13,7 @@ export function getFieldPropKeys() {
13
13
  'label',
14
14
  'name',
15
15
  'onChange',
16
+ 'onFieldChange',
16
17
  'onKeyDown',
17
18
  'value',
18
19
  ];
@@ -0,0 +1,2 @@
1
+ declare function formatDateValue(date?: Date | [Date, Date] | null): string | null;
2
+ export default formatDateValue;
@@ -0,0 +1,13 @@
1
+ import { formatDate } from '@sqrzro/utility';
2
+ function formatDateValue(date) {
3
+ if (!date) {
4
+ return null;
5
+ }
6
+ const dateArray = Array.isArray(date) ? date : [date];
7
+ const formattedArray = dateArray.map((item) => formatDate(item));
8
+ if (formattedArray[0] === formattedArray[1]) {
9
+ return formattedArray[0];
10
+ }
11
+ return formattedArray.join(' - ');
12
+ }
13
+ export default formatDateValue;
@@ -0,0 +1,2 @@
1
+ declare function formatFileSize(size: number): string;
2
+ export default formatFileSize;
@@ -0,0 +1,11 @@
1
+ const BYTES_IN_KB = 1024;
2
+ const DECIMAL_PLACES = 3;
3
+ function formatFileSize(size) {
4
+ const units = ['B', 'KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB'];
5
+ const exponent = Math.min(Math.floor(Math.log(size) / Math.log(BYTES_IN_KB)), units.length - 1);
6
+ const approx = size / BYTES_IN_KB ** exponent;
7
+ return exponent === 0
8
+ ? `${size} bytes`
9
+ : `${approx.toFixed(DECIMAL_PLACES)} ${units[exponent]} (${size} bytes)`;
10
+ }
11
+ export default formatFileSize;
@@ -1 +1,4 @@
1
1
  export { default as useClickOutside } from './useClickOutside';
2
+ export { default as useDownload } from './useDownload';
3
+ export { default as usePopover } from './usePopover';
4
+ export { default as useServerAction } from './useServerAction';
@@ -1 +1,4 @@
1
1
  export { default as useClickOutside } from './useClickOutside';
2
+ export { default as useDownload } from './useDownload';
3
+ export { default as usePopover } from './usePopover';
4
+ export { default as useServerAction } from './useServerAction';
@@ -0,0 +1,21 @@
1
+ import type { ActionEvent } from '../utility/interfaces';
2
+ interface UseConfirmableArgs {
3
+ isLoading?: boolean;
4
+ onBeforeConfirm?: () => void;
5
+ onConfirm: (event: ActionEvent, currentRef: HTMLButtonElement | null) => void;
6
+ onSuccess?: () => Promise<void> | void;
7
+ redirectOnSuccess?: string | false | ((response: Response) => string | false);
8
+ refreshOnSuccess?: boolean;
9
+ }
10
+ interface UseConfirmableReturn {
11
+ handle: (event?: ActionEvent) => void;
12
+ isOpen: boolean;
13
+ modalProps: {
14
+ isLoading: boolean;
15
+ onCancel: () => void;
16
+ onConfirm: () => void;
17
+ };
18
+ ref: React.RefObject<HTMLButtonElement | null>;
19
+ }
20
+ declare function useConfirmable({ isLoading, onBeforeConfirm, onConfirm, onSuccess, redirectOnSuccess, refreshOnSuccess, }: Readonly<UseConfirmableArgs>): UseConfirmableReturn;
21
+ export default useConfirmable;
@@ -0,0 +1,58 @@
1
+ 'use client';
2
+ import { useEffect, useRef, useState } from 'react';
3
+ import { useRouter } from 'next/navigation';
4
+ function useConfirmable({ isLoading, onBeforeConfirm, onConfirm, onSuccess, redirectOnSuccess, refreshOnSuccess, }) {
5
+ const ref = useRef(null);
6
+ const router = useRouter();
7
+ const [isModalOpen, setIsModalOpen] = useState(false);
8
+ const [isConfirmed, setIsConfirmed] = useState(false);
9
+ const [refEvent, setRefEvent] = useState();
10
+ function handle(event) {
11
+ onBeforeConfirm?.();
12
+ if (!isConfirmed) {
13
+ event?.preventDefault();
14
+ setIsModalOpen(true);
15
+ }
16
+ setRefEvent(event);
17
+ setIsConfirmed(false);
18
+ }
19
+ function handleConfirm() {
20
+ setIsConfirmed(true);
21
+ setTimeout(() => {
22
+ if (refEvent) {
23
+ onConfirm(refEvent, ref.current);
24
+ }
25
+ // If `isLoading` hasn't been set, we can just close the modal now. If it has, by
26
+ // setting `isConfirmed` to true above, we trigger the useEffect below to wait until
27
+ // after loading to close the modal.
28
+ if (typeof isLoading === 'undefined') {
29
+ setIsConfirmed(false);
30
+ setIsModalOpen(false);
31
+ }
32
+ }, 0);
33
+ }
34
+ function handleCancel() {
35
+ setIsModalOpen(false);
36
+ }
37
+ function handleSuccess() {
38
+ setIsConfirmed(false);
39
+ setIsModalOpen(false);
40
+ router.refresh();
41
+ }
42
+ useEffect(() => {
43
+ if (!isLoading && isConfirmed) {
44
+ handleSuccess();
45
+ }
46
+ }, [isLoading]);
47
+ return {
48
+ handle,
49
+ isOpen: isModalOpen,
50
+ modalProps: {
51
+ isLoading: isLoading ?? false,
52
+ onCancel: handleCancel,
53
+ onConfirm: handleConfirm,
54
+ },
55
+ ref,
56
+ };
57
+ }
58
+ export default useConfirmable;
@@ -0,0 +1,2 @@
1
+ declare function useDownload(): (data: Blob | string, filename: string) => void;
2
+ export default useDownload;
@@ -0,0 +1,18 @@
1
+ function download(data, filename) {
2
+ const href = typeof data === 'string' ? data : URL.createObjectURL(data);
3
+ // Create a temporary link element to trigger the download
4
+ const link = document.createElement('a');
5
+ link.href = href;
6
+ link.download = filename;
7
+ document.body.appendChild(link);
8
+ link.click();
9
+ // Clean up
10
+ document.body.removeChild(link);
11
+ if (typeof data !== 'string') {
12
+ URL.revokeObjectURL(href);
13
+ }
14
+ }
15
+ function useDownload() {
16
+ return download;
17
+ }
18
+ export default useDownload;
@@ -0,0 +1,12 @@
1
+ interface UsePopoverReturn<T extends HTMLElement = HTMLElement> {
2
+ controlProps: {
3
+ onClick: () => void;
4
+ };
5
+ isOpen: boolean;
6
+ ref: React.RefObject<T | null>;
7
+ targetProps: {
8
+ isOpen: boolean;
9
+ };
10
+ }
11
+ declare function usePopover<T extends HTMLElement = HTMLElement>(): UsePopoverReturn<T>;
12
+ export default usePopover;
@@ -0,0 +1,24 @@
1
+ import { useEffect } from 'react';
2
+ import useClickOutside from './useClickOutside';
3
+ import { usePathname } from 'next/navigation';
4
+ function usePopover() {
5
+ const pathname = usePathname();
6
+ const [isOpen, setIsOpen, ref] = useClickOutside();
7
+ function toggleIsOpen() {
8
+ setIsOpen(!isOpen);
9
+ }
10
+ useEffect(() => {
11
+ setIsOpen(false);
12
+ }, [pathname]);
13
+ return {
14
+ controlProps: {
15
+ onClick: toggleIsOpen,
16
+ },
17
+ isOpen,
18
+ ref,
19
+ targetProps: {
20
+ isOpen,
21
+ },
22
+ };
23
+ }
24
+ export default usePopover;
@@ -0,0 +1,12 @@
1
+ import type { InputEvent } from '../forms/interfaces';
2
+ interface UseSelectedReturn {
3
+ checkSelected: (id: string) => boolean;
4
+ isAllSelected: boolean;
5
+ onSelect: (event: InputEvent<boolean>) => void;
6
+ onSelectAll: () => void;
7
+ selected: string[];
8
+ }
9
+ declare function useSelected(data: {
10
+ id: string;
11
+ }[]): UseSelectedReturn;
12
+ export default useSelected;
@@ -0,0 +1,35 @@
1
+ import { toggleArrayItem } from '@sqrzro/utility';
2
+ import { useSearchParams } from 'next/navigation';
3
+ import useSearchParamsHref from './useSearchParamsHref';
4
+ function getSelectedFromSearchParams(searchParams) {
5
+ const selected = searchParams.get('selected');
6
+ return selected ? selected.split('|') : [];
7
+ }
8
+ function setSelectedToSearchParams(selected) {
9
+ return selected.length ? selected.join('|') : null;
10
+ }
11
+ function useSelected(data) {
12
+ const { setSearchParamsHref } = useSearchParamsHref();
13
+ const searchParams = useSearchParams();
14
+ const selected = getSelectedFromSearchParams(searchParams);
15
+ function onSelect(event) {
16
+ const value = toggleArrayItem(selected, event.target.name);
17
+ setSearchParamsHref({ selected: setSelectedToSearchParams(value) });
18
+ }
19
+ function onSelectAll() {
20
+ const value = selected.length === data.length ? [] : data.map((item) => item.id);
21
+ setSearchParamsHref({ selected: setSelectedToSearchParams(value) });
22
+ }
23
+ const isAllSelected = data.length > 0 && selected.length === data.length;
24
+ function checkSelected(id) {
25
+ return selected.includes(id);
26
+ }
27
+ return {
28
+ checkSelected,
29
+ isAllSelected,
30
+ onSelect,
31
+ onSelectAll,
32
+ selected,
33
+ };
34
+ }
35
+ export default useSelected;
@@ -0,0 +1,10 @@
1
+ import type { UseSuccessArgs } from './useSuccess';
2
+ interface UseServerActionArgs<Response> extends UseSuccessArgs<Response> {
3
+ onSuccess?: (response: Response) => void;
4
+ }
5
+ interface UseServerActionReturn {
6
+ handleClick: () => void;
7
+ isLoading: boolean;
8
+ }
9
+ declare function useServerAction<Response>(fn?: () => Promise<Response>, args?: UseServerActionArgs<Response>): UseServerActionReturn;
10
+ export default useServerAction;
@@ -0,0 +1,17 @@
1
+ import { useTransition } from 'react';
2
+ import useSuccess from './useSuccess';
3
+ function useServerAction(fn, args = {}) {
4
+ const { handleSuccess } = useSuccess(args);
5
+ const [isLoading, startTransition] = useTransition();
6
+ function handleClick() {
7
+ startTransition(async () => {
8
+ if (!fn) {
9
+ return;
10
+ }
11
+ const response = await fn();
12
+ await handleSuccess(response);
13
+ });
14
+ }
15
+ return { handleClick, isLoading };
16
+ }
17
+ export default useServerAction;
@@ -0,0 +1,10 @@
1
+ export interface UseSuccessArgs<Response> {
2
+ onSuccess?: (response: Response) => Promise<void> | void;
3
+ redirectOnSuccess?: string | false | ((response: Response) => Promise<string | false> | string | false);
4
+ refreshOnSuccess?: boolean;
5
+ }
6
+ interface UseSuccessReturn<Response> {
7
+ handleSuccess: (response: Response) => Promise<void>;
8
+ }
9
+ declare function useSuccess<Response>({ onSuccess, redirectOnSuccess, refreshOnSuccess, }: UseSuccessArgs<Response>): UseSuccessReturn<Response>;
10
+ export default useSuccess;