react-toolkits 2.24.19 → 2.24.20
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 +6 -0
- package/README.md +14 -0
- package/lib/chunk-3VI7KSDA.js +2 -0
- package/lib/{chunk-H5Y4DYUL.js.map → chunk-3VI7KSDA.js.map} +1 -1
- package/lib/chunk-3ZT3BOPJ.js +3 -0
- package/lib/chunk-3ZT3BOPJ.js.map +1 -0
- package/lib/{chunk-D75NVCYN.js → chunk-D5OM3OZU.js} +2 -2
- package/lib/{chunk-D75NVCYN.js.map → chunk-D5OM3OZU.js.map} +1 -1
- package/lib/chunk-F3OT6ENF.js +2 -0
- package/lib/{chunk-UPO7NB6O.js.map → chunk-F3OT6ENF.js.map} +1 -1
- package/lib/chunk-FD52RBG7.js +2 -0
- package/lib/{chunk-ZF7POJAA.js.map → chunk-FD52RBG7.js.map} +1 -1
- package/lib/{chunk-ST7VUWJ4.js → chunk-IWPBGSXS.js} +2 -2
- package/lib/{chunk-ST7VUWJ4.js.map → chunk-IWPBGSXS.js.map} +1 -1
- package/lib/chunk-S4LUEDFA.js +2 -0
- package/lib/{chunk-NNXVZIY2.js.map → chunk-S4LUEDFA.js.map} +1 -1
- package/lib/chunk-SMBHLRAO.js +2 -0
- package/lib/chunk-SMBHLRAO.js.map +1 -0
- package/lib/chunk-XX2BCZJU.js +2 -0
- package/lib/{chunk-MTRFNFEM.js.map → chunk-XX2BCZJU.js.map} +1 -1
- package/lib/{createMenuItem-SXFYDNCW.js → createMenuItem-5DDIEELO.js} +2 -2
- package/lib/{createMenuItem-SXFYDNCW.js.map → createMenuItem-5DDIEELO.js.map} +1 -1
- package/lib/index.css +1 -1
- package/lib/index.d.ts +9 -2
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/lib/{menuItemList-NIBRDRTA.js → menuItemList-4ZLZ7HSG.js} +2 -2
- package/lib/{menuItemList-NIBRDRTA.js.map → menuItemList-4ZLZ7HSG.js.map} +1 -1
- package/lib/{roleDetail-7HEBW7IS.js → roleDetail-42BOHDFS.js} +2 -2
- package/lib/{roleDetail-7HEBW7IS.js.map → roleDetail-42BOHDFS.js.map} +1 -1
- package/lib/{roleList-WGLD3HXB.js → roleList-KWWO3IFL.js} +2 -2
- package/lib/{roleList-WGLD3HXB.js.map → roleList-KWWO3IFL.js.map} +1 -1
- package/lib/updateMenuItem-E5QMBR2S.js +2 -0
- package/lib/{updateMenuItem-TECCUD6Z.js.map → updateMenuItem-E5QMBR2S.js.map} +1 -1
- package/lib/userDetail-L7Q3C67K.js +2 -0
- package/lib/{userDetail-WGQJ7IC5.js.map → userDetail-L7Q3C67K.js.map} +1 -1
- package/lib/userList-IU4L5YRJ.js +2 -0
- package/lib/{userList-2S2FRAG6.js.map → userList-IU4L5YRJ.js.map} +1 -1
- package/locale/context.js +1 -7
- package/locale/context.js.map +1 -1
- package/locale/en_GB.js +1 -94
- package/locale/en_GB.js.map +1 -1
- package/locale/hooks.js +1 -18
- package/locale/hooks.js.map +1 -1
- package/locale/index.js +1 -2
- package/locale/ja_JP.js +1 -94
- package/locale/ja_JP.js.map +1 -1
- package/locale/ko_KR.js +1 -94
- package/locale/ko_KR.js.map +1 -1
- package/locale/zh_CN.js +1 -94
- package/locale/zh_CN.js.map +1 -1
- package/package.json +1 -1
- package/lib/chunk-7X2LW6EY.js +0 -73
- package/lib/chunk-7X2LW6EY.js.map +0 -1
- package/lib/chunk-DLTAWT6S.js +0 -2
- package/lib/chunk-DLTAWT6S.js.map +0 -1
- package/lib/chunk-E6L6VKSV.js +0 -227
- package/lib/chunk-E6L6VKSV.js.map +0 -1
- package/lib/chunk-ESCBNFWD.js +0 -498
- package/lib/chunk-ESCBNFWD.js.map +0 -1
- package/lib/chunk-FSXYUF4U.js +0 -276
- package/lib/chunk-FSXYUF4U.js.map +0 -1
- package/lib/chunk-H5Y4DYUL.js +0 -2
- package/lib/chunk-LXMQLSQY.js +0 -46
- package/lib/chunk-LXMQLSQY.js.map +0 -1
- package/lib/chunk-MTRFNFEM.js +0 -2
- package/lib/chunk-NNXVZIY2.js +0 -2
- package/lib/chunk-OH74GXG4.js +0 -570
- package/lib/chunk-OH74GXG4.js.map +0 -1
- package/lib/chunk-P25BHLH3.js +0 -3
- package/lib/chunk-P25BHLH3.js.map +0 -1
- package/lib/chunk-QACSRYJY.js +0 -147
- package/lib/chunk-QACSRYJY.js.map +0 -1
- package/lib/chunk-UPO7NB6O.js +0 -2
- package/lib/chunk-Z6PDWY44.js +0 -17
- package/lib/chunk-Z6PDWY44.js.map +0 -1
- package/lib/chunk-ZF7POJAA.js +0 -2
- package/lib/chunk-ZOHMJAAX.js +0 -120
- package/lib/chunk-ZOHMJAAX.js.map +0 -1
- package/lib/createMenuItem-CICLQWU6.js +0 -86
- package/lib/createMenuItem-CICLQWU6.js.map +0 -1
- package/lib/menuItemList-EHQSS4YZ.js +0 -132
- package/lib/menuItemList-EHQSS4YZ.js.map +0 -1
- package/lib/roleDetail-JCDOXKAM.js +0 -72
- package/lib/roleDetail-JCDOXKAM.js.map +0 -1
- package/lib/roleList-4C77ULPK.js +0 -161
- package/lib/roleList-4C77ULPK.js.map +0 -1
- package/lib/updateMenuItem-K62CKVXP.js +0 -109
- package/lib/updateMenuItem-K62CKVXP.js.map +0 -1
- package/lib/updateMenuItem-TECCUD6Z.js +0 -2
- package/lib/userDetail-WGQJ7IC5.js +0 -2
- package/lib/userDetail-WYN52ZJ2.js +0 -116
- package/lib/userDetail-WYN52ZJ2.js.map +0 -1
- package/lib/userList-2S2FRAG6.js +0 -2
- package/lib/userList-AMVG7RCE.js +0 -195
- package/lib/userList-AMVG7RCE.js.map +0 -1
package/lib/chunk-E6L6VKSV.js
DELETED
|
@@ -1,227 +0,0 @@
|
|
|
1
|
-
import { useAllRoles, useCreateUser, useUpdateUser } from './chunk-QACSRYJY.js';
|
|
2
|
-
import { useFormModal } from './chunk-ZOHMJAAX.js';
|
|
3
|
-
import { useTranslation } from './chunk-Z6PDWY44.js';
|
|
4
|
-
import { __name, useToolkitsStore, useKy, queryKeys, WILDCARD } from './chunk-OH74GXG4.js';
|
|
5
|
-
import { MinusCircleOutlined } from '@ant-design/icons';
|
|
6
|
-
import { useQuery } from '@tanstack/react-query';
|
|
7
|
-
import { Typography, App, Form, Input, Select, Row, Col, Empty, Button } from 'antd';
|
|
8
|
-
import { last, first } from 'lodash-es';
|
|
9
|
-
import { Fragment as Fragment$1 } from 'react';
|
|
10
|
-
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
11
|
-
|
|
12
|
-
var { Text } = Typography;
|
|
13
|
-
var handleWildcardSelection = /* @__PURE__ */ __name((value, onChange) => {
|
|
14
|
-
if (last(value) === WILDCARD) {
|
|
15
|
-
onChange?.([WILDCARD]);
|
|
16
|
-
} else if (first(value) === WILDCARD) {
|
|
17
|
-
onChange?.(value.slice(1));
|
|
18
|
-
} else {
|
|
19
|
-
onChange?.(value);
|
|
20
|
-
}
|
|
21
|
-
}, "handleWildcardSelection");
|
|
22
|
-
var GroupSelect = /* @__PURE__ */ __name((props) => {
|
|
23
|
-
const { onChange, ...rest } = props;
|
|
24
|
-
const ky = useKy();
|
|
25
|
-
const { data, isLoading } = useQuery({
|
|
26
|
-
queryKey: queryKeys.enums.gameGroups,
|
|
27
|
-
queryFn: /* @__PURE__ */ __name(() => ky.get("/api/enum/get?enum=game_group&type=all"), "queryFn")
|
|
28
|
-
});
|
|
29
|
-
const options = [{ label: "\u901A\u7528", value: WILDCARD }].concat(
|
|
30
|
-
data?.map((group) => ({ label: group, value: group })) ?? []
|
|
31
|
-
);
|
|
32
|
-
return /* @__PURE__ */ jsx(
|
|
33
|
-
Select,
|
|
34
|
-
{
|
|
35
|
-
...rest,
|
|
36
|
-
allowClear: true,
|
|
37
|
-
showSearch: true,
|
|
38
|
-
mode: "tags",
|
|
39
|
-
optionFilterProp: "label",
|
|
40
|
-
loading: isLoading,
|
|
41
|
-
options,
|
|
42
|
-
onChange: (value) => handleWildcardSelection(value, onChange)
|
|
43
|
-
}
|
|
44
|
-
);
|
|
45
|
-
}, "GroupSelect");
|
|
46
|
-
var GameSelect = /* @__PURE__ */ __name((props) => {
|
|
47
|
-
const { groups, onChange, ...rest } = props;
|
|
48
|
-
const ky = useKy();
|
|
49
|
-
const { permissionVersion } = useToolkitsStore();
|
|
50
|
-
const isV3 = permissionVersion === "v3" /* V3 */;
|
|
51
|
-
const isV4 = permissionVersion === "v4" /* V4 */;
|
|
52
|
-
const { data, isLoading } = useQuery({
|
|
53
|
-
queryKey: queryKeys.enums.gameIds(isV4 ? [] : groups ?? []),
|
|
54
|
-
queryFn: /* @__PURE__ */ __name(() => ky.get(`/api/enum/game_group/get_game_ids${isV4 ? "" : `?game_groups=${groups?.join(",")}`}`).then((response) => response?.list), "queryFn"),
|
|
55
|
-
enabled: isV4 || isV3 && !!groups?.length
|
|
56
|
-
});
|
|
57
|
-
const options = data?.map((group) => ({ label: group.name, value: group.id }));
|
|
58
|
-
return /* @__PURE__ */ jsx(
|
|
59
|
-
Select,
|
|
60
|
-
{
|
|
61
|
-
...rest,
|
|
62
|
-
allowClear: true,
|
|
63
|
-
showSearch: true,
|
|
64
|
-
optionFilterProp: "label",
|
|
65
|
-
mode: "tags",
|
|
66
|
-
loading: isLoading,
|
|
67
|
-
options,
|
|
68
|
-
onChange: (value) => handleWildcardSelection(value, onChange)
|
|
69
|
-
}
|
|
70
|
-
);
|
|
71
|
-
}, "GameSelect");
|
|
72
|
-
var useUserModal = /* @__PURE__ */ __name(({ mode, onSuccess }) => {
|
|
73
|
-
const { message } = App.useApp();
|
|
74
|
-
const { t } = useTranslation();
|
|
75
|
-
const { data: roles, isLoading: isRolesLoading } = useAllRoles();
|
|
76
|
-
const create = useCreateUser();
|
|
77
|
-
const update = useUpdateUser();
|
|
78
|
-
const isCreateMode = mode === "create";
|
|
79
|
-
const title = isCreateMode ? t("User.createTitle") : t("User.updateTitle");
|
|
80
|
-
const content = /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
81
|
-
/* @__PURE__ */ jsx(Form.Item, { label: t("global.name"), name: "name", rules: [{ required: true }], children: /* @__PURE__ */ jsx(Input, { disabled: !isCreateMode }) }),
|
|
82
|
-
/* @__PURE__ */ jsx(Form.Item, { label: t("global.role"), name: "roles", children: /* @__PURE__ */ jsx(
|
|
83
|
-
Select,
|
|
84
|
-
{
|
|
85
|
-
allowClear: true,
|
|
86
|
-
showSearch: true,
|
|
87
|
-
mode: "multiple",
|
|
88
|
-
loading: isRolesLoading,
|
|
89
|
-
optionFilterProp: "label",
|
|
90
|
-
options: roles?.map((role) => ({ label: role.name, value: role.name }))
|
|
91
|
-
}
|
|
92
|
-
) })
|
|
93
|
-
] });
|
|
94
|
-
const onConfirm = /* @__PURE__ */ __name(async (values, extraValues) => {
|
|
95
|
-
if (isCreateMode) {
|
|
96
|
-
await create.mutateAsync(values);
|
|
97
|
-
message.success(t("User.createSuccessfully"));
|
|
98
|
-
} else {
|
|
99
|
-
await update.mutateAsync({ ...values, id: extraValues?.id });
|
|
100
|
-
message.success(t("User.updateSuccessfully"));
|
|
101
|
-
}
|
|
102
|
-
onSuccess?.();
|
|
103
|
-
}, "onConfirm");
|
|
104
|
-
return useFormModal({
|
|
105
|
-
title,
|
|
106
|
-
width: "600px",
|
|
107
|
-
formProps: {
|
|
108
|
-
autoComplete: "off",
|
|
109
|
-
labelCol: { flex: "80px" }
|
|
110
|
-
},
|
|
111
|
-
content,
|
|
112
|
-
onConfirm
|
|
113
|
-
});
|
|
114
|
-
}, "useUserModal");
|
|
115
|
-
var useUserModalV2 = /* @__PURE__ */ __name(({ mode, onSuccess }) => {
|
|
116
|
-
const { message } = App.useApp();
|
|
117
|
-
const { t } = useTranslation();
|
|
118
|
-
const { data: roles, isLoading: isRolesLoading } = useAllRoles();
|
|
119
|
-
const create = useCreateUser();
|
|
120
|
-
const update = useUpdateUser();
|
|
121
|
-
const isCreateMode = mode === "create";
|
|
122
|
-
const title = isCreateMode ? t("User.createTitle") : t("User.updateTitle");
|
|
123
|
-
const { permissionVersion } = useToolkitsStore();
|
|
124
|
-
const isV3 = permissionVersion === "v3" /* V3 */;
|
|
125
|
-
const content = /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
126
|
-
/* @__PURE__ */ jsx(Form.Item, { label: t("global.name"), name: "name", rules: [{ required: true }], children: /* @__PURE__ */ jsx(Input, { disabled: !isCreateMode }) }),
|
|
127
|
-
/* @__PURE__ */ jsx(Form.List, { name: "permissions", children: (fields, { add, remove }) => /* @__PURE__ */ jsxs(Row, { gutter: 8, children: [
|
|
128
|
-
isV3 && /* @__PURE__ */ jsx(Col, { span: 8, className: "text-center mb-4", children: /* @__PURE__ */ jsx(Text, { strong: true, children: t("global.projectGroup") }) }),
|
|
129
|
-
/* @__PURE__ */ jsx(Col, { span: isV3 ? 10 : 14, className: "text-center mb-4", children: /* @__PURE__ */ jsx(Text, { strong: true, children: t("global.game") }) }),
|
|
130
|
-
/* @__PURE__ */ jsx(Col, { span: isV3 ? 6 : 10, className: "text-center mb-4", children: /* @__PURE__ */ jsx(Text, { strong: true, children: t("global.role") }) }),
|
|
131
|
-
fields.map((field) => /* @__PURE__ */ jsxs(Fragment$1, { children: [
|
|
132
|
-
isV3 && /* @__PURE__ */ jsx(Col, { span: 8, children: /* @__PURE__ */ jsx(Form.Item, { noStyle: true, shouldUpdate: true, children: ({ setFieldValue }) => /* @__PURE__ */ jsx(Form.Item, { name: [field.name, "game_group"], children: /* @__PURE__ */ jsx(
|
|
133
|
-
GroupSelect,
|
|
134
|
-
{
|
|
135
|
-
onChange: () => {
|
|
136
|
-
setFieldValue(["permissions", field.name, "game_ids"], []);
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
) }) }) }),
|
|
140
|
-
/* @__PURE__ */ jsx(Col, { span: isV3 ? 10 : 14, children: isV3 ? /* @__PURE__ */ jsx(
|
|
141
|
-
Form.Item,
|
|
142
|
-
{
|
|
143
|
-
noStyle: true,
|
|
144
|
-
shouldUpdate: (prevValues, nextValues) => prevValues.permissions[field.name]?.game_group !== nextValues.permissions[field.name]?.game_group,
|
|
145
|
-
children: ({ getFieldValue }) => {
|
|
146
|
-
const _groups = getFieldValue(["permissions", field.name, "game_group"]);
|
|
147
|
-
return /* @__PURE__ */ jsx(
|
|
148
|
-
Form.Item,
|
|
149
|
-
{
|
|
150
|
-
name: [field.name, "game_ids"],
|
|
151
|
-
dependencies: [["permissions", field.name, "game_group"]],
|
|
152
|
-
rules: [{ required: !!_groups?.length, message: "\u8BF7\u9009\u62E9\u6E38\u620F" }],
|
|
153
|
-
children: /* @__PURE__ */ jsx(GameSelect, { groups: _groups })
|
|
154
|
-
}
|
|
155
|
-
);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
) : /* @__PURE__ */ jsx(Form.Item, { name: [field.name, "game_ids"], rules: [{ required: true, message: "\u8BF7\u9009\u62E9\u6E38\u620F" }], children: /* @__PURE__ */ jsx(GameSelect, {}) }) }),
|
|
159
|
-
/* @__PURE__ */ jsx(Col, { span: isV3 ? 6 : 10, children: /* @__PURE__ */ jsxs("div", { className: "flex", children: [
|
|
160
|
-
/* @__PURE__ */ jsx("div", { className: "flex-1", children: /* @__PURE__ */ jsx(
|
|
161
|
-
Form.Item,
|
|
162
|
-
{
|
|
163
|
-
name: [field.name, "role"],
|
|
164
|
-
rules: [
|
|
165
|
-
{ required: true, message: "\u8BF7\u9009\u62E9\u89D2\u8272" },
|
|
166
|
-
({ getFieldValue }) => ({
|
|
167
|
-
validator(_rule, value) {
|
|
168
|
-
const items = getFieldValue("permissions");
|
|
169
|
-
const otherItems = items.filter((item, index) => !!item && index !== field.name);
|
|
170
|
-
if (otherItems.some((item) => item.role === value)) {
|
|
171
|
-
return Promise.reject(new Error("\u8BF7\u52FF\u91CD\u590D\u9009\u62E9\u89D2\u8272"));
|
|
172
|
-
}
|
|
173
|
-
return Promise.resolve();
|
|
174
|
-
}
|
|
175
|
-
})
|
|
176
|
-
],
|
|
177
|
-
children: /* @__PURE__ */ jsx(
|
|
178
|
-
Select,
|
|
179
|
-
{
|
|
180
|
-
allowClear: true,
|
|
181
|
-
showSearch: true,
|
|
182
|
-
optionFilterProp: "label",
|
|
183
|
-
loading: isRolesLoading,
|
|
184
|
-
options: roles?.map((role) => ({ label: role.name, value: role.name }))
|
|
185
|
-
}
|
|
186
|
-
)
|
|
187
|
-
}
|
|
188
|
-
) }),
|
|
189
|
-
/* @__PURE__ */ jsx("div", { className: "w-8 text-center", children: /* @__PURE__ */ jsx(Form.Item, { children: /* @__PURE__ */ jsx(
|
|
190
|
-
MinusCircleOutlined,
|
|
191
|
-
{
|
|
192
|
-
onClick: () => {
|
|
193
|
-
remove(field.name);
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
) }) })
|
|
197
|
-
] }) })
|
|
198
|
-
] }, field.key)),
|
|
199
|
-
fields.length === 0 && /* @__PURE__ */ jsx(Col, { span: 24, children: /* @__PURE__ */ jsx(Empty, { className: "mb-6" }) }),
|
|
200
|
-
/* @__PURE__ */ jsx(Col, { span: 24, children: /* @__PURE__ */ jsx(Button, { block: true, type: "dashed", onClick: () => add(), children: t("global.add") }) })
|
|
201
|
-
] }) })
|
|
202
|
-
] });
|
|
203
|
-
const onConfirm = /* @__PURE__ */ __name(async (values, extraValues) => {
|
|
204
|
-
if (isCreateMode) {
|
|
205
|
-
await create.mutateAsync(values);
|
|
206
|
-
message.success(t("User.createSuccessfully"));
|
|
207
|
-
} else {
|
|
208
|
-
await update.mutateAsync({ ...values, id: extraValues?.id });
|
|
209
|
-
message.success(t("User.updateSuccessfully"));
|
|
210
|
-
}
|
|
211
|
-
onSuccess?.();
|
|
212
|
-
}, "onConfirm");
|
|
213
|
-
return useFormModal({
|
|
214
|
-
title,
|
|
215
|
-
width: "1000px",
|
|
216
|
-
formProps: {
|
|
217
|
-
autoComplete: "off",
|
|
218
|
-
labelCol: { flex: "80px" }
|
|
219
|
-
},
|
|
220
|
-
content,
|
|
221
|
-
onConfirm
|
|
222
|
-
});
|
|
223
|
-
}, "useUserModalV2");
|
|
224
|
-
|
|
225
|
-
export { useUserModal, useUserModalV2 };
|
|
226
|
-
//# sourceMappingURL=chunk-E6L6VKSV.js.map
|
|
227
|
-
//# sourceMappingURL=chunk-E6L6VKSV.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/modules/permission/hooks/user-hooks.tsx"],"names":["Fragment"],"mappings":"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","file":"chunk-E6L6VKSV.js","sourcesContent":["import { MinusCircleOutlined } from '@ant-design/icons'\nimport { useQuery } from '@tanstack/react-query'\nimport { App, Button, Col, Empty, Form, Input, Row, Select, Typography } from 'antd'\nimport { first, last } from 'lodash-es'\nimport { Fragment } from 'react'\nimport { type FC } from 'react'\n\nimport { useToolkitsStore } from '@/components'\nimport { PermissionVersion, WILDCARD } from '@/constants'\nimport { useFormModal } from '@/hooks/modal'\nimport { useKy } from '@/libs'\nimport { useTranslation } from '@/locale'\nimport { queryKeys } from '@/queryKeys'\n\nimport { useAllRoles, useCreateUser, useUpdateUser } from '../services'\n\nconst { Text } = Typography\n\n/**\n * 处理通配符选择逻辑\n * - 如果最后选择的是通配符,则只保留通配符\n * - 如果第一个是通配符但又选择了其他项,则移除通配符\n */\nconst handleWildcardSelection = (value: string[], onChange?: (value: string[]) => void) => {\n if (last(value) === WILDCARD) {\n onChange?.([WILDCARD])\n } else if (first(value) === WILDCARD) {\n onChange?.(value.slice(1))\n } else {\n onChange?.(value)\n }\n}\n\ninterface GroupSelectProps {\n value?: string[]\n onChange?: (value: string[]) => void\n}\n\nconst GroupSelect: FC<GroupSelectProps> = props => {\n const { onChange, ...rest } = props\n const ky = useKy()\n\n const { data, isLoading } = useQuery({\n queryKey: queryKeys.enums.gameGroups,\n queryFn: () => ky.get<string[]>('/api/enum/get?enum=game_group&type=all'),\n })\n\n const options = [{ label: '通用', value: WILDCARD }].concat(\n data?.map(group => ({ label: group, value: group })) ?? [],\n )\n\n return (\n <Select\n {...rest}\n allowClear\n showSearch\n mode=\"tags\"\n optionFilterProp=\"label\"\n loading={isLoading}\n options={options}\n onChange={value => handleWildcardSelection(value, onChange)}\n />\n )\n}\n\ninterface GameSelectProps {\n groups?: string[]\n value?: string[]\n onChange?: (value: string[]) => void\n}\n\n/**\n * 游戏选择组件\n * - V3: 依赖 groups 参数,需要先选择项目组才能加载游戏列表\n * - V4: 不依赖 groups,直接加载所有游戏列表\n */\nconst GameSelect: FC<GameSelectProps> = props => {\n const { groups, onChange, ...rest } = props\n const ky = useKy()\n const { permissionVersion } = useToolkitsStore()\n const isV3 = permissionVersion === PermissionVersion.V3\n const isV4 = permissionVersion === PermissionVersion.V4\n\n const { data, isLoading } = useQuery({\n queryKey: queryKeys.enums.gameIds(isV4 ? [] : (groups ?? [])),\n queryFn: () =>\n ky\n .get<{\n list: {\n id: string\n name: string\n }[]\n }>(`/api/enum/game_group/get_game_ids${isV4 ? '' : `?game_groups=${groups?.join(',')}`}`)\n .then(response => response?.list),\n enabled: isV4 || (isV3 && !!groups?.length),\n })\n\n const options = data?.map((group: { id: string; name: string }) => ({ label: group.name, value: group.id }))\n\n return (\n <Select\n {...rest}\n allowClear\n showSearch\n optionFilterProp=\"label\"\n mode=\"tags\"\n loading={isLoading}\n options={options}\n onChange={value => handleWildcardSelection(value, onChange)}\n />\n )\n}\n\ninterface UserModalFormSchema {\n name: string\n roles: string[]\n}\n\nexport const useUserModal = ({ mode, onSuccess }: { mode: 'create' | 'update'; onSuccess?: () => void }) => {\n const { message } = App.useApp()\n const { t } = useTranslation()\n const { data: roles, isLoading: isRolesLoading } = useAllRoles()\n const create = useCreateUser()\n const update = useUpdateUser()\n\n const isCreateMode = mode === 'create'\n\n const title = isCreateMode ? t('User.createTitle') : t('User.updateTitle')\n\n const content = (\n <>\n <Form.Item label={t('global.name')} name=\"name\" rules={[{ required: true }]}>\n <Input disabled={!isCreateMode} />\n </Form.Item>\n <Form.Item label={t('global.role')} name=\"roles\">\n <Select\n allowClear\n showSearch\n mode=\"multiple\"\n loading={isRolesLoading}\n optionFilterProp=\"label\"\n options={roles?.map(role => ({ label: role.name, value: role.name }))}\n />\n </Form.Item>\n </>\n )\n\n const onConfirm = async (values: UserModalFormSchema, extraValues: { id: string }) => {\n if (isCreateMode) {\n await create.mutateAsync(values)\n message.success(t('User.createSuccessfully'))\n } else {\n await update.mutateAsync({ ...values, id: extraValues?.id })\n message.success(t('User.updateSuccessfully'))\n }\n onSuccess?.()\n }\n\n return useFormModal<UserModalFormSchema, { id: string }>({\n title,\n width: '600px',\n formProps: {\n autoComplete: 'off',\n labelCol: { flex: '80px' },\n },\n content,\n onConfirm,\n })\n}\n\ninterface UserModalV2FormSchema {\n name: string\n permissions: {\n game_group: string[]\n game_ids: string[]\n role: string\n }[]\n}\n\n/**\n * 用户弹窗 V2 版本(用于 V3 和 V4 权限系统)\n * - V3: 显示项目组选择,游戏列表依赖项目组\n * - V4: 隐藏项目组选择,游戏列表独立加载\n */\nexport const useUserModalV2 = ({ mode, onSuccess }: { mode: 'create' | 'update'; onSuccess?: () => void }) => {\n const { message } = App.useApp()\n const { t } = useTranslation()\n const { data: roles, isLoading: isRolesLoading } = useAllRoles()\n const create = useCreateUser()\n const update = useUpdateUser()\n const isCreateMode = mode === 'create'\n const title = isCreateMode ? t('User.createTitle') : t('User.updateTitle')\n const { permissionVersion } = useToolkitsStore()\n const isV3 = permissionVersion === PermissionVersion.V3\n\n const content = (\n <>\n <Form.Item label={t('global.name')} name=\"name\" rules={[{ required: true }]}>\n <Input disabled={!isCreateMode} />\n </Form.Item>\n <Form.List name=\"permissions\">\n {(fields, { add, remove }) => (\n <Row gutter={8}>\n {isV3 && (\n <Col span={8} className=\"text-center mb-4\">\n <Text strong>{t('global.projectGroup')}</Text>\n </Col>\n )}\n <Col span={isV3 ? 10 : 14} className=\"text-center mb-4\">\n <Text strong>{t('global.game')}</Text>\n </Col>\n <Col span={isV3 ? 6 : 10} className=\"text-center mb-4\">\n <Text strong>{t('global.role')}</Text>\n </Col>\n {fields.map(field => (\n <Fragment key={field.key}>\n {isV3 && (\n <Col span={8}>\n <Form.Item noStyle shouldUpdate>\n {({ setFieldValue }) => (\n <Form.Item name={[field.name, 'game_group']}>\n <GroupSelect\n onChange={() => {\n setFieldValue(['permissions', field.name, 'game_ids'], [])\n }}\n />\n </Form.Item>\n )}\n </Form.Item>\n </Col>\n )}\n <Col span={isV3 ? 10 : 14}>\n {isV3 ? (\n <Form.Item\n noStyle\n shouldUpdate={(prevValues, nextValues) =>\n prevValues.permissions[field.name]?.game_group !==\n nextValues.permissions[field.name]?.game_group\n }\n >\n {({ getFieldValue }) => {\n const _groups = getFieldValue(['permissions', field.name, 'game_group'])\n\n return (\n <Form.Item\n name={[field.name, 'game_ids']}\n dependencies={[['permissions', field.name, 'game_group']]}\n rules={[{ required: !!_groups?.length, message: '请选择游戏' }]}\n >\n <GameSelect groups={_groups} />\n </Form.Item>\n )\n }}\n </Form.Item>\n ) : (\n <Form.Item name={[field.name, 'game_ids']} rules={[{ required: true, message: '请选择游戏' }]}>\n <GameSelect />\n </Form.Item>\n )}\n </Col>\n <Col span={isV3 ? 6 : 10}>\n <div className=\"flex\">\n <div className=\"flex-1\">\n <Form.Item\n name={[field.name, 'role']}\n rules={[\n { required: true, message: '请选择角色' },\n ({ getFieldValue }) => ({\n validator(_rule, value) {\n const items = getFieldValue('permissions') as UserModalV2FormSchema['permissions']\n const otherItems = items.filter((item, index) => !!item && index !== field.name)\n if (otherItems.some(item => item.role === value)) {\n return Promise.reject(new Error('请勿重复选择角色'))\n }\n return Promise.resolve()\n },\n }),\n ]}\n >\n <Select\n allowClear\n showSearch\n optionFilterProp=\"label\"\n loading={isRolesLoading}\n options={roles?.map(role => ({ label: role.name, value: role.name }))}\n />\n </Form.Item>\n </div>\n <div className=\"w-8 text-center\">\n <Form.Item>\n <MinusCircleOutlined\n onClick={() => {\n remove(field.name)\n }}\n />\n </Form.Item>\n </div>\n </div>\n </Col>\n </Fragment>\n ))}\n {fields.length === 0 && (\n <Col span={24}>\n <Empty className=\"mb-6\" />\n </Col>\n )}\n <Col span={24}>\n <Button block type=\"dashed\" onClick={() => add()}>\n {t('global.add')}\n </Button>\n </Col>\n </Row>\n )}\n </Form.List>\n </>\n )\n\n const onConfirm = async (values: UserModalV2FormSchema, extraValues: { id: string }) => {\n if (isCreateMode) {\n await create.mutateAsync(values)\n message.success(t('User.createSuccessfully'))\n } else {\n await update.mutateAsync({ ...values, id: extraValues?.id })\n message.success(t('User.updateSuccessfully'))\n }\n onSuccess?.()\n }\n\n return useFormModal<UserModalV2FormSchema, { id: string }>({\n title,\n width: '1000px',\n formProps: {\n autoComplete: 'off',\n labelCol: { flex: '80px' },\n },\n content,\n onConfirm,\n })\n}\n"]}
|