@goplusvn/core 0.1.1 → 0.1.3

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 (223) hide show
  1. package/package.json +31 -175
  2. package/dist/audit/index.d.mts +0 -115
  3. package/dist/audit/index.d.ts +0 -115
  4. package/dist/audit/index.js +0 -204
  5. package/dist/audit/index.js.map +0 -1
  6. package/dist/audit/index.mjs +0 -200
  7. package/dist/audit/index.mjs.map +0 -1
  8. package/dist/auth/index.d.mts +0 -86
  9. package/dist/auth/index.d.ts +0 -86
  10. package/dist/auth/index.js +0 -210
  11. package/dist/auth/index.js.map +0 -1
  12. package/dist/auth/index.mjs +0 -198
  13. package/dist/auth/index.mjs.map +0 -1
  14. package/dist/button-1dWvP9Ib.d.mts +0 -30
  15. package/dist/button-1dWvP9Ib.d.ts +0 -30
  16. package/dist/calendar-2QzdEo1z.d.mts +0 -20
  17. package/dist/calendar-2QzdEo1z.d.ts +0 -20
  18. package/dist/code-generation/index.d.mts +0 -30
  19. package/dist/code-generation/index.d.ts +0 -30
  20. package/dist/code-generation/index.js +0 -31
  21. package/dist/code-generation/index.js.map +0 -1
  22. package/dist/code-generation/index.mjs +0 -28
  23. package/dist/code-generation/index.mjs.map +0 -1
  24. package/dist/configs/index.d.mts +0 -175
  25. package/dist/configs/index.d.ts +0 -175
  26. package/dist/configs/index.js +0 -254
  27. package/dist/configs/index.js.map +0 -1
  28. package/dist/configs/index.mjs +0 -233
  29. package/dist/configs/index.mjs.map +0 -1
  30. package/dist/crud/index.d.mts +0 -646
  31. package/dist/crud/index.d.ts +0 -646
  32. package/dist/crud/index.js +0 -11772
  33. package/dist/crud/index.js.map +0 -1
  34. package/dist/crud/index.mjs +0 -11665
  35. package/dist/crud/index.mjs.map +0 -1
  36. package/dist/crud/server.d.mts +0 -20
  37. package/dist/crud/server.d.ts +0 -20
  38. package/dist/crud/server.js +0 -123
  39. package/dist/crud/server.js.map +0 -1
  40. package/dist/crud/server.mjs +0 -120
  41. package/dist/crud/server.mjs.map +0 -1
  42. package/dist/data-table-skeleton-12NA8Mjx.d.mts +0 -39
  43. package/dist/data-table-skeleton-12NA8Mjx.d.ts +0 -39
  44. package/dist/dialog-bKfjZMTd.d.mts +0 -22
  45. package/dist/dialog-bKfjZMTd.d.ts +0 -22
  46. package/dist/dynamic-icon-DrGIiu2N.d.mts +0 -10
  47. package/dist/dynamic-icon-DrGIiu2N.d.ts +0 -10
  48. package/dist/home/index.d.mts +0 -269
  49. package/dist/home/index.d.ts +0 -269
  50. package/dist/home/index.js +0 -1678
  51. package/dist/home/index.js.map +0 -1
  52. package/dist/home/index.mjs +0 -1635
  53. package/dist/home/index.mjs.map +0 -1
  54. package/dist/hooks/index.d.mts +0 -7
  55. package/dist/hooks/index.d.ts +0 -7
  56. package/dist/hooks/index.js +0 -8316
  57. package/dist/hooks/index.js.map +0 -1
  58. package/dist/hooks/index.mjs +0 -8255
  59. package/dist/hooks/index.mjs.map +0 -1
  60. package/dist/index-50hpiPrV.d.ts +0 -116
  61. package/dist/index-B9zQVEVi.d.mts +0 -116
  62. package/dist/index.d.mts +0 -5
  63. package/dist/index.d.ts +0 -5
  64. package/dist/index.js +0 -123
  65. package/dist/index.js.map +0 -1
  66. package/dist/index.mjs +0 -118
  67. package/dist/index.mjs.map +0 -1
  68. package/dist/infrastructure/index.d.mts +0 -423
  69. package/dist/infrastructure/index.d.ts +0 -423
  70. package/dist/infrastructure/index.js +0 -633
  71. package/dist/infrastructure/index.js.map +0 -1
  72. package/dist/infrastructure/index.mjs +0 -619
  73. package/dist/infrastructure/index.mjs.map +0 -1
  74. package/dist/label-DWTEkNPo.d.ts +0 -226
  75. package/dist/label-LPpdcoBx.d.mts +0 -226
  76. package/dist/layout/index.d.mts +0 -48
  77. package/dist/layout/index.d.ts +0 -48
  78. package/dist/layout/index.js +0 -117
  79. package/dist/layout/index.js.map +0 -1
  80. package/dist/layout/index.mjs +0 -90
  81. package/dist/layout/index.mjs.map +0 -1
  82. package/dist/navigation/index.d.mts +0 -16
  83. package/dist/navigation/index.d.ts +0 -16
  84. package/dist/navigation/index.js +0 -53
  85. package/dist/navigation/index.js.map +0 -1
  86. package/dist/navigation/index.mjs +0 -50
  87. package/dist/navigation/index.mjs.map +0 -1
  88. package/dist/notification/index.d.mts +0 -105
  89. package/dist/notification/index.d.ts +0 -105
  90. package/dist/notification/index.js +0 -278
  91. package/dist/notification/index.js.map +0 -1
  92. package/dist/notification/index.mjs +0 -274
  93. package/dist/notification/index.mjs.map +0 -1
  94. package/dist/organization/index.d.mts +0 -99
  95. package/dist/organization/index.d.ts +0 -99
  96. package/dist/organization/index.js +0 -360
  97. package/dist/organization/index.js.map +0 -1
  98. package/dist/organization/index.mjs +0 -352
  99. package/dist/organization/index.mjs.map +0 -1
  100. package/dist/plugin/index.d.mts +0 -83
  101. package/dist/plugin/index.d.ts +0 -83
  102. package/dist/plugin/index.js +0 -86
  103. package/dist/plugin/index.js.map +0 -1
  104. package/dist/plugin/index.mjs +0 -84
  105. package/dist/plugin/index.mjs.map +0 -1
  106. package/dist/providers/index.d.mts +0 -25
  107. package/dist/providers/index.d.ts +0 -25
  108. package/dist/providers/index.js +0 -84
  109. package/dist/providers/index.js.map +0 -1
  110. package/dist/providers/index.mjs +0 -77
  111. package/dist/providers/index.mjs.map +0 -1
  112. package/dist/rbac/index.d.mts +0 -226
  113. package/dist/rbac/index.d.ts +0 -226
  114. package/dist/rbac/index.js +0 -4784
  115. package/dist/rbac/index.js.map +0 -1
  116. package/dist/rbac/index.mjs +0 -4722
  117. package/dist/rbac/index.mjs.map +0 -1
  118. package/dist/rbac/permissions.d.mts +0 -26
  119. package/dist/rbac/permissions.d.ts +0 -26
  120. package/dist/rbac/permissions.js +0 -94
  121. package/dist/rbac/permissions.js.map +0 -1
  122. package/dist/rbac/permissions.mjs +0 -90
  123. package/dist/rbac/permissions.mjs.map +0 -1
  124. package/dist/rbac/server.d.mts +0 -1
  125. package/dist/rbac/server.d.ts +0 -1
  126. package/dist/rbac/server.js +0 -128
  127. package/dist/rbac/server.js.map +0 -1
  128. package/dist/rbac/server.mjs +0 -124
  129. package/dist/rbac/server.mjs.map +0 -1
  130. package/dist/schemas/index.d.mts +0 -1257
  131. package/dist/schemas/index.d.ts +0 -1257
  132. package/dist/schemas/index.js +0 -572
  133. package/dist/schemas/index.js.map +0 -1
  134. package/dist/schemas/index.mjs +0 -523
  135. package/dist/schemas/index.mjs.map +0 -1
  136. package/dist/server-QuYCTa89.d.mts +0 -83
  137. package/dist/server-QuYCTa89.d.ts +0 -83
  138. package/dist/sonner-C74GlRDQ.d.mts +0 -71
  139. package/dist/sonner-C74GlRDQ.d.ts +0 -71
  140. package/dist/status-BOXZgIqX.d.mts +0 -12
  141. package/dist/status-BOXZgIqX.d.ts +0 -12
  142. package/dist/system/index.d.mts +0 -77
  143. package/dist/system/index.d.ts +0 -77
  144. package/dist/system/index.js +0 -102
  145. package/dist/system/index.js.map +0 -1
  146. package/dist/system/index.mjs +0 -100
  147. package/dist/system/index.mjs.map +0 -1
  148. package/dist/tabs-C6FfBwPY.d.mts +0 -18
  149. package/dist/tabs-C6FfBwPY.d.ts +0 -18
  150. package/dist/tenant-provider-B8eC_Wpb.d.mts +0 -27
  151. package/dist/tenant-provider-B8eC_Wpb.d.ts +0 -27
  152. package/dist/types/index.d.mts +0 -469
  153. package/dist/types/index.d.ts +0 -469
  154. package/dist/types/index.js +0 -25
  155. package/dist/types/index.js.map +0 -1
  156. package/dist/types/index.mjs +0 -21
  157. package/dist/types/index.mjs.map +0 -1
  158. package/dist/ui/auth.d.mts +0 -39
  159. package/dist/ui/auth.d.ts +0 -39
  160. package/dist/ui/auth.js +0 -4941
  161. package/dist/ui/auth.js.map +0 -1
  162. package/dist/ui/auth.mjs +0 -4896
  163. package/dist/ui/auth.mjs.map +0 -1
  164. package/dist/ui/crud.d.mts +0 -2
  165. package/dist/ui/crud.d.ts +0 -2
  166. package/dist/ui/crud.js +0 -4
  167. package/dist/ui/crud.js.map +0 -1
  168. package/dist/ui/crud.mjs +0 -3
  169. package/dist/ui/crud.mjs.map +0 -1
  170. package/dist/ui/data-display.d.mts +0 -596
  171. package/dist/ui/data-display.d.ts +0 -596
  172. package/dist/ui/data-display.js +0 -5307
  173. package/dist/ui/data-display.js.map +0 -1
  174. package/dist/ui/data-display.mjs +0 -5212
  175. package/dist/ui/data-display.mjs.map +0 -1
  176. package/dist/ui/feedback.d.mts +0 -55
  177. package/dist/ui/feedback.d.ts +0 -55
  178. package/dist/ui/feedback.js +0 -2608
  179. package/dist/ui/feedback.js.map +0 -1
  180. package/dist/ui/feedback.mjs +0 -2526
  181. package/dist/ui/feedback.mjs.map +0 -1
  182. package/dist/ui/forms.d.mts +0 -309
  183. package/dist/ui/forms.d.ts +0 -309
  184. package/dist/ui/forms.js +0 -4656
  185. package/dist/ui/forms.js.map +0 -1
  186. package/dist/ui/forms.mjs +0 -4571
  187. package/dist/ui/forms.mjs.map +0 -1
  188. package/dist/ui/index.d.mts +0 -331
  189. package/dist/ui/index.d.ts +0 -331
  190. package/dist/ui/index.js +0 -16953
  191. package/dist/ui/index.js.map +0 -1
  192. package/dist/ui/index.mjs +0 -16598
  193. package/dist/ui/index.mjs.map +0 -1
  194. package/dist/ui/primitives/client.d.mts +0 -61
  195. package/dist/ui/primitives/client.d.ts +0 -61
  196. package/dist/ui/primitives/client.js +0 -3408
  197. package/dist/ui/primitives/client.js.map +0 -1
  198. package/dist/ui/primitives/client.mjs +0 -3256
  199. package/dist/ui/primitives/client.mjs.map +0 -1
  200. package/dist/ui/primitives.d.mts +0 -113
  201. package/dist/ui/primitives.d.ts +0 -113
  202. package/dist/ui/primitives.js +0 -3356
  203. package/dist/ui/primitives.js.map +0 -1
  204. package/dist/ui/primitives.mjs +0 -3227
  205. package/dist/ui/primitives.mjs.map +0 -1
  206. package/dist/user/index.d.mts +0 -228
  207. package/dist/user/index.d.ts +0 -228
  208. package/dist/user/index.js +0 -4306
  209. package/dist/user/index.js.map +0 -1
  210. package/dist/user/index.mjs +0 -4260
  211. package/dist/user/index.mjs.map +0 -1
  212. package/dist/utils/index.d.mts +0 -205
  213. package/dist/utils/index.d.ts +0 -205
  214. package/dist/utils/index.js +0 -574
  215. package/dist/utils/index.js.map +0 -1
  216. package/dist/utils/index.mjs +0 -514
  217. package/dist/utils/index.mjs.map +0 -1
  218. package/dist/workflow/index.d.mts +0 -40
  219. package/dist/workflow/index.d.ts +0 -40
  220. package/dist/workflow/index.js +0 -3710
  221. package/dist/workflow/index.js.map +0 -1
  222. package/dist/workflow/index.mjs +0 -3677
  223. package/dist/workflow/index.mjs.map +0 -1
