@dappworks/kit 0.5.34 → 0.5.35
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/dist/{PromiseState-DVdsif1j.d.ts → PromiseState-e64b3707.d.ts} +1 -1
- package/dist/{StorageState-qapaHguM.d.ts → StorageState-cfd942cb.d.ts} +1 -1
- package/dist/aiem.d.mts +1 -1
- package/dist/aiem.mjs +5 -5
- package/dist/{chunk-2BZKMJZX.mjs → chunk-2N4HH4ZF.mjs} +1 -1
- package/dist/chunk-2N4HH4ZF.mjs.map +1 -0
- package/dist/{chunk-R66SHRQE.mjs → chunk-GKAU4P5I.mjs} +2 -2
- package/dist/chunk-GKAU4P5I.mjs.map +1 -0
- package/dist/{chunk-SA53R6TL.mjs → chunk-IDKGZ5T4.mjs} +7 -7
- package/dist/chunk-IDKGZ5T4.mjs.map +1 -0
- package/dist/{chunk-7EL2RQI7.mjs → chunk-IMOLRP7I.mjs} +1 -1
- package/dist/chunk-IMOLRP7I.mjs.map +1 -0
- package/dist/{chunk-2PD23V7H.mjs → chunk-K7LFG5BA.mjs} +1 -1
- package/dist/{chunk-2PD23V7H.mjs.map → chunk-K7LFG5BA.mjs.map} +1 -1
- package/dist/{chunk-BAXWSAXB.mjs → chunk-MPOMTIDB.mjs} +21 -22
- package/dist/chunk-MPOMTIDB.mjs.map +1 -0
- package/dist/{chunk-FWK5VZHE.mjs → chunk-OBMZXW6O.mjs} +4 -4
- package/dist/chunk-OBMZXW6O.mjs.map +1 -0
- package/dist/{chunk-Z3LJE5QF.mjs → chunk-ONVPCAMQ.mjs} +1 -1
- package/dist/chunk-ONVPCAMQ.mjs.map +1 -0
- package/dist/{chunk-WWCB4WOQ.mjs → chunk-PGS2TG3C.mjs} +3 -3
- package/dist/chunk-PGS2TG3C.mjs.map +1 -0
- package/dist/{chunk-BQSQ4L7R.mjs → chunk-PHQTFYZL.mjs} +2 -2
- package/dist/chunk-PHQTFYZL.mjs.map +1 -0
- package/dist/{chunk-7WJMHFRA.mjs → chunk-R4N52NI2.mjs} +2 -2
- package/dist/chunk-R4N52NI2.mjs.map +1 -0
- package/dist/{chunk-4KRVA5CB.mjs → chunk-RU6ZML4R.mjs} +33 -29
- package/dist/chunk-RU6ZML4R.mjs.map +1 -0
- package/dist/{chunk-I2RSE63R.mjs → chunk-SL5OV6OR.mjs} +3 -3
- package/dist/chunk-SL5OV6OR.mjs.map +1 -0
- package/dist/{chunk-2L5EKCYR.mjs → chunk-VNT5YQS6.mjs} +6 -6
- package/dist/chunk-VNT5YQS6.mjs.map +1 -0
- package/dist/{chunk-VIK2VI34.mjs → chunk-YITAUACR.mjs} +1 -1
- package/dist/dev.d.mts +1 -1
- package/dist/dev.mjs +4 -4
- package/dist/dev.mjs.map +1 -1
- package/dist/experimental.d.mts +5 -5
- package/dist/experimental.mjs +5 -5
- package/dist/experimental.mjs.map +1 -1
- package/dist/form.d.mts +3 -3
- package/dist/form.mjs +6 -6
- package/dist/form.mjs.map +1 -1
- package/dist/{index-CUKoRIdy.d.ts → index-38be834f.d.ts} +1 -1
- package/dist/index.d.mts +5 -5
- package/dist/index.mjs +12 -12
- package/dist/inspector.d.mts +1 -1
- package/dist/inspector.mjs +1 -1
- package/dist/inspector.mjs.map +1 -1
- package/dist/jsoncomponent.d.mts +1 -1
- package/dist/jsoncomponent.mjs +1 -1
- package/dist/jsoncomponent.mjs.map +1 -1
- package/dist/jsontable.d.mts +2 -2
- package/dist/jsontable.mjs +6 -6
- package/dist/metrics.d.mts +1 -1
- package/dist/metrics.mjs +6 -6
- package/dist/metrics.mjs.map +1 -1
- package/dist/plugins.d.mts +3 -3
- package/dist/plugins.mjs +9 -9
- package/dist/plugins.mjs.map +1 -1
- package/dist/{root-BPMUmS6H.d.ts → root-218afa4f.d.ts} +1 -1
- package/dist/ui.mjs +3 -3
- package/dist/ui.mjs.map +1 -1
- package/dist/utils.mjs +4 -4
- package/dist/wallet.d.mts +3 -3
- package/dist/wallet.mjs +13 -13
- package/dist/wallet.mjs.map +1 -1
- package/package.json +173 -173
- package/dist/chunk-2BZKMJZX.mjs.map +0 -1
- package/dist/chunk-2L5EKCYR.mjs.map +0 -1
- package/dist/chunk-4KRVA5CB.mjs.map +0 -1
- package/dist/chunk-7EL2RQI7.mjs.map +0 -1
- package/dist/chunk-7WJMHFRA.mjs.map +0 -1
- package/dist/chunk-BAXWSAXB.mjs.map +0 -1
- package/dist/chunk-BQSQ4L7R.mjs.map +0 -1
- package/dist/chunk-FWK5VZHE.mjs.map +0 -1
- package/dist/chunk-I2RSE63R.mjs.map +0 -1
- package/dist/chunk-R66SHRQE.mjs.map +0 -1
- package/dist/chunk-SA53R6TL.mjs.map +0 -1
- package/dist/chunk-WWCB4WOQ.mjs.map +0 -1
- package/dist/chunk-Z3LJE5QF.mjs.map +0 -1
- /package/dist/{PaginationState-Bmrrw0ky.d.ts → PaginationState-c19e621a.d.ts} +0 -0
- /package/dist/{chunk-VIK2VI34.mjs.map → chunk-YITAUACR.mjs.map} +0 -0
package/package.json
CHANGED
|
@@ -1,174 +1,174 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@dappworks/kit",
|
|
3
|
-
"version": "0.5.
|
|
4
|
-
"description": "",
|
|
5
|
-
"main": "./dist/index.mjs",
|
|
6
|
-
"types": "./dist/index.d.mts",
|
|
7
|
-
"module": "./dist/index.mjs",
|
|
8
|
-
"files": [
|
|
9
|
-
"dist"
|
|
10
|
-
],
|
|
11
|
-
"directories": {
|
|
12
|
-
"lib": "lib"
|
|
13
|
-
},
|
|
14
|
-
"exports": {
|
|
15
|
-
".": {
|
|
16
|
-
"import": "./dist/index.mjs",
|
|
17
|
-
"require": "./dist/index.js"
|
|
18
|
-
},
|
|
19
|
-
"./wallet": {
|
|
20
|
-
"import": "./dist/wallet.mjs",
|
|
21
|
-
"require": "./dist/wallet.js"
|
|
22
|
-
},
|
|
23
|
-
"./metrics": {
|
|
24
|
-
"import": "./dist/metrics.mjs",
|
|
25
|
-
"require": "./dist/metrics.js"
|
|
26
|
-
},
|
|
27
|
-
"./form": {
|
|
28
|
-
"import": "./dist/form.mjs",
|
|
29
|
-
"require": "./dist/form.js"
|
|
30
|
-
},
|
|
31
|
-
"./plugins": {
|
|
32
|
-
"import": "./dist/plugins.mjs",
|
|
33
|
-
"require": "./dist/plugins.js"
|
|
34
|
-
},
|
|
35
|
-
"./dev": {
|
|
36
|
-
"import": "./dist/dev.mjs",
|
|
37
|
-
"require": "./dist/dev.js"
|
|
38
|
-
},
|
|
39
|
-
"./ui": {
|
|
40
|
-
"import": "./dist/ui.mjs",
|
|
41
|
-
"require": "./dist/ui.js"
|
|
42
|
-
},
|
|
43
|
-
"./inspector": {
|
|
44
|
-
"import": "./dist/inspector.mjs",
|
|
45
|
-
"require": "./dist/inspector.js"
|
|
46
|
-
},
|
|
47
|
-
"./jsontable": {
|
|
48
|
-
"import": "./dist/jsontable.mjs",
|
|
49
|
-
"require": "./dist/jsontable.js"
|
|
50
|
-
},
|
|
51
|
-
"./experimental": {
|
|
52
|
-
"import": "./dist/experimental.mjs",
|
|
53
|
-
"require": "./dist/experimental.js"
|
|
54
|
-
},
|
|
55
|
-
"./aiem": {
|
|
56
|
-
"import": "./dist/aiem.mjs",
|
|
57
|
-
"require": "./dist/aiem.js"
|
|
58
|
-
},
|
|
59
|
-
"./utils": {
|
|
60
|
-
"import": "./dist/utils.mjs",
|
|
61
|
-
"require": "./dist/utils.js"
|
|
62
|
-
},
|
|
63
|
-
"./jsoncomponent": {
|
|
64
|
-
"import": "./dist/jsoncomponent.mjs",
|
|
65
|
-
"require": "./dist/jsoncomponent.js"
|
|
66
|
-
}
|
|
67
|
-
},
|
|
68
|
-
"typesVersions": {
|
|
69
|
-
"*": {
|
|
70
|
-
".": [
|
|
71
|
-
"./dist/index.d.mts"
|
|
72
|
-
],
|
|
73
|
-
"wallet": [
|
|
74
|
-
"./dist/wallet.d.mts"
|
|
75
|
-
],
|
|
76
|
-
"metrics": [
|
|
77
|
-
"./dist/metrics.d.mts"
|
|
78
|
-
],
|
|
79
|
-
"form": [
|
|
80
|
-
"./dist/form.d.mts"
|
|
81
|
-
],
|
|
82
|
-
"plugins": [
|
|
83
|
-
"./dist/plugins.d.mts"
|
|
84
|
-
],
|
|
85
|
-
"dev": [
|
|
86
|
-
"./dist/dev.d.mts"
|
|
87
|
-
],
|
|
88
|
-
"ui": [
|
|
89
|
-
"./dist/ui.d.mts"
|
|
90
|
-
],
|
|
91
|
-
"inspector": [
|
|
92
|
-
"./dist/inspector.d.mts"
|
|
93
|
-
],
|
|
94
|
-
"jsontable": [
|
|
95
|
-
"./dist/jsontable.d.mts"
|
|
96
|
-
],
|
|
97
|
-
"experimental": [
|
|
98
|
-
"./dist/experimental.d.mts"
|
|
99
|
-
],
|
|
100
|
-
"aiem": [
|
|
101
|
-
"./dist/aiem.d.mts"
|
|
102
|
-
],
|
|
103
|
-
"utils": [
|
|
104
|
-
"./dist/utils.d.mts"
|
|
105
|
-
],
|
|
106
|
-
"jsoncomponent": [
|
|
107
|
-
"./dist/jsoncomponent.d.mts"
|
|
108
|
-
]
|
|
109
|
-
}
|
|
110
|
-
},
|
|
111
|
-
"scripts": {
|
|
112
|
-
"dev": "npm run build -- --watch",
|
|
113
|
-
"test": "echo \"Error: no test specified\" && exit 1",
|
|
114
|
-
"build": "tsup --format esm --dts",
|
|
115
|
-
"prepublishOnly": "npm run build"
|
|
116
|
-
},
|
|
117
|
-
"peerDependencies": {
|
|
118
|
-
"@iconify/react": ">=5.0.2",
|
|
119
|
-
"@iotexproject/iotex-address-ts": "^1.0.4",
|
|
120
|
-
"@monaco-editor/react": ">=4.0.0",
|
|
121
|
-
"@nextui-org/react": ">=2.4.8",
|
|
122
|
-
"@radix-ui/react-dialog": ">=1.0.0",
|
|
123
|
-
"@radix-ui/react-dropdown-menu": "^2.0.5",
|
|
124
|
-
"@rainbow-me/rainbowkit": ">=2.1.5",
|
|
125
|
-
"@rjsf/core": ">=5.19.4",
|
|
126
|
-
"@rjsf/utils": ">=5.19.4",
|
|
127
|
-
"@rjsf/validator-ajv8": ">=5.19.4",
|
|
128
|
-
"@safe-global/safe-apps-sdk": ">=9.1.0",
|
|
129
|
-
"@tanstack/react-query": ">=5.45.1",
|
|
130
|
-
"@tremor/react": ">=3.0.0",
|
|
131
|
-
"axios": ">=1.4.0",
|
|
132
|
-
"bignumber.js": ">=9.0.0",
|
|
133
|
-
"class-variance-authority": ">=0.7.0",
|
|
134
|
-
"copy-to-clipboard": ">=3.0.0",
|
|
135
|
-
"dataloader": ">=2.0.0",
|
|
136
|
-
"dexie": ">=3.0.0",
|
|
137
|
-
"fast-json-patch": ">3.0.0",
|
|
138
|
-
"json-format": ">=1.0.0",
|
|
139
|
-
"lodash-es": ">=4.17.21",
|
|
140
|
-
"lucide-react": ">=0.343.0",
|
|
141
|
-
"mobx": ">=6.0.0",
|
|
142
|
-
"mobx-react-lite": ">=3.0.0",
|
|
143
|
-
"next": ">=14.0.0",
|
|
144
|
-
"next-auth": ">=4.0.0",
|
|
145
|
-
"numeral": ">=2.0.0",
|
|
146
|
-
"react": ">=18.0.0",
|
|
147
|
-
"react-dev-inspector": ">=2.0.0",
|
|
148
|
-
"react-dom": ">=18.2.0",
|
|
149
|
-
"react-draggable": ">=4.0.0",
|
|
150
|
-
"react-hot-toast": ">=2.0.0",
|
|
151
|
-
"typed-emitter": ">=2.0.0",
|
|
152
|
-
"wagmi": ">=2.12.7",
|
|
153
|
-
"viem": ">=2.21.1",
|
|
154
|
-
"@ledgerhq/hw-app-eth": "^6.42.1",
|
|
155
|
-
"@ledgerhq/hw-transport-webusb": "^6.29.4"
|
|
156
|
-
},
|
|
157
|
-
"author": "uuz",
|
|
158
|
-
"license": "ISC",
|
|
159
|
-
"devDependencies": {
|
|
160
|
-
"currency.js": "^2.0.4",
|
|
161
|
-
"tsup": "7.2.0"
|
|
162
|
-
},
|
|
163
|
-
"publishConfig": {
|
|
164
|
-
"access": "public",
|
|
165
|
-
"registry": "https://registry.npmjs.org/"
|
|
166
|
-
},
|
|
167
|
-
"dependencies": {
|
|
168
|
-
"@internationalized/date": "^3.5.4",
|
|
169
|
-
"@isaacs/ttlcache": "^1.4.1",
|
|
170
|
-
"md5": "^2.3.0",
|
|
171
|
-
"reflect-metadata": "^0.2.2",
|
|
172
|
-
"virtua": "0.33.7"
|
|
173
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@dappworks/kit",
|
|
3
|
+
"version": "0.5.35",
|
|
4
|
+
"description": "",
|
|
5
|
+
"main": "./dist/index.mjs",
|
|
6
|
+
"types": "./dist/index.d.mts",
|
|
7
|
+
"module": "./dist/index.mjs",
|
|
8
|
+
"files": [
|
|
9
|
+
"dist"
|
|
10
|
+
],
|
|
11
|
+
"directories": {
|
|
12
|
+
"lib": "lib"
|
|
13
|
+
},
|
|
14
|
+
"exports": {
|
|
15
|
+
".": {
|
|
16
|
+
"import": "./dist/index.mjs",
|
|
17
|
+
"require": "./dist/index.js"
|
|
18
|
+
},
|
|
19
|
+
"./wallet": {
|
|
20
|
+
"import": "./dist/wallet.mjs",
|
|
21
|
+
"require": "./dist/wallet.js"
|
|
22
|
+
},
|
|
23
|
+
"./metrics": {
|
|
24
|
+
"import": "./dist/metrics.mjs",
|
|
25
|
+
"require": "./dist/metrics.js"
|
|
26
|
+
},
|
|
27
|
+
"./form": {
|
|
28
|
+
"import": "./dist/form.mjs",
|
|
29
|
+
"require": "./dist/form.js"
|
|
30
|
+
},
|
|
31
|
+
"./plugins": {
|
|
32
|
+
"import": "./dist/plugins.mjs",
|
|
33
|
+
"require": "./dist/plugins.js"
|
|
34
|
+
},
|
|
35
|
+
"./dev": {
|
|
36
|
+
"import": "./dist/dev.mjs",
|
|
37
|
+
"require": "./dist/dev.js"
|
|
38
|
+
},
|
|
39
|
+
"./ui": {
|
|
40
|
+
"import": "./dist/ui.mjs",
|
|
41
|
+
"require": "./dist/ui.js"
|
|
42
|
+
},
|
|
43
|
+
"./inspector": {
|
|
44
|
+
"import": "./dist/inspector.mjs",
|
|
45
|
+
"require": "./dist/inspector.js"
|
|
46
|
+
},
|
|
47
|
+
"./jsontable": {
|
|
48
|
+
"import": "./dist/jsontable.mjs",
|
|
49
|
+
"require": "./dist/jsontable.js"
|
|
50
|
+
},
|
|
51
|
+
"./experimental": {
|
|
52
|
+
"import": "./dist/experimental.mjs",
|
|
53
|
+
"require": "./dist/experimental.js"
|
|
54
|
+
},
|
|
55
|
+
"./aiem": {
|
|
56
|
+
"import": "./dist/aiem.mjs",
|
|
57
|
+
"require": "./dist/aiem.js"
|
|
58
|
+
},
|
|
59
|
+
"./utils": {
|
|
60
|
+
"import": "./dist/utils.mjs",
|
|
61
|
+
"require": "./dist/utils.js"
|
|
62
|
+
},
|
|
63
|
+
"./jsoncomponent": {
|
|
64
|
+
"import": "./dist/jsoncomponent.mjs",
|
|
65
|
+
"require": "./dist/jsoncomponent.js"
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
"typesVersions": {
|
|
69
|
+
"*": {
|
|
70
|
+
".": [
|
|
71
|
+
"./dist/index.d.mts"
|
|
72
|
+
],
|
|
73
|
+
"wallet": [
|
|
74
|
+
"./dist/wallet.d.mts"
|
|
75
|
+
],
|
|
76
|
+
"metrics": [
|
|
77
|
+
"./dist/metrics.d.mts"
|
|
78
|
+
],
|
|
79
|
+
"form": [
|
|
80
|
+
"./dist/form.d.mts"
|
|
81
|
+
],
|
|
82
|
+
"plugins": [
|
|
83
|
+
"./dist/plugins.d.mts"
|
|
84
|
+
],
|
|
85
|
+
"dev": [
|
|
86
|
+
"./dist/dev.d.mts"
|
|
87
|
+
],
|
|
88
|
+
"ui": [
|
|
89
|
+
"./dist/ui.d.mts"
|
|
90
|
+
],
|
|
91
|
+
"inspector": [
|
|
92
|
+
"./dist/inspector.d.mts"
|
|
93
|
+
],
|
|
94
|
+
"jsontable": [
|
|
95
|
+
"./dist/jsontable.d.mts"
|
|
96
|
+
],
|
|
97
|
+
"experimental": [
|
|
98
|
+
"./dist/experimental.d.mts"
|
|
99
|
+
],
|
|
100
|
+
"aiem": [
|
|
101
|
+
"./dist/aiem.d.mts"
|
|
102
|
+
],
|
|
103
|
+
"utils": [
|
|
104
|
+
"./dist/utils.d.mts"
|
|
105
|
+
],
|
|
106
|
+
"jsoncomponent": [
|
|
107
|
+
"./dist/jsoncomponent.d.mts"
|
|
108
|
+
]
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
"scripts": {
|
|
112
|
+
"dev": "npm run build -- --watch",
|
|
113
|
+
"test": "echo \"Error: no test specified\" && exit 1",
|
|
114
|
+
"build": "tsup --format esm --dts",
|
|
115
|
+
"prepublishOnly": "npm run build"
|
|
116
|
+
},
|
|
117
|
+
"peerDependencies": {
|
|
118
|
+
"@iconify/react": ">=5.0.2",
|
|
119
|
+
"@iotexproject/iotex-address-ts": "^1.0.4",
|
|
120
|
+
"@monaco-editor/react": ">=4.0.0",
|
|
121
|
+
"@nextui-org/react": ">=2.4.8",
|
|
122
|
+
"@radix-ui/react-dialog": ">=1.0.0",
|
|
123
|
+
"@radix-ui/react-dropdown-menu": "^2.0.5",
|
|
124
|
+
"@rainbow-me/rainbowkit": ">=2.1.5",
|
|
125
|
+
"@rjsf/core": ">=5.19.4",
|
|
126
|
+
"@rjsf/utils": ">=5.19.4",
|
|
127
|
+
"@rjsf/validator-ajv8": ">=5.19.4",
|
|
128
|
+
"@safe-global/safe-apps-sdk": ">=9.1.0",
|
|
129
|
+
"@tanstack/react-query": ">=5.45.1",
|
|
130
|
+
"@tremor/react": ">=3.0.0",
|
|
131
|
+
"axios": ">=1.4.0",
|
|
132
|
+
"bignumber.js": ">=9.0.0",
|
|
133
|
+
"class-variance-authority": ">=0.7.0",
|
|
134
|
+
"copy-to-clipboard": ">=3.0.0",
|
|
135
|
+
"dataloader": ">=2.0.0",
|
|
136
|
+
"dexie": ">=3.0.0",
|
|
137
|
+
"fast-json-patch": ">3.0.0",
|
|
138
|
+
"json-format": ">=1.0.0",
|
|
139
|
+
"lodash-es": ">=4.17.21",
|
|
140
|
+
"lucide-react": ">=0.343.0",
|
|
141
|
+
"mobx": ">=6.0.0",
|
|
142
|
+
"mobx-react-lite": ">=3.0.0",
|
|
143
|
+
"next": ">=14.0.0",
|
|
144
|
+
"next-auth": ">=4.0.0",
|
|
145
|
+
"numeral": ">=2.0.0",
|
|
146
|
+
"react": ">=18.0.0",
|
|
147
|
+
"react-dev-inspector": ">=2.0.0",
|
|
148
|
+
"react-dom": ">=18.2.0",
|
|
149
|
+
"react-draggable": ">=4.0.0",
|
|
150
|
+
"react-hot-toast": ">=2.0.0",
|
|
151
|
+
"typed-emitter": ">=2.0.0",
|
|
152
|
+
"wagmi": ">=2.12.7",
|
|
153
|
+
"viem": ">=2.21.1",
|
|
154
|
+
"@ledgerhq/hw-app-eth": "^6.42.1",
|
|
155
|
+
"@ledgerhq/hw-transport-webusb": "^6.29.4"
|
|
156
|
+
},
|
|
157
|
+
"author": "uuz",
|
|
158
|
+
"license": "ISC",
|
|
159
|
+
"devDependencies": {
|
|
160
|
+
"currency.js": "^2.0.4",
|
|
161
|
+
"tsup": "7.2.0"
|
|
162
|
+
},
|
|
163
|
+
"publishConfig": {
|
|
164
|
+
"access": "public",
|
|
165
|
+
"registry": "https://registry.npmjs.org/"
|
|
166
|
+
},
|
|
167
|
+
"dependencies": {
|
|
168
|
+
"@internationalized/date": "^3.5.4",
|
|
169
|
+
"@isaacs/ttlcache": "^1.4.1",
|
|
170
|
+
"md5": "^2.3.0",
|
|
171
|
+
"reflect-metadata": "^0.2.2",
|
|
172
|
+
"virtua": "0.33.7"
|
|
173
|
+
}
|
|
174
174
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../lib/dexie.ts"],"names":[],"mappings":";AAAA,OAAO,gBAAgB;AACvB,SAAS,aAAyB;AAE3B,IAAM,eAAN,cAA2B,MAAM;AAAA,EAGtC,cAAc;AACZ,UAAM,OAAO;AACb,SAAK,QAAQ,CAAC,EAAE,OAAO;AAAA,MACrB,IAAI;AAAA,IACN,CAAC;AAAA,EACH;AACF;AACO,IAAM,QAAQ,IAAI,aAAa;AAE/B,IAAM,aAAN,MAAiB;AAAA,EAAjB;AACL,cAAK,MAAM;AACX,kBAAS,IAAI;AAAA,MACX,OAAO,QAAkB;AACvB,cAAM,MAAM,MAAM,KAAK,GAAG,QAAQ,GAAG;AACrC,eAAO,IAAI,IAAI,CAAC,MAAM,uBAAG,KAAK;AAAA,MAChC;AAAA,MACA,EAAE,OAAO,MAAM;AAAA,IACjB;AACA,kBAAS,IAAI;AAAA,MACX,OAAO,QAAoD;AACzD,cAAM,MAAM,oBAAI,KAAK;AACrB,cAAM,KAAK,GAAG,QAAQ,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,OAAO,EAAE,OAAO,EAAE,OAAO,YAAY,IAAI,QAAQ,IAAI,QAAQ,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC;AACjI,eAAO;AAAA,MACT;AAAA,MACA,EAAE,OAAO,MAAM;AAAA,IACjB;AACA,mBAAU;AAAA,MACR,KAAK,KAAK;AAAA,MACV,QAAQ;AAAA,IACV;AAAA;AAAA,EAEA,MAAM,IAAI,MAAM;AACd,UAAM,MAAM,KAAK,QAAQ,SAAS;AAClC,YAAQ,KAAK,SAAS,GAAG;AACzB,UAAM,MAAM,MAAM,KAAK,OAAO,KAAK,GAAG;AACtC,YAAQ,QAAQ,SAAS,GAAG;AAC5B,UAAM,OAAO,2BAAK;AAClB,QAAI,CAAC;AAAM;AACX,WAAO,6BAAM;AAAA,EACf;AAAA,EAEA,MAAM,OAAO,MAAM;AACjB,UAAM,MAAM,KAAK,QAAQ,SAAS;AAClC,YAAQ,KAAK,SAAS,GAAG;AACzB,UAAM,MAAM,MAAM,KAAK,OAAO,KAAK,GAAG;AACtC,YAAQ,QAAQ,SAAS,GAAG;AAC5B,UAAM,OAAO,2BAAK;AAClB,QAAI,CAAC;AAAM;AACX,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,IAAI,MAAM,OAAO,SAA4B;AACjD,UAAM,MAAM,KAAK,QAAQ,SAAS;AAClC,SAAK,OAAO,KAAK,EAAE,KAAK,OAAO,MAAK,mCAAS,QAAO,KAAK,QAAQ,IAAI,CAAC;AAEtE,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO,KAAK;AAEhB;AAAA,EACF;AAAA,EAEA,MAAM,QAAQ;AAAA,EAAC;AAAA,EAEf,MAAM,KAAoE,KAAK,IAAO,MAAmE;AACvJ,QAAI,OAAO,MAAM,KAAK,OAAO,KAAK,GAAG;AACrC,SAAI,6BAAM,eAAc,IAAI,KAAK,KAAK,UAAU,KAAK,oBAAI,KAAK,GAAG;AAG/D,UAAI,6BAAM,WAAW;AACnB,WAAG,EACA,KAAK,CAAC,UAAU;AACf,eAAK,OAAO,KAAK,EAAE,KAAK,OAAO,MAAK,6BAAM,QAAO,KAAK,QAAQ,IAAI,CAAC;AAAA,QACrE,CAAC,EACA,MAAM,CAAC,QAAQ;AACd,kBAAQ,MAAM,GAAG;AAAA,QACnB,CAAC;AAAA,MACL,OAAO;AAEL,eAAO;AAAA,MACT;AAAA,IACF;AACA,QAAI,CAAC,MAAM;AAET,YAAM,QAAQ,MAAM,GAAG;AACvB,WAAK,OAAO,KAAK,EAAE,KAAK,OAAO,MAAK,6BAAM,QAAO,KAAK,QAAQ,IAAI,CAAC;AACnE,aAAO;AAAA,IACT;AACA,WAAO,KAAK;AAAA,EACd;AACF;AAEO,IAAM,QAAQ,IAAI,WAAW","sourcesContent":["import DataLoader from \"dataloader\";\r\nimport { Dexie, type Table } from \"dexie\";\r\n\r\nexport class DexieStorage extends Dexie {\r\n kv: Table<{ key: string; value: { value: any; expiration: number } }>;\r\n\r\n constructor() {\r\n super(\"cache\");\r\n this.version(1).stores({\r\n kv: \"key, value\",\r\n });\r\n }\r\n}\r\nexport const dexie = new DexieStorage();\r\n\r\nexport class DexieCache {\r\n kv = dexie.kv;\r\n kv_get = new DataLoader(\r\n async (ids: string[]) => {\r\n const res = await this.kv.bulkGet(ids);\r\n return res.map((i) => i?.value);\r\n },\r\n { cache: false },\r\n );\r\n kv_set = new DataLoader(\r\n async (ids: { key: string; value: any; ttl: number }[]) => {\r\n const now = new Date();\r\n await this.kv.bulkPut(ids.map((i) => ({ key: i.key, value: { value: i.value, expiration: now.setTime(now.getTime() + i.ttl) } })));\r\n return ids;\r\n },\r\n { cache: false },\r\n );\r\n options = {\r\n ttl: 60 * 1000,\r\n prefix: \"\",\r\n };\r\n\r\n async get(_key) {\r\n const key = this.options.prefix + _key;\r\n console.time(\"get \" + key);\r\n const res = await this.kv_get.load(key);\r\n console.timeEnd(\"get \" + key);\r\n const data = res?.value;\r\n if (!data) return;\r\n return data?.value;\r\n }\r\n\r\n async getRaw(_key) {\r\n const key = this.options.prefix + _key;\r\n console.time(\"get \" + key);\r\n const res = await this.kv_get.load(key);\r\n console.timeEnd(\"get \" + key);\r\n const data = res?.value;\r\n if (!data) return;\r\n return data;\r\n }\r\n\r\n async set(_key, value, options?: { ttl?: number }) {\r\n const key = this.options.prefix + _key;\r\n this.kv_set.load({ key, value, ttl: options?.ttl || this.options.ttl });\r\n\r\n return this;\r\n }\r\n\r\n async delete(key) {\r\n // return this.dataloader.load(['del', key]);\r\n return;\r\n }\r\n\r\n async clear() {}\r\n\r\n async wrap<T extends (...args: any[]) => Promise<any>, U = ReturnType<T>>(key, fn: T, args?: { ttl?: number; alowStale?: boolean }): Promise<Awaited<U>> {\r\n let data = await this.kv_get.load(key);\r\n if (data?.expiration && new Date(data.expiration) <= new Date()) {\r\n // console.log(\"cache expired\", key)\r\n\r\n if (args?.alowStale) {\r\n fn()\r\n .then((value) => {\r\n this.kv_set.load({ key, value, ttl: args?.ttl || this.options.ttl });\r\n })\r\n .catch((err) => {\r\n console.error(err);\r\n });\r\n } else {\r\n //@ts-ignore\r\n data = null;\r\n }\r\n }\r\n if (!data) {\r\n // console.log(\"miss cache\", key)\r\n const value = await fn();\r\n this.kv_set.load({ key, value, ttl: args?.ttl || this.options.ttl });\r\n return value;\r\n }\r\n return data.value;\r\n }\r\n}\r\n\r\nexport const cache = new DexieCache();\r\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../components/JSONTable/index.tsx","../components/ui/dropdown-menu.tsx"],"names":["React","ChevronRight","sortableColumnsDefaultValue","columns","collapsedTables","keys","showCollapsedTables","_a","_b","_","sortedData"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useRef, useState } from \"react\";\r\nimport { Card, Divider, Pagination as NextuiPagination, PaginationProps, Spinner, SpinnerProps } from \"@nextui-org/react\";\r\nimport { ChevronDown, ChevronLeft, ChevronRight, ChevronUp, ChevronsUpDown } from \"lucide-react\";\r\nimport { observer } from \"mobx-react-lite\";\r\nimport { PaginationState } from \"../../store/standard/PaginationState\";\r\nimport { SkeletonBox } from \"../Common/SkeletonBox\";\r\nimport { _ } from \"../../lib/lodash\";\r\nimport { cn } from \"../../lib/utils\";\r\nimport { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from \"../ui/dropdown-menu\";\r\nimport { VList } from \"virtua\";\r\n\r\nexport type TableClassNames = {\r\n table?: string;\r\n thead?: string;\r\n tr?: string;\r\n th?: string;\r\n tbody?: string;\r\n td?: string;\r\n};\r\n\r\nexport type HeaderKeys<T extends Record<string, any>> = Array<keyof T | \"$actions\">;\r\n\r\nexport type ColumnConfig<T> = {\r\n label?: React.ReactNode;\r\n width?: number;\r\n hidden?: boolean;\r\n sortable?: boolean;\r\n sortKey?: string;\r\n order?: number;\r\n render?: (item: T) => any;\r\n};\r\n\r\nexport type ColumnOptions<T> = {\r\n [key in keyof T]?: ColumnConfig<T>;\r\n} & {\r\n $actions?: ColumnConfig<T>;\r\n};\r\n\r\ntype Column<T> = {\r\n key: string;\r\n label: React.ReactNode;\r\n width: number;\r\n render?: (item: T) => any;\r\n};\r\n\r\ntype CollapsedTable<U> = {\r\n key: string;\r\n columns: Column<U>[];\r\n};\r\n\r\nexport type CardOptions = {\r\n cardContainerClassName?: string;\r\n cardClassName?: string;\r\n itemClassName?: string;\r\n labelClassName?: string;\r\n valueClassName?: string;\r\n showDivider?: boolean;\r\n dividerClassName?: string;\r\n virtualizedOptions?: {\r\n colSpan?: number;\r\n cardContainerClassName?: string;\r\n };\r\n};\r\n\r\nexport type LoadingOptions = {\r\n type?: \"skeleton\" | \"spinner\";\r\n skeleton?: {\r\n boxClassName?: string;\r\n skeletonClassName?: string;\r\n line?: number;\r\n };\r\n spinner?: {\r\n boxClassName?: string;\r\n spinnerProps?: SpinnerProps;\r\n text?: string;\r\n textClassName?: string;\r\n };\r\n};\r\n\r\nexport type SortingUIOptions = {\r\n showDropdown?: boolean;\r\n dropdownTriggerBtnClassName?: string;\r\n dropdownContentClassName?: string;\r\n dropdownItemClassName?: string;\r\n titles?: {\r\n asc?: string;\r\n desc?: string;\r\n none?: string;\r\n };\r\n};\r\n\r\nexport type CollapsedTableConfig<T> = {\r\n classNames?: TableClassNames;\r\n options: {\r\n key: keyof T;\r\n headerKeys: string[];\r\n columnOptions: ColumnOptions<any>;\r\n }[];\r\n collapsedHandlerPosition?: \"left\" | \"right\";\r\n collapsedHandlerBoxCss?: string;\r\n openedIcon?: React.ReactNode;\r\n closedIcon?: React.ReactNode;\r\n onRowClick?: (item: any) => void;\r\n rowCss?: string | ((item: any) => string | undefined);\r\n emptyContent?: React.ReactNode;\r\n};\r\n\r\nexport type VirtualizedOptions = {\r\n isVirtualized?: boolean;\r\n vListHeight?: number;\r\n classNames?: {\r\n header?: string;\r\n headerCell?: string;\r\n row?: string;\r\n rowCell?: string;\r\n };\r\n cardOptions?: {\r\n colSpan?: number;\r\n cardContainerClassName?: string;\r\n };\r\n fetchData?: () => Promise<void>;\r\n};\r\n\r\nexport interface JSONTableProps<T extends Record<string, any>> {\r\n className?: string;\r\n classNames?: TableClassNames;\r\n rowKey?: string;\r\n dataSource: T[];\r\n headerKeys?: HeaderKeys<T>;\r\n columnOptions?: ColumnOptions<T>;\r\n isServerPaging?: boolean;\r\n pagination?: PaginationState;\r\n nextuiPaginationProps?: Partial<PaginationProps>;\r\n showPagination?: boolean;\r\n onRowClick?: (item: T) => void;\r\n rowCss?: string | ((item: T) => string | undefined);\r\n asCard?: boolean;\r\n cardOptions?: CardOptions;\r\n autoScrollToTop?: boolean;\r\n emptyContent?: React.ReactNode;\r\n isLoading?: boolean;\r\n loadingOptions?: LoadingOptions;\r\n loadingContent?: React.ReactNode;\r\n columnSlot?: ((props: { row: T }) => React.ReactNode) | React.ReactNode;\r\n isHeaderSticky?: boolean;\r\n sortingUIOptions?: SortingUIOptions;\r\n collapsedTableConfig?: CollapsedTableConfig<T>;\r\n virtualizedOptions?: VirtualizedOptions;\r\n}\r\n\r\nexport const JSONTable = <T extends Record<string, any>>(props: JSONTableProps<T>) => {\r\n const {\r\n className,\r\n classNames,\r\n dataSource = [],\r\n columnOptions,\r\n headerKeys,\r\n isServerPaging,\r\n pagination,\r\n nextuiPaginationProps,\r\n showPagination = true,\r\n rowKey,\r\n onRowClick,\r\n rowCss,\r\n columnSlot,\r\n asCard = false,\r\n cardOptions,\r\n autoScrollToTop = false,\r\n emptyContent,\r\n isLoading = false,\r\n loadingOptions,\r\n loadingContent,\r\n isHeaderSticky = false,\r\n sortingUIOptions,\r\n collapsedTableConfig,\r\n virtualizedOptions,\r\n } = props;\r\n const [sortableColumnsMap, setSortableColumnsMap] = useState<{ [k: string]: \"asc\" | \"desc\" | \"none\" }>({});\r\n const [sortedData, setSortedData] = useState<T[]>(dataSource);\r\n\r\n const { columns, sortableColumnsDefaultValue, showCollapsedTables, collapsedTables } = useMemo(() => {\r\n const firstData = dataSource[0];\r\n\r\n const allKeys = firstData ? Object.keys(firstData) : [];\r\n const keys = headerKeys ? headerKeys : columnOptions ? allKeys.filter((key) => !columnOptions[key]?.hidden) : allKeys;\r\n if (!keys.includes(\"$actions\") && columnOptions && columnOptions[\"$actions\"]) {\r\n keys.push(\"$actions\");\r\n }\r\n\r\n const sortableColumnsDefaultValue: { [k: string]: \"asc\" | \"desc\" | \"none\" } = {};\r\n\r\n let columns: Column<T>[] = keys.map((key: string) => {\r\n const sortable = columnOptions?.[key]?.sortable;\r\n if (sortable) {\r\n sortableColumnsDefaultValue[key] = \"none\";\r\n }\r\n return {\r\n key,\r\n label: columnOptions?.[key]?.label ?? (key === \"$actions\" ? \"\" : key),\r\n width: columnOptions?.[key]?.width ?? 60,\r\n render: columnOptions?.[key]?.render,\r\n };\r\n });\r\n\r\n if (!headerKeys && columnOptions) {\r\n columns.sort((a, b) => {\r\n const aOrder = columnOptions[a.key]?.order ?? 0;\r\n const bOrder = columnOptions[b.key]?.order ?? 0;\r\n return bOrder - aOrder;\r\n });\r\n }\r\n\r\n let collapsedTables: CollapsedTable<any>[] = [];\r\n if (firstData && collapsedTableConfig?.options) {\r\n const collapsedTableOptions = collapsedTableConfig.options;\r\n collapsedTables = collapsedTableOptions\r\n .filter((item) => {\r\n return Array.isArray(firstData[item.key]);\r\n })\r\n .map((item) => {\r\n const index = columns.findIndex((c) => c.key === item.key);\r\n if (index > -1) {\r\n columns.splice(index, 1);\r\n }\r\n const keys = item.headerKeys || [];\r\n if (!keys.includes(\"$actions\") && item.columnOptions && item.columnOptions[\"$actions\"]) {\r\n keys.push(\"$actions\");\r\n }\r\n return {\r\n key: item.key as string,\r\n columns: keys.map((k) => {\r\n const option = item.columnOptions[k];\r\n return {\r\n key: k,\r\n label: option?.label ?? k,\r\n width: option?.width ?? 60,\r\n render: option?.render,\r\n };\r\n }),\r\n };\r\n });\r\n }\r\n\r\n const showCollapsedTables = collapsedTables.length > 0;\r\n if (showCollapsedTables && !virtualizedOptions?.isVirtualized) {\r\n const collapsedHandlerPosition = collapsedTableConfig?.collapsedHandlerPosition || \"right\";\r\n if (collapsedHandlerPosition === \"right\") {\r\n columns.push({\r\n key: \"$collapsedHandler\",\r\n label: \"\",\r\n width: 60,\r\n });\r\n } else {\r\n columns = [\r\n {\r\n key: \"$collapsedHandler\",\r\n label: \"\",\r\n width: 60,\r\n },\r\n ...columns,\r\n ];\r\n }\r\n }\r\n\r\n return {\r\n columns,\r\n sortableColumnsDefaultValue,\r\n showCollapsedTables,\r\n collapsedTables,\r\n };\r\n }, [dataSource, columnOptions]);\r\n\r\n useEffect(() => {\r\n setSortableColumnsMap(sortableColumnsDefaultValue);\r\n }, [sortableColumnsDefaultValue]);\r\n\r\n useEffect(() => {\r\n setSortedData(dataSource);\r\n }, [dataSource]);\r\n\r\n if (asCard) {\r\n if (virtualizedOptions?.isVirtualized) {\r\n return (\r\n <VirtualizedCardUI\r\n className={className}\r\n rowKey={rowKey}\r\n sortedData={sortedData}\r\n columns={columns}\r\n cardOptions={cardOptions}\r\n onRowClick={onRowClick}\r\n autoScrollToTop={autoScrollToTop}\r\n emptyContent={emptyContent}\r\n isLoading={isLoading}\r\n loadingOptions={loadingOptions}\r\n loadingContent={loadingContent}\r\n virtualizedOptions={virtualizedOptions}\r\n columnSlot={columnSlot}\r\n />\r\n );\r\n } else {\r\n return (\r\n <CardUI\r\n className={className}\r\n rowKey={rowKey}\r\n sortedData={sortedData}\r\n columns={columns}\r\n cardOptions={cardOptions}\r\n onRowClick={onRowClick}\r\n autoScrollToTop={autoScrollToTop}\r\n emptyContent={emptyContent}\r\n columnSlot={columnSlot}\r\n showPagination={showPagination}\r\n pagination={pagination}\r\n nextuiPaginationProps={nextuiPaginationProps}\r\n />\r\n );\r\n }\r\n } else {\r\n if (virtualizedOptions?.isVirtualized) {\r\n return (\r\n <VirtualizedListUI\r\n className={className}\r\n rowKey={rowKey}\r\n sortedData={sortedData}\r\n dataSource={dataSource}\r\n columns={columns}\r\n columnOptions={columnOptions}\r\n sortableColumnsMap={sortableColumnsMap}\r\n sortingUIOptions={sortingUIOptions}\r\n setSortableColumnsMap={setSortableColumnsMap}\r\n setSortedData={setSortedData}\r\n onRowClick={onRowClick}\r\n emptyContent={emptyContent}\r\n isLoading={isLoading}\r\n loadingOptions={loadingOptions}\r\n loadingContent={loadingContent}\r\n virtualizedOptions={virtualizedOptions}\r\n />\r\n );\r\n } else {\r\n return (\r\n <TableUI\r\n className={className}\r\n classNames={classNames}\r\n isHeaderSticky={isHeaderSticky}\r\n sortedData={sortedData}\r\n dataSource={dataSource}\r\n columns={columns}\r\n columnOptions={columnOptions}\r\n sortableColumnsMap={sortableColumnsMap}\r\n sortingUIOptions={sortingUIOptions}\r\n setSortableColumnsMap={setSortableColumnsMap}\r\n setSortedData={setSortedData}\r\n isLoading={isLoading}\r\n loadingContent={loadingContent}\r\n loadingOptions={loadingOptions}\r\n emptyContent={emptyContent}\r\n rowCss={rowCss}\r\n onRowClick={onRowClick}\r\n showCollapsedTables={showCollapsedTables}\r\n collapsedTableConfig={collapsedTableConfig}\r\n collapsedTables={collapsedTables}\r\n rowKey={rowKey}\r\n isServerPaging={isServerPaging}\r\n showPagination={showPagination}\r\n pagination={pagination}\r\n nextuiPaginationProps={nextuiPaginationProps}\r\n autoScrollToTop={autoScrollToTop}\r\n columnSlot={columnSlot}\r\n />\r\n );\r\n }\r\n }\r\n};\r\n\r\nfunction renderFieldValue(v: any) {\r\n if (typeof v == \"string\" || typeof v == \"number\") {\r\n return v;\r\n }\r\n if (v == null) {\r\n return null;\r\n }\r\n return JSON.stringify(v);\r\n}\r\n\r\nfunction sortData<T>({\r\n sortKey,\r\n key,\r\n type,\r\n sortableColumnsMap,\r\n dataSource,\r\n}: {\r\n sortKey: string | undefined;\r\n key: string;\r\n type: \"asc\" | \"desc\" | \"none\";\r\n sortableColumnsMap: {\r\n [k: string]: \"asc\" | \"desc\" | \"none\";\r\n };\r\n dataSource: T[];\r\n}) {\r\n const sortableColumns: { [k: string]: \"asc\" | \"desc\" | \"none\" } = {};\r\n Object.keys(sortableColumnsMap).map((k) => {\r\n sortableColumns[k] = k === key ? type : \"none\";\r\n });\r\n let sortedData = dataSource;\r\n if (type !== \"none\") {\r\n const result = _.orderBy(\r\n dataSource,\r\n (o) => {\r\n const v = _.get(o, sortKey || key);\r\n if (v == null) {\r\n return type === \"desc\" ? \"\" : v;\r\n }\r\n if (typeof v === \"string\") {\r\n const _v = Number(v.replace(\"%\", \"\").replace(\"$\", \"\").replace(/,/g, \"\"));\r\n if (isNaN(_v)) {\r\n return v.toLowerCase();\r\n } else {\r\n return _v;\r\n }\r\n }\r\n return v;\r\n },\r\n type,\r\n );\r\n sortedData = result;\r\n }\r\n return {\r\n sortableColumns,\r\n sortedData,\r\n };\r\n}\r\n\r\nfunction SortingComponent<T>({\r\n sortingUIOptions,\r\n columnOptions,\r\n sortableColumnsMap,\r\n item,\r\n onSort,\r\n}: {\r\n sortingUIOptions: SortingUIOptions;\r\n columnOptions?: ColumnOptions<T>;\r\n sortableColumnsMap: { [k: string]: \"asc\" | \"desc\" | \"none\" };\r\n item: Column<T>;\r\n onSort: (e: { type: \"asc\" | \"desc\" | \"none\"; key: string; sortKey: string }) => void;\r\n}) {\r\n if (sortingUIOptions?.showDropdown) {\r\n return (\r\n <DropdownMenu>\r\n <DropdownMenuTrigger>\r\n <button className={cn(\"outline-none p-1\", sortingUIOptions?.dropdownTriggerBtnClassName)}>\r\n {sortableColumnsMap[item.key] === \"desc\" && <ChevronDown size={14} />}\r\n {sortableColumnsMap[item.key] === \"asc\" && <ChevronUp size={14} />}\r\n {sortableColumnsMap[item.key] === \"none\" && <ChevronsUpDown size={14} />}\r\n </button>\r\n </DropdownMenuTrigger>\r\n <DropdownMenuContent className={cn(\"p-2 space-y-1 min-w-[4rem]\", sortingUIOptions?.dropdownContentClassName)} collisionPadding={10} sideOffset={5}>\r\n <DropdownMenuItem\r\n className={cn(\"text-xs font-bold cursor-pointer\", sortingUIOptions?.dropdownItemClassName)}\r\n onClick={() => {\r\n onSort({\r\n type: \"asc\",\r\n key: item.key,\r\n sortKey: columnOptions?.[item.key]?.sortKey,\r\n });\r\n }}\r\n >\r\n {sortingUIOptions?.titles?.asc || \"ASC\"}\r\n </DropdownMenuItem>\r\n <DropdownMenuItem\r\n className={cn(\"text-xs font-bold cursor-pointer\", sortingUIOptions?.dropdownItemClassName)}\r\n onClick={() => {\r\n onSort({\r\n type: \"desc\",\r\n key: item.key,\r\n sortKey: columnOptions?.[item.key]?.sortKey,\r\n });\r\n }}\r\n >\r\n {sortingUIOptions?.titles?.desc || \"DESC\"}\r\n </DropdownMenuItem>\r\n <DropdownMenuItem\r\n className={cn(\"text-xs font-bold cursor-pointer\", sortingUIOptions?.dropdownItemClassName)}\r\n onClick={() => {\r\n onSort({\r\n type: \"none\",\r\n key: item.key,\r\n sortKey: columnOptions?.[item.key]?.sortKey,\r\n });\r\n }}\r\n >\r\n {sortingUIOptions?.titles?.none || \"NONE\"}\r\n </DropdownMenuItem>\r\n </DropdownMenuContent>\r\n </DropdownMenu>\r\n );\r\n }\r\n\r\n return (\r\n <button className={cn(\"outline-none p-1\", sortingUIOptions?.dropdownTriggerBtnClassName)}>\r\n {sortableColumnsMap[item.key] === \"none\" && (\r\n <ChevronsUpDown\r\n size={14}\r\n onClick={() => {\r\n onSort({\r\n type: \"desc\",\r\n key: item.key,\r\n sortKey: columnOptions?.[item.key]?.sortKey,\r\n });\r\n }}\r\n />\r\n )}\r\n {sortableColumnsMap[item.key] === \"desc\" && (\r\n <ChevronDown\r\n size={14}\r\n onClick={() => {\r\n onSort({\r\n type: \"asc\",\r\n key: item.key,\r\n sortKey: columnOptions?.[item.key]?.sortKey,\r\n });\r\n }}\r\n />\r\n )}\r\n {sortableColumnsMap[item.key] === \"asc\" && (\r\n <ChevronUp\r\n size={14}\r\n onClick={() => {\r\n onSort({\r\n type: \"none\",\r\n key: item.key,\r\n sortKey: columnOptions?.[item.key]?.sortKey,\r\n });\r\n }}\r\n />\r\n )}\r\n </button>\r\n );\r\n}\r\n\r\nconst CardUI = observer(\r\n <T,>({\r\n className,\r\n sortedData,\r\n columns,\r\n rowKey,\r\n cardOptions,\r\n onRowClick,\r\n emptyContent,\r\n columnSlot,\r\n isServerPaging,\r\n showPagination,\r\n pagination,\r\n nextuiPaginationProps,\r\n autoScrollToTop,\r\n }: {\r\n className?: string;\r\n sortedData: T[];\r\n columns: Column<T>[];\r\n rowKey?: string;\r\n cardOptions?: CardOptions;\r\n onRowClick?: (item: T) => void;\r\n autoScrollToTop?: boolean;\r\n emptyContent?: React.ReactNode;\r\n columnSlot?: ((props: { row: T }) => React.ReactNode) | React.ReactNode;\r\n isServerPaging?: boolean;\r\n showPagination: boolean;\r\n pagination?: PaginationState;\r\n nextuiPaginationProps?: PaginationProps | {};\r\n }) => {\r\n const cardBoxRef = useRef<HTMLDivElement>(null);\r\n pagination = pagination\r\n ? pagination\r\n : useRef(\r\n new PaginationState({\r\n page: 1,\r\n limit: 10,\r\n }),\r\n ).current;\r\n\r\n useEffect(() => {\r\n if (!isServerPaging && pagination) {\r\n pagination.setData({\r\n total: sortedData.length,\r\n });\r\n }\r\n }, [sortedData]);\r\n\r\n const data = isServerPaging || !showPagination ? sortedData : sortedData.slice(pagination.offset, pagination.offset + pagination.limit);\r\n\r\n return (\r\n <div className={className} ref={cardBoxRef}>\r\n {sortedData.length > 0 ? (\r\n <>\r\n <div className={cardOptions?.cardContainerClassName}>\r\n {data.map((item, index) => {\r\n return (\r\n <Card\r\n key={rowKey ? item[rowKey] || index : index}\r\n className={cn(\"mb-2 w-full shadow-sm p-4 rounded-lg\", cardOptions?.cardClassName)}\r\n isPressable={!!onRowClick}\r\n onPress={() => {\r\n onRowClick?.(item);\r\n }}\r\n >\r\n {columns.map((column, i) => {\r\n return (\r\n <div className=\"w-full\" key={column.key}>\r\n <div className={cn(\"w-full\", cardOptions?.itemClassName)}>\r\n <div className={cn(\"font-meidum text-xs text-foreground-400\", cardOptions?.labelClassName)}>{column.label}</div>\r\n <div className={cn(\"text-xs\", cardOptions?.valueClassName)}>{column.render ? column.render(item) : renderFieldValue(item[column.key])}</div>\r\n </div>\r\n {cardOptions?.showDivider && i !== columns.length - 1 && <Divider className={cn(\"my-2\", cardOptions?.dividerClassName)} />}\r\n </div>\r\n );\r\n })}\r\n {typeof columnSlot === \"function\" ? columnSlot({ row: item }) : columnSlot}\r\n </Card>\r\n );\r\n })}\r\n </div>\r\n {showPagination && pagination.total > pagination.limit && (\r\n <div className=\"flex justify-center\">\r\n <NextuiPagination\r\n className=\"mt-2\"\r\n showControls\r\n showShadow\r\n size=\"sm\"\r\n radius=\"sm\"\r\n color=\"primary\"\r\n initialPage={1}\r\n total={Math.ceil(pagination.total / pagination.limit)}\r\n page={pagination.page}\r\n onChange={(currentPage) => {\r\n pagination.setData({\r\n page: currentPage,\r\n });\r\n if (autoScrollToTop && cardBoxRef.current) {\r\n scrollIntoTop(cardBoxRef.current);\r\n }\r\n }}\r\n {...nextuiPaginationProps}\r\n />\r\n </div>\r\n )}\r\n </>\r\n ) : (\r\n (emptyContent ?? <DefaultEmptyContent />)\r\n )}\r\n </div>\r\n );\r\n },\r\n);\r\n\r\nfunction VirtualizedCardUI<T>({\r\n className,\r\n sortedData,\r\n columns,\r\n rowKey,\r\n cardOptions,\r\n onRowClick,\r\n emptyContent,\r\n isLoading,\r\n loadingOptions,\r\n loadingContent,\r\n virtualizedOptions,\r\n columnSlot,\r\n}: {\r\n className?: string;\r\n sortedData: T[];\r\n columns: Column<T>[];\r\n rowKey?: string;\r\n cardOptions?: CardOptions;\r\n onRowClick?: (item: T) => void;\r\n autoScrollToTop?: boolean;\r\n emptyContent?: React.ReactNode;\r\n isLoading?: boolean;\r\n loadingOptions?: LoadingOptions;\r\n loadingContent?: React.ReactNode;\r\n virtualizedOptions?: VirtualizedOptions;\r\n columnSlot?: ((props: { row: T }) => React.ReactNode) | React.ReactNode;\r\n}) {\r\n const colSpan = virtualizedOptions?.cardOptions?.colSpan || cardOptions?.virtualizedOptions?.colSpan || 1;\r\n const fetchedCountRef = useRef(-1);\r\n const elements = useMemo(() => {\r\n const MyCard = ({ item }) => {\r\n return (\r\n <Card\r\n className={cn(\"mb-2 w-full shadow-sm p-4 rounded-lg\", cardOptions?.cardClassName)}\r\n isPressable={!!onRowClick}\r\n onPress={() => {\r\n onRowClick?.(item);\r\n }}\r\n >\r\n {columns.map((column, i) => {\r\n return (\r\n <div className=\"w-full\" key={column.key}>\r\n <div className={cn(\"w-full\", cardOptions?.itemClassName)}>\r\n <div className={cn(\"font-meidum text-xs text-foreground-400\", cardOptions?.labelClassName)}>{column.label}</div>\r\n <div className={cn(\"text-xs\", cardOptions?.valueClassName)}>{column.render ? column.render(item) : renderFieldValue(item[column.key])}</div>\r\n </div>\r\n {cardOptions?.showDivider && i !== columns.length - 1 && <Divider className={cn(\"my-2\", cardOptions?.dividerClassName)} />}\r\n </div>\r\n );\r\n })}\r\n {typeof columnSlot === \"function\" ? columnSlot({ row: item }) : columnSlot}\r\n </Card>\r\n );\r\n };\r\n if (colSpan === 1) {\r\n return sortedData.map((item, index) => {\r\n return <MyCard key={rowKey ? item[rowKey] || index : index} item={item} />;\r\n });\r\n } else {\r\n const groupData = groupByColSpan(sortedData, colSpan);\r\n return groupData.map((group, gIndex) => {\r\n return (\r\n <div\r\n className={cn(\"flex items-center justify-between space-x-1\", virtualizedOptions?.cardOptions?.cardContainerClassName || cardOptions?.virtualizedOptions?.cardContainerClassName)}\r\n key={gIndex}\r\n >\r\n {group.map((item, index) => {\r\n return <MyCard key={rowKey ? item[rowKey] || index : index} item={item} />;\r\n })}\r\n </div>\r\n );\r\n });\r\n }\r\n }, [sortedData]);\r\n return (\r\n <div className={className}>\r\n {sortedData.length > 0 ? (\r\n <VList\r\n style={{ height: virtualizedOptions?.vListHeight || 400 }}\r\n onRangeChange={async (_, endIndex) => {\r\n const count = sortedData.length / colSpan;\r\n if (endIndex + 1 >= count && fetchedCountRef.current < count) {\r\n fetchedCountRef.current = count;\r\n if (virtualizedOptions?.fetchData) {\r\n await virtualizedOptions.fetchData();\r\n }\r\n }\r\n }}\r\n >\r\n {elements}\r\n {isLoading ? loadingContent || DefaultLoading({ loadingOptions }) : null}\r\n </VList>\r\n ) : (\r\n (emptyContent ?? <DefaultEmptyContent />)\r\n )}\r\n </div>\r\n );\r\n}\r\n\r\nfunction VirtualizedListUI<T>({\r\n className,\r\n sortedData,\r\n dataSource,\r\n columns,\r\n columnOptions,\r\n sortableColumnsMap,\r\n sortingUIOptions,\r\n setSortableColumnsMap,\r\n setSortedData,\r\n rowKey,\r\n onRowClick,\r\n rowCss,\r\n emptyContent,\r\n isLoading,\r\n loadingOptions,\r\n loadingContent,\r\n virtualizedOptions,\r\n}: {\r\n className: string;\r\n sortedData: T[];\r\n dataSource: T[];\r\n columns: Column<T>[];\r\n columnOptions: ColumnOptions<T>;\r\n sortableColumnsMap: { [k: string]: \"asc\" | \"desc\" | \"none\" };\r\n sortingUIOptions: SortingUIOptions;\r\n setSortableColumnsMap: (\r\n value: React.SetStateAction<{\r\n [k: string]: \"asc\" | \"desc\" | \"none\";\r\n }>,\r\n ) => void;\r\n setSortedData: (value: React.SetStateAction<T[]>) => void;\r\n rowKey?: string;\r\n onRowClick?: (item: T) => void;\r\n rowCss?: string | ((item: T) => string | undefined);\r\n emptyContent?: React.ReactNode;\r\n isLoading?: boolean;\r\n loadingOptions?: LoadingOptions;\r\n loadingContent?: React.ReactNode;\r\n virtualizedOptions?: VirtualizedOptions;\r\n}) {\r\n const fetchedCountRef = useRef(-1);\r\n const elements = useMemo(\r\n () =>\r\n sortedData.map((item, index) => {\r\n return (\r\n <div\r\n key={rowKey ? item[rowKey] || index : index}\r\n className={cn(\"w-full flex items-center space-x-1\", virtualizedOptions?.classNames?.row, typeof rowCss === \"function\" ? rowCss(item) : rowCss)}\r\n onClick={() => {\r\n onRowClick?.(item);\r\n }}\r\n >\r\n {columns.map((column) => {\r\n return (\r\n <div\r\n key={column.key}\r\n className={cn(\"w-full flex-grow py-2 px-4 text-xs whitespace-nowrap overflow-auto\", virtualizedOptions?.classNames?.rowCell)}\r\n style={{\r\n minWidth: column.width,\r\n }}\r\n >\r\n {column.render ? column.render(item) : renderFieldValue(item[column.key])}\r\n </div>\r\n );\r\n })}\r\n </div>\r\n );\r\n }),\r\n [sortedData],\r\n );\r\n\r\n return (\r\n <div className={cn(\"w-full overflow-x-auto\", className)}>\r\n <div className=\"inline-block min-w-fit w-full\">\r\n <div className={cn(\"w-full flex items-center rounded-lg bg-default-100 space-x-1 mb-2\", virtualizedOptions?.classNames?.header)}>\r\n {columns.map((column) => {\r\n return (\r\n <div\r\n key={column.key}\r\n className={cn(\"w-full flex-grow py-2 px-4 flex items-center text-xs font-semibold whitespace-nowrap overflow-auto\", virtualizedOptions?.classNames?.headerCell)}\r\n style={{\r\n minWidth: column.width,\r\n }}\r\n >\r\n <span>{column.label}</span>\r\n {!!sortableColumnsMap[column.key] && (\r\n <SortingComponent\r\n sortingUIOptions={sortingUIOptions}\r\n columnOptions={columnOptions}\r\n sortableColumnsMap={sortableColumnsMap}\r\n item={column}\r\n onSort={({ type, key, sortKey }) => {\r\n const { sortableColumns, sortedData } = sortData({\r\n type,\r\n key,\r\n sortKey,\r\n sortableColumnsMap,\r\n dataSource,\r\n });\r\n setSortableColumnsMap(sortableColumns);\r\n setSortedData(sortedData);\r\n }}\r\n />\r\n )}\r\n </div>\r\n );\r\n })}\r\n </div>\r\n {sortedData.length > 0 ? (\r\n <VList\r\n style={{ height: virtualizedOptions?.vListHeight || 200 }}\r\n onRangeChange={async (_, endIndex) => {\r\n const count = sortedData.length;\r\n if (endIndex + 1 >= count && fetchedCountRef.current < count) {\r\n fetchedCountRef.current = count;\r\n if (virtualizedOptions?.fetchData) {\r\n await virtualizedOptions.fetchData();\r\n }\r\n }\r\n }}\r\n >\r\n {elements}\r\n {isLoading ? loadingContent || DefaultLoading({ loadingOptions }) : null}\r\n </VList>\r\n ) : (\r\n (emptyContent ?? <DefaultEmptyContent />)\r\n )}\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\nconst TableUI = observer(\r\n <T,>({\r\n className,\r\n classNames = {},\r\n isHeaderSticky,\r\n sortedData,\r\n dataSource,\r\n columns,\r\n columnOptions,\r\n sortableColumnsMap,\r\n sortingUIOptions,\r\n setSortableColumnsMap,\r\n setSortedData,\r\n isLoading,\r\n loadingContent,\r\n loadingOptions,\r\n emptyContent,\r\n rowCss,\r\n onRowClick,\r\n showCollapsedTables,\r\n collapsedTableConfig,\r\n collapsedTables,\r\n rowKey,\r\n isServerPaging,\r\n showPagination,\r\n pagination,\r\n nextuiPaginationProps = {},\r\n autoScrollToTop,\r\n columnSlot,\r\n }: {\r\n className: string;\r\n classNames?: TableClassNames;\r\n isHeaderSticky: boolean;\r\n sortedData: T[];\r\n dataSource: T[];\r\n columns: Column<T>[];\r\n columnOptions?: ColumnOptions<T>;\r\n sortableColumnsMap: { [k: string]: \"asc\" | \"desc\" | \"none\" };\r\n sortingUIOptions: SortingUIOptions;\r\n setSortableColumnsMap: (value: React.SetStateAction<{ [k: string]: \"asc\" | \"desc\" | \"none\" }>) => void;\r\n setSortedData: (value: React.SetStateAction<T[]>) => void;\r\n isLoading: boolean;\r\n loadingContent?: React.ReactNode;\r\n loadingOptions?: LoadingOptions;\r\n emptyContent?: React.ReactNode;\r\n rowCss?: string | ((item: T) => string | undefined);\r\n onRowClick?: (item: T) => void;\r\n showCollapsedTables: boolean;\r\n collapsedTableConfig?: CollapsedTableConfig<T>;\r\n collapsedTables: CollapsedTable<any>[];\r\n rowKey?: string;\r\n isServerPaging?: boolean;\r\n showPagination: boolean;\r\n pagination?: PaginationState;\r\n nextuiPaginationProps?: PaginationProps | {};\r\n autoScrollToTop: boolean;\r\n columnSlot?: ((props: { row: T }) => React.ReactNode) | React.ReactNode;\r\n }) => {\r\n const tableBoxRef = useRef<HTMLDivElement>(null);\r\n pagination = pagination\r\n ? pagination\r\n : useRef(\r\n new PaginationState({\r\n page: 1,\r\n limit: 10,\r\n }),\r\n ).current;\r\n\r\n useEffect(() => {\r\n if (!isServerPaging) {\r\n pagination.setData({\r\n total: dataSource.length,\r\n });\r\n }\r\n }, [dataSource]);\r\n\r\n const data = isServerPaging || !showPagination ? sortedData : sortedData.slice(pagination.offset, pagination.offset + pagination.limit);\r\n\r\n return (\r\n <>\r\n <div className={cn(\"relative w-full\", className)} ref={tableBoxRef}>\r\n <table className={cn(\"w-full h-auto table-auto\", classNames.table)}>\r\n <thead className={cn(classNames.thead, { \"sticky top-0 z-30 [&>tr]:first:shadow-small [&>tr]:first:rounded-lg\": isHeaderSticky })}>\r\n <tr className={classNames.tr}>\r\n {columns.map((item) => (\r\n <th\r\n key={item.key}\r\n className={cn(\"px-3 h-10 text-xs font-semibold whitespace-nowrap bg-default-100 first:rounded-l-lg last:rounded-r-lg outline-none\", classNames.th)}\r\n style={{\r\n minWidth: item.width,\r\n }}\r\n >\r\n <div className=\"flex items-center\">\r\n <span>{item.label}</span>\r\n {!!sortableColumnsMap[item.key] && (\r\n <SortingComponent\r\n sortingUIOptions={sortingUIOptions}\r\n columnOptions={columnOptions}\r\n sortableColumnsMap={sortableColumnsMap}\r\n item={item}\r\n onSort={({ type, key, sortKey }) => {\r\n const { sortableColumns, sortedData } = sortData({\r\n type,\r\n key,\r\n sortKey,\r\n sortableColumnsMap,\r\n dataSource,\r\n });\r\n setSortableColumnsMap(sortableColumns);\r\n setSortedData(sortedData);\r\n }}\r\n />\r\n )}\r\n </div>\r\n </th>\r\n ))}\r\n </tr>\r\n <tr aria-hidden=\"true\" className=\"w-px h-px block ml-[0.25rem] mt-[0.25rem]\"></tr>\r\n </thead>\r\n {isLoading ? (\r\n <tbody className={classNames.tbody}>\r\n <tr className={classNames.tr}>\r\n <td className={classNames.td} colSpan={columns.length}>\r\n {loadingContent || DefaultLoading({ loadingOptions })}\r\n </td>\r\n </tr>\r\n </tbody>\r\n ) : data.length > 0 ? (\r\n <tbody className={classNames.tbody}>\r\n {showCollapsedTables\r\n ? data.map((item) => {\r\n return (\r\n <CollapseBodyRow\r\n classNames={classNames}\r\n item={item}\r\n columns={columns}\r\n rowCss={rowCss}\r\n onRowClick={onRowClick}\r\n collapsedTableConfig={collapsedTableConfig}\r\n collapsedTables={collapsedTables}\r\n />\r\n );\r\n })\r\n : data.map((item, index) => {\r\n return (\r\n <>\r\n <tr\r\n key={rowKey ? item[rowKey] || index : index}\r\n className={cn(classNames.tr, typeof rowCss === \"function\" ? rowCss(item) : rowCss)}\r\n onClick={() => {\r\n onRowClick?.(item);\r\n }}\r\n >\r\n {columns.map((column) => {\r\n return (\r\n <td\r\n key={column.key}\r\n className={cn(\"py-2 px-3 text-xs\", classNames.td)}\r\n style={{\r\n minWidth: column.width,\r\n }}\r\n >\r\n {column.render ? column.render(item) : renderFieldValue(item[column.key])}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n {columnSlot && (\r\n <tr>\r\n <td colSpan={columns.length}>{typeof columnSlot === \"function\" ? columnSlot({ row: item }) : columnSlot}</td>\r\n </tr>\r\n )}\r\n </>\r\n );\r\n })}\r\n </tbody>\r\n ) : (\r\n <tbody className={classNames.tbody}>\r\n <tr className={classNames.tr}>\r\n <td className={classNames.td} colSpan={columns.length}>\r\n {emptyContent ?? <DefaultEmptyContent />}\r\n </td>\r\n </tr>\r\n </tbody>\r\n )}\r\n </table>\r\n </div>\r\n {showPagination && pagination.total > pagination.limit && (\r\n <div className=\"flex justify-center\">\r\n <NextuiPagination\r\n className=\"mt-2\"\r\n showControls\r\n showShadow\r\n size=\"sm\"\r\n radius=\"sm\"\r\n color=\"primary\"\r\n initialPage={1}\r\n total={Math.ceil(pagination.total / pagination.limit)}\r\n page={pagination.page}\r\n onChange={(currentPage) => {\r\n pagination.setData({\r\n page: currentPage,\r\n });\r\n if (autoScrollToTop && tableBoxRef.current) {\r\n scrollIntoTop(tableBoxRef.current);\r\n }\r\n }}\r\n {...nextuiPaginationProps}\r\n />\r\n </div>\r\n )}\r\n </>\r\n );\r\n },\r\n);\r\n\r\nfunction DefaultLoading({ loadingOptions }: { loadingOptions?: LoadingOptions }) {\r\n const type = loadingOptions?.type || \"skeleton\";\r\n const skeletonOptions = loadingOptions?.skeleton;\r\n const spinnerOptions = loadingOptions?.spinner;\r\n const spinnerProps = spinnerOptions?.spinnerProps || {};\r\n\r\n if (type === \"skeleton\") {\r\n return <SkeletonBox className={cn(\"mt-2 flex-col\", skeletonOptions?.boxClassName)} skClassName={cn(\"h-[30px] rounded\", skeletonOptions?.skeletonClassName)} line={skeletonOptions?.line || 5} />;\r\n }\r\n\r\n return (\r\n <div className={cn(\"w-full h-[60px] flex justify-center items-center\", spinnerOptions?.boxClassName)}>\r\n <Spinner size=\"sm\" color=\"primary\" {...spinnerProps} />\r\n <div className={cn(\"ml-2 text-[#64748B] text-sm\", spinnerOptions?.textClassName)}>{spinnerOptions?.text || \"Loading...\"}</div>\r\n </div>\r\n );\r\n}\r\n\r\nfunction DefaultEmptyContent() {\r\n return <div className=\"w-full h-[60px] flex justify-center items-center text-xs text-[#64748B] dark:text-[#cacaca]\">No Data</div>;\r\n}\r\n\r\nfunction scrollIntoTop(target: HTMLElement) {\r\n if (target) {\r\n const { top } = target.getBoundingClientRect();\r\n window.scrollTo({\r\n top: top + window.scrollY - 100,\r\n behavior: \"smooth\",\r\n });\r\n }\r\n}\r\n\r\nfunction CollapseBodyRow<T>({\r\n classNames,\r\n item,\r\n columns,\r\n rowCss,\r\n onRowClick,\r\n collapsedTableConfig,\r\n collapsedTables,\r\n}: {\r\n classNames?: TableClassNames;\r\n item: T;\r\n columns: Column<T>[];\r\n rowCss?: string | ((item: T) => string | undefined);\r\n onRowClick?: (item: T) => void;\r\n collapsedTableConfig?: {\r\n classNames?: TableClassNames;\r\n collapsedHandlerPosition?: \"left\" | \"right\";\r\n collapsedHandlerBoxCss?: string;\r\n openedIcon?: React.ReactNode;\r\n closedIcon?: React.ReactNode;\r\n onRowClick?: (item: any) => void;\r\n rowCss?: string | ((item: any) => string | undefined);\r\n emptyContent?: React.ReactNode;\r\n };\r\n collapsedTables: CollapsedTable<any>[];\r\n}) {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const collapsedHandlerPosition = collapsedTableConfig?.collapsedHandlerPosition || \"right\";\r\n\r\n const { OpenedIcon, ClosedIcon } = useMemo(() => {\r\n const defaultOpenedIcon = <ChevronDown size={18} />;\r\n const defaultClosedIcon = collapsedHandlerPosition === \"left\" ? <ChevronRight size={18} /> : <ChevronLeft size={18} />;\r\n return {\r\n OpenedIcon: collapsedTableConfig?.openedIcon || defaultOpenedIcon,\r\n ClosedIcon: collapsedTableConfig?.closedIcon || defaultClosedIcon,\r\n };\r\n }, []);\r\n\r\n return (\r\n <>\r\n <tr\r\n className={cn(\"text-xs cursor-pointer\", classNames?.tr, typeof rowCss === \"function\" ? rowCss(item) : rowCss)}\r\n onClick={(e: any) => {\r\n onRowClick?.(item);\r\n }}\r\n >\r\n {columns.map((column) => {\r\n if (column.key === \"$collapsedHandler\") {\r\n return (\r\n <td\r\n className={classNames?.td}\r\n style={{\r\n minWidth: column.width,\r\n }}\r\n >\r\n <div\r\n className={cn(\"w-6 h-6 flex items-center justify-center rounded-sm hover:bg-[#f3f3f4] dark:hover:bg-[#1e1e1e]\", collapsedTableConfig?.collapsedHandlerBoxCss)}\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n setIsOpen((v) => !v);\r\n }}\r\n >\r\n {isOpen ? OpenedIcon : ClosedIcon}\r\n </div>\r\n </td>\r\n );\r\n }\r\n return (\r\n <td\r\n key={column.key}\r\n className={cn(\"py-2 px-3 text-xs\", classNames?.td)}\r\n style={{\r\n minWidth: column.width,\r\n }}\r\n >\r\n {column.render ? column.render(item) : renderFieldValue(item[column.key])}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n <tr className={cn(classNames?.tr, isOpen ? \"table-row\" : \"hidden\")}>\r\n <td colSpan={columns.length} className={cn(\"py-2 px-3 text-xs\", classNames?.td)}>\r\n {collapsedTables.map((ex) => {\r\n const exColumns = ex.columns;\r\n const exData = item[ex.key] || [];\r\n return (\r\n <table className={cn(\"w-full h-auto table-auto\", collapsedTableConfig?.classNames?.table)} key={ex.key}>\r\n <thead className={collapsedTableConfig?.classNames?.thead}>\r\n <tr className={collapsedTableConfig?.classNames?.tr}>\r\n {exColumns?.map((exC) => {\r\n return (\r\n <th\r\n key={exC.key}\r\n className={cn(\"px-3 h-10 text-xs text-left font-semibold bg-default-100 first:rounded-l-lg last:rounded-r-lg outline-none\", collapsedTableConfig?.classNames?.th)}\r\n style={{\r\n minWidth: exC.width,\r\n }}\r\n >\r\n {exC.label}\r\n </th>\r\n );\r\n })}\r\n </tr>\r\n <tr aria-hidden=\"true\" className=\"w-px h-px block ml-[0.25rem] mt-[0.25rem]\"></tr>\r\n </thead>\r\n {exData.length > 0 ? (\r\n <tbody className={collapsedTableConfig?.classNames?.tbody}>\r\n {exData.map((exItem) => (\r\n <tr\r\n key={exItem.key}\r\n className={cn(\r\n \"text-xs\",\r\n collapsedTableConfig?.classNames?.tr,\r\n typeof collapsedTableConfig?.rowCss === \"function\"\r\n ? collapsedTableConfig?.rowCss({\r\n ...exItem,\r\n $parent: item,\r\n })\r\n : collapsedTableConfig?.rowCss,\r\n )}\r\n onClick={(e: any) => {\r\n collapsedTableConfig?.onRowClick?.({\r\n ...exItem,\r\n $parent: item,\r\n });\r\n }}\r\n >\r\n {exColumns?.map((exC) => {\r\n return (\r\n <td\r\n key={exC.key}\r\n className={cn(\"py-2 px-3 text-xs\", collapsedTableConfig?.classNames?.td)}\r\n style={{\r\n minWidth: exC.width,\r\n }}\r\n >\r\n {exC.render\r\n ? exC.render({\r\n ...exItem,\r\n $parent: item,\r\n })\r\n : renderFieldValue(exItem[exC.key])}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n ))}\r\n </tbody>\r\n ) : (\r\n <tbody className={collapsedTableConfig?.classNames?.tbody}>\r\n <tr className={collapsedTableConfig?.classNames?.tr}>\r\n <td className={collapsedTableConfig?.classNames?.td} colSpan={columns.length}>\r\n {collapsedTableConfig?.emptyContent ?? <DefaultEmptyContent />}\r\n </td>\r\n </tr>\r\n </tbody>\r\n )}\r\n </table>\r\n );\r\n })}\r\n </td>\r\n </tr>\r\n </>\r\n );\r\n}\r\n\r\nfunction groupByColSpan(arr: any[], colSpan: number) {\r\n const result = [];\r\n for (let i = 0; i < arr.length; i += colSpan) {\r\n result.push(arr.slice(i, i + colSpan));\r\n }\r\n return result;\r\n}\r\n","\"use client\"\r\n\r\nimport * as React from \"react\"\r\nimport * as DropdownMenuPrimitive from \"@radix-ui/react-dropdown-menu\"\r\nimport { Check, ChevronRight, Circle } from \"lucide-react\"\r\n\r\nimport { cn } from \"../../lib/utils\";\r\n\r\nconst DropdownMenu = DropdownMenuPrimitive.Root\r\n\r\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger\r\n\r\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group\r\n\r\nconst DropdownMenuPortal = DropdownMenuPrimitive.Portal\r\n\r\nconst DropdownMenuSub = DropdownMenuPrimitive.Sub\r\n\r\nconst DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup\r\n\r\nconst DropdownMenuArrow = DropdownMenuPrimitive.Arrow\r\n\r\nconst DropdownMenuSubTrigger = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.SubTrigger>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubTrigger> & {\r\n inset?: boolean\r\n }\r\n>(({ className, inset, children, ...props }, ref) => (\r\n <DropdownMenuPrimitive.SubTrigger\r\n ref={ref}\r\n className={cn(\r\n \"flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent\",\r\n inset && \"pl-8\",\r\n className\r\n )}\r\n {...props}\r\n >\r\n {children}\r\n <ChevronRight className=\"ml-auto h-4 w-4\" />\r\n </DropdownMenuPrimitive.SubTrigger>\r\n))\r\nDropdownMenuSubTrigger.displayName =\r\n DropdownMenuPrimitive.SubTrigger.displayName\r\n\r\nconst DropdownMenuSubContent = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.SubContent>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubContent>\r\n>(({ className, ...props }, ref) => (\r\n <DropdownMenuPrimitive.SubContent\r\n ref={ref}\r\n className={cn(\r\n \"z-50 min-w-[8rem] overflow-hidden rounded-md bg-white dark:bg-[#18181B] border dark:border-none p-1 text-popover-foreground shadow-md animate-in data-[side=bottom]:slide-in-from-top-1 data-[side=left]:slide-in-from-right-1 data-[side=right]:slide-in-from-left-1 data-[side=top]:slide-in-from-bottom-1\",\r\n className\r\n )}\r\n {...props}\r\n />\r\n))\r\nDropdownMenuSubContent.displayName =\r\n DropdownMenuPrimitive.SubContent.displayName\r\n\r\nconst DropdownMenuContent = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.Content>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\r\n>(({ className, sideOffset = 4, ...props }, ref) => (\r\n <DropdownMenuPrimitive.Portal>\r\n <DropdownMenuPrimitive.Content\r\n ref={ref}\r\n sideOffset={sideOffset}\r\n className={cn(\r\n \"z-50 min-w-[8rem] overflow-hidden rounded-lg bg-white dark:bg-[#18181B] border dark:border-[#3e3e3e] p-1 text-popover-foreground shadow-md animate-in data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\r\n className\r\n )}\r\n {...props}\r\n />\r\n </DropdownMenuPrimitive.Portal>\r\n))\r\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName\r\n\r\nconst DropdownMenuItem = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.Item>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item> & {\r\n inset?: boolean\r\n }\r\n>(({ className, inset, ...props }, ref) => (\r\n <DropdownMenuPrimitive.Item\r\n ref={ref}\r\n className={cn(\r\n \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\r\n inset && \"pl-8\",\r\n className\r\n )}\r\n {...props}\r\n />\r\n))\r\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName\r\n\r\nconst DropdownMenuCheckboxItem = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.CheckboxItem>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.CheckboxItem>\r\n>(({ className, children, checked, ...props }, ref) => (\r\n <DropdownMenuPrimitive.CheckboxItem\r\n ref={ref}\r\n className={cn(\r\n \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\r\n className\r\n )}\r\n checked={checked}\r\n {...props}\r\n >\r\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\r\n <DropdownMenuPrimitive.ItemIndicator>\r\n <Check className=\"h-4 w-4\" />\r\n </DropdownMenuPrimitive.ItemIndicator>\r\n </span>\r\n {children}\r\n </DropdownMenuPrimitive.CheckboxItem>\r\n))\r\nDropdownMenuCheckboxItem.displayName =\r\n DropdownMenuPrimitive.CheckboxItem.displayName\r\n\r\nconst DropdownMenuRadioItem = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.RadioItem>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.RadioItem>\r\n>(({ className, children, ...props }, ref) => (\r\n <DropdownMenuPrimitive.RadioItem\r\n ref={ref}\r\n className={cn(\r\n \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\r\n className\r\n )}\r\n {...props}\r\n >\r\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\r\n <DropdownMenuPrimitive.ItemIndicator>\r\n <Circle className=\"h-2 w-2 fill-current\" />\r\n </DropdownMenuPrimitive.ItemIndicator>\r\n </span>\r\n {children}\r\n </DropdownMenuPrimitive.RadioItem>\r\n))\r\nDropdownMenuRadioItem.displayName = DropdownMenuPrimitive.RadioItem.displayName\r\n\r\nconst DropdownMenuLabel = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.Label>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Label> & {\r\n inset?: boolean\r\n }\r\n>(({ className, inset, ...props }, ref) => (\r\n <DropdownMenuPrimitive.Label\r\n ref={ref}\r\n className={cn(\r\n \"px-2 py-1.5 text-sm font-semibold\",\r\n inset && \"pl-8\",\r\n className\r\n )}\r\n {...props}\r\n />\r\n))\r\nDropdownMenuLabel.displayName = DropdownMenuPrimitive.Label.displayName\r\n\r\nconst DropdownMenuSeparator = React.forwardRef<\r\n React.ElementRef<typeof DropdownMenuPrimitive.Separator>,\r\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Separator>\r\n>(({ className, ...props }, ref) => (\r\n <DropdownMenuPrimitive.Separator\r\n ref={ref}\r\n className={cn(\"-mx-1 my-1 h-px bg-muted\", className)}\r\n {...props}\r\n />\r\n))\r\nDropdownMenuSeparator.displayName = DropdownMenuPrimitive.Separator.displayName\r\n\r\nconst DropdownMenuShortcut = ({\r\n className,\r\n ...props\r\n}: React.HTMLAttributes<HTMLSpanElement>) => {\r\n return (\r\n <span\r\n className={cn(\"ml-auto text-xs tracking-widest opacity-60\", className)}\r\n {...props}\r\n />\r\n )\r\n}\r\nDropdownMenuShortcut.displayName = \"DropdownMenuShortcut\"\r\n\r\nexport {\r\n DropdownMenu,\r\n DropdownMenuTrigger,\r\n DropdownMenuContent,\r\n DropdownMenuItem,\r\n DropdownMenuCheckboxItem,\r\n DropdownMenuRadioItem,\r\n DropdownMenuLabel,\r\n DropdownMenuSeparator,\r\n DropdownMenuShortcut,\r\n DropdownMenuGroup,\r\n DropdownMenuPortal,\r\n DropdownMenuSub,\r\n DropdownMenuSubContent,\r\n DropdownMenuSubTrigger,\r\n DropdownMenuRadioGroup,\r\n DropdownMenuArrow,\r\n}\r\n"]}
|