react-toolkits 0.8.60 → 0.8.62
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/CHANGELOG.md +14 -1
- package/lib/{index-0fh4T-82.chunk.js → index-Jn5VaOqJ.chunk.js} +4 -4
- package/lib/{index-0fh4T-82.chunk.js.map → index-Jn5VaOqJ.chunk.js.map} +1 -1
- package/lib/{index-p8WXdnu_.chunk.js → index-OScTuQq5.chunk.js} +41 -41
- package/lib/index-OScTuQq5.chunk.js.map +1 -0
- package/lib/{index-wqEAgQbu.chunk.js → index-Oc3dh_ZN.chunk.js} +24 -24
- package/lib/index-Oc3dh_ZN.chunk.js.map +1 -0
- package/lib/{index-QEbb1ngP.chunk.js → index-k8GuuOCY.chunk.js} +1607 -1613
- package/lib/{index-QEbb1ngP.chunk.js.map → index-k8GuuOCY.chunk.js.map} +1 -1
- package/lib/{index-VvfM7Qb8.chunk.js → index-s9GwU8Ka.chunk.js} +3 -3
- package/lib/{index-VvfM7Qb8.chunk.js.map → index-s9GwU8Ka.chunk.js.map} +1 -1
- package/lib/index-tI7pd8AJ.chunk.js +219 -0
- package/lib/index-tI7pd8AJ.chunk.js.map +1 -0
- package/lib/index.d.ts +8 -17
- package/lib/index.js +13 -13
- package/package.json +1 -1
- package/lib/index-goOUs9qe.chunk.js +0 -213
- package/lib/index-goOUs9qe.chunk.js.map +0 -1
- package/lib/index-p8WXdnu_.chunk.js.map +0 -1
- package/lib/index-wqEAgQbu.chunk.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,10 +1,23 @@
|
|
|
1
1
|
# react-toolkits
|
|
2
2
|
|
|
3
|
+
## 0.8.62
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- b49f737: fix: http request not be triggered sometimes
|
|
8
|
+
|
|
9
|
+
## 0.8.61
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- a2c318a: chore: remove onRehydrateStorage
|
|
14
|
+
|
|
3
15
|
## 0.8.60
|
|
4
16
|
|
|
5
17
|
### Patch Changes
|
|
6
18
|
|
|
7
|
-
-
|
|
19
|
+
- 2060653: fix: data does not updated while game has changed
|
|
20
|
+
- 2060653: refactor: add useRequest hook
|
|
8
21
|
|
|
9
22
|
## 0.8.59
|
|
10
23
|
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { a as t, j as i } from "./index-
|
|
1
|
+
import { a as t, j as i } from "./index-k8GuuOCY.chunk.js";
|
|
2
2
|
import { Breadcrumb as m, Card as n, Skeleton as a, Descriptions as l } from "antd";
|
|
3
3
|
import { useParams as c, Link as x } from "react-router-dom";
|
|
4
|
-
import { P as j } from "./index-
|
|
5
|
-
import { g as p } from "./index-
|
|
4
|
+
import { P as j } from "./index-s9GwU8Ka.chunk.js";
|
|
5
|
+
import { g as p } from "./index-tI7pd8AJ.chunk.js";
|
|
6
6
|
import "react";
|
|
7
7
|
import "react-dom";
|
|
8
8
|
const k = () => {
|
|
@@ -37,4 +37,4 @@ const k = () => {
|
|
|
37
37
|
export {
|
|
38
38
|
k as default
|
|
39
39
|
};
|
|
40
|
-
//# sourceMappingURL=index-
|
|
40
|
+
//# sourceMappingURL=index-Jn5VaOqJ.chunk.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-
|
|
1
|
+
{"version":3,"file":"index-Jn5VaOqJ.chunk.js","sources":["../src/pages/permission/RoleDetail/index.tsx"],"sourcesContent":["import { Breadcrumb, Card, Descriptions, Skeleton } from 'antd'\nimport { Link, useParams } from 'react-router-dom'\nimport { PermissionList, useRole } from '../../../features/permission'\nimport { useTranslation } from '../../../hooks/i18n'\n\nconst RoleDetail = () => {\n const params = useParams()\n const { data, isLoading } = useRole(params.name as string)\n const t = useTranslation()\n\n return (\n <>\n <Breadcrumb\n style={{ marginBottom: 24 }}\n items={[\n {\n key: '1',\n title: <Link to=\"..\">{t('global.role')}</Link>,\n },\n {\n key: '2',\n title: params.name,\n },\n ]}\n />\n <Card title={t('RoleDetail.title')}>\n <Skeleton loading={isLoading}>\n <Descriptions column={3} layout=\"vertical\">\n <Descriptions.Item label={t('global.name')}>{data?.name}</Descriptions.Item>\n <Descriptions.Item label=\"ID\">{data?.id}</Descriptions.Item>\n <Descriptions.Item label={t('global.creationTime')}>{data?.ctime}</Descriptions.Item>\n </Descriptions>\n <PermissionList readonly value={data?.permissions} />\n </Skeleton>\n </Card>\n </>\n )\n}\n\nexport default RoleDetail\n"],"names":["RoleDetail","params","useParams","data","isLoading","useRole","t","useTranslation","jsxs","Fragment","jsx","Breadcrumb","Link","Card","Skeleton","Descriptions","PermissionList"],"mappings":";;;;;;;AAKA,MAAMA,IAAa,MAAM;AACvB,QAAMC,IAASC,KACT,EAAE,MAAAC,GAAM,WAAAC,EAAA,IAAcC,EAAQJ,EAAO,IAAc,GACnDK,IAAIC;AAEV,SAEIC,gBAAAA,EAAA,KAAAC,YAAA,EAAA,UAAA;AAAA,IAAAC,gBAAAA,EAAA;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,OAAO,EAAE,cAAc,GAAG;AAAA,QAC1B,OAAO;AAAA,UACL;AAAA,YACE,KAAK;AAAA,YACL,OAAQD,gBAAAA,EAAAA,IAAAE,GAAA,EAAK,IAAG,MAAM,UAAAN,EAAE,aAAa,GAAE;AAAA,UACzC;AAAA,UACA;AAAA,YACE,KAAK;AAAA,YACL,OAAOL,EAAO;AAAA,UAChB;AAAA,QACF;AAAA,MAAA;AAAA,IACF;AAAA,IACAS,gBAAAA,EAAAA,IAACG,KAAK,OAAOP,EAAE,kBAAkB,GAC/B,UAAAE,gBAAAA,EAAAA,KAACM,GAAS,EAAA,SAASV,GACjB,UAAA;AAAA,MAAAI,gBAAAA,EAAA,KAACO,GAAa,EAAA,QAAQ,GAAG,QAAO,YAC9B,UAAA;AAAA,QAACL,gBAAAA,EAAAA,IAAAK,EAAa,MAAb,EAAkB,OAAOT,EAAE,aAAa,GAAI,iCAAM,MAAK;AAAA,8BACvDS,EAAa,MAAb,EAAkB,OAAM,MAAM,iCAAM,IAAG;AAAA,QACxCL,gBAAAA,EAAAA,IAACK,EAAa,MAAb,EAAkB,OAAOT,EAAE,qBAAqB,GAAI,UAAAH,KAAA,gBAAAA,EAAM,OAAM;AAAA,MAAA,GACnE;AAAA,4BACCa,GAAe,EAAA,UAAQ,IAAC,OAAOb,KAAA,gBAAAA,EAAM,aAAa;AAAA,IAAA,EAAA,CACrD,EACF,CAAA;AAAA,EACF,EAAA,CAAA;AAEJ;"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { A as T, _ as R, u as j, a as b, j as e, P as
|
|
2
|
-
import { App as U, Row as
|
|
1
|
+
import { A as T, _ as R, u as j, a as b, j as e, P as g, H as z, Q as F, b as L } from "./index-k8GuuOCY.chunk.js";
|
|
2
|
+
import { App as U, Row as E, Col as G, Tag as w, Space as P, Card as D, Form as x, Input as S, Select as f } from "antd";
|
|
3
3
|
import { p as I } from "./immer-BLf7GM7E.chunk.js";
|
|
4
4
|
import { Link as N } from "react-router-dom";
|
|
5
|
-
import { u as Q, a as _, b as k, c as $ } from "./index-
|
|
5
|
+
import { u as Q, a as _, b as k, c as $ } from "./index-tI7pd8AJ.chunk.js";
|
|
6
6
|
import * as M from "react";
|
|
7
7
|
import "react-dom";
|
|
8
8
|
var q = { icon: { tag: "svg", attrs: { viewBox: "64 64 896 896", focusable: "false" }, children: [{ tag: "path", attrs: { d: "M678.3 642.4c24.2-13 51.9-20.4 81.4-20.4h.1c3 0 4.4-3.6 2.2-5.6a371.67 371.67 0 00-103.7-65.8c-.4-.2-.8-.3-1.2-.5C719.2 505 759.6 431.7 759.6 349c0-137-110.8-248-247.5-248S264.7 212 264.7 349c0 82.7 40.4 156 102.6 201.1-.4.2-.8.3-1.2.5-44.7 18.9-84.8 46-119.3 80.6a373.42 373.42 0 00-80.4 119.5A373.6 373.6 0 00137 888.8a8 8 0 008 8.2h59.9c4.3 0 7.9-3.5 8-7.8 2-77.2 32.9-149.5 87.6-204.3C357 628.2 432.2 597 512.2 597c56.7 0 111.1 15.7 158 45.1a8.1 8.1 0 008.1.3zM512.2 521c-45.8 0-88.9-17.9-121.4-50.4A171.2 171.2 0 01340.5 349c0-45.9 17.9-89.1 50.3-121.6S466.3 177 512.2 177s88.9 17.9 121.4 50.4A171.2 171.2 0 01683.9 349c0 45.9-17.9 89.1-50.3 121.6C601.1 503.1 558 521 512.2 521zM880 759h-84v-84c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v84h-84c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h84v84c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-84h84c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z" } }] }, name: "user-add", theme: "outlined" };
|
|
@@ -14,34 +14,34 @@ var O = function(i, n) {
|
|
|
14
14
|
}));
|
|
15
15
|
};
|
|
16
16
|
process.env.NODE_ENV !== "production" && (O.displayName = "UserAddOutlined");
|
|
17
|
-
const H = /* @__PURE__ */ M.forwardRef(O), { Option: K } =
|
|
17
|
+
const H = /* @__PURE__ */ M.forwardRef(O), { Option: K } = f, h = "/api/usystem/user/list";
|
|
18
18
|
function J() {
|
|
19
|
-
const { message: d } = U.useApp(), i = _(), { data: n, isLoading: u } = k(), {
|
|
19
|
+
const { message: d } = U.useApp(), i = _(), { data: n, isLoading: u } = k(), { refresh: m } = j(), a = b();
|
|
20
20
|
return L({
|
|
21
|
-
title:
|
|
21
|
+
title: a("UserList.createTitle"),
|
|
22
22
|
formProps: {
|
|
23
23
|
labelCol: { flex: "80px" }
|
|
24
24
|
},
|
|
25
25
|
content: /* @__PURE__ */ e.jsxs(e.Fragment, { children: [
|
|
26
|
-
/* @__PURE__ */ e.jsx(x.Item, { label:
|
|
27
|
-
/* @__PURE__ */ e.jsx(x.Item, { label:
|
|
26
|
+
/* @__PURE__ */ e.jsx(x.Item, { label: a("global.name"), name: "name", rules: [{ required: !0 }], children: /* @__PURE__ */ e.jsx(S, {}) }),
|
|
27
|
+
/* @__PURE__ */ e.jsx(x.Item, { label: a("global.role"), name: "roles", children: /* @__PURE__ */ e.jsx(f, { allowClear: !0, mode: "multiple", loading: u, children: (n ?? []).map((t) => /* @__PURE__ */ e.jsx(K, { value: t.name, children: t.name }, t.id)) }) })
|
|
28
28
|
] }),
|
|
29
29
|
async onConfirm(t) {
|
|
30
|
-
await i.trigger(t), m(
|
|
30
|
+
await i.trigger(t), m(h, 1), d.success(a("UserList.createSuccessfully"));
|
|
31
31
|
}
|
|
32
32
|
});
|
|
33
33
|
}
|
|
34
34
|
function W() {
|
|
35
|
-
const { message: d } = U.useApp(), i = $(), { data: n, isLoading: u } = k(), { mutate: m } = j(),
|
|
35
|
+
const { message: d } = U.useApp(), i = $(), { data: n, isLoading: u } = k(), { mutate: m } = j(), a = b();
|
|
36
36
|
return L({
|
|
37
|
-
title:
|
|
37
|
+
title: a("UserList.updateTitle"),
|
|
38
38
|
formProps: {
|
|
39
39
|
labelCol: { flex: "80px" }
|
|
40
40
|
},
|
|
41
41
|
content: /* @__PURE__ */ e.jsxs(e.Fragment, { children: [
|
|
42
|
-
/* @__PURE__ */ e.jsx(x.Item, { label:
|
|
43
|
-
/* @__PURE__ */ e.jsx(x.Item, { label:
|
|
44
|
-
|
|
42
|
+
/* @__PURE__ */ e.jsx(x.Item, { label: a("global.name"), name: "name", rules: [{ required: !0 }], children: /* @__PURE__ */ e.jsx(S, { readOnly: !0 }) }),
|
|
43
|
+
/* @__PURE__ */ e.jsx(x.Item, { label: a("global.role"), name: "roles", children: /* @__PURE__ */ e.jsx(
|
|
44
|
+
f,
|
|
45
45
|
{
|
|
46
46
|
allowClear: !0,
|
|
47
47
|
mode: "multiple",
|
|
@@ -55,8 +55,8 @@ function W() {
|
|
|
55
55
|
] }),
|
|
56
56
|
async onConfirm(t, p) {
|
|
57
57
|
await i.trigger(t), m(
|
|
58
|
-
|
|
59
|
-
(
|
|
58
|
+
h,
|
|
59
|
+
(o) => I(o, (c) => {
|
|
60
60
|
var s;
|
|
61
61
|
if (c != null && c.dataSource) {
|
|
62
62
|
const l = (s = c.dataSource) == null ? void 0 : s.findIndex((r) => r.id === (p == null ? void 0 : p.id));
|
|
@@ -64,14 +64,14 @@ function W() {
|
|
|
64
64
|
}
|
|
65
65
|
}),
|
|
66
66
|
{ revalidate: !1 }
|
|
67
|
-
), d.success(
|
|
67
|
+
), d.success(a("UserList.updateSuccessfully"));
|
|
68
68
|
}
|
|
69
69
|
});
|
|
70
70
|
}
|
|
71
71
|
const te = () => {
|
|
72
|
-
const { modal: d, message: i } = U.useApp(), n = Q(), { mutate: u } = j(), { show: m, modal:
|
|
72
|
+
const { modal: d, message: i } = U.useApp(), n = Q(), { mutate: u } = j(), { show: m, modal: a } = J(), { show: t, modal: p } = W(), o = b(), c = [
|
|
73
73
|
{
|
|
74
|
-
title:
|
|
74
|
+
title: o("global.name"),
|
|
75
75
|
dataIndex: "name",
|
|
76
76
|
key: "name"
|
|
77
77
|
},
|
|
@@ -81,26 +81,26 @@ const te = () => {
|
|
|
81
81
|
key: "id"
|
|
82
82
|
},
|
|
83
83
|
{
|
|
84
|
-
title:
|
|
84
|
+
title: o("global.role"),
|
|
85
85
|
dataIndex: "roles",
|
|
86
86
|
key: "roles",
|
|
87
87
|
width: "40%",
|
|
88
88
|
render(s) {
|
|
89
|
-
return /* @__PURE__ */ e.jsx(
|
|
89
|
+
return /* @__PURE__ */ e.jsx(E, { gutter: [4, 4], children: (s || []).map((l) => /* @__PURE__ */ e.jsx(G, { children: l === "root" ? /* @__PURE__ */ e.jsx(w, { color: "#f50", children: l }) : /* @__PURE__ */ e.jsx(w, { color: "#ff5a00", children: /* @__PURE__ */ e.jsx(N, { to: `/permission/role/${l}`, children: l }) }) }, l)) });
|
|
90
90
|
}
|
|
91
91
|
},
|
|
92
92
|
{
|
|
93
|
-
title:
|
|
93
|
+
title: o("global.creationTime"),
|
|
94
94
|
dataIndex: "Ctime",
|
|
95
95
|
key: "ctime"
|
|
96
96
|
},
|
|
97
97
|
{
|
|
98
|
-
title:
|
|
98
|
+
title: o("global.operation"),
|
|
99
99
|
width: 150,
|
|
100
100
|
align: "center",
|
|
101
|
-
render: (s) => /* @__PURE__ */ e.jsxs(
|
|
101
|
+
render: (s) => /* @__PURE__ */ e.jsxs(P, { children: [
|
|
102
102
|
/* @__PURE__ */ e.jsx(
|
|
103
|
-
|
|
103
|
+
g,
|
|
104
104
|
{
|
|
105
105
|
isGlobal: !0,
|
|
106
106
|
size: "small",
|
|
@@ -117,11 +117,11 @@ const te = () => {
|
|
|
117
117
|
}
|
|
118
118
|
});
|
|
119
119
|
},
|
|
120
|
-
children:
|
|
120
|
+
children: o("global.update")
|
|
121
121
|
}
|
|
122
122
|
),
|
|
123
123
|
/* @__PURE__ */ e.jsx(
|
|
124
|
-
|
|
124
|
+
g,
|
|
125
125
|
{
|
|
126
126
|
isGlobal: !0,
|
|
127
127
|
danger: !0,
|
|
@@ -130,21 +130,21 @@ const te = () => {
|
|
|
130
130
|
type: "link",
|
|
131
131
|
onClick: () => {
|
|
132
132
|
d.confirm({
|
|
133
|
-
title:
|
|
134
|
-
content: /* @__PURE__ */ e.jsx(z, { texts: [s.name], children:
|
|
133
|
+
title: o("UserList.deleteTitle"),
|
|
134
|
+
content: /* @__PURE__ */ e.jsx(z, { texts: [s.name], children: o("UserList.deleteContent", { user: s.name }) }),
|
|
135
135
|
async onOk() {
|
|
136
136
|
await n.trigger({
|
|
137
137
|
id: s.id,
|
|
138
138
|
name: s.name
|
|
139
|
-
}), u(
|
|
139
|
+
}), u(h, (l) => I(l, (r) => {
|
|
140
140
|
var C, A;
|
|
141
|
-
const
|
|
142
|
-
|
|
143
|
-
})), i.success(
|
|
141
|
+
const y = (C = r == null ? void 0 : r.dataSource) == null ? void 0 : C.findIndex((v) => v.id === s.id);
|
|
142
|
+
y && ((A = r == null ? void 0 : r.dataSource) == null || A.splice(y, 1));
|
|
143
|
+
})), i.success(o("UserList.deleteSuccessfully"));
|
|
144
144
|
}
|
|
145
145
|
});
|
|
146
146
|
},
|
|
147
|
-
children:
|
|
147
|
+
children: o("global.delete")
|
|
148
148
|
}
|
|
149
149
|
)
|
|
150
150
|
] })
|
|
@@ -154,9 +154,9 @@ const te = () => {
|
|
|
154
154
|
/* @__PURE__ */ e.jsx(
|
|
155
155
|
D,
|
|
156
156
|
{
|
|
157
|
-
title:
|
|
157
|
+
title: o("global.user"),
|
|
158
158
|
extra: /* @__PURE__ */ e.jsx(
|
|
159
|
-
|
|
159
|
+
g,
|
|
160
160
|
{
|
|
161
161
|
isGlobal: !0,
|
|
162
162
|
type: "primary",
|
|
@@ -165,7 +165,7 @@ const te = () => {
|
|
|
165
165
|
onClick: () => {
|
|
166
166
|
m();
|
|
167
167
|
},
|
|
168
|
-
children:
|
|
168
|
+
children: o("UserList.createTitle")
|
|
169
169
|
}
|
|
170
170
|
),
|
|
171
171
|
children: /* @__PURE__ */ e.jsx(
|
|
@@ -173,7 +173,7 @@ const te = () => {
|
|
|
173
173
|
{
|
|
174
174
|
isGlobal: !0,
|
|
175
175
|
code: "100001",
|
|
176
|
-
action:
|
|
176
|
+
action: h,
|
|
177
177
|
rowKey: "id",
|
|
178
178
|
columns: c,
|
|
179
179
|
getTotal: (s) => s.Total,
|
|
@@ -182,12 +182,12 @@ const te = () => {
|
|
|
182
182
|
)
|
|
183
183
|
}
|
|
184
184
|
),
|
|
185
|
-
|
|
185
|
+
a,
|
|
186
186
|
p
|
|
187
187
|
] });
|
|
188
188
|
};
|
|
189
189
|
export {
|
|
190
|
-
|
|
190
|
+
h as action,
|
|
191
191
|
te as default
|
|
192
192
|
};
|
|
193
|
-
//# sourceMappingURL=index-
|
|
193
|
+
//# sourceMappingURL=index-OScTuQq5.chunk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-OScTuQq5.chunk.js","sources":["../../../node_modules/.pnpm/@ant-design+icons-svg@4.3.2/node_modules/@ant-design/icons-svg/es/asn/UserAddOutlined.js","../../../node_modules/.pnpm/@ant-design+icons@5.2.6_react-dom@18.2.0_react@18.2.0/node_modules/@ant-design/icons/es/icons/UserAddOutlined.js","../src/pages/permission/UserList/index.tsx"],"sourcesContent":["// This icon file is generated automatically.\nvar UserAddOutlined = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"64 64 896 896\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M678.3 642.4c24.2-13 51.9-20.4 81.4-20.4h.1c3 0 4.4-3.6 2.2-5.6a371.67 371.67 0 00-103.7-65.8c-.4-.2-.8-.3-1.2-.5C719.2 505 759.6 431.7 759.6 349c0-137-110.8-248-247.5-248S264.7 212 264.7 349c0 82.7 40.4 156 102.6 201.1-.4.2-.8.3-1.2.5-44.7 18.9-84.8 46-119.3 80.6a373.42 373.42 0 00-80.4 119.5A373.6 373.6 0 00137 888.8a8 8 0 008 8.2h59.9c4.3 0 7.9-3.5 8-7.8 2-77.2 32.9-149.5 87.6-204.3C357 628.2 432.2 597 512.2 597c56.7 0 111.1 15.7 158 45.1a8.1 8.1 0 008.1.3zM512.2 521c-45.8 0-88.9-17.9-121.4-50.4A171.2 171.2 0 01340.5 349c0-45.9 17.9-89.1 50.3-121.6S466.3 177 512.2 177s88.9 17.9 121.4 50.4A171.2 171.2 0 01683.9 349c0 45.9-17.9 89.1-50.3 121.6C601.1 503.1 558 521 512.2 521zM880 759h-84v-84c0-4.4-3.6-8-8-8h-56c-4.4 0-8 3.6-8 8v84h-84c-4.4 0-8 3.6-8 8v56c0 4.4 3.6 8 8 8h84v84c0 4.4 3.6 8 8 8h56c4.4 0 8-3.6 8-8v-84h84c4.4 0 8-3.6 8-8v-56c0-4.4-3.6-8-8-8z\" } }] }, \"name\": \"user-add\", \"theme\": \"outlined\" };\nexport default UserAddOutlined;\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\n\nimport * as React from 'react';\nimport UserAddOutlinedSvg from \"@ant-design/icons-svg/es/asn/UserAddOutlined\";\nimport AntdIcon from \"../components/AntdIcon\";\nvar UserAddOutlined = function UserAddOutlined(props, ref) {\n return /*#__PURE__*/React.createElement(AntdIcon, _extends({}, props, {\n ref: ref,\n icon: UserAddOutlinedSvg\n }));\n};\nif (process.env.NODE_ENV !== 'production') {\n UserAddOutlined.displayName = 'UserAddOutlined';\n}\nexport default /*#__PURE__*/React.forwardRef(UserAddOutlined);","import { UserAddOutlined } from '@ant-design/icons'\nimport type { TableColumnsType } from 'antd'\nimport { App, Card, Col, Form, Input, Row, Select, Space, Tag } from 'antd'\nimport { produce } from 'immer'\nimport type { FC } from 'react'\nimport { Link } from 'react-router-dom'\nimport Highlight from '../../../components/Highlight'\nimport PermissionButton from '../../../components/PermissionButton'\nimport QueryList from '../../../components/QueryList'\nimport type { UserListItem } from '../../../features/permission'\nimport { useAllRoles, useCreateUser, useRemoveUser, useUpdateUser } from '../../../features/permission'\nimport { useFormModal } from '../../../hooks/formModal'\nimport { useTranslation } from '../../../hooks/i18n'\nimport { useQueryListStore } from '../../../stores/queryList'\n\nconst { Option } = Select\n\nexport const action = '/api/usystem/user/list'\n\nfunction useCreateModal() {\n const { message } = App.useApp()\n const create = useCreateUser()\n const { data: roles, isLoading } = useAllRoles()\n const { refresh } = useQueryListStore()\n const t = useTranslation()\n\n return useFormModal<{ id: string; name: string; roles: string[] }>({\n title: t('UserList.createTitle'),\n formProps: {\n labelCol: { flex: '80px' },\n },\n content: (\n <>\n <Form.Item label={t('global.name')} name=\"name\" rules={[{ required: true }]}>\n <Input />\n </Form.Item>\n <Form.Item label={t('global.role')} name=\"roles\">\n <Select allowClear mode=\"multiple\" loading={isLoading}>\n {(roles ?? []).map(role => (\n <Option value={role.name} key={role.id}>\n {role.name}\n </Option>\n ))}\n </Select>\n </Form.Item>\n </>\n ),\n async onConfirm(values) {\n await create.trigger(values)\n refresh(action, 1)\n message.success(t('UserList.createSuccessfully'))\n },\n })\n}\n\nfunction useUpdateUserModal() {\n const { message } = App.useApp()\n const update = useUpdateUser()\n const { data: roles, isLoading } = useAllRoles()\n const { mutate } = useQueryListStore()\n const t = useTranslation()\n\n return useFormModal<{ id: string; name: string; roles: string[] }, { id: string }>({\n title: t('UserList.updateTitle'),\n formProps: {\n labelCol: { flex: '80px' },\n },\n content: (\n <>\n <Form.Item label={t('global.name')} name=\"name\" rules={[{ required: true }]}>\n <Input readOnly />\n </Form.Item>\n <Form.Item label={t('global.role')} name=\"roles\">\n <Select\n allowClear\n mode=\"multiple\"\n loading={isLoading}\n options={roles?.map(role => ({\n label: role.name,\n value: role.name,\n }))}\n />\n </Form.Item>\n </>\n ),\n async onConfirm(values, extraValues) {\n await update.trigger(values)\n mutate<UserListItem>(\n action,\n prev => {\n return produce(prev, draft => {\n if (draft?.dataSource) {\n const index = draft.dataSource?.findIndex(item => item.id === extraValues?.id)\n if (index !== -1) {\n draft.dataSource[index].roles = values.roles\n }\n }\n })\n },\n { revalidate: false },\n )\n message.success(t('UserList.updateSuccessfully'))\n },\n })\n}\n\nconst UserList: FC = () => {\n const { modal, message } = App.useApp()\n const remove = useRemoveUser()\n const { mutate } = useQueryListStore()\n const { show: showCreateModal, modal: createModal } = useCreateModal()\n const { show: showUpdateModal, modal: updateModal } = useUpdateUserModal()\n const t = useTranslation()\n\n const columns: TableColumnsType<UserListItem> = [\n {\n title: t('global.name'),\n dataIndex: 'name',\n key: 'name',\n },\n {\n title: 'ID',\n dataIndex: 'id',\n key: 'id',\n },\n {\n title: t('global.role'),\n dataIndex: 'roles',\n key: 'roles',\n width: '40%',\n render(value: string[]) {\n return (\n <Row gutter={[4, 4]}>\n {(value || []).map((item: string) => (\n <Col key={item}>\n {item === 'root' ? (\n <Tag color=\"#f50\">{item}</Tag>\n ) : (\n <Tag color=\"#ff5a00\">\n <Link to={`/permission/role/${item}`}>{item}</Link>\n </Tag>\n )}\n </Col>\n ))}\n </Row>\n )\n },\n },\n {\n title: t('global.creationTime'),\n dataIndex: 'Ctime',\n key: 'ctime',\n },\n {\n title: t('global.operation'),\n width: 150,\n align: 'center',\n render: (value: UserListItem) => (\n <Space>\n <PermissionButton\n isGlobal\n size=\"small\"\n type=\"link\"\n code=\"100003\"\n onClick={() => {\n showUpdateModal({\n initialValues: {\n name: value.name,\n roles: value.roles,\n },\n extraValues: {\n id: value.id,\n },\n })\n }}\n >\n {t('global.update')}\n </PermissionButton>\n <PermissionButton\n isGlobal\n danger\n size=\"small\"\n code=\"100004\"\n type=\"link\"\n onClick={() => {\n modal.confirm({\n title: t('UserList.deleteTitle'),\n content: (\n <Highlight texts={[value.name]}>{t('UserList.deleteContent', { user: value.name })}</Highlight>\n ),\n async onOk() {\n await remove.trigger({\n id: value.id,\n name: value.name,\n })\n mutate(action, prev => {\n return produce(prev, draft => {\n const index = draft?.dataSource?.findIndex(item => item.id === value.id)\n if (index) {\n draft?.dataSource?.splice(index, 1)\n }\n })\n })\n message.success(t('UserList.deleteSuccessfully'))\n },\n })\n }}\n >\n {t('global.delete')}\n </PermissionButton>\n </Space>\n ),\n },\n ]\n\n return (\n <>\n <Card\n title={t('global.user')}\n extra={\n <PermissionButton\n isGlobal\n type=\"primary\"\n icon={<UserAddOutlined />}\n code=\"100002\"\n onClick={() => {\n showCreateModal()\n }}\n >\n {t('UserList.createTitle')}\n </PermissionButton>\n }\n >\n <QueryList<UserListItem, undefined, { List: UserListItem[]; Total: number }>\n isGlobal\n code=\"100001\"\n action={action}\n rowKey=\"id\"\n columns={columns}\n getTotal={response => response.Total}\n getDataSource={response => response.List}\n />\n </Card>\n {createModal}\n {updateModal}\n </>\n )\n}\n\nexport default UserList\n"],"names":["UserAddOutlined","UserAddOutlinedSvg","props","ref","React","AntdIcon","_extends","UserAddOutlined$1","Option","Select","action","useCreateModal","message","App","create","useCreateUser","roles","isLoading","useAllRoles","refresh","useQueryListStore","t","useTranslation","useFormModal","jsxs","Fragment","jsx","Form","Input","role","values","useUpdateUserModal","update","useUpdateUser","mutate","extraValues","prev","produce","draft","index","_a","item","UserList","modal","remove","useRemoveUser","showCreateModal","createModal","showUpdateModal","updateModal","columns","value","Row","Col","Tag","Link","Space","PermissionButton","Highlight","_b","Card","QueryList","response"],"mappings":"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","x_google_ignoreList":[0,1]}
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
import { A as
|
|
2
|
-
import { App as
|
|
1
|
+
import { A as U, _, c as z, d as P, u as y, a as f, e as $, j as e, P as j, H as F, Q as G, b as L } from "./index-k8GuuOCY.chunk.js";
|
|
2
|
+
import { App as b, Space as q, Card as B, Form as g, Input as A } from "antd";
|
|
3
3
|
import { p as k } from "./immer-BLf7GM7E.chunk.js";
|
|
4
4
|
import { Link as E } from "react-router-dom";
|
|
5
|
-
import { P as v } from "./index-
|
|
6
|
-
import { d as
|
|
5
|
+
import { P as v } from "./index-s9GwU8Ka.chunk.js";
|
|
6
|
+
import { d as D, e as N, f as Q } from "./index-tI7pd8AJ.chunk.js";
|
|
7
7
|
import * as I from "react";
|
|
8
8
|
import "react-dom";
|
|
9
|
-
var
|
|
10
|
-
const
|
|
9
|
+
var H = { icon: { tag: "svg", attrs: { viewBox: "64 64 896 896", focusable: "false" }, children: [{ tag: "path", attrs: { d: "M892 772h-80v-80c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v80h-80c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h80v80c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-80h80c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM373.5 498.4c-.9-8.7-1.4-17.5-1.4-26.4 0-15.9 1.5-31.4 4.3-46.5.7-3.6-1.2-7.3-4.5-8.8-13.6-6.1-26.1-14.5-36.9-25.1a127.54 127.54 0 01-38.7-95.4c.9-32.1 13.8-62.6 36.3-85.6 24.7-25.3 57.9-39.1 93.2-38.7 31.9.3 62.7 12.6 86 34.4 7.9 7.4 14.7 15.6 20.4 24.4 2 3.1 5.9 4.4 9.3 3.2 17.6-6.1 36.2-10.4 55.3-12.4 5.6-.6 8.8-6.6 6.3-11.6-32.5-64.3-98.9-108.7-175.7-109.9-110.8-1.7-203.2 89.2-203.2 200 0 62.8 28.9 118.8 74.2 155.5-31.8 14.7-61.1 35-86.5 60.4-54.8 54.7-85.8 126.9-87.8 204a8 8 0 008 8.2h56.1c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5 29.4-29.4 65.4-49.8 104.7-59.7 3.8-1.1 6.4-4.8 5.9-8.8zM824 472c0-109.4-87.9-198.3-196.9-200C516.3 270.3 424 361.2 424 472c0 62.8 29 118.8 74.2 155.5a300.95 300.95 0 00-86.4 60.4C357 742.6 326 814.8 324 891.8a8 8 0 008 8.2h56c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5C505.8 695.7 563 672 624 672c110.4 0 200-89.5 200-200zm-109.5 90.5C690.3 586.7 658.2 600 624 600s-66.3-13.3-90.5-37.5a127.26 127.26 0 01-37.5-91.8c.3-32.8 13.4-64.5 36.3-88 24-24.6 56.1-38.3 90.4-38.7 33.9-.3 66.8 12.9 91 36.6 24.8 24.3 38.4 56.8 38.4 91.4-.1 34.2-13.4 66.3-37.6 90.5z" } }] }, name: "usergroup-add", theme: "outlined" };
|
|
10
|
+
const K = H;
|
|
11
11
|
var M = function(r, a) {
|
|
12
|
-
return /* @__PURE__ */ I.createElement(
|
|
12
|
+
return /* @__PURE__ */ I.createElement(U, _({}, r, {
|
|
13
13
|
ref: a,
|
|
14
|
-
icon:
|
|
14
|
+
icon: K
|
|
15
15
|
}));
|
|
16
16
|
};
|
|
17
17
|
process.env.NODE_ENV !== "production" && (M.displayName = "UsergroupAddOutlined");
|
|
18
|
-
const
|
|
19
|
-
const { message: c } =
|
|
18
|
+
const J = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", W = () => {
|
|
19
|
+
const { message: c } = b.useApp(), { refresh: r } = y(), a = N(), n = f(), l = async (o) => {
|
|
20
20
|
await a.trigger({
|
|
21
21
|
name: `role_${o.name}`,
|
|
22
22
|
permissions: o.permissions
|
|
23
|
-
}), r(h,
|
|
23
|
+
}), r(h, 1), c.success(n("RoleList.createSuccessfully"));
|
|
24
24
|
};
|
|
25
25
|
return L({
|
|
26
26
|
title: n("RoleList.createTitle"),
|
|
@@ -34,8 +34,8 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
34
34
|
] }),
|
|
35
35
|
onConfirm: l
|
|
36
36
|
});
|
|
37
|
-
},
|
|
38
|
-
const { message: c } =
|
|
37
|
+
}, X = () => {
|
|
38
|
+
const { message: c } = b.useApp(), { mutate: r } = y(), a = Q(), n = f();
|
|
39
39
|
return L({
|
|
40
40
|
title: n("RoleList.updateTitle"),
|
|
41
41
|
width: "50vw",
|
|
@@ -59,8 +59,8 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
59
59
|
), c.success(n("RoleList.updateSuccessfully"));
|
|
60
60
|
}
|
|
61
61
|
});
|
|
62
|
-
},
|
|
63
|
-
const { accessible: c } =
|
|
62
|
+
}, ie = () => {
|
|
63
|
+
const { accessible: c } = z("200005", !0), { modal: r, message: a } = b.useApp(), { usePermissionApiV2: n } = P(), l = D(), { mutate: o } = y(), { show: x, modal: m } = W(), { show: u, modal: p } = X(), t = f(), S = $(), O = [
|
|
64
64
|
{
|
|
65
65
|
title: t("global.name"),
|
|
66
66
|
key: "name",
|
|
@@ -82,7 +82,7 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
82
82
|
title: t("global.operation"),
|
|
83
83
|
width: 150,
|
|
84
84
|
align: "center",
|
|
85
|
-
render: (s) => /* @__PURE__ */ e.jsxs(
|
|
85
|
+
render: (s) => /* @__PURE__ */ e.jsxs(q, { size: "small", children: [
|
|
86
86
|
/* @__PURE__ */ e.jsx(
|
|
87
87
|
j,
|
|
88
88
|
{
|
|
@@ -91,7 +91,7 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
91
91
|
size: "small",
|
|
92
92
|
type: "link",
|
|
93
93
|
onClick: async () => {
|
|
94
|
-
const { data: i } = await
|
|
94
|
+
const { data: i } = await S(
|
|
95
95
|
`/api/usystem/role/info${n ? "V2" : ""}?name=${s.name}`,
|
|
96
96
|
{ isGlobal: !0 }
|
|
97
97
|
);
|
|
@@ -119,14 +119,14 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
119
119
|
onClick: () => {
|
|
120
120
|
r.confirm({
|
|
121
121
|
title: t("RoleList.deleteTitle"),
|
|
122
|
-
content: /* @__PURE__ */ e.jsx(
|
|
122
|
+
content: /* @__PURE__ */ e.jsx(F, { texts: [s.name], children: t("RoleList.deleteContent", { role: s.name }) }),
|
|
123
123
|
async onOk() {
|
|
124
124
|
await l.trigger({
|
|
125
125
|
id: s.id,
|
|
126
126
|
name: s.name
|
|
127
127
|
}), o(h, (i) => k(i, (d) => {
|
|
128
128
|
var R, C;
|
|
129
|
-
const w = (R = d == null ? void 0 : d.dataSource) == null ? void 0 : R.findIndex((
|
|
129
|
+
const w = (R = d == null ? void 0 : d.dataSource) == null ? void 0 : R.findIndex((T) => T.id === s.id);
|
|
130
130
|
w && ((C = d == null ? void 0 : d.dataSource) == null || C.splice(w, 1));
|
|
131
131
|
})), a.success(t("RoleList.deleteSuccessfully"));
|
|
132
132
|
}
|
|
@@ -149,7 +149,7 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
149
149
|
isGlobal: !0,
|
|
150
150
|
type: "primary",
|
|
151
151
|
code: "200002",
|
|
152
|
-
icon: /* @__PURE__ */ e.jsx(
|
|
152
|
+
icon: /* @__PURE__ */ e.jsx(J, {}),
|
|
153
153
|
onClick: () => {
|
|
154
154
|
x();
|
|
155
155
|
},
|
|
@@ -157,11 +157,11 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
157
157
|
}
|
|
158
158
|
),
|
|
159
159
|
children: /* @__PURE__ */ e.jsx(
|
|
160
|
-
|
|
160
|
+
G,
|
|
161
161
|
{
|
|
162
162
|
isGlobal: !0,
|
|
163
163
|
rowKey: "name",
|
|
164
|
-
columns:
|
|
164
|
+
columns: O,
|
|
165
165
|
code: "200001",
|
|
166
166
|
action: h,
|
|
167
167
|
getTotal: (s) => s.Total,
|
|
@@ -175,6 +175,6 @@ const K = /* @__PURE__ */ I.forwardRef(M), h = "/api/usystem/role/list", J = ()
|
|
|
175
175
|
] });
|
|
176
176
|
};
|
|
177
177
|
export {
|
|
178
|
-
|
|
178
|
+
ie as default
|
|
179
179
|
};
|
|
180
|
-
//# sourceMappingURL=index-
|
|
180
|
+
//# sourceMappingURL=index-Oc3dh_ZN.chunk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-Oc3dh_ZN.chunk.js","sources":["../../../node_modules/.pnpm/@ant-design+icons-svg@4.3.2/node_modules/@ant-design/icons-svg/es/asn/UsergroupAddOutlined.js","../../../node_modules/.pnpm/@ant-design+icons@5.2.6_react-dom@18.2.0_react@18.2.0/node_modules/@ant-design/icons/es/icons/UsergroupAddOutlined.js","../src/pages/permission/RoleList/index.tsx"],"sourcesContent":["// This icon file is generated automatically.\nvar UsergroupAddOutlined = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"64 64 896 896\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M892 772h-80v-80c0-4.4-3.6-8-8-8h-48c-4.4 0-8 3.6-8 8v80h-80c-4.4 0-8 3.6-8 8v48c0 4.4 3.6 8 8 8h80v80c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8v-80h80c4.4 0 8-3.6 8-8v-48c0-4.4-3.6-8-8-8zM373.5 498.4c-.9-8.7-1.4-17.5-1.4-26.4 0-15.9 1.5-31.4 4.3-46.5.7-3.6-1.2-7.3-4.5-8.8-13.6-6.1-26.1-14.5-36.9-25.1a127.54 127.54 0 01-38.7-95.4c.9-32.1 13.8-62.6 36.3-85.6 24.7-25.3 57.9-39.1 93.2-38.7 31.9.3 62.7 12.6 86 34.4 7.9 7.4 14.7 15.6 20.4 24.4 2 3.1 5.9 4.4 9.3 3.2 17.6-6.1 36.2-10.4 55.3-12.4 5.6-.6 8.8-6.6 6.3-11.6-32.5-64.3-98.9-108.7-175.7-109.9-110.8-1.7-203.2 89.2-203.2 200 0 62.8 28.9 118.8 74.2 155.5-31.8 14.7-61.1 35-86.5 60.4-54.8 54.7-85.8 126.9-87.8 204a8 8 0 008 8.2h56.1c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5 29.4-29.4 65.4-49.8 104.7-59.7 3.8-1.1 6.4-4.8 5.9-8.8zM824 472c0-109.4-87.9-198.3-196.9-200C516.3 270.3 424 361.2 424 472c0 62.8 29 118.8 74.2 155.5a300.95 300.95 0 00-86.4 60.4C357 742.6 326 814.8 324 891.8a8 8 0 008 8.2h56c4.3 0 7.9-3.4 8-7.7 1.9-58 25.4-112.3 66.7-153.5C505.8 695.7 563 672 624 672c110.4 0 200-89.5 200-200zm-109.5 90.5C690.3 586.7 658.2 600 624 600s-66.3-13.3-90.5-37.5a127.26 127.26 0 01-37.5-91.8c.3-32.8 13.4-64.5 36.3-88 24-24.6 56.1-38.3 90.4-38.7 33.9-.3 66.8 12.9 91 36.6 24.8 24.3 38.4 56.8 38.4 91.4-.1 34.2-13.4 66.3-37.6 90.5z\" } }] }, \"name\": \"usergroup-add\", \"theme\": \"outlined\" };\nexport default UsergroupAddOutlined;\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\n\nimport * as React from 'react';\nimport UsergroupAddOutlinedSvg from \"@ant-design/icons-svg/es/asn/UsergroupAddOutlined\";\nimport AntdIcon from \"../components/AntdIcon\";\nvar UsergroupAddOutlined = function UsergroupAddOutlined(props, ref) {\n return /*#__PURE__*/React.createElement(AntdIcon, _extends({}, props, {\n ref: ref,\n icon: UsergroupAddOutlinedSvg\n }));\n};\nif (process.env.NODE_ENV !== 'production') {\n UsergroupAddOutlined.displayName = 'UsergroupAddOutlined';\n}\nexport default /*#__PURE__*/React.forwardRef(UsergroupAddOutlined);","import { UsergroupAddOutlined } from '@ant-design/icons'\nimport type { TableColumnsType } from 'antd'\nimport { App, Card, Form, Input, Space } from 'antd'\nimport { produce } from 'immer'\nimport { Link } from 'react-router-dom'\nimport { useToolkitsContext } from '../../../components/ContextProvider'\nimport Highlight from '../../../components/Highlight'\nimport PermissionButton from '../../../components/PermissionButton'\nimport QueryList from '../../../components/QueryList'\nimport type { RoleListItem, RoleV1, RoleV2 } from '../../../features/permission'\nimport { PermissionList, useCreateRole, useRemoveRole, useUpdateRole } from '../../../features/permission'\nimport { useFormModal } from '../../../hooks/formModal'\nimport { useTranslation } from '../../../hooks/i18n'\nimport { usePermission } from '../../../hooks/permission'\nimport { useRequest } from '../../../hooks/request'\nimport { useQueryListStore } from '../../../stores/queryList'\n\nconst action = '/api/usystem/role/list'\n\nconst useCreateModal = () => {\n const { message } = App.useApp()\n const { refresh } = useQueryListStore()\n const create = useCreateRole()\n const t = useTranslation()\n\n const onConfirm = async (values: { name: string; permissions: RoleV1['permissions'] | RoleV2['permissions'] }) => {\n await create.trigger({\n name: `role_${values.name}`,\n permissions: values.permissions,\n })\n refresh(action, 1)\n message.success(t('RoleList.createSuccessfully'))\n }\n\n return useFormModal<{\n name: string\n permissions: RoleV1['permissions'] | RoleV2['permissions']\n }>({\n title: t('RoleList.createTitle'),\n width: '50vw',\n formProps: {\n layout: 'vertical',\n },\n content: (\n <>\n <Form.Item label={t('global.name')} name=\"name\" rules={[{ required: true }]}>\n <Input addonBefore=\"role_\" />\n </Form.Item>\n <Form.Item name=\"permissions\">\n <PermissionList />\n </Form.Item>\n </>\n ),\n onConfirm,\n })\n}\n\nconst useUpdateModal = () => {\n const { message } = App.useApp()\n const { mutate } = useQueryListStore()\n const update = useUpdateRole()\n const t = useTranslation()\n\n return useFormModal<\n {\n name: string\n permissions: RoleV1['permissions'] | RoleV2['permissions']\n },\n {\n id: number\n }\n >({\n title: t('RoleList.updateTitle'),\n width: '50vw',\n content: (\n <>\n <Form.Item label={t('global.name')} name=\"name\" rules={[{ required: true }]}>\n <Input readOnly addonBefore=\"role_\" />\n </Form.Item>\n <Form.Item name=\"permissions\">\n <PermissionList />\n </Form.Item>\n </>\n ),\n onConfirm: async (values, extraValues) => {\n await update.trigger({\n id: extraValues?.id as number,\n name: `role_${values.name}`,\n permissions: values.permissions,\n })\n mutate(\n action,\n prev =>\n produce(prev, draft => {\n const match = draft?.dataSource?.find(item => item.id === extraValues?.id)\n\n if (match) {\n match.permissions = values.permissions\n }\n }),\n { revalidate: false },\n )\n message.success(t('RoleList.updateSuccessfully'))\n },\n })\n}\n\nconst RoleList = () => {\n const { accessible: viewable } = usePermission('200005', true)\n const { modal, message } = App.useApp()\n const { usePermissionApiV2 } = useToolkitsContext()\n const remove = useRemoveRole()\n const { mutate } = useQueryListStore()\n const { show: showCreateModal, modal: createModal } = useCreateModal()\n const { show: showUpdateModal, modal: updateModal } = useUpdateModal()\n const t = useTranslation()\n const request = useRequest()\n\n const columns: TableColumnsType<RoleListItem> = [\n {\n title: t('global.name'),\n key: 'name',\n render(value: RoleListItem) {\n if (viewable) {\n return (\n <Link to={`${value.name}`} relative=\"path\">\n {value.name}\n </Link>\n )\n } else {\n return <>{value.name}</>\n }\n },\n },\n {\n title: 'ID',\n dataIndex: 'id',\n key: 'id',\n },\n {\n title: t('global.creationTime'),\n dataIndex: 'ctime',\n key: 'ctime',\n },\n {\n title: t('global.operation'),\n width: 150,\n align: 'center',\n render: (value: RoleListItem) => {\n return (\n <Space size=\"small\">\n <PermissionButton\n isGlobal\n code=\"200003\"\n size=\"small\"\n type=\"link\"\n onClick={async () => {\n const { data: role } = await request<RoleV1 | RoleV2>(\n `/api/usystem/role/info${usePermissionApiV2 ? 'V2' : ''}?name=${value.name}`,\n { isGlobal: true },\n )\n showUpdateModal({\n initialValues: {\n permissions: role?.permissions,\n name: role?.name.replace(/^role_/, ''),\n },\n extraValues: {\n id: role?.id,\n },\n })\n }}\n >\n {t('global.edit')}\n </PermissionButton>\n <PermissionButton\n isGlobal\n danger\n code=\"200004\"\n size=\"small\"\n type=\"link\"\n onClick={() => {\n modal.confirm({\n title: t('RoleList.deleteTitle'),\n content: (\n <Highlight texts={[value.name]}>{t('RoleList.deleteContent', { role: value.name })}</Highlight>\n ),\n async onOk() {\n await remove.trigger({\n id: value.id,\n name: value.name,\n })\n mutate(action, prev => {\n return produce(prev, draft => {\n const index = draft?.dataSource?.findIndex(item => item.id === value.id)\n if (index) {\n draft?.dataSource?.splice(index, 1)\n }\n })\n })\n message.success(t('RoleList.deleteSuccessfully'))\n },\n })\n }}\n >\n {t('global.delete')}\n </PermissionButton>\n </Space>\n )\n },\n },\n ]\n\n return (\n <>\n <Card\n title={t('global.role')}\n extra={\n <PermissionButton\n isGlobal\n type=\"primary\"\n code=\"200002\"\n icon={<UsergroupAddOutlined />}\n onClick={() => {\n showCreateModal()\n }}\n >\n {t('RoleList.createTitle')}\n </PermissionButton>\n }\n >\n <QueryList<RoleListItem, undefined, { List: RoleListItem[]; Total: number }>\n isGlobal\n rowKey=\"name\"\n columns={columns}\n code=\"200001\"\n action={action}\n getTotal={response => response.Total}\n getDataSource={response => response.List}\n />\n </Card>\n {createModal}\n {updateModal}\n </>\n )\n}\n\nexport default RoleList\n"],"names":["UsergroupAddOutlined","UsergroupAddOutlinedSvg","props","ref","React","AntdIcon","_extends","UsergroupAddOutlined$1","action","useCreateModal","message","App","refresh","useQueryListStore","create","useCreateRole","t","useTranslation","onConfirm","values","useFormModal","jsxs","Fragment","jsx","Form","Input","PermissionList","useUpdateModal","mutate","update","useUpdateRole","extraValues","prev","produce","draft","match","_a","item","RoleList","viewable","usePermission","modal","usePermissionApiV2","useToolkitsContext","remove","useRemoveRole","showCreateModal","createModal","showUpdateModal","updateModal","request","useRequest","columns","value","Link","Space","PermissionButton","role","Highlight","index","_b","Card","QueryList","response"],"mappings":";;;;;;;;AACA,IAAIA,IAAuB,EAAE,MAAQ,EAAE,KAAO,OAAO,OAAS,EAAE,SAAW,iBAAiB,WAAa,QAAS,GAAE,UAAY,CAAC,EAAE,KAAO,QAAQ,OAAS,EAAE,GAAK,4wCAA2wC,GAAI,EAAC,GAAI,MAAQ,iBAAiB,OAAS,WAAU;AACl+C,MAAAC,IAAeD;ACKf,IAAIA,IAAuB,SAA8BE,GAAOC,GAAK;AACnE,SAAoB,gBAAAC,EAAM,cAAcC,GAAUC,EAAS,CAAA,GAAIJ,GAAO;AAAA,IACpE,KAAKC;AAAA,IACL,MAAMF;AAAA,EACP,CAAA,CAAC;AACJ;AACI,QAAQ,IAAI,aAAa,iBAC3BD,EAAqB,cAAc;AAErC,MAAAO,IAA4B,gBAAAH,EAAM,WAAWJ,CAAoB,GCC3DQ,IAAS,0BAETC,IAAiB,MAAM;AAC3B,QAAM,EAAE,SAAAC,EAAA,IAAYC,EAAI,OAAO,GACzB,EAAE,SAAAC,MAAYC,KACdC,IAASC,KACTC,IAAIC,KAEJC,IAAY,OAAOC,MAAyF;AAChH,UAAML,EAAO,QAAQ;AAAA,MACnB,MAAM,QAAQK,EAAO,IAAI;AAAA,MACzB,aAAaA,EAAO;AAAA,IAAA,CACrB,GACDP,EAAQJ,GAAQ,CAAC,GACTE,EAAA,QAAQM,EAAE,6BAA6B,CAAC;AAAA,EAAA;AAGlD,SAAOI,EAGJ;AAAA,IACD,OAAOJ,EAAE,sBAAsB;AAAA,IAC/B,OAAO;AAAA,IACP,WAAW;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,IACA,SAEIK,gBAAAA,EAAA,KAAAC,YAAA,EAAA,UAAA;AAAA,MAACC,gBAAAA,MAAAC,EAAK,MAAL,EAAU,OAAOR,EAAE,aAAa,GAAG,MAAK,QAAO,OAAO,CAAC,EAAE,UAAU,IAAM,GACxE,gCAACS,GAAM,EAAA,aAAY,QAAQ,CAAA,GAC7B;AAAA,MACAF,gBAAAA,EAAAA,IAACC,EAAK,MAAL,EAAU,MAAK,eACd,UAAAD,gBAAAA,MAACG,IAAe,CAAA,GAClB;AAAA,IAAA,GACF;AAAA,IAEF,WAAAR;AAAA,EAAA,CACD;AACH,GAEMS,IAAiB,MAAM;AAC3B,QAAM,EAAE,SAAAjB,EAAA,IAAYC,EAAI,OAAO,GACzB,EAAE,QAAAiB,MAAWf,KACbgB,IAASC,KACTd,IAAIC;AAEV,SAAOG,EAQL;AAAA,IACA,OAAOJ,EAAE,sBAAsB;AAAA,IAC/B,OAAO;AAAA,IACP,SAEIK,gBAAAA,EAAA,KAAAC,YAAA,EAAA,UAAA;AAAA,MAACC,gBAAAA,EAAAA,IAAAC,EAAK,MAAL,EAAU,OAAOR,EAAE,aAAa,GAAG,MAAK,QAAO,OAAO,CAAC,EAAE,UAAU,IAAM,GACxE,UAAAO,gBAAAA,EAAAA,IAACE,KAAM,UAAQ,IAAC,aAAY,QAAA,CAAQ,EACtC,CAAA;AAAA,MACAF,gBAAAA,EAAAA,IAACC,EAAK,MAAL,EAAU,MAAK,eACd,UAAAD,gBAAAA,MAACG,IAAe,CAAA,GAClB;AAAA,IAAA,GACF;AAAA,IAEF,WAAW,OAAOP,GAAQY,MAAgB;AACxC,YAAMF,EAAO,QAAQ;AAAA,QACnB,IAAIE,KAAA,gBAAAA,EAAa;AAAA,QACjB,MAAM,QAAQZ,EAAO,IAAI;AAAA,QACzB,aAAaA,EAAO;AAAA,MAAA,CACrB,GACDS;AAAA,QACEpB;AAAA,QACA,CAAAwB,MACEC,EAAQD,GAAM,CAASE,MAAA;;AACf,gBAAAC,KAAQC,IAAAF,KAAA,gBAAAA,EAAO,eAAP,gBAAAE,EAAmB,KAAK,OAAQC,EAAK,QAAON,KAAA,gBAAAA,EAAa;AAEvE,UAAII,MACFA,EAAM,cAAchB,EAAO;AAAA,QAC7B,CACD;AAAA,QACH,EAAE,YAAY,GAAM;AAAA,MAAA,GAEdT,EAAA,QAAQM,EAAE,6BAA6B,CAAC;AAAA,IAClD;AAAA,EAAA,CACD;AACH,GAEMsB,KAAW,MAAM;AACrB,QAAM,EAAE,YAAYC,EAAA,IAAaC,EAAc,UAAU,EAAI,GACvD,EAAE,OAAAC,GAAO,SAAA/B,EAAQ,IAAIC,EAAI,OAAO,GAChC,EAAE,oBAAA+B,MAAuBC,KACzBC,IAASC,KACT,EAAE,QAAAjB,MAAWf,KACb,EAAE,MAAMiC,GAAiB,OAAOC,EAAA,IAAgBtC,KAChD,EAAE,MAAMuC,GAAiB,OAAOC,EAAA,IAAgBtB,KAChD,IAAIV,KACJiC,IAAUC,KAEVC,IAA0C;AAAA,IAC9C;AAAA,MACE,OAAO,EAAE,aAAa;AAAA,MACtB,KAAK;AAAA,MACL,OAAOC,GAAqB;AAC1B,eAAId,IAEAhB,gBAAAA,EAAA,IAAC+B,GAAK,EAAA,IAAI,GAAGD,EAAM,IAAI,IAAI,UAAS,QACjC,UAAAA,EAAM,KACT,CAAA,IAGK9B,gBAAAA,EAAAA,IAAAD,EAAAA,UAAA,EAAG,YAAM,KAAK,CAAA;AAAA,MAEzB;AAAA,IACF;AAAA,IACA;AAAA,MACE,OAAO;AAAA,MACP,WAAW;AAAA,MACX,KAAK;AAAA,IACP;AAAA,IACA;AAAA,MACE,OAAO,EAAE,qBAAqB;AAAA,MAC9B,WAAW;AAAA,MACX,KAAK;AAAA,IACP;AAAA,IACA;AAAA,MACE,OAAO,EAAE,kBAAkB;AAAA,MAC3B,OAAO;AAAA,MACP,OAAO;AAAA,MACP,QAAQ,CAAC+B,MAELhC,gBAAAA,EAAA,KAACkC,GAAM,EAAA,MAAK,SACV,UAAA;AAAA,QAAAhC,gBAAAA,EAAA;AAAA,UAACiC;AAAA,UAAA;AAAA,YACC,UAAQ;AAAA,YACR,MAAK;AAAA,YACL,MAAK;AAAA,YACL,MAAK;AAAA,YACL,SAAS,YAAY;AACnB,oBAAM,EAAE,MAAMC,EAAK,IAAI,MAAMP;AAAA,gBAC3B,yBAAyBR,IAAqB,OAAO,EAAE,SAASW,EAAM,IAAI;AAAA,gBAC1E,EAAE,UAAU,GAAK;AAAA,cAAA;AAEH,cAAAL,EAAA;AAAA,gBACd,eAAe;AAAA,kBACb,aAAaS,KAAA,gBAAAA,EAAM;AAAA,kBACnB,MAAMA,KAAA,gBAAAA,EAAM,KAAK,QAAQ,UAAU;AAAA,gBACrC;AAAA,gBACA,aAAa;AAAA,kBACX,IAAIA,KAAA,gBAAAA,EAAM;AAAA,gBACZ;AAAA,cAAA,CACD;AAAA,YACH;AAAA,YAEC,YAAE,aAAa;AAAA,UAAA;AAAA,QAClB;AAAA,QACAlC,gBAAAA,EAAA;AAAA,UAACiC;AAAA,UAAA;AAAA,YACC,UAAQ;AAAA,YACR,QAAM;AAAA,YACN,MAAK;AAAA,YACL,MAAK;AAAA,YACL,MAAK;AAAA,YACL,SAAS,MAAM;AACb,cAAAf,EAAM,QAAQ;AAAA,gBACZ,OAAO,EAAE,sBAAsB;AAAA,gBAC/B,SACElB,gBAAAA,EAAA,IAACmC,GAAU,EAAA,OAAO,CAACL,EAAM,IAAI,GAAI,UAAA,EAAE,0BAA0B,EAAE,MAAMA,EAAM,KAAM,CAAA,GAAE;AAAA,gBAErF,MAAM,OAAO;AACX,wBAAMT,EAAO,QAAQ;AAAA,oBACnB,IAAIS,EAAM;AAAA,oBACV,MAAMA,EAAM;AAAA,kBAAA,CACb,GACDzB,EAAOpB,GAAQ,CAAQwB,MACdC,EAAQD,GAAM,CAASE,MAAA;;AACtB,0BAAAyB,KAAQvB,IAAAF,KAAA,gBAAAA,EAAO,eAAP,gBAAAE,EAAmB,UAAU,OAAQC,EAAK,OAAOgB,EAAM;AACrE,oBAAIM,OACKC,IAAA1B,KAAA,gBAAAA,EAAA,eAAA,QAAA0B,EAAY,OAAOD,GAAO;AAAA,kBACnC,CACD,CACF,GACOjD,EAAA,QAAQ,EAAE,6BAA6B,CAAC;AAAA,gBAClD;AAAA,cAAA,CACD;AAAA,YACH;AAAA,YAEC,YAAE,eAAe;AAAA,UAAA;AAAA,QACpB;AAAA,MACF,EAAA,CAAA;AAAA,IAGN;AAAA,EAAA;AAGF,SAEIW,gBAAAA,EAAA,KAAAC,YAAA,EAAA,UAAA;AAAA,IAAAC,gBAAAA,EAAA;AAAA,MAACsC;AAAA,MAAA;AAAA,QACC,OAAO,EAAE,aAAa;AAAA,QACtB,OACEtC,gBAAAA,EAAA;AAAA,UAACiC;AAAA,UAAA;AAAA,YACC,UAAQ;AAAA,YACR,MAAK;AAAA,YACL,MAAK;AAAA,YACL,4BAAOxD,GAAqB,EAAA;AAAA,YAC5B,SAAS,MAAM;AACG,cAAA8C;YAClB;AAAA,YAEC,YAAE,sBAAsB;AAAA,UAAA;AAAA,QAC3B;AAAA,QAGF,UAAAvB,gBAAAA,EAAA;AAAA,UAACuC;AAAA,UAAA;AAAA,YACC,UAAQ;AAAA,YACR,QAAO;AAAA,YACP,SAAAV;AAAA,YACA,MAAK;AAAA,YACL,QAAA5C;AAAA,YACA,UAAU,OAAYuD,EAAS;AAAA,YAC/B,eAAe,OAAYA,EAAS;AAAA,UAAA;AAAA,QACtC;AAAA,MAAA;AAAA,IACF;AAAA,IACChB;AAAA,IACAE;AAAA,EACH,EAAA,CAAA;AAEJ;","x_google_ignoreList":[0,1]}
|