@@ -1,469 +0,0 @@
1
- import { icons, LucideIcon } from 'lucide-react';
2
- import { ReactNode, SVGAttributes, ComponentType } from 'react';
3
- import { z } from 'zod';
4
-
5
- declare const supportedLocales: readonly ["vi", "en"];
6
- type LocaleType = (typeof supportedLocales)[number];
7
- interface SearchResultItem {
8
- id: string;
9
- title: string;
10
- subtitle?: string;
11
- url?: string;
12
- action?: () => void;
13
- iconName?: DynamicIconNameType;
14
- }
15
- interface SearchGroup {
16
- heading: string;
17
- items: SearchResultItem[];
18
- }
19
- declare const supportedThemes: readonly ["zinc", "slate", "stone", "gray", "neutral", "red", "rose", "orange", "green", "blue", "yellow", "violet"];
20
- type ThemeType = (typeof supportedThemes)[number];
21
- declare const radii: readonly [0, 0.3, 0.5, 0.75, 1];
22
- type RadiusType = (typeof radii)[number];
23
- type LayoutType = "vertical" | "horizontal";
24
- type ModeType = "light" | "dark" | "system";
25
- type OrientationType = "vertical" | "horizontal";
26
- type DirectionType = "ltr" | "rtl";
27
- type SidebarVariantType = "sidebar" | "floating" | "inset";
28
- type SidebarCollapsibleType = "offcanvas" | "icon" | "none";
29
- type DensityType = "comfortable" | "compact";
30
- type SettingsType = {
31
- theme: ThemeType;
32
- mode: ModeType;
33
- radius: RadiusType;
34
- layout: LayoutType;
35
- locale: LocaleType;
36
- sidebarVariant: SidebarVariantType;
37
- sidebarCollapsible: SidebarCollapsibleType;
38
- density: DensityType;
39
- };
40
- interface IconProps extends SVGAttributes<SVGElement> {
41
- children?: never;
42
- color?: string;
43
- }
44
- type IconType = ComponentType<IconProps> | LucideIcon;
45
- type DynamicIconNameType = keyof typeof icons;
46
- interface ForgotPasswordFormType {
47
- email: string;
48
- }
49
- interface NewPasswordFormType {
50
- password: string;
51
- confirmPassword: string;
52
- }
53
- interface SignInFormType {
54
- email: string;
55
- password: string;
56
- }
57
- interface RegisterFormType {
58
- firstName: string;
59
- lastName: string;
60
- username: string;
61
- email: string;
62
- password: string;
63
- confirmPassword: string;
64
- }
65
- interface VerifyEmailFormType {
66
- email: string;
67
- }
68
- interface UserType {
69
- id: string;
70
- firstName: string;
71
- lastName: string;
72
- name: string;
73
- password: string;
74
- username: string;
75
- role: string;
76
- avatar: string;
77
- background: string;
78
- status: string;
79
- phoneNumber: string;
80
- email: string;
81
- state: string;
82
- country: string;
83
- address: string;
84
- zipCode: string;
85
- language: string;
86
- timeZone: string;
87
- currency: string;
88
- organization: string;
89
- twoFactorAuth: boolean;
90
- loginAlerts: boolean;
91
- accountReoveryOption?: "email" | "sms" | "codes";
92
- connections: number;
93
- followers: number;
94
- }
95
- interface Permission {
96
- resourceCode: string;
97
- actionCode: string;
98
- }
99
- type PermissionType = Permission;
100
- type PermissionMatrix = Record<string, Record<string, boolean>>;
101
- interface RouteType {
102
- type: "guest" | "public";
103
- exceptions?: string[];
104
- }
105
- interface NotificationType {
106
- unreadCount: number;
107
- notifications: Array<{
108
- id: string;
109
- iconName: DynamicIconNameType;
110
- content: string;
111
- url: string;
112
- date: Date;
113
- isRead: boolean;
114
- }>;
115
- }
116
- type FormatStyleType = "percent" | "duration" | "currency" | "regular";
117
- interface NavigationType {
118
- title: string;
119
- iconName?: DynamicIconNameType;
120
- items: NavigationRootItem[];
121
- }
122
- type NavigationRootItem = NavigationRootItemWithHrefType | NavigationRootItemWithItemsType;
123
- interface NavigationRootItemBasicType {
124
- title: string;
125
- label?: string;
126
- iconName: DynamicIconNameType;
127
- resource?: string;
128
- action?: string;
129
- }
130
- interface NavigationRootItemWithHrefType extends NavigationRootItemBasicType {
131
- href: string;
132
- items?: never;
133
- }
134
- interface NavigationRootItemWithItemsType extends NavigationRootItemBasicType {
135
- items: (NavigationNestedItemWithHrefType | NavigationNestedItemWithItemsType)[];
136
- href?: never;
137
- }
138
- interface NavigationNestedItemBasicType {
139
- title: string;
140
- label?: string;
141
- resource?: string;
142
- action?: string;
143
- iconName?: DynamicIconNameType;
144
- }
145
- interface NavigationNestedItemWithHrefType extends NavigationNestedItemBasicType {
146
- href: string;
147
- items?: never;
148
- }
149
- interface NavigationNestedItemWithItemsType extends NavigationNestedItemBasicType {
150
- items: (NavigationNestedItemWithHrefType | NavigationNestedItemWithItemsType)[];
151
- href?: never;
152
- }
153
- type NavigationNestedItem = NavigationNestedItemWithHrefType | NavigationNestedItemWithItemsType;
154
- interface OAuthLinkType {
155
- href: string;
156
- label: string;
157
- icon: IconType;
158
- }
159
- interface FileType {
160
- id: string;
161
- name: string;
162
- size: number;
163
- type: string;
164
- url: string;
165
- }
166
- interface EntityConfig {
167
- name: string;
168
- label: string;
169
- pluralLabel: string;
170
- icon?: LucideIcon;
171
- iconName?: string;
172
- description?: string;
173
- /**
174
- * Resource code used for permission checking.
175
- * If not specified, falls back to `name`.
176
- * Must match a valid resource code in the Resource table.
177
- */
178
- permissionResource?: string;
179
- apiEndpoint: string;
180
- idField: string;
181
- displayField: string;
182
- fields: FieldConfig[];
183
- filters?: FilterConfig[];
184
- defaultSort?: {
185
- field: string;
186
- direction: "asc" | "desc";
187
- };
188
- permissions?: CrudPermissions;
189
- features?: CrudFeatures;
190
- codeGeneration?: CodeGenerationConfig;
191
- formSections?: FormSection[];
192
- formMode?: FormModeConfig;
193
- rowActions?: RowAction[];
194
- include?: string[];
195
- }
196
- interface CodeGenerationConfig {
197
- enabled: boolean;
198
- field: string;
199
- ruleId?: string;
200
- entityType?: string;
201
- showPreview?: boolean;
202
- allowManualOverride?: boolean;
203
- generateOnCreate?: boolean;
204
- generateOnEdit?: boolean;
205
- }
206
- interface FormSection {
207
- title: string;
208
- description?: string;
209
- fields: string[];
210
- defaultOpen?: boolean;
211
- }
212
- interface FormModeConfig {
213
- create?: "dialog" | "sheet" | "navigate";
214
- edit?: "dialog" | "sheet" | "navigate";
215
- createPath?: string;
216
- editPath?: string;
217
- sheetSide?: "top" | "right" | "bottom" | "left";
218
- }
219
- interface RowAction {
220
- label: string;
221
- icon?: string;
222
- action: "copy" | "duplicate" | "view" | "archive" | "custom" | "approve" | "reject" | "set-default" | "view-history";
223
- handler?: (rowId: string, rowData: Record<string, unknown>) => void | Promise<void>;
224
- visibleWhen?: (rowData: Record<string, unknown>) => boolean;
225
- variant?: "default" | "destructive" | "outline" | "secondary" | "ghost" | "link";
226
- excludeFields?: string[];
227
- transformData?: (rowData: Record<string, unknown>) => Record<string, unknown>;
228
- }
229
- type FieldType = "text" | "email" | "url" | "number" | "integer" | "textarea" | "boolean" | "date" | "datetime" | "time" | "select" | "multiselect" | "file" | "image" | "json" | "custom" | "switch" | "relation";
230
- interface FieldConfig {
231
- name: string;
232
- label: string;
233
- type: FieldType;
234
- required?: boolean;
235
- defaultValue?: unknown;
236
- placeholder?: string;
237
- helpText?: string;
238
- description?: string;
239
- rows?: number;
240
- disabled?: boolean;
241
- disableOnCreate?: boolean;
242
- disableOnEdit?: boolean;
243
- fullWidth?: boolean;
244
- validation?: z.ZodTypeAny;
245
- hideInTable?: boolean;
246
- hideInForm?: boolean;
247
- showInImport?: boolean;
248
- width?: number | string;
249
- minWidth?: number | string;
250
- maxWidth?: number | string;
251
- isDisplayOnly?: boolean;
252
- sortable?: boolean;
253
- filterable?: boolean;
254
- order?: number;
255
- options?: Array<string | number | boolean | {
256
- label: string;
257
- value: string | number | boolean;
258
- }>;
259
- dataSource?: DataSource;
260
- dependsOn?: string;
261
- section?: string;
262
- showWhen?: FieldShowWhen;
263
- calculate?: FieldCalculate;
264
- format?: FieldFormat;
265
- transform?: FieldTransform;
266
- actions?: FieldAction[];
267
- help?: FieldHelp;
268
- dependencies?: FieldDependencies;
269
- cascade?: FieldCascade;
270
- renderCell?: (value: unknown, row: Record<string, unknown>) => ReactNode;
271
- renderForm?: (props: Record<string, unknown>) => ReactNode;
272
- renderInput?: (value: unknown, onChange: (value: unknown) => void) => ReactNode;
273
- relation?: {
274
- entity: string;
275
- displayField: string;
276
- valueField: string;
277
- filter?: Record<string, unknown>;
278
- };
279
- }
280
- interface FieldShowWhen {
281
- field: string;
282
- value: unknown;
283
- operator?: "equals" | "notEquals" | "contains" | "greaterThan" | "lessThan" | "isEmpty" | "isNotEmpty";
284
- }
285
- interface FieldCalculate {
286
- dependsOn: string[];
287
- formula: string | ((values: Record<string, unknown>) => unknown);
288
- mode?: "onChange" | "onBlur" | "always";
289
- }
290
- interface FieldFormat {
291
- type: "currency" | "percentage" | "date" | "datetime" | "number" | "custom";
292
- options?: {
293
- currency?: string;
294
- locale?: string;
295
- decimals?: number;
296
- dateFormat?: string;
297
- custom?: (value: unknown) => string;
298
- };
299
- }
300
- interface FieldTransform {
301
- input?: (value: unknown) => unknown;
302
- output?: (value: unknown) => unknown;
303
- }
304
- interface FieldAction {
305
- label: string;
306
- icon?: string;
307
- action: "clear" | "copy" | "generate" | "validate" | "custom";
308
- handler?: (field: FieldConfig, formData: Record<string, unknown>) => void | Promise<void>;
309
- visibleWhen?: {
310
- field: string;
311
- operator: "equals" | "notEquals" | "isEmpty" | "isNotEmpty";
312
- value: unknown;
313
- };
314
- }
315
- interface FieldHelp {
316
- text?: string;
317
- tooltip?: string;
318
- link?: {
319
- url: string;
320
- text: string;
321
- openInNewTab?: boolean;
322
- };
323
- examples?: string[];
324
- }
325
- interface FieldDependencies {
326
- fields: string[];
327
- condition: "all" | "any" | "none";
328
- rules: Array<{
329
- field: string;
330
- operator: "equals" | "notEquals" | "contains" | "greaterThan" | "lessThan" | "isEmpty" | "isNotEmpty";
331
- value: unknown;
332
- }>;
333
- }
334
- interface FieldCascade {
335
- triggerField: string;
336
- action: "clear" | "reset" | "update";
337
- updateFields?: string[];
338
- }
339
- interface ValidationRule {
340
- type: "required" | "email" | "url" | "min" | "max" | "minLength" | "maxLength" | "pattern" | "custom";
341
- value?: unknown;
342
- message: string;
343
- validator?: (value: unknown, formData: Record<string, unknown>) => boolean;
344
- }
345
- interface DataSource {
346
- type: "static" | "api";
347
- options?: Array<{
348
- label: string;
349
- value: string | number | boolean;
350
- }>;
351
- endpoint?: string;
352
- params?: Record<string, unknown>;
353
- labelField?: string;
354
- valueField?: string;
355
- searchable?: boolean;
356
- cacheTime?: number;
357
- transform?: (data: unknown[]) => Array<{
358
- label: string;
359
- value: string | number | boolean;
360
- }>;
361
- }
362
- type FilterType = "text" | "datetime" | "select" | "checkbox" | "switch" | "radio" | "custom";
363
- interface FilterConfig {
364
- name: string;
365
- label: string;
366
- type: FilterType;
367
- field: string;
368
- operator?: FilterOperator;
369
- defaultValue?: unknown;
370
- options?: Array<{
371
- label: string;
372
- value: string | number | boolean;
373
- }>;
374
- dataSource?: DataSource;
375
- renderFilter?: (props: Record<string, unknown>) => ReactNode;
376
- multiple?: boolean;
377
- mode?: "single" | "range" | string;
378
- }
379
- type FilterOperator = "eq" | "ne" | "gt" | "gte" | "lt" | "lte" | "contains" | "startsWith" | "endsWith" | "in" | "notIn" | "between" | "isNull" | "isNotNull";
380
- interface ActiveFilter {
381
- name: string;
382
- value: unknown;
383
- operator: FilterOperator;
384
- }
385
- interface SortingState {
386
- field: string;
387
- direction: "asc" | "desc";
388
- }
389
- interface CrudQueryParams {
390
- page: number;
391
- pageSize: number;
392
- search?: string;
393
- sort?: SortingState;
394
- filters?: ActiveFilter[];
395
- }
396
- interface CrudResponse<T = unknown> {
397
- data: T[];
398
- total: number;
399
- page: number;
400
- pageSize: number;
401
- }
402
- interface CrudPermissions {
403
- create?: boolean;
404
- read?: boolean;
405
- update?: boolean;
406
- delete?: boolean;
407
- export?: boolean;
408
- import?: boolean;
409
- approve?: boolean;
410
- reject?: boolean;
411
- }
412
- interface CrudFeatures {
413
- search?: boolean;
414
- bulkActions?: boolean;
415
- export?: boolean;
416
- import?: boolean;
417
- showRowNumber?: boolean;
418
- showRowSelection?: boolean;
419
- }
420
- interface ImportOptions {
421
- format: "csv" | "xlsx" | "json";
422
- skipErrors?: boolean;
423
- updateExisting?: boolean;
424
- mapping?: Record<string, string>;
425
- }
426
- interface ExportOptions {
427
- format: "csv" | "xlsx" | "json";
428
- fields?: string[];
429
- filters?: ActiveFilter[];
430
- allData?: boolean;
431
- }
432
- interface ImportResult {
433
- success: boolean;
434
- imported: number;
435
- failed: number;
436
- errors: Array<{
437
- row: number;
438
- field: string;
439
- message: string;
440
- }>;
441
- }
442
- interface ActionFilters {
443
- page?: number;
444
- pageSize?: number;
445
- search?: string;
446
- status?: string;
447
- }
448
- interface ResourceFilters {
449
- page?: number;
450
- pageSize?: number;
451
- search?: string;
452
- status?: string;
453
- group?: string;
454
- type?: string;
455
- }
456
- interface UomFilters {
457
- page?: number;
458
- pageSize?: number;
459
- search?: string;
460
- status?: string;
461
- }
462
- interface WarehouseFilters {
463
- page?: number;
464
- pageSize?: number;
465
- search?: string;
466
- status?: string;
467
- }
468
-
469
- export { type ActionFilters, type ActiveFilter, type CodeGenerationConfig, type CrudFeatures, type CrudPermissions, type CrudQueryParams, type CrudResponse, type DataSource, type DensityType, type DirectionType, type DynamicIconNameType, type EntityConfig, type ExportOptions, type FieldAction, type FieldCalculate, type FieldCascade, type FieldConfig, type FieldDependencies, type FieldFormat, type FieldHelp, type FieldShowWhen, type FieldTransform, type FieldType, type FileType, type FilterConfig, type FilterOperator, type FilterType, type ForgotPasswordFormType, type FormModeConfig, type FormSection, type FormatStyleType, type IconProps, type IconType, type ImportOptions, type ImportResult, type LayoutType, type LocaleType, type ModeType, type NavigationNestedItem, type NavigationNestedItemBasicType, type NavigationNestedItemWithHrefType, type NavigationNestedItemWithItemsType, type NavigationRootItem, type NavigationRootItemBasicType, type NavigationRootItemWithHrefType, type NavigationRootItemWithItemsType, type NavigationType, type NewPasswordFormType, type NotificationType, type OAuthLinkType, type OrientationType, type Permission, type PermissionMatrix, type PermissionType, type RadiusType, type RegisterFormType, type ResourceFilters, type RouteType, type RowAction, type SearchGroup, type SearchResultItem, type SettingsType, type SidebarCollapsibleType, type SidebarVariantType, type SignInFormType, type SortingState, type ThemeType, type UomFilters, type UserType, type ValidationRule, type VerifyEmailFormType, type WarehouseFilters, radii, supportedLocales, supportedThemes };
@@ -1,25 +0,0 @@
1
- 'use strict';
2
-
3
- // src/types/index.ts
4
- var supportedLocales = ["vi", "en"];
5
- var supportedThemes = [
6
- "zinc",
7
- "slate",
8
- "stone",
9
- "gray",
10
- "neutral",
11
- "red",
12
- "rose",
13
- "orange",
14
- "green",
15
- "blue",
16
- "yellow",
17
- "violet"
18
- ];
19
- var radii = [0, 0.3, 0.5, 0.75, 1];
20
-
21
- exports.radii = radii;
22
- exports.supportedLocales = supportedLocales;
23
- exports.supportedThemes = supportedThemes;
24
- //# sourceMappingURL=index.js.map
25
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/types/index.ts"],"names":[],"mappings":";;;AAYO,IAAM,gBAAA,GAAmB,CAAC,IAAA,EAAM,IAAI;AAiBpC,IAAM,eAAA,GAAkB;AAAA,EAC7B,MAAA;AAAA,EACA,OAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA,KAAA;AAAA,EACA,MAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,QAAA;AAAA,EACA;AACF;AAGO,IAAM,QAAQ,CAAC,CAAA,EAAG,GAAA,EAAK,GAAA,EAAK,MAAM,CAAC","file":"index.js","sourcesContent":["// @goerp/core/types\n// Core TypeScript types for GoERP platform\n// Consolidated from packages/shared/types\n\nimport type { LucideIcon, icons } from \"lucide-react\";\nimport type { ComponentType, SVGAttributes, ReactNode } from \"react\";\nimport type { z } from \"zod\";\n\n// ============================================================================\n// Locale & Theme Types\n// ============================================================================\n\nexport const supportedLocales = [\"vi\", \"en\"] as const;\nexport type LocaleType = (typeof supportedLocales)[number];\n\nexport interface SearchResultItem {\n id: string;\n title: string;\n subtitle?: string;\n url?: string;\n action?: () => void;\n iconName?: DynamicIconNameType;\n}\n\nexport interface SearchGroup {\n heading: string;\n items: SearchResultItem[];\n}\n\nexport const supportedThemes = [\n \"zinc\",\n \"slate\",\n \"stone\",\n \"gray\",\n \"neutral\",\n \"red\",\n \"rose\",\n \"orange\",\n \"green\",\n \"blue\",\n \"yellow\",\n \"violet\",\n] as const;\nexport type ThemeType = (typeof supportedThemes)[number];\n\nexport const radii = [0, 0.3, 0.5, 0.75, 1] as const;\nexport type RadiusType = (typeof radii)[number];\n\n// ============================================================================\n// Layout & UI Types\n// ============================================================================\n\nexport type LayoutType = \"vertical\" | \"horizontal\";\nexport type ModeType = \"light\" | \"dark\" | \"system\";\nexport type OrientationType = \"vertical\" | \"horizontal\";\nexport type DirectionType = \"ltr\" | \"rtl\";\nexport type SidebarVariantType = \"sidebar\" | \"floating\" | \"inset\";\nexport type SidebarCollapsibleType = \"offcanvas\" | \"icon\" | \"none\";\nexport type DensityType = \"comfortable\" | \"compact\";\n\nexport type SettingsType = {\n theme: ThemeType;\n mode: ModeType;\n radius: RadiusType;\n layout: LayoutType;\n locale: LocaleType;\n sidebarVariant: SidebarVariantType;\n sidebarCollapsible: SidebarCollapsibleType;\n density: DensityType;\n};\n\n// ============================================================================\n// Icon Types\n// ============================================================================\n\nexport interface IconProps extends SVGAttributes<SVGElement> {\n children?: never;\n color?: string;\n}\n\nexport type IconType = ComponentType<IconProps> | LucideIcon;\nexport type DynamicIconNameType = keyof typeof icons;\n\n// ============================================================================\n// Auth Form Types\n// ============================================================================\n\nexport interface ForgotPasswordFormType {\n email: string;\n}\n\nexport interface NewPasswordFormType {\n password: string;\n confirmPassword: string;\n}\n\nexport interface SignInFormType {\n email: string;\n password: string;\n}\n\nexport interface RegisterFormType {\n firstName: string;\n lastName: string;\n username: string;\n email: string;\n password: string;\n confirmPassword: string;\n}\n\nexport interface VerifyEmailFormType {\n email: string;\n}\n\n// ============================================================================\n// User Types\n// ============================================================================\n\nexport interface UserType {\n id: string;\n firstName: string;\n lastName: string;\n name: string;\n password: string;\n username: string;\n role: string;\n avatar: string;\n background: string;\n status: string;\n phoneNumber: string;\n email: string;\n state: string;\n country: string;\n address: string;\n zipCode: string;\n language: string;\n timeZone: string;\n currency: string;\n organization: string;\n twoFactorAuth: boolean;\n loginAlerts: boolean;\n accountReoveryOption?: \"email\" | \"sms\" | \"codes\";\n connections: number;\n followers: number;\n}\n\n// ============================================================================\n// Permission Types\n// ============================================================================\n\nexport interface Permission {\n resourceCode: string;\n actionCode: string;\n}\n\nexport type PermissionType = Permission;\n\nexport type PermissionMatrix = Record<string, Record<string, boolean>>;\n\n// ============================================================================\n// Route & Navigation Types\n// ============================================================================\n\nexport interface RouteType {\n type: \"guest\" | \"public\";\n exceptions?: string[];\n}\n\nexport interface NotificationType {\n unreadCount: number;\n notifications: Array<{\n id: string;\n iconName: DynamicIconNameType;\n content: string;\n url: string;\n date: Date;\n isRead: boolean;\n }>;\n}\n\nexport type FormatStyleType = \"percent\" | \"duration\" | \"currency\" | \"regular\";\n\nexport interface NavigationType {\n title: string;\n iconName?: DynamicIconNameType;\n items: NavigationRootItem[];\n}\n\nexport type NavigationRootItem =\n | NavigationRootItemWithHrefType\n | NavigationRootItemWithItemsType;\n\nexport interface NavigationRootItemBasicType {\n title: string;\n label?: string;\n iconName: DynamicIconNameType;\n resource?: string;\n action?: string;\n}\n\nexport interface NavigationRootItemWithHrefType\n extends NavigationRootItemBasicType {\n href: string;\n items?: never;\n}\n\nexport interface NavigationRootItemWithItemsType\n extends NavigationRootItemBasicType {\n items: (\n | NavigationNestedItemWithHrefType\n | NavigationNestedItemWithItemsType\n )[];\n href?: never;\n}\n\nexport interface NavigationNestedItemBasicType {\n title: string;\n label?: string;\n resource?: string;\n action?: string;\n iconName?: DynamicIconNameType;\n}\n\nexport interface NavigationNestedItemWithHrefType\n extends NavigationNestedItemBasicType {\n href: string;\n items?: never;\n}\n\nexport interface NavigationNestedItemWithItemsType\n extends NavigationNestedItemBasicType {\n items: (\n | NavigationNestedItemWithHrefType\n | NavigationNestedItemWithItemsType\n )[];\n href?: never;\n}\n\nexport type NavigationNestedItem =\n | NavigationNestedItemWithHrefType\n | NavigationNestedItemWithItemsType;\n\n// ============================================================================\n// OAuth & File Types\n// ============================================================================\n\nexport interface OAuthLinkType {\n href: string;\n label: string;\n icon: IconType;\n}\n\nexport interface FileType {\n id: string;\n name: string;\n size: number;\n type: string;\n url: string;\n}\n\n// ============================================================================\n// Entity Configuration\n// ============================================================================\n\nexport interface EntityConfig {\n name: string;\n label: string;\n pluralLabel: string;\n icon?: LucideIcon;\n iconName?: string;\n description?: string;\n /**\n * Resource code used for permission checking.\n * If not specified, falls back to `name`.\n * Must match a valid resource code in the Resource table.\n */\n permissionResource?: string;\n apiEndpoint: string;\n idField: string;\n displayField: string;\n fields: FieldConfig[];\n filters?: FilterConfig[];\n defaultSort?: {\n field: string;\n direction: \"asc\" | \"desc\";\n };\n permissions?: CrudPermissions;\n features?: CrudFeatures;\n codeGeneration?: CodeGenerationConfig;\n formSections?: FormSection[];\n formMode?: FormModeConfig;\n rowActions?: RowAction[];\n include?: string[];\n}\n\nexport interface CodeGenerationConfig {\n enabled: boolean;\n field: string;\n ruleId?: string;\n entityType?: string;\n showPreview?: boolean;\n allowManualOverride?: boolean;\n generateOnCreate?: boolean;\n generateOnEdit?: boolean;\n}\n\nexport interface FormSection {\n title: string;\n description?: string;\n fields: string[];\n defaultOpen?: boolean;\n}\n\nexport interface FormModeConfig {\n create?: \"dialog\" | \"sheet\" | \"navigate\";\n edit?: \"dialog\" | \"sheet\" | \"navigate\";\n createPath?: string;\n editPath?: string;\n sheetSide?: \"top\" | \"right\" | \"bottom\" | \"left\";\n}\n\nexport interface RowAction {\n label: string;\n icon?: string;\n action:\n | \"copy\"\n | \"duplicate\"\n | \"view\"\n | \"archive\"\n | \"custom\"\n | \"approve\"\n | \"reject\"\n | \"set-default\"\n | \"view-history\";\n handler?: (\n rowId: string,\n rowData: Record<string, unknown>,\n ) => void | Promise<void>;\n visibleWhen?: (rowData: Record<string, unknown>) => boolean;\n variant?:\n | \"default\"\n | \"destructive\"\n | \"outline\"\n | \"secondary\"\n | \"ghost\"\n | \"link\";\n excludeFields?: string[];\n transformData?: (rowData: Record<string, unknown>) => Record<string, unknown>;\n}\n\n// ============================================================================\n// Field Configuration\n// ============================================================================\n\nexport type FieldType =\n | \"text\"\n | \"email\"\n | \"url\"\n | \"number\"\n | \"integer\"\n | \"textarea\"\n | \"boolean\"\n | \"date\"\n | \"datetime\"\n | \"time\"\n | \"select\"\n | \"multiselect\"\n | \"file\"\n | \"image\"\n | \"json\"\n | \"custom\"\n | \"switch\"\n | \"relation\";\n\nexport interface FieldConfig {\n name: string;\n label: string;\n type: FieldType;\n required?: boolean;\n defaultValue?: unknown;\n placeholder?: string;\n helpText?: string;\n description?: string;\n rows?: number;\n disabled?: boolean;\n disableOnCreate?: boolean;\n disableOnEdit?: boolean;\n fullWidth?: boolean;\n validation?: z.ZodTypeAny;\n hideInTable?: boolean;\n hideInForm?: boolean;\n showInImport?: boolean;\n width?: number | string;\n minWidth?: number | string;\n maxWidth?: number | string;\n isDisplayOnly?: boolean;\n sortable?: boolean;\n filterable?: boolean;\n order?: number;\n options?: Array<\n | string\n | number\n | boolean\n | { label: string; value: string | number | boolean }\n >;\n dataSource?: DataSource;\n dependsOn?: string;\n section?: string;\n showWhen?: FieldShowWhen;\n calculate?: FieldCalculate;\n format?: FieldFormat;\n transform?: FieldTransform;\n actions?: FieldAction[];\n help?: FieldHelp;\n dependencies?: FieldDependencies;\n cascade?: FieldCascade;\n renderCell?: (value: unknown, row: Record<string, unknown>) => ReactNode;\n renderForm?: (props: Record<string, unknown>) => ReactNode;\n renderInput?: (\n value: unknown,\n onChange: (value: unknown) => void,\n ) => ReactNode;\n relation?: {\n entity: string;\n displayField: string;\n valueField: string;\n filter?: Record<string, unknown>;\n };\n}\n\nexport interface FieldShowWhen {\n field: string;\n value: unknown;\n operator?:\n | \"equals\"\n | \"notEquals\"\n | \"contains\"\n | \"greaterThan\"\n | \"lessThan\"\n | \"isEmpty\"\n | \"isNotEmpty\";\n}\n\nexport interface FieldCalculate {\n dependsOn: string[];\n formula: string | ((values: Record<string, unknown>) => unknown);\n mode?: \"onChange\" | \"onBlur\" | \"always\";\n}\n\nexport interface FieldFormat {\n type: \"currency\" | \"percentage\" | \"date\" | \"datetime\" | \"number\" | \"custom\";\n options?: {\n currency?: string;\n locale?: string;\n decimals?: number;\n dateFormat?: string;\n custom?: (value: unknown) => string;\n };\n}\n\nexport interface FieldTransform {\n input?: (value: unknown) => unknown;\n output?: (value: unknown) => unknown;\n}\n\nexport interface FieldAction {\n label: string;\n icon?: string;\n action: \"clear\" | \"copy\" | \"generate\" | \"validate\" | \"custom\";\n handler?: (\n field: FieldConfig,\n formData: Record<string, unknown>,\n ) => void | Promise<void>;\n visibleWhen?: {\n field: string;\n operator: \"equals\" | \"notEquals\" | \"isEmpty\" | \"isNotEmpty\";\n value: unknown;\n };\n}\n\nexport interface FieldHelp {\n text?: string;\n tooltip?: string;\n link?: {\n url: string;\n text: string;\n openInNewTab?: boolean;\n };\n examples?: string[];\n}\n\nexport interface FieldDependencies {\n fields: string[];\n condition: \"all\" | \"any\" | \"none\";\n rules: Array<{\n field: string;\n operator:\n | \"equals\"\n | \"notEquals\"\n | \"contains\"\n | \"greaterThan\"\n | \"lessThan\"\n | \"isEmpty\"\n | \"isNotEmpty\";\n value: unknown;\n }>;\n}\n\nexport interface FieldCascade {\n triggerField: string;\n action: \"clear\" | \"reset\" | \"update\";\n updateFields?: string[];\n}\n\nexport interface ValidationRule {\n type:\n | \"required\"\n | \"email\"\n | \"url\"\n | \"min\"\n | \"max\"\n | \"minLength\"\n | \"maxLength\"\n | \"pattern\"\n | \"custom\";\n value?: unknown;\n message: string;\n validator?: (value: unknown, formData: Record<string, unknown>) => boolean;\n}\n\n// ============================================================================\n// Data Source\n// ============================================================================\n\nexport interface DataSource {\n type: \"static\" | \"api\";\n options?: Array<{ label: string; value: string | number | boolean }>;\n endpoint?: string;\n params?: Record<string, unknown>;\n labelField?: string;\n valueField?: string;\n searchable?: boolean;\n cacheTime?: number;\n transform?: (\n data: unknown[],\n ) => Array<{ label: string; value: string | number | boolean }>;\n}\n\n// ============================================================================\n// Filter Configuration\n// ============================================================================\n\nexport type FilterType =\n | \"text\"\n | \"datetime\"\n | \"select\"\n | \"checkbox\"\n | \"switch\"\n | \"radio\"\n | \"custom\";\n\nexport interface FilterConfig {\n name: string;\n label: string;\n type: FilterType;\n field: string;\n operator?: FilterOperator;\n defaultValue?: unknown;\n options?: Array<{ label: string; value: string | number | boolean }>;\n dataSource?: DataSource;\n renderFilter?: (props: Record<string, unknown>) => ReactNode;\n multiple?: boolean;\n mode?: \"single\" | \"range\" | string;\n}\n\nexport type FilterOperator =\n | \"eq\"\n | \"ne\"\n | \"gt\"\n | \"gte\"\n | \"lt\"\n | \"lte\"\n | \"contains\"\n | \"startsWith\"\n | \"endsWith\"\n | \"in\"\n | \"notIn\"\n | \"between\"\n | \"isNull\"\n | \"isNotNull\";\n\nexport interface ActiveFilter {\n name: string;\n value: unknown;\n operator: FilterOperator;\n}\n\n// ============================================================================\n// CRUD Operations\n// ============================================================================\n\nexport interface SortingState {\n field: string;\n direction: \"asc\" | \"desc\";\n}\n\nexport interface CrudQueryParams {\n page: number;\n pageSize: number;\n search?: string;\n sort?: SortingState;\n filters?: ActiveFilter[];\n}\n\nexport interface CrudResponse<T = unknown> {\n data: T[];\n total: number;\n page: number;\n pageSize: number;\n}\n\nexport interface CrudPermissions {\n create?: boolean;\n read?: boolean;\n update?: boolean;\n delete?: boolean;\n export?: boolean;\n import?: boolean;\n approve?: boolean;\n reject?: boolean;\n}\n\nexport interface CrudFeatures {\n search?: boolean;\n bulkActions?: boolean;\n export?: boolean;\n import?: boolean;\n showRowNumber?: boolean;\n showRowSelection?: boolean;\n}\n\n// ============================================================================\n// Import/Export\n// ============================================================================\n\nexport interface ImportOptions {\n format: \"csv\" | \"xlsx\" | \"json\";\n skipErrors?: boolean;\n updateExisting?: boolean;\n mapping?: Record<string, string>;\n}\n\nexport interface ExportOptions {\n format: \"csv\" | \"xlsx\" | \"json\";\n fields?: string[];\n filters?: ActiveFilter[];\n allData?: boolean;\n}\n\nexport interface ImportResult {\n success: boolean;\n imported: number;\n failed: number;\n errors: Array<{\n row: number;\n field: string;\n message: string;\n }>;\n}\n\n// ============================================================================\n// Entity Filter Types\n// ============================================================================\n\nexport interface ActionFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n}\n\nexport interface ResourceFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n group?: string;\n type?: string;\n}\n\nexport interface UomFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n}\n\nexport interface WarehouseFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n}\n"]}
@@ -1,21 +0,0 @@
1
- // src/types/index.ts
2
- var supportedLocales = ["vi", "en"];
3
- var supportedThemes = [
4
- "zinc",
5
- "slate",
6
- "stone",
7
- "gray",
8
- "neutral",
9
- "red",
10
- "rose",
11
- "orange",
12
- "green",
13
- "blue",
14
- "yellow",
15
- "violet"
16
- ];
17
- var radii = [0, 0.3, 0.5, 0.75, 1];
18
-
19
- export { radii, supportedLocales, supportedThemes };
20
- //# sourceMappingURL=index.mjs.map
21
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/types/index.ts"],"names":[],"mappings":";AAYO,IAAM,gBAAA,GAAmB,CAAC,IAAA,EAAM,IAAI;AAiBpC,IAAM,eAAA,GAAkB;AAAA,EAC7B,MAAA;AAAA,EACA,OAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA,KAAA;AAAA,EACA,MAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,QAAA;AAAA,EACA;AACF;AAGO,IAAM,QAAQ,CAAC,CAAA,EAAG,GAAA,EAAK,GAAA,EAAK,MAAM,CAAC","file":"index.mjs","sourcesContent":["// @goerp/core/types\n// Core TypeScript types for GoERP platform\n// Consolidated from packages/shared/types\n\nimport type { LucideIcon, icons } from \"lucide-react\";\nimport type { ComponentType, SVGAttributes, ReactNode } from \"react\";\nimport type { z } from \"zod\";\n\n// ============================================================================\n// Locale & Theme Types\n// ============================================================================\n\nexport const supportedLocales = [\"vi\", \"en\"] as const;\nexport type LocaleType = (typeof supportedLocales)[number];\n\nexport interface SearchResultItem {\n id: string;\n title: string;\n subtitle?: string;\n url?: string;\n action?: () => void;\n iconName?: DynamicIconNameType;\n}\n\nexport interface SearchGroup {\n heading: string;\n items: SearchResultItem[];\n}\n\nexport const supportedThemes = [\n \"zinc\",\n \"slate\",\n \"stone\",\n \"gray\",\n \"neutral\",\n \"red\",\n \"rose\",\n \"orange\",\n \"green\",\n \"blue\",\n \"yellow\",\n \"violet\",\n] as const;\nexport type ThemeType = (typeof supportedThemes)[number];\n\nexport const radii = [0, 0.3, 0.5, 0.75, 1] as const;\nexport type RadiusType = (typeof radii)[number];\n\n// ============================================================================\n// Layout & UI Types\n// ============================================================================\n\nexport type LayoutType = \"vertical\" | \"horizontal\";\nexport type ModeType = \"light\" | \"dark\" | \"system\";\nexport type OrientationType = \"vertical\" | \"horizontal\";\nexport type DirectionType = \"ltr\" | \"rtl\";\nexport type SidebarVariantType = \"sidebar\" | \"floating\" | \"inset\";\nexport type SidebarCollapsibleType = \"offcanvas\" | \"icon\" | \"none\";\nexport type DensityType = \"comfortable\" | \"compact\";\n\nexport type SettingsType = {\n theme: ThemeType;\n mode: ModeType;\n radius: RadiusType;\n layout: LayoutType;\n locale: LocaleType;\n sidebarVariant: SidebarVariantType;\n sidebarCollapsible: SidebarCollapsibleType;\n density: DensityType;\n};\n\n// ============================================================================\n// Icon Types\n// ============================================================================\n\nexport interface IconProps extends SVGAttributes<SVGElement> {\n children?: never;\n color?: string;\n}\n\nexport type IconType = ComponentType<IconProps> | LucideIcon;\nexport type DynamicIconNameType = keyof typeof icons;\n\n// ============================================================================\n// Auth Form Types\n// ============================================================================\n\nexport interface ForgotPasswordFormType {\n email: string;\n}\n\nexport interface NewPasswordFormType {\n password: string;\n confirmPassword: string;\n}\n\nexport interface SignInFormType {\n email: string;\n password: string;\n}\n\nexport interface RegisterFormType {\n firstName: string;\n lastName: string;\n username: string;\n email: string;\n password: string;\n confirmPassword: string;\n}\n\nexport interface VerifyEmailFormType {\n email: string;\n}\n\n// ============================================================================\n// User Types\n// ============================================================================\n\nexport interface UserType {\n id: string;\n firstName: string;\n lastName: string;\n name: string;\n password: string;\n username: string;\n role: string;\n avatar: string;\n background: string;\n status: string;\n phoneNumber: string;\n email: string;\n state: string;\n country: string;\n address: string;\n zipCode: string;\n language: string;\n timeZone: string;\n currency: string;\n organization: string;\n twoFactorAuth: boolean;\n loginAlerts: boolean;\n accountReoveryOption?: \"email\" | \"sms\" | \"codes\";\n connections: number;\n followers: number;\n}\n\n// ============================================================================\n// Permission Types\n// ============================================================================\n\nexport interface Permission {\n resourceCode: string;\n actionCode: string;\n}\n\nexport type PermissionType = Permission;\n\nexport type PermissionMatrix = Record<string, Record<string, boolean>>;\n\n// ============================================================================\n// Route & Navigation Types\n// ============================================================================\n\nexport interface RouteType {\n type: \"guest\" | \"public\";\n exceptions?: string[];\n}\n\nexport interface NotificationType {\n unreadCount: number;\n notifications: Array<{\n id: string;\n iconName: DynamicIconNameType;\n content: string;\n url: string;\n date: Date;\n isRead: boolean;\n }>;\n}\n\nexport type FormatStyleType = \"percent\" | \"duration\" | \"currency\" | \"regular\";\n\nexport interface NavigationType {\n title: string;\n iconName?: DynamicIconNameType;\n items: NavigationRootItem[];\n}\n\nexport type NavigationRootItem =\n | NavigationRootItemWithHrefType\n | NavigationRootItemWithItemsType;\n\nexport interface NavigationRootItemBasicType {\n title: string;\n label?: string;\n iconName: DynamicIconNameType;\n resource?: string;\n action?: string;\n}\n\nexport interface NavigationRootItemWithHrefType\n extends NavigationRootItemBasicType {\n href: string;\n items?: never;\n}\n\nexport interface NavigationRootItemWithItemsType\n extends NavigationRootItemBasicType {\n items: (\n | NavigationNestedItemWithHrefType\n | NavigationNestedItemWithItemsType\n )[];\n href?: never;\n}\n\nexport interface NavigationNestedItemBasicType {\n title: string;\n label?: string;\n resource?: string;\n action?: string;\n iconName?: DynamicIconNameType;\n}\n\nexport interface NavigationNestedItemWithHrefType\n extends NavigationNestedItemBasicType {\n href: string;\n items?: never;\n}\n\nexport interface NavigationNestedItemWithItemsType\n extends NavigationNestedItemBasicType {\n items: (\n | NavigationNestedItemWithHrefType\n | NavigationNestedItemWithItemsType\n )[];\n href?: never;\n}\n\nexport type NavigationNestedItem =\n | NavigationNestedItemWithHrefType\n | NavigationNestedItemWithItemsType;\n\n// ============================================================================\n// OAuth & File Types\n// ============================================================================\n\nexport interface OAuthLinkType {\n href: string;\n label: string;\n icon: IconType;\n}\n\nexport interface FileType {\n id: string;\n name: string;\n size: number;\n type: string;\n url: string;\n}\n\n// ============================================================================\n// Entity Configuration\n// ============================================================================\n\nexport interface EntityConfig {\n name: string;\n label: string;\n pluralLabel: string;\n icon?: LucideIcon;\n iconName?: string;\n description?: string;\n /**\n * Resource code used for permission checking.\n * If not specified, falls back to `name`.\n * Must match a valid resource code in the Resource table.\n */\n permissionResource?: string;\n apiEndpoint: string;\n idField: string;\n displayField: string;\n fields: FieldConfig[];\n filters?: FilterConfig[];\n defaultSort?: {\n field: string;\n direction: \"asc\" | \"desc\";\n };\n permissions?: CrudPermissions;\n features?: CrudFeatures;\n codeGeneration?: CodeGenerationConfig;\n formSections?: FormSection[];\n formMode?: FormModeConfig;\n rowActions?: RowAction[];\n include?: string[];\n}\n\nexport interface CodeGenerationConfig {\n enabled: boolean;\n field: string;\n ruleId?: string;\n entityType?: string;\n showPreview?: boolean;\n allowManualOverride?: boolean;\n generateOnCreate?: boolean;\n generateOnEdit?: boolean;\n}\n\nexport interface FormSection {\n title: string;\n description?: string;\n fields: string[];\n defaultOpen?: boolean;\n}\n\nexport interface FormModeConfig {\n create?: \"dialog\" | \"sheet\" | \"navigate\";\n edit?: \"dialog\" | \"sheet\" | \"navigate\";\n createPath?: string;\n editPath?: string;\n sheetSide?: \"top\" | \"right\" | \"bottom\" | \"left\";\n}\n\nexport interface RowAction {\n label: string;\n icon?: string;\n action:\n | \"copy\"\n | \"duplicate\"\n | \"view\"\n | \"archive\"\n | \"custom\"\n | \"approve\"\n | \"reject\"\n | \"set-default\"\n | \"view-history\";\n handler?: (\n rowId: string,\n rowData: Record<string, unknown>,\n ) => void | Promise<void>;\n visibleWhen?: (rowData: Record<string, unknown>) => boolean;\n variant?:\n | \"default\"\n | \"destructive\"\n | \"outline\"\n | \"secondary\"\n | \"ghost\"\n | \"link\";\n excludeFields?: string[];\n transformData?: (rowData: Record<string, unknown>) => Record<string, unknown>;\n}\n\n// ============================================================================\n// Field Configuration\n// ============================================================================\n\nexport type FieldType =\n | \"text\"\n | \"email\"\n | \"url\"\n | \"number\"\n | \"integer\"\n | \"textarea\"\n | \"boolean\"\n | \"date\"\n | \"datetime\"\n | \"time\"\n | \"select\"\n | \"multiselect\"\n | \"file\"\n | \"image\"\n | \"json\"\n | \"custom\"\n | \"switch\"\n | \"relation\";\n\nexport interface FieldConfig {\n name: string;\n label: string;\n type: FieldType;\n required?: boolean;\n defaultValue?: unknown;\n placeholder?: string;\n helpText?: string;\n description?: string;\n rows?: number;\n disabled?: boolean;\n disableOnCreate?: boolean;\n disableOnEdit?: boolean;\n fullWidth?: boolean;\n validation?: z.ZodTypeAny;\n hideInTable?: boolean;\n hideInForm?: boolean;\n showInImport?: boolean;\n width?: number | string;\n minWidth?: number | string;\n maxWidth?: number | string;\n isDisplayOnly?: boolean;\n sortable?: boolean;\n filterable?: boolean;\n order?: number;\n options?: Array<\n | string\n | number\n | boolean\n | { label: string; value: string | number | boolean }\n >;\n dataSource?: DataSource;\n dependsOn?: string;\n section?: string;\n showWhen?: FieldShowWhen;\n calculate?: FieldCalculate;\n format?: FieldFormat;\n transform?: FieldTransform;\n actions?: FieldAction[];\n help?: FieldHelp;\n dependencies?: FieldDependencies;\n cascade?: FieldCascade;\n renderCell?: (value: unknown, row: Record<string, unknown>) => ReactNode;\n renderForm?: (props: Record<string, unknown>) => ReactNode;\n renderInput?: (\n value: unknown,\n onChange: (value: unknown) => void,\n ) => ReactNode;\n relation?: {\n entity: string;\n displayField: string;\n valueField: string;\n filter?: Record<string, unknown>;\n };\n}\n\nexport interface FieldShowWhen {\n field: string;\n value: unknown;\n operator?:\n | \"equals\"\n | \"notEquals\"\n | \"contains\"\n | \"greaterThan\"\n | \"lessThan\"\n | \"isEmpty\"\n | \"isNotEmpty\";\n}\n\nexport interface FieldCalculate {\n dependsOn: string[];\n formula: string | ((values: Record<string, unknown>) => unknown);\n mode?: \"onChange\" | \"onBlur\" | \"always\";\n}\n\nexport interface FieldFormat {\n type: \"currency\" | \"percentage\" | \"date\" | \"datetime\" | \"number\" | \"custom\";\n options?: {\n currency?: string;\n locale?: string;\n decimals?: number;\n dateFormat?: string;\n custom?: (value: unknown) => string;\n };\n}\n\nexport interface FieldTransform {\n input?: (value: unknown) => unknown;\n output?: (value: unknown) => unknown;\n}\n\nexport interface FieldAction {\n label: string;\n icon?: string;\n action: \"clear\" | \"copy\" | \"generate\" | \"validate\" | \"custom\";\n handler?: (\n field: FieldConfig,\n formData: Record<string, unknown>,\n ) => void | Promise<void>;\n visibleWhen?: {\n field: string;\n operator: \"equals\" | \"notEquals\" | \"isEmpty\" | \"isNotEmpty\";\n value: unknown;\n };\n}\n\nexport interface FieldHelp {\n text?: string;\n tooltip?: string;\n link?: {\n url: string;\n text: string;\n openInNewTab?: boolean;\n };\n examples?: string[];\n}\n\nexport interface FieldDependencies {\n fields: string[];\n condition: \"all\" | \"any\" | \"none\";\n rules: Array<{\n field: string;\n operator:\n | \"equals\"\n | \"notEquals\"\n | \"contains\"\n | \"greaterThan\"\n | \"lessThan\"\n | \"isEmpty\"\n | \"isNotEmpty\";\n value: unknown;\n }>;\n}\n\nexport interface FieldCascade {\n triggerField: string;\n action: \"clear\" | \"reset\" | \"update\";\n updateFields?: string[];\n}\n\nexport interface ValidationRule {\n type:\n | \"required\"\n | \"email\"\n | \"url\"\n | \"min\"\n | \"max\"\n | \"minLength\"\n | \"maxLength\"\n | \"pattern\"\n | \"custom\";\n value?: unknown;\n message: string;\n validator?: (value: unknown, formData: Record<string, unknown>) => boolean;\n}\n\n// ============================================================================\n// Data Source\n// ============================================================================\n\nexport interface DataSource {\n type: \"static\" | \"api\";\n options?: Array<{ label: string; value: string | number | boolean }>;\n endpoint?: string;\n params?: Record<string, unknown>;\n labelField?: string;\n valueField?: string;\n searchable?: boolean;\n cacheTime?: number;\n transform?: (\n data: unknown[],\n ) => Array<{ label: string; value: string | number | boolean }>;\n}\n\n// ============================================================================\n// Filter Configuration\n// ============================================================================\n\nexport type FilterType =\n | \"text\"\n | \"datetime\"\n | \"select\"\n | \"checkbox\"\n | \"switch\"\n | \"radio\"\n | \"custom\";\n\nexport interface FilterConfig {\n name: string;\n label: string;\n type: FilterType;\n field: string;\n operator?: FilterOperator;\n defaultValue?: unknown;\n options?: Array<{ label: string; value: string | number | boolean }>;\n dataSource?: DataSource;\n renderFilter?: (props: Record<string, unknown>) => ReactNode;\n multiple?: boolean;\n mode?: \"single\" | \"range\" | string;\n}\n\nexport type FilterOperator =\n | \"eq\"\n | \"ne\"\n | \"gt\"\n | \"gte\"\n | \"lt\"\n | \"lte\"\n | \"contains\"\n | \"startsWith\"\n | \"endsWith\"\n | \"in\"\n | \"notIn\"\n | \"between\"\n | \"isNull\"\n | \"isNotNull\";\n\nexport interface ActiveFilter {\n name: string;\n value: unknown;\n operator: FilterOperator;\n}\n\n// ============================================================================\n// CRUD Operations\n// ============================================================================\n\nexport interface SortingState {\n field: string;\n direction: \"asc\" | \"desc\";\n}\n\nexport interface CrudQueryParams {\n page: number;\n pageSize: number;\n search?: string;\n sort?: SortingState;\n filters?: ActiveFilter[];\n}\n\nexport interface CrudResponse<T = unknown> {\n data: T[];\n total: number;\n page: number;\n pageSize: number;\n}\n\nexport interface CrudPermissions {\n create?: boolean;\n read?: boolean;\n update?: boolean;\n delete?: boolean;\n export?: boolean;\n import?: boolean;\n approve?: boolean;\n reject?: boolean;\n}\n\nexport interface CrudFeatures {\n search?: boolean;\n bulkActions?: boolean;\n export?: boolean;\n import?: boolean;\n showRowNumber?: boolean;\n showRowSelection?: boolean;\n}\n\n// ============================================================================\n// Import/Export\n// ============================================================================\n\nexport interface ImportOptions {\n format: \"csv\" | \"xlsx\" | \"json\";\n skipErrors?: boolean;\n updateExisting?: boolean;\n mapping?: Record<string, string>;\n}\n\nexport interface ExportOptions {\n format: \"csv\" | \"xlsx\" | \"json\";\n fields?: string[];\n filters?: ActiveFilter[];\n allData?: boolean;\n}\n\nexport interface ImportResult {\n success: boolean;\n imported: number;\n failed: number;\n errors: Array<{\n row: number;\n field: string;\n message: string;\n }>;\n}\n\n// ============================================================================\n// Entity Filter Types\n// ============================================================================\n\nexport interface ActionFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n}\n\nexport interface ResourceFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n group?: string;\n type?: string;\n}\n\nexport interface UomFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n}\n\nexport interface WarehouseFilters {\n page?: number;\n pageSize?: number;\n search?: string;\n status?: string;\n}\n"]}
@@ -1,39 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import { ComponentProps } from 'react';
3
- import { StaticImageData } from 'next/image';
4
-
5
- type AuthDictionaryType = any;
6
- interface AuthProps extends ComponentProps<"div"> {
7
- imgSrc?: string | StaticImageData;
8
- imgClassName?: string;
9
- imageClassName?: string;
10
- dictionary: AuthDictionaryType;
11
- }
12
- declare function Auth({ className, children, imgSrc, imgClassName, imageClassName, dictionary, ...props }: AuthProps): react_jsx_runtime.JSX.Element;
13
- interface AuthImageProps extends ComponentProps<"div"> {
14
- imgSrc: string | StaticImageData;
15
- imageClassName?: string;
16
- }
17
- declare function AuthImage({ className, imageClassName, imgSrc, ...props }: AuthImageProps): react_jsx_runtime.JSX.Element;
18
- declare function AuthHeader({ className, ...props }: ComponentProps<"div">): react_jsx_runtime.JSX.Element;
19
- declare function AuthTitle({ className, ...props }: ComponentProps<"h1">): react_jsx_runtime.JSX.Element;
20
- declare function AuthDescription({ className, ...props }: ComponentProps<"p">): react_jsx_runtime.JSX.Element;
21
- declare function AuthForm({ className, ...props }: ComponentProps<"div">): react_jsx_runtime.JSX.Element;
22
- declare function AuthFooter({ className, ...props }: ComponentProps<"div">): react_jsx_runtime.JSX.Element;
23
-
24
- declare function SignInForm(): react_jsx_runtime.JSX.Element;
25
-
26
- declare function RegisterForm(): react_jsx_runtime.JSX.Element;
27
-
28
- interface OAuthLinksProps {
29
- className?: string;
30
- }
31
- declare function OAuthLinks({ className }: OAuthLinksProps): react_jsx_runtime.JSX.Element;
32
-
33
- declare function ForgotPasswordForm(): react_jsx_runtime.JSX.Element;
34
-
35
- declare function NewPasswordForm(): react_jsx_runtime.JSX.Element;
36
-
37
- declare function VerifyEmailForm(): react_jsx_runtime.JSX.Element;
38
-
39
- export { Auth, AuthDescription, type AuthDictionaryType, AuthFooter, AuthForm, AuthHeader, AuthImage, AuthTitle, ForgotPasswordForm, NewPasswordForm, OAuthLinks, RegisterForm, SignInForm, VerifyEmailForm };