@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.
- package/package.json +31 -175
- package/dist/audit/index.d.mts +0 -115
- package/dist/audit/index.d.ts +0 -115
- package/dist/audit/index.js +0 -204
- package/dist/audit/index.js.map +0 -1
- package/dist/audit/index.mjs +0 -200
- package/dist/audit/index.mjs.map +0 -1
- package/dist/auth/index.d.mts +0 -86
- package/dist/auth/index.d.ts +0 -86
- package/dist/auth/index.js +0 -210
- package/dist/auth/index.js.map +0 -1
- package/dist/auth/index.mjs +0 -198
- package/dist/auth/index.mjs.map +0 -1
- package/dist/button-1dWvP9Ib.d.mts +0 -30
- package/dist/button-1dWvP9Ib.d.ts +0 -30
- package/dist/calendar-2QzdEo1z.d.mts +0 -20
- package/dist/calendar-2QzdEo1z.d.ts +0 -20
- package/dist/code-generation/index.d.mts +0 -30
- package/dist/code-generation/index.d.ts +0 -30
- package/dist/code-generation/index.js +0 -31
- package/dist/code-generation/index.js.map +0 -1
- package/dist/code-generation/index.mjs +0 -28
- package/dist/code-generation/index.mjs.map +0 -1
- package/dist/configs/index.d.mts +0 -175
- package/dist/configs/index.d.ts +0 -175
- package/dist/configs/index.js +0 -254
- package/dist/configs/index.js.map +0 -1
- package/dist/configs/index.mjs +0 -233
- package/dist/configs/index.mjs.map +0 -1
- package/dist/crud/index.d.mts +0 -646
- package/dist/crud/index.d.ts +0 -646
- package/dist/crud/index.js +0 -11772
- package/dist/crud/index.js.map +0 -1
- package/dist/crud/index.mjs +0 -11665
- package/dist/crud/index.mjs.map +0 -1
- package/dist/crud/server.d.mts +0 -20
- package/dist/crud/server.d.ts +0 -20
- package/dist/crud/server.js +0 -123
- package/dist/crud/server.js.map +0 -1
- package/dist/crud/server.mjs +0 -120
- package/dist/crud/server.mjs.map +0 -1
- package/dist/data-table-skeleton-12NA8Mjx.d.mts +0 -39
- package/dist/data-table-skeleton-12NA8Mjx.d.ts +0 -39
- package/dist/dialog-bKfjZMTd.d.mts +0 -22
- package/dist/dialog-bKfjZMTd.d.ts +0 -22
- package/dist/dynamic-icon-DrGIiu2N.d.mts +0 -10
- package/dist/dynamic-icon-DrGIiu2N.d.ts +0 -10
- package/dist/home/index.d.mts +0 -269
- package/dist/home/index.d.ts +0 -269
- package/dist/home/index.js +0 -1678
- package/dist/home/index.js.map +0 -1
- package/dist/home/index.mjs +0 -1635
- package/dist/home/index.mjs.map +0 -1
- package/dist/hooks/index.d.mts +0 -7
- package/dist/hooks/index.d.ts +0 -7
- package/dist/hooks/index.js +0 -8316
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/index.mjs +0 -8255
- package/dist/hooks/index.mjs.map +0 -1
- package/dist/index-50hpiPrV.d.ts +0 -116
- package/dist/index-B9zQVEVi.d.mts +0 -116
- package/dist/index.d.mts +0 -5
- package/dist/index.d.ts +0 -5
- package/dist/index.js +0 -123
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -118
- package/dist/index.mjs.map +0 -1
- package/dist/infrastructure/index.d.mts +0 -423
- package/dist/infrastructure/index.d.ts +0 -423
- package/dist/infrastructure/index.js +0 -633
- package/dist/infrastructure/index.js.map +0 -1
- package/dist/infrastructure/index.mjs +0 -619
- package/dist/infrastructure/index.mjs.map +0 -1
- package/dist/label-DWTEkNPo.d.ts +0 -226
- package/dist/label-LPpdcoBx.d.mts +0 -226
- package/dist/layout/index.d.mts +0 -48
- package/dist/layout/index.d.ts +0 -48
- package/dist/layout/index.js +0 -117
- package/dist/layout/index.js.map +0 -1
- package/dist/layout/index.mjs +0 -90
- package/dist/layout/index.mjs.map +0 -1
- package/dist/navigation/index.d.mts +0 -16
- package/dist/navigation/index.d.ts +0 -16
- package/dist/navigation/index.js +0 -53
- package/dist/navigation/index.js.map +0 -1
- package/dist/navigation/index.mjs +0 -50
- package/dist/navigation/index.mjs.map +0 -1
- package/dist/notification/index.d.mts +0 -105
- package/dist/notification/index.d.ts +0 -105
- package/dist/notification/index.js +0 -278
- package/dist/notification/index.js.map +0 -1
- package/dist/notification/index.mjs +0 -274
- package/dist/notification/index.mjs.map +0 -1
- package/dist/organization/index.d.mts +0 -99
- package/dist/organization/index.d.ts +0 -99
- package/dist/organization/index.js +0 -360
- package/dist/organization/index.js.map +0 -1
- package/dist/organization/index.mjs +0 -352
- package/dist/organization/index.mjs.map +0 -1
- package/dist/plugin/index.d.mts +0 -83
- package/dist/plugin/index.d.ts +0 -83
- package/dist/plugin/index.js +0 -86
- package/dist/plugin/index.js.map +0 -1
- package/dist/plugin/index.mjs +0 -84
- package/dist/plugin/index.mjs.map +0 -1
- package/dist/providers/index.d.mts +0 -25
- package/dist/providers/index.d.ts +0 -25
- package/dist/providers/index.js +0 -84
- package/dist/providers/index.js.map +0 -1
- package/dist/providers/index.mjs +0 -77
- package/dist/providers/index.mjs.map +0 -1
- package/dist/rbac/index.d.mts +0 -226
- package/dist/rbac/index.d.ts +0 -226
- package/dist/rbac/index.js +0 -4784
- package/dist/rbac/index.js.map +0 -1
- package/dist/rbac/index.mjs +0 -4722
- package/dist/rbac/index.mjs.map +0 -1
- package/dist/rbac/permissions.d.mts +0 -26
- package/dist/rbac/permissions.d.ts +0 -26
- package/dist/rbac/permissions.js +0 -94
- package/dist/rbac/permissions.js.map +0 -1
- package/dist/rbac/permissions.mjs +0 -90
- package/dist/rbac/permissions.mjs.map +0 -1
- package/dist/rbac/server.d.mts +0 -1
- package/dist/rbac/server.d.ts +0 -1
- package/dist/rbac/server.js +0 -128
- package/dist/rbac/server.js.map +0 -1
- package/dist/rbac/server.mjs +0 -124
- package/dist/rbac/server.mjs.map +0 -1
- package/dist/schemas/index.d.mts +0 -1257
- package/dist/schemas/index.d.ts +0 -1257
- package/dist/schemas/index.js +0 -572
- package/dist/schemas/index.js.map +0 -1
- package/dist/schemas/index.mjs +0 -523
- package/dist/schemas/index.mjs.map +0 -1
- package/dist/server-QuYCTa89.d.mts +0 -83
- package/dist/server-QuYCTa89.d.ts +0 -83
- package/dist/sonner-C74GlRDQ.d.mts +0 -71
- package/dist/sonner-C74GlRDQ.d.ts +0 -71
- package/dist/status-BOXZgIqX.d.mts +0 -12
- package/dist/status-BOXZgIqX.d.ts +0 -12
- package/dist/system/index.d.mts +0 -77
- package/dist/system/index.d.ts +0 -77
- package/dist/system/index.js +0 -102
- package/dist/system/index.js.map +0 -1
- package/dist/system/index.mjs +0 -100
- package/dist/system/index.mjs.map +0 -1
- package/dist/tabs-C6FfBwPY.d.mts +0 -18
- package/dist/tabs-C6FfBwPY.d.ts +0 -18
- package/dist/tenant-provider-B8eC_Wpb.d.mts +0 -27
- package/dist/tenant-provider-B8eC_Wpb.d.ts +0 -27
- package/dist/types/index.d.mts +0 -469
- package/dist/types/index.d.ts +0 -469
- package/dist/types/index.js +0 -25
- package/dist/types/index.js.map +0 -1
- package/dist/types/index.mjs +0 -21
- package/dist/types/index.mjs.map +0 -1
- package/dist/ui/auth.d.mts +0 -39
- package/dist/ui/auth.d.ts +0 -39
- package/dist/ui/auth.js +0 -4941
- package/dist/ui/auth.js.map +0 -1
- package/dist/ui/auth.mjs +0 -4896
- package/dist/ui/auth.mjs.map +0 -1
- package/dist/ui/crud.d.mts +0 -2
- package/dist/ui/crud.d.ts +0 -2
- package/dist/ui/crud.js +0 -4
- package/dist/ui/crud.js.map +0 -1
- package/dist/ui/crud.mjs +0 -3
- package/dist/ui/crud.mjs.map +0 -1
- package/dist/ui/data-display.d.mts +0 -596
- package/dist/ui/data-display.d.ts +0 -596
- package/dist/ui/data-display.js +0 -5307
- package/dist/ui/data-display.js.map +0 -1
- package/dist/ui/data-display.mjs +0 -5212
- package/dist/ui/data-display.mjs.map +0 -1
- package/dist/ui/feedback.d.mts +0 -55
- package/dist/ui/feedback.d.ts +0 -55
- package/dist/ui/feedback.js +0 -2608
- package/dist/ui/feedback.js.map +0 -1
- package/dist/ui/feedback.mjs +0 -2526
- package/dist/ui/feedback.mjs.map +0 -1
- package/dist/ui/forms.d.mts +0 -309
- package/dist/ui/forms.d.ts +0 -309
- package/dist/ui/forms.js +0 -4656
- package/dist/ui/forms.js.map +0 -1
- package/dist/ui/forms.mjs +0 -4571
- package/dist/ui/forms.mjs.map +0 -1
- package/dist/ui/index.d.mts +0 -331
- package/dist/ui/index.d.ts +0 -331
- package/dist/ui/index.js +0 -16953
- package/dist/ui/index.js.map +0 -1
- package/dist/ui/index.mjs +0 -16598
- package/dist/ui/index.mjs.map +0 -1
- package/dist/ui/primitives/client.d.mts +0 -61
- package/dist/ui/primitives/client.d.ts +0 -61
- package/dist/ui/primitives/client.js +0 -3408
- package/dist/ui/primitives/client.js.map +0 -1
- package/dist/ui/primitives/client.mjs +0 -3256
- package/dist/ui/primitives/client.mjs.map +0 -1
- package/dist/ui/primitives.d.mts +0 -113
- package/dist/ui/primitives.d.ts +0 -113
- package/dist/ui/primitives.js +0 -3356
- package/dist/ui/primitives.js.map +0 -1
- package/dist/ui/primitives.mjs +0 -3227
- package/dist/ui/primitives.mjs.map +0 -1
- package/dist/user/index.d.mts +0 -228
- package/dist/user/index.d.ts +0 -228
- package/dist/user/index.js +0 -4306
- package/dist/user/index.js.map +0 -1
- package/dist/user/index.mjs +0 -4260
- package/dist/user/index.mjs.map +0 -1
- package/dist/utils/index.d.mts +0 -205
- package/dist/utils/index.d.ts +0 -205
- package/dist/utils/index.js +0 -574
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/index.mjs +0 -514
- package/dist/utils/index.mjs.map +0 -1
- package/dist/workflow/index.d.mts +0 -40
- package/dist/workflow/index.d.ts +0 -40
- package/dist/workflow/index.js +0 -3710
- package/dist/workflow/index.js.map +0 -1
- package/dist/workflow/index.mjs +0 -3677
- package/dist/workflow/index.mjs.map +0 -1
package/dist/index-50hpiPrV.d.ts
DELETED
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import { DynamicIconNameType, NavigationType, DensityType, SettingsType } from './types/index.js';
|
|
3
|
-
import { ReactNode } from 'react';
|
|
4
|
-
import { b as TenantContextValue } from './tenant-provider-B8eC_Wpb.js';
|
|
5
|
-
|
|
6
|
-
interface Tab {
|
|
7
|
-
id: string;
|
|
8
|
-
path: string;
|
|
9
|
-
title: string;
|
|
10
|
-
createdAt: number;
|
|
11
|
-
badge?: number | string;
|
|
12
|
-
isLoading?: boolean;
|
|
13
|
-
hasUnsavedChanges?: boolean;
|
|
14
|
-
isPinned?: boolean;
|
|
15
|
-
iconName?: DynamicIconNameType;
|
|
16
|
-
}
|
|
17
|
-
interface TabNavigationContextValue {
|
|
18
|
-
tabs: Tab[];
|
|
19
|
-
activeTabId: string | null;
|
|
20
|
-
addTab: (path: string, title?: string) => void;
|
|
21
|
-
removeTab: (id: string) => void;
|
|
22
|
-
setActiveTab: (id: string) => void;
|
|
23
|
-
clearTabs: () => void;
|
|
24
|
-
removeOtherTabs: (id: string) => void;
|
|
25
|
-
removeTabsToRight: (id: string) => void;
|
|
26
|
-
goToNextTab: () => void;
|
|
27
|
-
goToPreviousTab: () => void;
|
|
28
|
-
goToTabByIndex: (index: number) => void;
|
|
29
|
-
closeAndGoToParent: () => void;
|
|
30
|
-
}
|
|
31
|
-
declare function TabNavigationProvider({ children, navigations, }: {
|
|
32
|
-
children: ReactNode;
|
|
33
|
-
navigations: NavigationType[];
|
|
34
|
-
}): react_jsx_runtime.JSX.Element;
|
|
35
|
-
declare function useTabNavigation(): TabNavigationContextValue;
|
|
36
|
-
|
|
37
|
-
declare function useTenant(): TenantContextValue;
|
|
38
|
-
|
|
39
|
-
declare function useDebounce<T>(value: T, delay: number): T;
|
|
40
|
-
declare function useLocalStorage<T>(key: string, initialValue: T): [T, (value: T | ((prev: T) => T)) => void];
|
|
41
|
-
declare function usePrevious<T>(value: T): T | undefined;
|
|
42
|
-
declare function useToggle(initialValue?: boolean): [boolean, () => void, (value: boolean) => void];
|
|
43
|
-
declare function useMounted(): boolean;
|
|
44
|
-
declare function useMediaQuery(query: string): boolean;
|
|
45
|
-
declare function useMobile(): boolean;
|
|
46
|
-
declare function useCopyToClipboard(): [
|
|
47
|
-
string | null,
|
|
48
|
-
(text: string) => Promise<boolean>
|
|
49
|
-
];
|
|
50
|
-
declare function useSettings(): {
|
|
51
|
-
settings: SettingsType;
|
|
52
|
-
updateSettings: (newSettings: SettingsType) => void;
|
|
53
|
-
resetSettings: () => void;
|
|
54
|
-
};
|
|
55
|
-
declare function useIsVertical(): boolean;
|
|
56
|
-
declare function useIsDarkMode(): boolean;
|
|
57
|
-
declare function useRadius(asPx?: boolean): number;
|
|
58
|
-
declare function useDensity(): DensityType;
|
|
59
|
-
declare function useIsRtl(): boolean;
|
|
60
|
-
declare function useViewMode(storageKey: string, defaultMode?: "table" | "kanban" | "grid"): readonly ["table" | "grid" | "kanban", (mode: "table" | "kanban" | "grid") => void];
|
|
61
|
-
type DictionaryType = any;
|
|
62
|
-
interface DictionaryProviderProps {
|
|
63
|
-
dictionary: DictionaryType;
|
|
64
|
-
children: ReactNode;
|
|
65
|
-
}
|
|
66
|
-
declare function DictionaryProvider({ dictionary, children, }: DictionaryProviderProps): react_jsx_runtime.JSX.Element;
|
|
67
|
-
declare function useDictionary(): any;
|
|
68
|
-
declare function useDictionaryValue(key: string, fallback?: string): string;
|
|
69
|
-
declare function useCrudTranslations(): {
|
|
70
|
-
t: (key: string, _params?: Record<string, string | number>) => Promise<string>;
|
|
71
|
-
tSync: (translations: DictionaryType, key: string, params?: Record<string, string | number>) => string;
|
|
72
|
-
locale: string;
|
|
73
|
-
};
|
|
74
|
-
declare function usePrefetch(): {
|
|
75
|
-
prefetchRoute: (route: string) => void;
|
|
76
|
-
prefetchAPI: (endpoint: string, options?: RequestInit) => void;
|
|
77
|
-
prefetchCrudPage: (entity: string, apiEndpoint: string) => void;
|
|
78
|
-
prefetchNextPage: (apiEndpoint: string, currentPage: number, pageSize: number, queryParams?: Record<string, unknown>) => void;
|
|
79
|
-
};
|
|
80
|
-
interface UseUrlFiltersOptions {
|
|
81
|
-
filters?: {
|
|
82
|
-
search?: string;
|
|
83
|
-
dateRange?: {
|
|
84
|
-
from?: Date;
|
|
85
|
-
to?: Date;
|
|
86
|
-
};
|
|
87
|
-
materialGroups?: string[];
|
|
88
|
-
suppliers?: string[];
|
|
89
|
-
statuses?: string[];
|
|
90
|
-
warehouses?: string[];
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
declare function useUrlFilters(options?: UseUrlFiltersOptions): {
|
|
94
|
-
currentFilters: {
|
|
95
|
-
search: string;
|
|
96
|
-
dateRange: {
|
|
97
|
-
from: Date | undefined;
|
|
98
|
-
to: Date | undefined;
|
|
99
|
-
};
|
|
100
|
-
materialGroups: string[];
|
|
101
|
-
suppliers: string[];
|
|
102
|
-
statuses: string[];
|
|
103
|
-
warehouses: string[];
|
|
104
|
-
};
|
|
105
|
-
updateFilters: (filters: UseUrlFiltersOptions["filters"]) => void;
|
|
106
|
-
clearFilters: () => void;
|
|
107
|
-
};
|
|
108
|
-
|
|
109
|
-
/**
|
|
110
|
-
* Hook to handle back navigation that integrates with the tab system.
|
|
111
|
-
*/
|
|
112
|
-
declare function useTabNavigationBack(): {
|
|
113
|
-
navigateBack: any;
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
export { DictionaryProvider as D, type Tab as T, type DictionaryType as a, TabNavigationProvider as b, useCrudTranslations as c, useDebounce as d, useDensity as e, useDictionary as f, useDictionaryValue as g, useIsDarkMode as h, useIsRtl as i, useIsVertical as j, useLocalStorage as k, useMediaQuery as l, useMobile as m, useMounted as n, usePrefetch as o, usePrevious as p, useRadius as q, useSettings as r, useTabNavigation as s, useTabNavigationBack as t, useCopyToClipboard as u, useTenant as v, useToggle as w, useUrlFilters as x, useViewMode as y };
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import { DynamicIconNameType, NavigationType, DensityType, SettingsType } from './types/index.mjs';
|
|
3
|
-
import { ReactNode } from 'react';
|
|
4
|
-
import { b as TenantContextValue } from './tenant-provider-B8eC_Wpb.mjs';
|
|
5
|
-
|
|
6
|
-
interface Tab {
|
|
7
|
-
id: string;
|
|
8
|
-
path: string;
|
|
9
|
-
title: string;
|
|
10
|
-
createdAt: number;
|
|
11
|
-
badge?: number | string;
|
|
12
|
-
isLoading?: boolean;
|
|
13
|
-
hasUnsavedChanges?: boolean;
|
|
14
|
-
isPinned?: boolean;
|
|
15
|
-
iconName?: DynamicIconNameType;
|
|
16
|
-
}
|
|
17
|
-
interface TabNavigationContextValue {
|
|
18
|
-
tabs: Tab[];
|
|
19
|
-
activeTabId: string | null;
|
|
20
|
-
addTab: (path: string, title?: string) => void;
|
|
21
|
-
removeTab: (id: string) => void;
|
|
22
|
-
setActiveTab: (id: string) => void;
|
|
23
|
-
clearTabs: () => void;
|
|
24
|
-
removeOtherTabs: (id: string) => void;
|
|
25
|
-
removeTabsToRight: (id: string) => void;
|
|
26
|
-
goToNextTab: () => void;
|
|
27
|
-
goToPreviousTab: () => void;
|
|
28
|
-
goToTabByIndex: (index: number) => void;
|
|
29
|
-
closeAndGoToParent: () => void;
|
|
30
|
-
}
|
|
31
|
-
declare function TabNavigationProvider({ children, navigations, }: {
|
|
32
|
-
children: ReactNode;
|
|
33
|
-
navigations: NavigationType[];
|
|
34
|
-
}): react_jsx_runtime.JSX.Element;
|
|
35
|
-
declare function useTabNavigation(): TabNavigationContextValue;
|
|
36
|
-
|
|
37
|
-
declare function useTenant(): TenantContextValue;
|
|
38
|
-
|
|
39
|
-
declare function useDebounce<T>(value: T, delay: number): T;
|
|
40
|
-
declare function useLocalStorage<T>(key: string, initialValue: T): [T, (value: T | ((prev: T) => T)) => void];
|
|
41
|
-
declare function usePrevious<T>(value: T): T | undefined;
|
|
42
|
-
declare function useToggle(initialValue?: boolean): [boolean, () => void, (value: boolean) => void];
|
|
43
|
-
declare function useMounted(): boolean;
|
|
44
|
-
declare function useMediaQuery(query: string): boolean;
|
|
45
|
-
declare function useMobile(): boolean;
|
|
46
|
-
declare function useCopyToClipboard(): [
|
|
47
|
-
string | null,
|
|
48
|
-
(text: string) => Promise<boolean>
|
|
49
|
-
];
|
|
50
|
-
declare function useSettings(): {
|
|
51
|
-
settings: SettingsType;
|
|
52
|
-
updateSettings: (newSettings: SettingsType) => void;
|
|
53
|
-
resetSettings: () => void;
|
|
54
|
-
};
|
|
55
|
-
declare function useIsVertical(): boolean;
|
|
56
|
-
declare function useIsDarkMode(): boolean;
|
|
57
|
-
declare function useRadius(asPx?: boolean): number;
|
|
58
|
-
declare function useDensity(): DensityType;
|
|
59
|
-
declare function useIsRtl(): boolean;
|
|
60
|
-
declare function useViewMode(storageKey: string, defaultMode?: "table" | "kanban" | "grid"): readonly ["table" | "grid" | "kanban", (mode: "table" | "kanban" | "grid") => void];
|
|
61
|
-
type DictionaryType = any;
|
|
62
|
-
interface DictionaryProviderProps {
|
|
63
|
-
dictionary: DictionaryType;
|
|
64
|
-
children: ReactNode;
|
|
65
|
-
}
|
|
66
|
-
declare function DictionaryProvider({ dictionary, children, }: DictionaryProviderProps): react_jsx_runtime.JSX.Element;
|
|
67
|
-
declare function useDictionary(): any;
|
|
68
|
-
declare function useDictionaryValue(key: string, fallback?: string): string;
|
|
69
|
-
declare function useCrudTranslations(): {
|
|
70
|
-
t: (key: string, _params?: Record<string, string | number>) => Promise<string>;
|
|
71
|
-
tSync: (translations: DictionaryType, key: string, params?: Record<string, string | number>) => string;
|
|
72
|
-
locale: string;
|
|
73
|
-
};
|
|
74
|
-
declare function usePrefetch(): {
|
|
75
|
-
prefetchRoute: (route: string) => void;
|
|
76
|
-
prefetchAPI: (endpoint: string, options?: RequestInit) => void;
|
|
77
|
-
prefetchCrudPage: (entity: string, apiEndpoint: string) => void;
|
|
78
|
-
prefetchNextPage: (apiEndpoint: string, currentPage: number, pageSize: number, queryParams?: Record<string, unknown>) => void;
|
|
79
|
-
};
|
|
80
|
-
interface UseUrlFiltersOptions {
|
|
81
|
-
filters?: {
|
|
82
|
-
search?: string;
|
|
83
|
-
dateRange?: {
|
|
84
|
-
from?: Date;
|
|
85
|
-
to?: Date;
|
|
86
|
-
};
|
|
87
|
-
materialGroups?: string[];
|
|
88
|
-
suppliers?: string[];
|
|
89
|
-
statuses?: string[];
|
|
90
|
-
warehouses?: string[];
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
declare function useUrlFilters(options?: UseUrlFiltersOptions): {
|
|
94
|
-
currentFilters: {
|
|
95
|
-
search: string;
|
|
96
|
-
dateRange: {
|
|
97
|
-
from: Date | undefined;
|
|
98
|
-
to: Date | undefined;
|
|
99
|
-
};
|
|
100
|
-
materialGroups: string[];
|
|
101
|
-
suppliers: string[];
|
|
102
|
-
statuses: string[];
|
|
103
|
-
warehouses: string[];
|
|
104
|
-
};
|
|
105
|
-
updateFilters: (filters: UseUrlFiltersOptions["filters"]) => void;
|
|
106
|
-
clearFilters: () => void;
|
|
107
|
-
};
|
|
108
|
-
|
|
109
|
-
/**
|
|
110
|
-
* Hook to handle back navigation that integrates with the tab system.
|
|
111
|
-
*/
|
|
112
|
-
declare function useTabNavigationBack(): {
|
|
113
|
-
navigateBack: any;
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
export { DictionaryProvider as D, type Tab as T, type DictionaryType as a, TabNavigationProvider as b, useCrudTranslations as c, useDebounce as d, useDensity as e, useDictionary as f, useDictionaryValue as g, useIsDarkMode as h, useIsRtl as i, useIsVertical as j, useLocalStorage as k, useMediaQuery as l, useMobile as m, useMounted as n, usePrefetch as o, usePrevious as p, useRadius as q, useSettings as r, useTabNavigation as s, useTabNavigationBack as t, useCopyToClipboard as u, useTenant as v, useToggle as w, useUrlFilters as x, useViewMode as y };
|
package/dist/index.d.mts
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export { FeatureConfig, ModuleManifest, ModuleRegistry, NavigationItem, registry } from './system/index.mjs';
|
|
2
|
-
export { ActionFilters, ActiveFilter, CodeGenerationConfig, CrudFeatures, CrudPermissions, CrudQueryParams, CrudResponse, DataSource, DensityType, DirectionType, DynamicIconNameType, EntityConfig, ExportOptions, FieldAction, FieldCalculate, FieldCascade, FieldConfig, FieldDependencies, FieldFormat, FieldHelp, FieldShowWhen, FieldTransform, FieldType, FileType, FilterConfig, FilterOperator, FilterType, ForgotPasswordFormType, FormModeConfig, FormSection, FormatStyleType, IconProps, IconType, ImportOptions, ImportResult, LayoutType, LocaleType, ModeType, NavigationNestedItem, NavigationNestedItemBasicType, NavigationNestedItemWithHrefType, NavigationNestedItemWithItemsType, NavigationRootItem, NavigationRootItemBasicType, NavigationRootItemWithHrefType, NavigationRootItemWithItemsType, NavigationType, NewPasswordFormType, NotificationType, OAuthLinkType, OrientationType, Permission, PermissionMatrix, PermissionType, RadiusType, RegisterFormType, ResourceFilters, RouteType, RowAction, SearchGroup, SearchResultItem, SettingsType, SidebarCollapsibleType, SidebarVariantType, SignInFormType, SortingState, ThemeType, UomFilters, UserType, ValidationRule, VerifyEmailFormType, WarehouseFilters, radii, supportedLocales, supportedThemes } from './types/index.mjs';
|
|
3
|
-
import 'lucide-react';
|
|
4
|
-
import 'react';
|
|
5
|
-
import 'zod';
|
package/dist/index.d.ts
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export { FeatureConfig, ModuleManifest, ModuleRegistry, NavigationItem, registry } from './system/index.js';
|
|
2
|
-
export { ActionFilters, ActiveFilter, CodeGenerationConfig, CrudFeatures, CrudPermissions, CrudQueryParams, CrudResponse, DataSource, DensityType, DirectionType, DynamicIconNameType, EntityConfig, ExportOptions, FieldAction, FieldCalculate, FieldCascade, FieldConfig, FieldDependencies, FieldFormat, FieldHelp, FieldShowWhen, FieldTransform, FieldType, FileType, FilterConfig, FilterOperator, FilterType, ForgotPasswordFormType, FormModeConfig, FormSection, FormatStyleType, IconProps, IconType, ImportOptions, ImportResult, LayoutType, LocaleType, ModeType, NavigationNestedItem, NavigationNestedItemBasicType, NavigationNestedItemWithHrefType, NavigationNestedItemWithItemsType, NavigationRootItem, NavigationRootItemBasicType, NavigationRootItemWithHrefType, NavigationRootItemWithItemsType, NavigationType, NewPasswordFormType, NotificationType, OAuthLinkType, OrientationType, Permission, PermissionMatrix, PermissionType, RadiusType, RegisterFormType, ResourceFilters, RouteType, RowAction, SearchGroup, SearchResultItem, SettingsType, SidebarCollapsibleType, SidebarVariantType, SignInFormType, SortingState, ThemeType, UomFilters, UserType, ValidationRule, VerifyEmailFormType, WarehouseFilters, radii, supportedLocales, supportedThemes } from './types/index.js';
|
|
3
|
-
import 'lucide-react';
|
|
4
|
-
import 'react';
|
|
5
|
-
import 'zod';
|
package/dist/index.js
DELETED
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
// src/system/index.ts
|
|
4
|
-
var ModuleRegistry = class {
|
|
5
|
-
constructor() {
|
|
6
|
-
this.modules = /* @__PURE__ */ new Map();
|
|
7
|
-
this.initialized = false;
|
|
8
|
-
}
|
|
9
|
-
/**
|
|
10
|
-
* Register a module with the registry
|
|
11
|
-
*/
|
|
12
|
-
register(manifest) {
|
|
13
|
-
if (this.modules.has(manifest.name)) {
|
|
14
|
-
console.warn(
|
|
15
|
-
`Module "${manifest.name}" is already registered. Skipping.`
|
|
16
|
-
);
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
if (manifest.depends) {
|
|
20
|
-
for (const dep of manifest.depends) {
|
|
21
|
-
if (dep !== "@goerp/core" && !this.modules.has(dep)) {
|
|
22
|
-
console.warn(
|
|
23
|
-
`Module "${manifest.name}" depends on "${dep}" which is not registered yet.`
|
|
24
|
-
);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
this.modules.set(manifest.name, manifest);
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Get all registered modules
|
|
32
|
-
*/
|
|
33
|
-
getModules() {
|
|
34
|
-
return Array.from(this.modules.values());
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Get a specific module by name
|
|
38
|
-
*/
|
|
39
|
-
getModule(name) {
|
|
40
|
-
return this.modules.get(name);
|
|
41
|
-
}
|
|
42
|
-
/**
|
|
43
|
-
* Get combined navigation from all modules
|
|
44
|
-
*/
|
|
45
|
-
getNavigation() {
|
|
46
|
-
const items = [];
|
|
47
|
-
for (const manifest of this.modules.values()) {
|
|
48
|
-
if (manifest.navigation) {
|
|
49
|
-
items.push(...manifest.navigation);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
return items;
|
|
53
|
-
}
|
|
54
|
-
/**
|
|
55
|
-
* Get all permissions from all modules
|
|
56
|
-
*/
|
|
57
|
-
getPermissions() {
|
|
58
|
-
const permissions = [];
|
|
59
|
-
for (const manifest of this.modules.values()) {
|
|
60
|
-
if (manifest.permissions) {
|
|
61
|
-
permissions.push(...manifest.permissions);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
return permissions;
|
|
65
|
-
}
|
|
66
|
-
/**
|
|
67
|
-
* Get all entities from all modules
|
|
68
|
-
*/
|
|
69
|
-
getEntities() {
|
|
70
|
-
const entities = [];
|
|
71
|
-
for (const manifest of this.modules.values()) {
|
|
72
|
-
if (manifest.entities) {
|
|
73
|
-
entities.push(...manifest.entities);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
return entities;
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* Check if registry is initialized
|
|
80
|
-
*/
|
|
81
|
-
isInitialized() {
|
|
82
|
-
return this.initialized;
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Mark registry as initialized
|
|
86
|
-
*/
|
|
87
|
-
markInitialized() {
|
|
88
|
-
this.initialized = true;
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Clear all registered modules (useful for testing)
|
|
92
|
-
*/
|
|
93
|
-
clear() {
|
|
94
|
-
this.modules.clear();
|
|
95
|
-
this.initialized = false;
|
|
96
|
-
}
|
|
97
|
-
};
|
|
98
|
-
var registry = new ModuleRegistry();
|
|
99
|
-
|
|
100
|
-
// src/types/index.ts
|
|
101
|
-
var supportedLocales = ["vi", "en"];
|
|
102
|
-
var supportedThemes = [
|
|
103
|
-
"zinc",
|
|
104
|
-
"slate",
|
|
105
|
-
"stone",
|
|
106
|
-
"gray",
|
|
107
|
-
"neutral",
|
|
108
|
-
"red",
|
|
109
|
-
"rose",
|
|
110
|
-
"orange",
|
|
111
|
-
"green",
|
|
112
|
-
"blue",
|
|
113
|
-
"yellow",
|
|
114
|
-
"violet"
|
|
115
|
-
];
|
|
116
|
-
var radii = [0, 0.3, 0.5, 0.75, 1];
|
|
117
|
-
|
|
118
|
-
exports.radii = radii;
|
|
119
|
-
exports.registry = registry;
|
|
120
|
-
exports.supportedLocales = supportedLocales;
|
|
121
|
-
exports.supportedThemes = supportedThemes;
|
|
122
|
-
//# sourceMappingURL=index.js.map
|
|
123
|
-
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/system/index.ts","../src/types/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["// @goerp/core/system\n// Module registry, manifest loader, and core system utilities\n\nexport interface ModuleManifest {\n /** Unique module identifier */\n name: string;\n /** Semantic version */\n version: string;\n /** Module category (e.g., 'Supply Chain', 'HR', 'Sales') */\n category?: string;\n /** Human-readable description */\n description?: string;\n /** Module dependencies */\n depends?: string[];\n /** Entities registered by this module */\n entities?: string[];\n /** Navigation items */\n navigation?: NavigationItem[];\n /** Permissions defined by this module */\n permissions?: string[];\n /** Feature flags */\n features?: Record<string, FeatureConfig>;\n}\n\nexport interface NavigationItem {\n label: string;\n icon?: string;\n path?: string;\n children?: NavigationItem[];\n permission?: string;\n}\n\nexport interface FeatureConfig {\n enabled: boolean;\n component?: React.ComponentType<any>;\n}\n\n/**\n * Module Registry - Central registry for all modules\n */\nclass ModuleRegistry {\n private modules = new Map<string, ModuleManifest>();\n private initialized = false;\n\n /**\n * Register a module with the registry\n */\n register(manifest: ModuleManifest): void {\n if (this.modules.has(manifest.name)) {\n console.warn(\n `Module \"${manifest.name}\" is already registered. Skipping.`,\n );\n return;\n }\n\n // Validate dependencies\n if (manifest.depends) {\n for (const dep of manifest.depends) {\n if (dep !== \"@goerp/core\" && !this.modules.has(dep)) {\n console.warn(\n `Module \"${manifest.name}\" depends on \"${dep}\" which is not registered yet.`,\n );\n }\n }\n }\n\n this.modules.set(manifest.name, manifest);\n }\n\n /**\n * Get all registered modules\n */\n getModules(): ModuleManifest[] {\n return Array.from(this.modules.values());\n }\n\n /**\n * Get a specific module by name\n */\n getModule(name: string): ModuleManifest | undefined {\n return this.modules.get(name);\n }\n\n /**\n * Get combined navigation from all modules\n */\n getNavigation(): NavigationItem[] {\n const items: NavigationItem[] = [];\n for (const manifest of this.modules.values()) {\n if (manifest.navigation) {\n items.push(...manifest.navigation);\n }\n }\n return items;\n }\n\n /**\n * Get all permissions from all modules\n */\n getPermissions(): string[] {\n const permissions: string[] = [];\n for (const manifest of this.modules.values()) {\n if (manifest.permissions) {\n permissions.push(...manifest.permissions);\n }\n }\n return permissions;\n }\n\n /**\n * Get all entities from all modules\n */\n getEntities(): string[] {\n const entities: string[] = [];\n for (const manifest of this.modules.values()) {\n if (manifest.entities) {\n entities.push(...manifest.entities);\n }\n }\n return entities;\n }\n\n /**\n * Check if registry is initialized\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Mark registry as initialized\n */\n markInitialized(): void {\n this.initialized = true;\n }\n\n /**\n * Clear all registered modules (useful for testing)\n */\n clear(): void {\n this.modules.clear();\n this.initialized = false;\n }\n}\n\n// Singleton registry instance\nexport const registry = new ModuleRegistry();\n\n// Export types\nexport type { ModuleRegistry };\n","// @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"]}
|
package/dist/index.mjs
DELETED
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
// src/system/index.ts
|
|
2
|
-
var ModuleRegistry = class {
|
|
3
|
-
constructor() {
|
|
4
|
-
this.modules = /* @__PURE__ */ new Map();
|
|
5
|
-
this.initialized = false;
|
|
6
|
-
}
|
|
7
|
-
/**
|
|
8
|
-
* Register a module with the registry
|
|
9
|
-
*/
|
|
10
|
-
register(manifest) {
|
|
11
|
-
if (this.modules.has(manifest.name)) {
|
|
12
|
-
console.warn(
|
|
13
|
-
`Module "${manifest.name}" is already registered. Skipping.`
|
|
14
|
-
);
|
|
15
|
-
return;
|
|
16
|
-
}
|
|
17
|
-
if (manifest.depends) {
|
|
18
|
-
for (const dep of manifest.depends) {
|
|
19
|
-
if (dep !== "@goerp/core" && !this.modules.has(dep)) {
|
|
20
|
-
console.warn(
|
|
21
|
-
`Module "${manifest.name}" depends on "${dep}" which is not registered yet.`
|
|
22
|
-
);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
this.modules.set(manifest.name, manifest);
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Get all registered modules
|
|
30
|
-
*/
|
|
31
|
-
getModules() {
|
|
32
|
-
return Array.from(this.modules.values());
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Get a specific module by name
|
|
36
|
-
*/
|
|
37
|
-
getModule(name) {
|
|
38
|
-
return this.modules.get(name);
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Get combined navigation from all modules
|
|
42
|
-
*/
|
|
43
|
-
getNavigation() {
|
|
44
|
-
const items = [];
|
|
45
|
-
for (const manifest of this.modules.values()) {
|
|
46
|
-
if (manifest.navigation) {
|
|
47
|
-
items.push(...manifest.navigation);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
return items;
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Get all permissions from all modules
|
|
54
|
-
*/
|
|
55
|
-
getPermissions() {
|
|
56
|
-
const permissions = [];
|
|
57
|
-
for (const manifest of this.modules.values()) {
|
|
58
|
-
if (manifest.permissions) {
|
|
59
|
-
permissions.push(...manifest.permissions);
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
return permissions;
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Get all entities from all modules
|
|
66
|
-
*/
|
|
67
|
-
getEntities() {
|
|
68
|
-
const entities = [];
|
|
69
|
-
for (const manifest of this.modules.values()) {
|
|
70
|
-
if (manifest.entities) {
|
|
71
|
-
entities.push(...manifest.entities);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
return entities;
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* Check if registry is initialized
|
|
78
|
-
*/
|
|
79
|
-
isInitialized() {
|
|
80
|
-
return this.initialized;
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Mark registry as initialized
|
|
84
|
-
*/
|
|
85
|
-
markInitialized() {
|
|
86
|
-
this.initialized = true;
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* Clear all registered modules (useful for testing)
|
|
90
|
-
*/
|
|
91
|
-
clear() {
|
|
92
|
-
this.modules.clear();
|
|
93
|
-
this.initialized = false;
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
var registry = new ModuleRegistry();
|
|
97
|
-
|
|
98
|
-
// src/types/index.ts
|
|
99
|
-
var supportedLocales = ["vi", "en"];
|
|
100
|
-
var supportedThemes = [
|
|
101
|
-
"zinc",
|
|
102
|
-
"slate",
|
|
103
|
-
"stone",
|
|
104
|
-
"gray",
|
|
105
|
-
"neutral",
|
|
106
|
-
"red",
|
|
107
|
-
"rose",
|
|
108
|
-
"orange",
|
|
109
|
-
"green",
|
|
110
|
-
"blue",
|
|
111
|
-
"yellow",
|
|
112
|
-
"violet"
|
|
113
|
-
];
|
|
114
|
-
var radii = [0, 0.3, 0.5, 0.75, 1];
|
|
115
|
-
|
|
116
|
-
export { radii, registry, supportedLocales, supportedThemes };
|
|
117
|
-
//# sourceMappingURL=index.mjs.map
|
|
118
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/system/index.ts","../src/types/index.ts"],"names":[],"mappings":"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","file":"index.mjs","sourcesContent":["// @goerp/core/system\n// Module registry, manifest loader, and core system utilities\n\nexport interface ModuleManifest {\n /** Unique module identifier */\n name: string;\n /** Semantic version */\n version: string;\n /** Module category (e.g., 'Supply Chain', 'HR', 'Sales') */\n category?: string;\n /** Human-readable description */\n description?: string;\n /** Module dependencies */\n depends?: string[];\n /** Entities registered by this module */\n entities?: string[];\n /** Navigation items */\n navigation?: NavigationItem[];\n /** Permissions defined by this module */\n permissions?: string[];\n /** Feature flags */\n features?: Record<string, FeatureConfig>;\n}\n\nexport interface NavigationItem {\n label: string;\n icon?: string;\n path?: string;\n children?: NavigationItem[];\n permission?: string;\n}\n\nexport interface FeatureConfig {\n enabled: boolean;\n component?: React.ComponentType<any>;\n}\n\n/**\n * Module Registry - Central registry for all modules\n */\nclass ModuleRegistry {\n private modules = new Map<string, ModuleManifest>();\n private initialized = false;\n\n /**\n * Register a module with the registry\n */\n register(manifest: ModuleManifest): void {\n if (this.modules.has(manifest.name)) {\n console.warn(\n `Module \"${manifest.name}\" is already registered. Skipping.`,\n );\n return;\n }\n\n // Validate dependencies\n if (manifest.depends) {\n for (const dep of manifest.depends) {\n if (dep !== \"@goerp/core\" && !this.modules.has(dep)) {\n console.warn(\n `Module \"${manifest.name}\" depends on \"${dep}\" which is not registered yet.`,\n );\n }\n }\n }\n\n this.modules.set(manifest.name, manifest);\n }\n\n /**\n * Get all registered modules\n */\n getModules(): ModuleManifest[] {\n return Array.from(this.modules.values());\n }\n\n /**\n * Get a specific module by name\n */\n getModule(name: string): ModuleManifest | undefined {\n return this.modules.get(name);\n }\n\n /**\n * Get combined navigation from all modules\n */\n getNavigation(): NavigationItem[] {\n const items: NavigationItem[] = [];\n for (const manifest of this.modules.values()) {\n if (manifest.navigation) {\n items.push(...manifest.navigation);\n }\n }\n return items;\n }\n\n /**\n * Get all permissions from all modules\n */\n getPermissions(): string[] {\n const permissions: string[] = [];\n for (const manifest of this.modules.values()) {\n if (manifest.permissions) {\n permissions.push(...manifest.permissions);\n }\n }\n return permissions;\n }\n\n /**\n * Get all entities from all modules\n */\n getEntities(): string[] {\n const entities: string[] = [];\n for (const manifest of this.modules.values()) {\n if (manifest.entities) {\n entities.push(...manifest.entities);\n }\n }\n return entities;\n }\n\n /**\n * Check if registry is initialized\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Mark registry as initialized\n */\n markInitialized(): void {\n this.initialized = true;\n }\n\n /**\n * Clear all registered modules (useful for testing)\n */\n clear(): void {\n this.modules.clear();\n this.initialized = false;\n }\n}\n\n// Singleton registry instance\nexport const registry = new ModuleRegistry();\n\n// Export types\nexport type { ModuleRegistry };\n","// @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"]}
|