@g4rcez/components 0.0.1
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/.idea/bigweld.iml +12 -0
- package/.idea/codeStyles/Project.xml +72 -0
- package/.idea/codeStyles/codeStyleConfig.xml +5 -0
- package/.idea/inspectionProfiles/Project_Default.xml +30 -0
- package/.idea/jsLibraryMappings.xml +6 -0
- package/.idea/modules.xml +8 -0
- package/.idea/prettier.xml +7 -0
- package/.idea/reason.xml +6 -0
- package/.idea/vcs.xml +6 -0
- package/.prettierrc.json +13 -0
- package/README.md +35 -0
- package/app/client-table.tsx +35 -0
- package/app/favicon.ico +0 -0
- package/app/layout.tsx +39 -0
- package/app/page.tsx +72 -0
- package/dist/components/core/button.d.ts +21 -0
- package/dist/components/core/button.d.ts.map +1 -0
- package/dist/components/core/polymorph.d.ts +10 -0
- package/dist/components/core/polymorph.d.ts.map +1 -0
- package/dist/components/display/card.d.ts +4 -0
- package/dist/components/display/card.d.ts.map +1 -0
- package/dist/components/floating/dropdown.d.ts +11 -0
- package/dist/components/floating/dropdown.d.ts.map +1 -0
- package/dist/components/floating/tooltip.d.ts +9 -0
- package/dist/components/floating/tooltip.d.ts.map +1 -0
- package/dist/components/form/autocomplete.d.ts +16 -0
- package/dist/components/form/autocomplete.d.ts.map +1 -0
- package/dist/components/form/file-upload.d.ts +12 -0
- package/dist/components/form/file-upload.d.ts.map +1 -0
- package/dist/components/form/form.d.ts +4 -0
- package/dist/components/form/form.d.ts.map +1 -0
- package/dist/components/form/input-field.d.ts +25 -0
- package/dist/components/form/input-field.d.ts.map +1 -0
- package/dist/components/form/input.d.ts +9 -0
- package/dist/components/form/input.d.ts.map +1 -0
- package/dist/components/form/select.d.ts +11 -0
- package/dist/components/form/select.d.ts.map +1 -0
- package/dist/components/form/switch.d.ts +7 -0
- package/dist/components/form/switch.d.ts.map +1 -0
- package/dist/components/index.d.ts +15 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/table/filter.d.ts +70 -0
- package/dist/components/table/filter.d.ts.map +1 -0
- package/dist/components/table/group.d.ts +17 -0
- package/dist/components/table/group.d.ts.map +1 -0
- package/dist/components/table/index.d.ts +28 -0
- package/dist/components/table/index.d.ts.map +1 -0
- package/dist/components/table/metadata.d.ts +3 -0
- package/dist/components/table/metadata.d.ts.map +1 -0
- package/dist/components/table/sort.d.ts +28 -0
- package/dist/components/table/sort.d.ts.map +1 -0
- package/dist/components/table/table-lib.d.ts +99 -0
- package/dist/components/table/table-lib.d.ts.map +1 -0
- package/dist/components/table/thead.d.ts +7 -0
- package/dist/components/table/thead.d.ts.map +1 -0
- package/dist/hooks/use-form.d.ts +28 -0
- package/dist/hooks/use-form.d.ts.map +1 -0
- package/dist/hooks/use-previous.d.ts +2 -0
- package/dist/hooks/use-previous.d.ts.map +1 -0
- package/dist/hooks/use-reactive.d.ts +2 -0
- package/dist/hooks/use-reactive.d.ts.map +1 -0
- package/dist/index.css +1670 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.mjs +21864 -0
- package/dist/index.mjs.map +1 -0
- package/dist/index.umd.js +151 -0
- package/dist/index.umd.js.map +1 -0
- package/dist/lib/dom.d.ts +6 -0
- package/dist/lib/dom.d.ts.map +1 -0
- package/dist/lib/fns.d.ts +5 -0
- package/dist/lib/fns.d.ts.map +1 -0
- package/dist/next.svg +1 -0
- package/dist/styles/design-tokens.d.ts +26 -0
- package/dist/styles/design-tokens.d.ts.map +1 -0
- package/dist/tailwind.config.d.ts +32 -0
- package/dist/tailwind.config.d.ts.map +1 -0
- package/dist/tailwind.config.js +153 -0
- package/dist/types.d.ts +9 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/vercel.svg +1 -0
- package/docs/README.md +36 -0
- package/docs/next.config.mjs +4 -0
- package/docs/package.json +28 -0
- package/docs/pnpm-lock.yaml +1030 -0
- package/docs/postcss.config.mjs +8 -0
- package/docs/public/next.svg +1 -0
- package/docs/public/vercel.svg +1 -0
- package/docs/src/app/favicon.ico +0 -0
- package/docs/src/app/globals.css +33 -0
- package/docs/src/app/layout.tsx +22 -0
- package/docs/src/app/page.tsx +10 -0
- package/docs/tailwind.config.ts +15 -0
- package/docs/tsconfig.json +26 -0
- package/next-env.d.ts +5 -0
- package/next.config.mjs +4 -0
- package/package.json +72 -0
- package/postcss.config.mjs +8 -0
- package/public/next.svg +1 -0
- package/public/vercel.svg +1 -0
- package/src/components/core/button.tsx +91 -0
- package/src/components/core/polymorph.tsx +17 -0
- package/src/components/display/card.tsx +8 -0
- package/src/components/floating/dropdown.tsx +93 -0
- package/src/components/floating/tooltip.tsx +67 -0
- package/src/components/form/autocomplete.tsx +222 -0
- package/src/components/form/file-upload.tsx +129 -0
- package/src/components/form/form.tsx +28 -0
- package/src/components/form/input-field.tsx +105 -0
- package/src/components/form/input.tsx +73 -0
- package/src/components/form/select.tsx +58 -0
- package/src/components/form/switch.tsx +40 -0
- package/src/components/index.ts +14 -0
- package/src/components/table/filter.tsx +186 -0
- package/src/components/table/group.tsx +123 -0
- package/src/components/table/index.tsx +207 -0
- package/src/components/table/metadata.tsx +55 -0
- package/src/components/table/sort.tsx +141 -0
- package/src/components/table/table-lib.ts +130 -0
- package/src/components/table/thead.tsx +108 -0
- package/src/hooks/use-form.ts +155 -0
- package/src/hooks/use-previous.ts +9 -0
- package/src/hooks/use-reactive.ts +10 -0
- package/src/index.css +37 -0
- package/src/index.ts +6 -0
- package/src/lib/dom.ts +27 -0
- package/src/lib/fns.ts +23 -0
- package/src/styles/dark.json +66 -0
- package/src/styles/design-tokens.ts +57 -0
- package/src/styles/light.json +49 -0
- package/src/types.ts +11 -0
- package/styles.config.ts +42 -0
- package/tailwind.config.ts +11 -0
- package/tsconfig.json +55 -0
- package/tsconfig.lib.json +50 -0
- package/tsconfig.lib.tsbuildinfo +1 -0
- package/tsconfig.tailwind.json +32 -0
- package/tsconfig.tsbuildinfo +1 -0
- package/vite.config.mts +39 -0
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Label } from "~/types";
|
|
3
|
+
import { Col, ColType, TableConfiguration } from "./table-lib";
|
|
4
|
+
declare const operators: {
|
|
5
|
+
contains: {
|
|
6
|
+
value: string;
|
|
7
|
+
label: string;
|
|
8
|
+
symbol: "includes";
|
|
9
|
+
};
|
|
10
|
+
is: {
|
|
11
|
+
value: string;
|
|
12
|
+
label: string;
|
|
13
|
+
symbol: "is";
|
|
14
|
+
};
|
|
15
|
+
isNot: {
|
|
16
|
+
value: string;
|
|
17
|
+
label: string;
|
|
18
|
+
symbol: "!==";
|
|
19
|
+
};
|
|
20
|
+
notContains: {
|
|
21
|
+
value: string;
|
|
22
|
+
label: string;
|
|
23
|
+
symbol: "notIncludes";
|
|
24
|
+
};
|
|
25
|
+
lessThan: {
|
|
26
|
+
value: string;
|
|
27
|
+
label: string;
|
|
28
|
+
symbol: "<=";
|
|
29
|
+
};
|
|
30
|
+
greaterThan: {
|
|
31
|
+
value: string;
|
|
32
|
+
label: string;
|
|
33
|
+
symbol: ">=";
|
|
34
|
+
};
|
|
35
|
+
startsWith: {
|
|
36
|
+
value: string;
|
|
37
|
+
label: string;
|
|
38
|
+
symbol: "startsWith";
|
|
39
|
+
};
|
|
40
|
+
endsWith: {
|
|
41
|
+
value: string;
|
|
42
|
+
label: string;
|
|
43
|
+
symbol: "endsWith";
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
type Operator = keyof typeof operators;
|
|
47
|
+
type Operators = (typeof operators)[Operator];
|
|
48
|
+
type FilterValue = string | number | string[] | boolean;
|
|
49
|
+
export type FilterConfig<T extends {} = {}> = {
|
|
50
|
+
id: string;
|
|
51
|
+
label: Label;
|
|
52
|
+
name: keyof T;
|
|
53
|
+
type: ColType;
|
|
54
|
+
operation: Operators;
|
|
55
|
+
value: FilterValue;
|
|
56
|
+
};
|
|
57
|
+
type Props<T extends {}> = TableConfiguration<T, {
|
|
58
|
+
cols: Col<T>[];
|
|
59
|
+
filters: FilterConfig<T>[];
|
|
60
|
+
set: React.Dispatch<React.SetStateAction<FilterConfig<T>[]>>;
|
|
61
|
+
}>;
|
|
62
|
+
export declare const createFilterFromCol: <T extends {}>(f: Col<T>, rest?: Partial<FilterConfig<T>>) => FilterConfig<T>;
|
|
63
|
+
export declare const Filter: <T extends {}>(props: Props<T>) => import("react/jsx-runtime").JSX.Element;
|
|
64
|
+
type ColumnHeaderFilterProps<T extends {}> = {
|
|
65
|
+
filter: FilterConfig<T>;
|
|
66
|
+
set: React.Dispatch<React.SetStateAction<FilterConfig<T>[]>>;
|
|
67
|
+
};
|
|
68
|
+
export declare const ColumnHeaderFilter: <T extends {}>({ filter, set }: ColumnHeaderFilterProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
69
|
+
export {};
|
|
70
|
+
//# sourceMappingURL=filter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../../src/components/table/filter.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAKxC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,GAAG,EAAE,OAAO,EAAY,kBAAkB,EAAiB,MAAM,aAAa,CAAC;AAExF,QAAA,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAS8C,CAAC;AAE9D,KAAK,QAAQ,GAAG,MAAM,OAAO,SAAS,CAAC;AAEvC,KAAK,SAAS,GAAG,CAAC,OAAO,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC;AAQ9C,KAAK,WAAW,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,OAAO,CAAC;AAExD,MAAM,MAAM,YAAY,CAAC,CAAC,SAAS,EAAE,GAAG,EAAE,IAAI;IAC1C,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,KAAK,CAAC;IACb,IAAI,EAAE,MAAM,CAAC,CAAC;IACd,IAAI,EAAE,OAAO,CAAC;IACd,SAAS,EAAE,SAAS,CAAC;IACrB,KAAK,EAAE,WAAW,CAAC;CACtB,CAAC;AAEF,KAAK,KAAK,CAAC,CAAC,SAAS,EAAE,IAAI,kBAAkB,CACzC,CAAC,EACD;IACI,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACf,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;IAC3B,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CAChE,CACJ,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,CAAC,SAAS,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,SAAQ,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,KAAQ,YAAY,CAAC,CAAC,CAMhH,CAAC;AAEF,eAAO,MAAM,MAAM,GAAI,CAAC,SAAS,EAAE,SAAS,KAAK,CAAC,CAAC,CAAC,4CA8FnD,CAAC;AAEF,KAAK,uBAAuB,CAAC,CAAC,SAAS,EAAE,IAAI;IACzC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;IACxB,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CAChE,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,CAAC,SAAS,EAAE,mBAAmB,uBAAuB,CAAC,CAAC,CAAC,4CAyB3F,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Col, TableConfiguration } from "./table-lib";
|
|
3
|
+
export type GroupItem<T extends {}> = Col<T> & {
|
|
4
|
+
rows: T[];
|
|
5
|
+
index: number;
|
|
6
|
+
groupId: string;
|
|
7
|
+
groupName: string;
|
|
8
|
+
groupKey: keyof T;
|
|
9
|
+
};
|
|
10
|
+
type Props<T extends {}> = TableConfiguration<T, {
|
|
11
|
+
rows: T[];
|
|
12
|
+
groups: GroupItem<T>[];
|
|
13
|
+
setGroups: React.Dispatch<React.SetStateAction<GroupItem<T>[]>>;
|
|
14
|
+
}>;
|
|
15
|
+
export declare const Group: <T extends {}>(props: Props<T>) => import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=group.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"group.d.ts","sourceRoot":"","sources":["../../../src/components/table/group.tsx"],"names":[],"mappings":"AAIA,OAAO,KAA6B,MAAM,OAAO,CAAC;AAMlD,OAAO,EAAE,GAAG,EAAoB,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAExE,MAAM,MAAM,SAAS,CAAC,CAAC,SAAS,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG;IAC3C,IAAI,EAAE,CAAC,EAAE,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC,CAAC;CACrB,CAAC;AAEF,KAAK,KAAK,CAAC,CAAC,SAAS,EAAE,IAAI,kBAAkB,CACzC,CAAC,EACD;IACI,IAAI,EAAE,CAAC,EAAE,CAAC;IACV,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;IACvB,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CACnE,CACJ,CAAC;AAqBF,eAAO,MAAM,KAAK,GAAI,CAAC,SAAS,EAAE,SAAS,KAAK,CAAC,CAAC,CAAC,4CA0ElD,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import React, { HTMLAttributes } from "react";
|
|
2
|
+
import { OptionProps } from "~/components/form/select";
|
|
3
|
+
import { FilterConfig } from "./filter";
|
|
4
|
+
import { GroupItem } from "./group";
|
|
5
|
+
import { Sorter } from "./sort";
|
|
6
|
+
import { Col, TableOperationProps } from "./table-lib";
|
|
7
|
+
type InnerTableProps<T extends {}> = HTMLAttributes<HTMLTableElement> & TableOperationProps<T> & {
|
|
8
|
+
loading?: boolean;
|
|
9
|
+
group?: GroupItem<T>;
|
|
10
|
+
groups?: GroupItem<T>[];
|
|
11
|
+
optionCols: OptionProps[];
|
|
12
|
+
index: number;
|
|
13
|
+
rows: T[];
|
|
14
|
+
cols: Col<T>[];
|
|
15
|
+
sorters?: Sorter<T>[];
|
|
16
|
+
showMetadata?: boolean;
|
|
17
|
+
filters?: FilterConfig<T>[];
|
|
18
|
+
setGroups: React.Dispatch<React.SetStateAction<GroupItem<T>[]>>;
|
|
19
|
+
};
|
|
20
|
+
export type TableProps<T extends {}> = Pick<InnerTableProps<T>, "cols" | "rows"> & {
|
|
21
|
+
name: string;
|
|
22
|
+
} & Partial<TableOperationProps<T> & {
|
|
23
|
+
reference: keyof T;
|
|
24
|
+
loading: boolean;
|
|
25
|
+
}>;
|
|
26
|
+
export declare const Table: <T extends {}>(props: TableProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/table/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,EAAY,cAAc,EAAW,MAAM,OAAO,CAAC;AAIjE,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEpC,OAAO,EAAa,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC3C,OAAO,EAAoB,GAAG,EAA+B,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAGtG,KAAK,eAAe,CAAC,CAAC,SAAS,EAAE,IAAI,cAAc,CAAC,gBAAgB,CAAC,GACjE,mBAAmB,CAAC,CAAC,CAAC,GAAG;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;IACrB,MAAM,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;IACxB,UAAU,EAAE,WAAW,EAAE,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,CAAC,EAAE,CAAC;IACV,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;IACtB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,OAAO,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;IAC5B,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CACnE,CAAC;AAiFN,MAAM,MAAM,UAAU,CAAC,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,GAAG;IAC/E,IAAI,EAAE,MAAM,CAAC;CAChB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,GAAG;IAAE,SAAS,EAAE,MAAM,CAAC,CAAC;IAAC,OAAO,EAAE,OAAO,CAAA;CAAE,CAAC,CAAC;AAO/E,eAAO,MAAM,KAAK,GAAI,CAAC,SAAS,EAAE,SAAS,UAAU,CAAC,CAAC,CAAC,4CAwFvD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.d.ts","sourceRoot":"","sources":["../../../src/components/table/metadata.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,mBAAmB,EAAiB,MAAM,aAAa,CAAC;AAEjE,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,EAAE,SAAS,mBAAmB,CAAC,CAAC,CAAC,4CAiDnE,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Label } from "~/types";
|
|
3
|
+
import { Col, TableConfiguration, TableOperationProps } from "./table-lib";
|
|
4
|
+
type Keyof<T extends {}> = keyof T extends infer R extends string ? R : never;
|
|
5
|
+
declare enum Order {
|
|
6
|
+
Asc = "asc",
|
|
7
|
+
Desc = "desc",
|
|
8
|
+
Undefined = "undefined"
|
|
9
|
+
}
|
|
10
|
+
export type Sorter<T extends {}> = {
|
|
11
|
+
value: Keyof<T>;
|
|
12
|
+
type: Order;
|
|
13
|
+
label: Label;
|
|
14
|
+
id: string;
|
|
15
|
+
};
|
|
16
|
+
export declare const multiSort: <T extends {}>(array: T[], fields: Sorter<T>[]) => T[];
|
|
17
|
+
type Props<T extends {}> = TableConfiguration<T, {
|
|
18
|
+
cols: Col<T>[];
|
|
19
|
+
sorters: Sorter<T>[];
|
|
20
|
+
set: React.Dispatch<React.SetStateAction<Sorter<T>[]>>;
|
|
21
|
+
}>;
|
|
22
|
+
export declare const Sort: <T extends {}>(props: Props<T>) => import("react/jsx-runtime").JSX.Element;
|
|
23
|
+
type SorterHeadProps<T extends {}> = Pick<TableOperationProps<T>, "sorters" | "setSorters"> & {
|
|
24
|
+
col: Col<T>;
|
|
25
|
+
};
|
|
26
|
+
export declare const SorterHead: <T extends {}>(props: SorterHeadProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=sort.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sort.d.ts","sourceRoot":"","sources":["../../../src/components/table/sort.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAwC,MAAM,OAAO,CAAC;AAI7D,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,GAAG,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAE3E,KAAK,KAAK,CAAC,CAAC,SAAS,EAAE,IAAI,MAAM,CAAC,SAAS,MAAM,CAAC,SAAS,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC;AAE9E,aAAK,KAAK;IACN,GAAG,QAAQ;IACX,IAAI,SAAS;IACb,SAAS,cAAc;CAC1B;AAED,MAAM,MAAM,MAAM,CAAC,CAAC,SAAS,EAAE,IAAI;IAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;IAAC,IAAI,EAAE,KAAK,CAAC;IAAC,KAAK,EAAE,KAAK,CAAC;IAAC,EAAE,EAAE,MAAM,CAAA;CAAE,CAAC;AAY9F,eAAO,MAAM,SAAS,GAAI,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,CAAC,CAAC,EAAE,QAAuC,CAAC;AAS/G,KAAK,KAAK,CAAC,CAAC,SAAS,EAAE,IAAI,kBAAkB,CACzC,CAAC,EACD;IACI,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACf,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;IACrB,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CAC1D,CACJ,CAAC;AASF,eAAO,MAAM,IAAI,GAAI,CAAC,SAAS,EAAE,SAAS,KAAK,CAAC,CAAC,CAAC,4CA2DjD,CAAC;AAEF,KAAK,eAAe,CAAC,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,SAAS,GAAG,YAAY,CAAC,GAAG;IAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAA;CAAE,CAAC;AAE9G,eAAO,MAAM,UAAU,GAAI,CAAC,SAAS,EAAE,SAAS,eAAe,CAAC,CAAC,CAAC,4CAuBjE,CAAC"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { OptionProps } from "~/components/form/select";
|
|
3
|
+
import { POJO, SetState } from "~/types";
|
|
4
|
+
import { FilterConfig } from "./filter";
|
|
5
|
+
import { GroupItem } from "./group";
|
|
6
|
+
import { Sorter } from "./sort";
|
|
7
|
+
export declare const getLabel: <T extends {}>(col: Col<T>) => string | number | boolean | React.ReactElement<any, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode>;
|
|
8
|
+
export type TableConfiguration<T extends {}, M extends {} = {}> = M & {
|
|
9
|
+
cols: Col<T>[];
|
|
10
|
+
options: OptionProps[];
|
|
11
|
+
};
|
|
12
|
+
export declare const createOptionCols: <T extends {}>(cols: Col<T>[]) => OptionProps[];
|
|
13
|
+
export declare enum ColType {
|
|
14
|
+
Boolean = "boolean",
|
|
15
|
+
Number = "number",
|
|
16
|
+
Select = "select",
|
|
17
|
+
Text = "text"
|
|
18
|
+
}
|
|
19
|
+
export declare const valueFromType: (input: HTMLInputElement) => string | number;
|
|
20
|
+
type THead = React.ReactElement | React.ReactNode;
|
|
21
|
+
export type ColMatrix = `${number},${number}`;
|
|
22
|
+
export type CellPropsElement<T extends {}, K extends keyof T> = {
|
|
23
|
+
row: T;
|
|
24
|
+
value: T[K];
|
|
25
|
+
rowIndex: number;
|
|
26
|
+
matrix: ColMatrix;
|
|
27
|
+
col: ColOptions<T, K> & {
|
|
28
|
+
id: K;
|
|
29
|
+
thead: THead;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
type ColOptions<T extends {}, K extends keyof T> = Partial<{
|
|
33
|
+
cellProps: React.HTMLAttributes<HTMLTableCellElement>;
|
|
34
|
+
thProps: React.HTMLAttributes<HTMLTableCellElement>;
|
|
35
|
+
type: ColType;
|
|
36
|
+
headerLabel: string;
|
|
37
|
+
allowFilter: boolean;
|
|
38
|
+
Element: (props: CellPropsElement<T, K>) => React.ReactNode;
|
|
39
|
+
}>;
|
|
40
|
+
export type ColConstructor<T extends {}> = {
|
|
41
|
+
remove: <K extends keyof T>(id: K) => void;
|
|
42
|
+
add: <K extends keyof T>(id: K, thead: THead, props?: ColOptions<T, K>) => void;
|
|
43
|
+
};
|
|
44
|
+
declare const cols: <T extends POJO>() => <K extends keyof T>(id: K, thead: THead, options: ColOptions<T, K>) => {
|
|
45
|
+
id: K;
|
|
46
|
+
thead: THead;
|
|
47
|
+
cellProps?: React.HTMLAttributes<HTMLTableCellElement> | undefined;
|
|
48
|
+
thProps?: React.HTMLAttributes<HTMLTableCellElement> | undefined;
|
|
49
|
+
type?: ColType | undefined;
|
|
50
|
+
headerLabel?: string | undefined;
|
|
51
|
+
allowFilter?: boolean | undefined;
|
|
52
|
+
Element?: ((props: CellPropsElement<T, K>) => React.ReactNode) | undefined;
|
|
53
|
+
};
|
|
54
|
+
export type Col<T extends {}> = ReturnType<ReturnType<typeof cols<T>>>;
|
|
55
|
+
type TableGetters<T extends POJO> = {
|
|
56
|
+
rows: T[];
|
|
57
|
+
cols: Col<T>[];
|
|
58
|
+
groups: GroupItem<T>[];
|
|
59
|
+
sorters: Sorter<T>[];
|
|
60
|
+
filters: FilterConfig<T>[];
|
|
61
|
+
};
|
|
62
|
+
type TableSetters<T extends POJO> = {
|
|
63
|
+
setCols: SetState<Col<T>[]>;
|
|
64
|
+
setSorters: SetState<Sorter<T>[]>;
|
|
65
|
+
setGroups: SetState<GroupItem<T>[]>;
|
|
66
|
+
setFilters: SetState<FilterConfig<T>[]>;
|
|
67
|
+
};
|
|
68
|
+
export type TableOperationProps<T extends {}> = TableConfiguration<T, TableSetters<T> & TableGetters<T> & {
|
|
69
|
+
set?: (v: TableGetters<T>) => void;
|
|
70
|
+
}>;
|
|
71
|
+
export declare const createColumns: <T extends {}>(callback: (o: ColConstructor<T>) => void) => {
|
|
72
|
+
id: keyof T;
|
|
73
|
+
thead: THead;
|
|
74
|
+
cellProps?: React.HTMLAttributes<HTMLTableCellElement> | undefined;
|
|
75
|
+
thProps?: React.HTMLAttributes<HTMLTableCellElement> | undefined;
|
|
76
|
+
type?: ColType | undefined;
|
|
77
|
+
headerLabel?: string | undefined;
|
|
78
|
+
allowFilter?: boolean | undefined;
|
|
79
|
+
Element?: ((props: CellPropsElement<T, keyof T>) => React.ReactNode) | undefined;
|
|
80
|
+
}[];
|
|
81
|
+
export declare const useTablePreferences: <T extends POJO>(name: string, options?: Partial<TableGetters<T>>) => {
|
|
82
|
+
name: string;
|
|
83
|
+
set: (getters: TableGetters<T>) => void;
|
|
84
|
+
cols: {
|
|
85
|
+
id: keyof T;
|
|
86
|
+
thead: THead;
|
|
87
|
+
cellProps?: React.HTMLAttributes<HTMLTableCellElement> | undefined;
|
|
88
|
+
thProps?: React.HTMLAttributes<HTMLTableCellElement> | undefined;
|
|
89
|
+
type?: ColType | undefined;
|
|
90
|
+
headerLabel?: string | undefined;
|
|
91
|
+
allowFilter?: boolean | undefined;
|
|
92
|
+
Element?: ((props: CellPropsElement<T, keyof T>) => React.ReactNode) | undefined;
|
|
93
|
+
}[];
|
|
94
|
+
groups: GroupItem<T>[];
|
|
95
|
+
sorters: Sorter<T>[];
|
|
96
|
+
filters: FilterConfig<T>[];
|
|
97
|
+
};
|
|
98
|
+
export {};
|
|
99
|
+
//# sourceMappingURL=table-lib.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-lib.d.ts","sourceRoot":"","sources":["../../../src/components/table/table-lib.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Col, TableOperationProps } from "./table-lib";
|
|
2
|
+
type TableHeaderProps<T extends {}> = {
|
|
3
|
+
headers: Col<T>[];
|
|
4
|
+
} & Pick<TableOperationProps<T>, "filters" | "setFilters" | "setCols" | "setSorters" | "sorters">;
|
|
5
|
+
export declare const TableHeader: <T extends {}>(props: TableHeaderProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
export {};
|
|
7
|
+
//# sourceMappingURL=thead.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"thead.d.ts","sourceRoot":"","sources":["../../../src/components/table/thead.tsx"],"names":[],"mappings":"AAMA,OAAO,EAAE,GAAG,EAAY,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEjE,KAAK,gBAAgB,CAAC,CAAC,SAAS,EAAE,IAAI;IAClC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;CACrB,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,SAAS,GAAG,YAAY,GAAG,SAAS,GAAG,YAAY,GAAG,SAAS,CAAC,CAAC;AAgElG,eAAO,MAAM,WAAW,GAAI,CAAC,SAAS,EAAE,SAAS,gBAAgB,CAAC,CAAC,CAAC,4CAiCnE,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { AllPaths } from "sidekicker";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
import { InputProps } from "~/components/form/input";
|
|
5
|
+
import { SelectProps } from "~/components/form/select";
|
|
6
|
+
export declare const formToJson: (form: HTMLFormElement) => any;
|
|
7
|
+
export declare const convertPath: (path: string) => string[];
|
|
8
|
+
export declare const getSchemaShape: <T extends z.ZodObject<any>>(name: string, schema: T) => T;
|
|
9
|
+
type CustomOnInvalid = (args: {
|
|
10
|
+
form: HTMLFormElement;
|
|
11
|
+
errors: Record<string, string>;
|
|
12
|
+
}) => any;
|
|
13
|
+
type CustomOnSubmit<T> = (args: {
|
|
14
|
+
json: T;
|
|
15
|
+
form: HTMLFormElement;
|
|
16
|
+
reset: () => void;
|
|
17
|
+
event: React.FormEvent<HTMLFormElement>;
|
|
18
|
+
}) => any;
|
|
19
|
+
export declare const useForm: <T extends z.ZodObject<any>>(schema: T) => {
|
|
20
|
+
input: <Props extends InputProps>(name: AllPaths<z.infer<T>>, props?: Props) => Props;
|
|
21
|
+
select: <Props extends SelectProps>(name: AllPaths<z.infer<T>>, props?: Props) => Props;
|
|
22
|
+
onSubmit: (exec: CustomOnSubmit<z.infer<T>>) => (event: React.FormEvent<HTMLFormElement>) => void;
|
|
23
|
+
errors: Record<string, string | undefined> | null;
|
|
24
|
+
onInvalid: (exec?: CustomOnInvalid) => (event: React.FormEvent<HTMLFormElement>) => void;
|
|
25
|
+
disabled: boolean;
|
|
26
|
+
};
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=use-form.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-form.d.ts","sourceRoot":"","sources":["../../src/hooks/use-form.ts"],"names":[],"mappings":"AACA,OAAO,KAAmD,MAAM,OAAO,CAAC;AACxE,OAAO,EAAE,QAAQ,EAAe,MAAM,YAAY,CAAC;AACnD,OAAO,EAAE,CAAC,EAAuB,MAAM,KAAK,CAAC;AAE7C,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAiBvD,eAAO,MAAM,UAAU,SAAU,eAAe,KAAG,GAIlD,CAAC;AAEF,eAAO,MAAM,WAAW,SAAU,MAAM,aAAuD,CAAC;AAEhG,eAAO,MAAM,cAAc,GAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,MAAM,UAAU,CAAC,MAKpE,CAAC;AAQf,KAAK,eAAe,GAAG,CAAC,IAAI,EAAE;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CAAE,KAAK,GAAG,CAAC;AAEhG,KAAK,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE;IAAE,IAAI,EAAE,CAAC,CAAC;IAAC,IAAI,EAAE,eAAe,CAAC;IAAC,KAAK,EAAE,MAAM,IAAI,CAAC;IAAC,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC,eAAe,CAAC,CAAA;CAAE,KAAK,GAAG,CAAC;AAEvI,eAAO,MAAM,OAAO,GAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC;YAkB1C,KAAK,SAAS,UAAU,QAAQ,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,KAAK,KAAG,KAAK;aAd1E,KAAK,SAAS,WAAW,QAAQ,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,KAAK,KAAG,KAAK;qBAkFjF,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,aAAa,KAAK,CAAC,SAAS,CAAC,eAAe,CAAC;;uBAnBtE,eAAe,aAAa,KAAK,CAAC,SAAS,CAAC,eAAe,CAAC;;CAuC3E,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-previous.d.ts","sourceRoot":"","sources":["../../src/hooks/use-previous.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,WAAW,GAAI,CAAC,SAAS,CAAC,KAAG,CAMzC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-reactive.d.ts","sourceRoot":"","sources":["../../src/hooks/use-reactive.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,WAAW,GAAI,CAAC,SAAS,OAAO,KAAK,CAAC,YAAY,CAAC,8EAM/D,CAAC"}
|