@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.
Files changed (139) hide show
  1. package/.idea/bigweld.iml +12 -0
  2. package/.idea/codeStyles/Project.xml +72 -0
  3. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  4. package/.idea/inspectionProfiles/Project_Default.xml +30 -0
  5. package/.idea/jsLibraryMappings.xml +6 -0
  6. package/.idea/modules.xml +8 -0
  7. package/.idea/prettier.xml +7 -0
  8. package/.idea/reason.xml +6 -0
  9. package/.idea/vcs.xml +6 -0
  10. package/.prettierrc.json +13 -0
  11. package/README.md +35 -0
  12. package/app/client-table.tsx +35 -0
  13. package/app/favicon.ico +0 -0
  14. package/app/layout.tsx +39 -0
  15. package/app/page.tsx +72 -0
  16. package/dist/components/core/button.d.ts +21 -0
  17. package/dist/components/core/button.d.ts.map +1 -0
  18. package/dist/components/core/polymorph.d.ts +10 -0
  19. package/dist/components/core/polymorph.d.ts.map +1 -0
  20. package/dist/components/display/card.d.ts +4 -0
  21. package/dist/components/display/card.d.ts.map +1 -0
  22. package/dist/components/floating/dropdown.d.ts +11 -0
  23. package/dist/components/floating/dropdown.d.ts.map +1 -0
  24. package/dist/components/floating/tooltip.d.ts +9 -0
  25. package/dist/components/floating/tooltip.d.ts.map +1 -0
  26. package/dist/components/form/autocomplete.d.ts +16 -0
  27. package/dist/components/form/autocomplete.d.ts.map +1 -0
  28. package/dist/components/form/file-upload.d.ts +12 -0
  29. package/dist/components/form/file-upload.d.ts.map +1 -0
  30. package/dist/components/form/form.d.ts +4 -0
  31. package/dist/components/form/form.d.ts.map +1 -0
  32. package/dist/components/form/input-field.d.ts +25 -0
  33. package/dist/components/form/input-field.d.ts.map +1 -0
  34. package/dist/components/form/input.d.ts +9 -0
  35. package/dist/components/form/input.d.ts.map +1 -0
  36. package/dist/components/form/select.d.ts +11 -0
  37. package/dist/components/form/select.d.ts.map +1 -0
  38. package/dist/components/form/switch.d.ts +7 -0
  39. package/dist/components/form/switch.d.ts.map +1 -0
  40. package/dist/components/index.d.ts +15 -0
  41. package/dist/components/index.d.ts.map +1 -0
  42. package/dist/components/table/filter.d.ts +70 -0
  43. package/dist/components/table/filter.d.ts.map +1 -0
  44. package/dist/components/table/group.d.ts +17 -0
  45. package/dist/components/table/group.d.ts.map +1 -0
  46. package/dist/components/table/index.d.ts +28 -0
  47. package/dist/components/table/index.d.ts.map +1 -0
  48. package/dist/components/table/metadata.d.ts +3 -0
  49. package/dist/components/table/metadata.d.ts.map +1 -0
  50. package/dist/components/table/sort.d.ts +28 -0
  51. package/dist/components/table/sort.d.ts.map +1 -0
  52. package/dist/components/table/table-lib.d.ts +99 -0
  53. package/dist/components/table/table-lib.d.ts.map +1 -0
  54. package/dist/components/table/thead.d.ts +7 -0
  55. package/dist/components/table/thead.d.ts.map +1 -0
  56. package/dist/hooks/use-form.d.ts +28 -0
  57. package/dist/hooks/use-form.d.ts.map +1 -0
  58. package/dist/hooks/use-previous.d.ts +2 -0
  59. package/dist/hooks/use-previous.d.ts.map +1 -0
  60. package/dist/hooks/use-reactive.d.ts +2 -0
  61. package/dist/hooks/use-reactive.d.ts.map +1 -0
  62. package/dist/index.css +1670 -0
  63. package/dist/index.d.ts +7 -0
  64. package/dist/index.d.ts.map +1 -0
  65. package/dist/index.mjs +21864 -0
  66. package/dist/index.mjs.map +1 -0
  67. package/dist/index.umd.js +151 -0
  68. package/dist/index.umd.js.map +1 -0
  69. package/dist/lib/dom.d.ts +6 -0
  70. package/dist/lib/dom.d.ts.map +1 -0
  71. package/dist/lib/fns.d.ts +5 -0
  72. package/dist/lib/fns.d.ts.map +1 -0
  73. package/dist/next.svg +1 -0
  74. package/dist/styles/design-tokens.d.ts +26 -0
  75. package/dist/styles/design-tokens.d.ts.map +1 -0
  76. package/dist/tailwind.config.d.ts +32 -0
  77. package/dist/tailwind.config.d.ts.map +1 -0
  78. package/dist/tailwind.config.js +153 -0
  79. package/dist/types.d.ts +9 -0
  80. package/dist/types.d.ts.map +1 -0
  81. package/dist/vercel.svg +1 -0
  82. package/docs/README.md +36 -0
  83. package/docs/next.config.mjs +4 -0
  84. package/docs/package.json +28 -0
  85. package/docs/pnpm-lock.yaml +1030 -0
  86. package/docs/postcss.config.mjs +8 -0
  87. package/docs/public/next.svg +1 -0
  88. package/docs/public/vercel.svg +1 -0
  89. package/docs/src/app/favicon.ico +0 -0
  90. package/docs/src/app/globals.css +33 -0
  91. package/docs/src/app/layout.tsx +22 -0
  92. package/docs/src/app/page.tsx +10 -0
  93. package/docs/tailwind.config.ts +15 -0
  94. package/docs/tsconfig.json +26 -0
  95. package/next-env.d.ts +5 -0
  96. package/next.config.mjs +4 -0
  97. package/package.json +72 -0
  98. package/postcss.config.mjs +8 -0
  99. package/public/next.svg +1 -0
  100. package/public/vercel.svg +1 -0
  101. package/src/components/core/button.tsx +91 -0
  102. package/src/components/core/polymorph.tsx +17 -0
  103. package/src/components/display/card.tsx +8 -0
  104. package/src/components/floating/dropdown.tsx +93 -0
  105. package/src/components/floating/tooltip.tsx +67 -0
  106. package/src/components/form/autocomplete.tsx +222 -0
  107. package/src/components/form/file-upload.tsx +129 -0
  108. package/src/components/form/form.tsx +28 -0
  109. package/src/components/form/input-field.tsx +105 -0
  110. package/src/components/form/input.tsx +73 -0
  111. package/src/components/form/select.tsx +58 -0
  112. package/src/components/form/switch.tsx +40 -0
  113. package/src/components/index.ts +14 -0
  114. package/src/components/table/filter.tsx +186 -0
  115. package/src/components/table/group.tsx +123 -0
  116. package/src/components/table/index.tsx +207 -0
  117. package/src/components/table/metadata.tsx +55 -0
  118. package/src/components/table/sort.tsx +141 -0
  119. package/src/components/table/table-lib.ts +130 -0
  120. package/src/components/table/thead.tsx +108 -0
  121. package/src/hooks/use-form.ts +155 -0
  122. package/src/hooks/use-previous.ts +9 -0
  123. package/src/hooks/use-reactive.ts +10 -0
  124. package/src/index.css +37 -0
  125. package/src/index.ts +6 -0
  126. package/src/lib/dom.ts +27 -0
  127. package/src/lib/fns.ts +23 -0
  128. package/src/styles/dark.json +66 -0
  129. package/src/styles/design-tokens.ts +57 -0
  130. package/src/styles/light.json +49 -0
  131. package/src/types.ts +11 -0
  132. package/styles.config.ts +42 -0
  133. package/tailwind.config.ts +11 -0
  134. package/tsconfig.json +55 -0
  135. package/tsconfig.lib.json +50 -0
  136. package/tsconfig.lib.tsbuildinfo +1 -0
  137. package/tsconfig.tailwind.json +32 -0
  138. package/tsconfig.tsbuildinfo +1 -0
  139. 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,3 @@
1
+ import { TableOperationProps } from "./table-lib";
2
+ export declare const Metadata: <T extends {}>(props: TableOperationProps<T>) => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=metadata.d.ts.map
@@ -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,2 @@
1
+ export declare const usePrevious: <T>(value: T) => T;
2
+ //# sourceMappingURL=use-previous.d.ts.map
@@ -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,2 @@
1
+ export declare const useReactive: <T extends unknown>(t: T, initial?: T) => readonly [T, import("react").Dispatch<import("react").SetStateAction<T>>];
2
+ //# sourceMappingURL=use-reactive.d.ts.map
@@ -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"}