react-toolkits 2.26.1 → 2.27.0
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/lib/chunk-56C2GQCB.js +2 -0
- package/lib/chunk-56C2GQCB.js.map +1 -0
- package/lib/chunk-6SMI25Y3.js +19 -0
- package/lib/chunk-6SMI25Y3.js.map +1 -0
- package/lib/{chunk-D5YXBSTI.js → chunk-7XR7V6IS.js} +2 -2
- package/lib/{chunk-D5YXBSTI.js.map → chunk-7XR7V6IS.js.map} +1 -1
- package/lib/chunk-AFURMXX2.js +2 -0
- package/lib/chunk-AFURMXX2.js.map +1 -0
- package/lib/{chunk-MVG7YFPB.js → chunk-COONHXCY.js} +2 -2
- package/lib/{chunk-MVG7YFPB.js.map → chunk-COONHXCY.js.map} +1 -1
- package/lib/chunk-DBYHBFI6.js +206 -0
- package/lib/chunk-DBYHBFI6.js.map +1 -0
- package/lib/chunk-JJR5NJTU.js +75 -0
- package/lib/chunk-JJR5NJTU.js.map +1 -0
- package/lib/chunk-LUVKLLW7.js +2 -0
- package/lib/chunk-LUVKLLW7.js.map +1 -0
- package/lib/chunk-M2C4DTSM.js +46 -0
- package/lib/chunk-M2C4DTSM.js.map +1 -0
- package/lib/{chunk-5QAEUAZE.js → chunk-NEOHLVWG.js} +2 -2
- package/lib/{chunk-5QAEUAZE.js.map → chunk-NEOHLVWG.js.map} +1 -1
- package/lib/chunk-O7INKFFW.js +161 -0
- package/lib/chunk-O7INKFFW.js.map +1 -0
- package/lib/chunk-Q6MAXVON.js +2 -0
- package/lib/chunk-Q6MAXVON.js.map +1 -0
- package/lib/chunk-QEUTBIBK.js +125 -0
- package/lib/chunk-QEUTBIBK.js.map +1 -0
- package/lib/chunk-R72QFX5M.js +495 -0
- package/lib/chunk-R72QFX5M.js.map +1 -0
- package/lib/chunk-TYMPX257.js +268 -0
- package/lib/chunk-TYMPX257.js.map +1 -0
- package/lib/chunk-UICHZXQP.js +3 -0
- package/lib/chunk-UICHZXQP.js.map +1 -0
- package/lib/{chunk-P5T74EXP.js → chunk-WFRMJYD3.js} +2 -2
- package/lib/chunk-WFRMJYD3.js.map +1 -0
- package/lib/chunk-Z7GW3RVV.js +658 -0
- package/lib/chunk-Z7GW3RVV.js.map +1 -0
- package/lib/createMenuItem-7R7QR4R6.js +83 -0
- package/lib/createMenuItem-7R7QR4R6.js.map +1 -0
- package/lib/{createMenuItem-Q5TJGFKZ.js → createMenuItem-A3ES4CDV.js} +2 -2
- package/lib/{createMenuItem-Q5TJGFKZ.js.map → createMenuItem-A3ES4CDV.js.map} +1 -1
- package/lib/index.css +1 -1
- package/lib/index.d.ts +21 -10
- package/lib/index.js +1446 -2
- package/lib/index.js.map +1 -1
- package/lib/menuItemList-BUUJMOU7.js +129 -0
- package/lib/menuItemList-BUUJMOU7.js.map +1 -0
- package/lib/{menuItemList-5QGQYB3N.js → menuItemList-YFQB4BCS.js} +2 -2
- package/lib/{menuItemList-5QGQYB3N.js.map → menuItemList-YFQB4BCS.js.map} +1 -1
- package/lib/{roleDetail-ODJVDVB4.js → roleDetail-H2X34J57.js} +2 -2
- package/lib/{roleDetail-ODJVDVB4.js.map → roleDetail-H2X34J57.js.map} +1 -1
- package/lib/roleDetail-IP654MAU.js +72 -0
- package/lib/roleDetail-IP654MAU.js.map +1 -0
- package/lib/roleList-QMAYO4MG.js +161 -0
- package/lib/roleList-QMAYO4MG.js.map +1 -0
- package/lib/roleList-UCMHN5NJ.js +2 -0
- package/lib/roleList-UCMHN5NJ.js.map +1 -0
- package/lib/updateMenuItem-NUYWRAV5.js +2 -0
- package/lib/updateMenuItem-NUYWRAV5.js.map +1 -0
- package/lib/updateMenuItem-SZVEK3TL.js +106 -0
- package/lib/updateMenuItem-SZVEK3TL.js.map +1 -0
- package/lib/userDetail-6XMOY3I4.js +2 -0
- package/lib/userDetail-6XMOY3I4.js.map +1 -0
- package/lib/userDetail-MPTJGRMY.js +118 -0
- package/lib/userDetail-MPTJGRMY.js.map +1 -0
- package/lib/{userList-7CQLR3HK.js → userList-3WABI7V4.js} +2 -2
- package/lib/{userList-7CQLR3HK.js.map → userList-3WABI7V4.js.map} +1 -1
- package/lib/userList-KXYDP7V5.js +166 -0
- package/lib/userList-KXYDP7V5.js.map +1 -0
- package/locale/context.js +7 -1
- package/locale/context.js.map +1 -1
- package/locale/en_GB.js +94 -1
- package/locale/en_GB.js.map +1 -1
- package/locale/hooks.js +20 -1
- package/locale/hooks.js.map +1 -1
- package/locale/index.js +2 -1
- package/locale/ja_JP.js +94 -1
- package/locale/ja_JP.js.map +1 -1
- package/locale/ko_KR.js +94 -1
- package/locale/ko_KR.js.map +1 -1
- package/locale/zh_CN.js +94 -1
- package/locale/zh_CN.js.map +1 -1
- package/package.json +21 -21
- package/lib/chunk-24U2EF5M.js +0 -2
- package/lib/chunk-24U2EF5M.js.map +0 -1
- package/lib/chunk-F2GDEOP4.js +0 -3
- package/lib/chunk-F2GDEOP4.js.map +0 -1
- package/lib/chunk-FIT6S4UM.js +0 -2
- package/lib/chunk-FIT6S4UM.js.map +0 -1
- package/lib/chunk-JDCSIJL7.js +0 -2
- package/lib/chunk-JDCSIJL7.js.map +0 -1
- package/lib/chunk-KZHYK554.js +0 -2
- package/lib/chunk-KZHYK554.js.map +0 -1
- package/lib/chunk-P5T74EXP.js.map +0 -1
- package/lib/roleList-ATJYWJ6Q.js +0 -2
- package/lib/roleList-ATJYWJ6Q.js.map +0 -1
- package/lib/updateMenuItem-4HDRJAY7.js +0 -2
- package/lib/updateMenuItem-4HDRJAY7.js.map +0 -1
- package/lib/userDetail-B5H4A4X2.js +0 -2
- package/lib/userDetail-B5H4A4X2.js.map +0 -1
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { useUpdateMenu } from './chunk-M2C4DTSM.js';
|
|
2
|
+
import { useMenuList } from './chunk-JJR5NJTU.js';
|
|
3
|
+
import { __name, useHttpGet, queryKeys, FRONTEND_ROUTE_PREFIX } from './chunk-Z7GW3RVV.js';
|
|
4
|
+
import { Editor } from '@monaco-editor/react';
|
|
5
|
+
import { useQuery } from '@tanstack/react-query';
|
|
6
|
+
import { App, Form, Card, Input, Switch, InputNumber, Button } from 'antd';
|
|
7
|
+
import { useEffect } from 'react';
|
|
8
|
+
import { useNavigate, useParams } from 'react-router-dom';
|
|
9
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
10
|
+
|
|
11
|
+
var EditMenuItem = /* @__PURE__ */ __name(() => {
|
|
12
|
+
const { message } = App.useApp();
|
|
13
|
+
const [form] = Form.useForm();
|
|
14
|
+
const navigate = useNavigate();
|
|
15
|
+
const { mutateAsync } = useUpdateMenu();
|
|
16
|
+
const params = useParams();
|
|
17
|
+
const { refetch } = useMenuList();
|
|
18
|
+
const get = useHttpGet();
|
|
19
|
+
const { data, isLoading } = useQuery({
|
|
20
|
+
queryKey: queryKeys.menus.detail(Number(params.id)),
|
|
21
|
+
queryFn: /* @__PURE__ */ __name(() => get(`/api/usystem/menu/info?id=${params.id}`), "queryFn"),
|
|
22
|
+
enabled: !!params.id
|
|
23
|
+
});
|
|
24
|
+
const onFinish = /* @__PURE__ */ __name(async (values) => {
|
|
25
|
+
const { permissions, front_route, ...rest } = values;
|
|
26
|
+
await mutateAsync({
|
|
27
|
+
...rest,
|
|
28
|
+
permissions: permissions ? JSON.parse(permissions) : void 0,
|
|
29
|
+
front_route: FRONTEND_ROUTE_PREFIX + front_route,
|
|
30
|
+
id: +params.id
|
|
31
|
+
});
|
|
32
|
+
refetch();
|
|
33
|
+
message.success("\u66F4\u65B0\u6210\u529F", 0.8, () => navigate("../..", { relative: "route" }));
|
|
34
|
+
}, "onFinish");
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
const { permissions, front_route, ...rest } = data ?? {};
|
|
37
|
+
const permissionsString = JSON.stringify(permissions || [], null, 2);
|
|
38
|
+
const frontRoute = front_route?.replace(FRONTEND_ROUTE_PREFIX, "");
|
|
39
|
+
form.setFieldsValue({
|
|
40
|
+
...rest,
|
|
41
|
+
permissions: permissionsString,
|
|
42
|
+
front_route: frontRoute
|
|
43
|
+
});
|
|
44
|
+
}, [data, form]);
|
|
45
|
+
return /* @__PURE__ */ jsx(Card, { title: "\u66F4\u65B0\u83DC\u5355\u9879", loading: isLoading, children: /* @__PURE__ */ jsxs(
|
|
46
|
+
Form,
|
|
47
|
+
{
|
|
48
|
+
scrollToFirstError: true,
|
|
49
|
+
form,
|
|
50
|
+
labelCol: { flex: "120px" },
|
|
51
|
+
initialValues: { is_common: false, is_model: false, order: 0 },
|
|
52
|
+
onFinish,
|
|
53
|
+
children: [
|
|
54
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "\u83DC\u5355\u9879\u540D\u79F0", name: "category", rules: [{ required: true }], children: /* @__PURE__ */ jsx(Input, {}) }),
|
|
55
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "\u524D\u7AEF\u8DEF\u7531", name: "front_route", rules: [{ required: true }], children: /* @__PURE__ */ jsx(Input, { prefix: FRONTEND_ROUTE_PREFIX }) }),
|
|
56
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "\u6A21\u677F\u540D\u79F0", name: "model_name", rules: [{ required: true }], children: /* @__PURE__ */ jsx(Input, {}) }),
|
|
57
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "Is Common", name: "is_common", rules: [{ required: true }], valuePropName: "checked", children: /* @__PURE__ */ jsx(Switch, {}) }),
|
|
58
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "Order", name: "order", children: /* @__PURE__ */ jsx(InputNumber, { className: "w-full" }) }),
|
|
59
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "\u63A5\u53E3\u89C4\u5219", name: "permissions", children: /* @__PURE__ */ jsx(
|
|
60
|
+
Editor,
|
|
61
|
+
{
|
|
62
|
+
theme: "vs-dark",
|
|
63
|
+
height: "300px",
|
|
64
|
+
language: "json",
|
|
65
|
+
options: {
|
|
66
|
+
minimap: {
|
|
67
|
+
enabled: false
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
) }),
|
|
72
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "Schema", name: "scheme", rules: [{ required: true }], children: /* @__PURE__ */ jsx(
|
|
73
|
+
Editor,
|
|
74
|
+
{
|
|
75
|
+
theme: "vs-dark",
|
|
76
|
+
height: "600px",
|
|
77
|
+
language: "json",
|
|
78
|
+
options: {
|
|
79
|
+
minimap: {
|
|
80
|
+
enabled: false
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
) }),
|
|
85
|
+
/* @__PURE__ */ jsx(Form.Item, { label: "Ext", name: "ext", children: /* @__PURE__ */ jsx(Input.TextArea, { rows: 5 }) }),
|
|
86
|
+
/* @__PURE__ */ jsx(Form.Item, { children: /* @__PURE__ */ jsxs("div", { className: "flex justify-center gap-8", children: [
|
|
87
|
+
/* @__PURE__ */ jsx(Button, { type: "primary", htmlType: "submit", children: "\u63D0\u4EA4" }),
|
|
88
|
+
/* @__PURE__ */ jsx(
|
|
89
|
+
Button,
|
|
90
|
+
{
|
|
91
|
+
onClick: () => {
|
|
92
|
+
navigate("../..", { relative: "path" });
|
|
93
|
+
},
|
|
94
|
+
children: "\u53D6\u6D88"
|
|
95
|
+
}
|
|
96
|
+
)
|
|
97
|
+
] }) })
|
|
98
|
+
]
|
|
99
|
+
}
|
|
100
|
+
) });
|
|
101
|
+
}, "EditMenuItem");
|
|
102
|
+
var updateMenuItem_default = EditMenuItem;
|
|
103
|
+
|
|
104
|
+
export { updateMenuItem_default as default };
|
|
105
|
+
//# sourceMappingURL=updateMenuItem-SZVEK3TL.js.map
|
|
106
|
+
//# sourceMappingURL=updateMenuItem-SZVEK3TL.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/modules/menu/pages/updateMenuItem/index.tsx"],"names":[],"mappings":"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","file":"updateMenuItem-SZVEK3TL.js","sourcesContent":["import { Editor } from '@monaco-editor/react'\nimport { useQuery } from '@tanstack/react-query'\nimport { App, Button, Card, Form, Input, InputNumber, Switch } from 'antd'\nimport { useEffect } from 'react'\nimport { useNavigate, useParams } from 'react-router-dom'\n\nimport { FRONTEND_ROUTE_PREFIX } from '@/constants'\nimport { useHttpGet } from '@/libs'\nimport { queryKeys } from '@/queryKeys'\nimport { useMenuList } from '@/services'\nimport type { MenuListItem } from '@/types'\n\nimport { useUpdateMenu } from '../../services'\n\ntype FormSchema = Omit<MenuListItem, 'id' | 'permissions'> & { permissions: string }\n\nconst EditMenuItem = () => {\n const { message } = App.useApp()\n const [form] = Form.useForm<FormSchema>()\n const navigate = useNavigate()\n const { mutateAsync } = useUpdateMenu()\n const params = useParams<'id'>()\n const { refetch } = useMenuList()\n const get = useHttpGet()\n\n const { data, isLoading } = useQuery({\n queryKey: queryKeys.menus.detail(Number(params.id)),\n queryFn: () => get<MenuListItem>(`/api/usystem/menu/info?id=${params.id}`),\n enabled: !!params.id,\n })\n\n const onFinish = async (values: FormSchema) => {\n const { permissions, front_route, ...rest } = values\n\n await mutateAsync({\n ...rest,\n permissions: permissions ? JSON.parse(permissions) : undefined,\n front_route: FRONTEND_ROUTE_PREFIX + front_route,\n id: +params.id!,\n })\n refetch()\n message.success('更新成功', 0.8, () => navigate('../..', { relative: 'route' }))\n }\n\n useEffect(() => {\n const { permissions, front_route, ...rest } = data ?? {}\n const permissionsString = JSON.stringify(permissions || [], null, 2)\n const frontRoute = front_route?.replace(FRONTEND_ROUTE_PREFIX, '')\n form.setFieldsValue({\n ...rest,\n permissions: permissionsString,\n front_route: frontRoute,\n })\n }, [data, form])\n\n return (\n <Card title=\"更新菜单项\" loading={isLoading}>\n <Form\n scrollToFirstError\n form={form}\n labelCol={{ flex: '120px' }}\n initialValues={{ is_common: false, is_model: false, order: 0 }}\n onFinish={onFinish}\n >\n <Form.Item label=\"菜单项名称\" name=\"category\" rules={[{ required: true }]}>\n <Input />\n </Form.Item>\n <Form.Item label=\"前端路由\" name=\"front_route\" rules={[{ required: true }]}>\n <Input prefix={FRONTEND_ROUTE_PREFIX} />\n </Form.Item>\n <Form.Item label=\"模板名称\" name=\"model_name\" rules={[{ required: true }]}>\n <Input />\n </Form.Item>\n <Form.Item label=\"Is Common\" name=\"is_common\" rules={[{ required: true }]} valuePropName=\"checked\">\n <Switch />\n </Form.Item>\n <Form.Item label=\"Order\" name=\"order\">\n <InputNumber className=\"w-full\" />\n </Form.Item>\n <Form.Item label=\"接口规则\" name=\"permissions\">\n <Editor\n theme=\"vs-dark\"\n height=\"300px\"\n language=\"json\"\n options={{\n minimap: {\n enabled: false,\n },\n }}\n />\n </Form.Item>\n <Form.Item label=\"Schema\" name=\"scheme\" rules={[{ required: true }]}>\n <Editor\n theme=\"vs-dark\"\n height=\"600px\"\n language=\"json\"\n options={{\n minimap: {\n enabled: false,\n },\n }}\n />\n </Form.Item>\n <Form.Item label=\"Ext\" name=\"ext\">\n <Input.TextArea rows={5} />\n </Form.Item>\n <Form.Item>\n <div className=\"flex justify-center gap-8\">\n <Button type=\"primary\" htmlType=\"submit\">\n 提交\n </Button>\n <Button\n onClick={() => {\n navigate('../..', { relative: 'path' })\n }}\n >\n 取消\n </Button>\n </div>\n </Form.Item>\n </Form>\n </Card>\n )\n}\n\nexport default EditMenuItem\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {a as a$2}from'./chunk-56C2GQCB.js';import'./chunk-AFURMXX2.js';import {a as a$3}from'./chunk-NEOHLVWG.js';import {a}from'./chunk-7XR7V6IS.js';import {c,a as a$1}from'./chunk-LUVKLLW7.js';import {i,l,n}from'./chunk-UICHZXQP.js';import {useQuery}from'@tanstack/react-query';import {Tag,Breadcrumb,Card,Descriptions,Table}from'antd';import {useParams,Link}from'react-router-dom';import {jsx,jsxs,Fragment}from'react/jsx-runtime';var P=()=>{let i$1=useParams(),{t:o}=a(),{context:{useGameApiV2:D,permissionMode:T}}=i(),h=T==="group_based",G=l(),{data:s,isLoading:L,refetch:x}=useQuery({queryKey:n.users.detail(i$1.id||""),queryFn:()=>G(`/api/usystem/user/info?id=${i$1.id}`),enabled:!!i$1.id}),{data:A}=c(),{data:B}=a$1("200005"),{show:C,modal:S}=a$2({mode:"update",onSuccess(){x();}}),U=[h&&{key:"group",title:o("global.projectGroup"),dataIndex:"game_group",render(r){return r.map(t=>jsx(Tag,{children:t==="*"?"\u901A\u7528":t},t))}},{key:"game",title:o("global.game"),dataIndex:"game_ids",render(r){return r.map(t=>{let V=A?.find(n=>String(D?n.game_id:n.id)===t);return jsx(Tag,{children:V?.name??(t==="*"?"\u901A\u7528":t)},t)})}},{key:"role",title:o("global.role"),dataIndex:"role",render(r){return B?jsx(Link,{to:`../../role/${r}`,relative:"path",children:r}):r}}].filter(Boolean);return jsxs(Fragment,{children:[jsx(Breadcrumb,{className:"mb-6",items:[{key:"1",title:jsx(Link,{to:"..",relative:"path",children:o("global.user")})},{key:"2",title:"\u7528\u6237\u8BE6\u60C5"}]}),jsx(Card,{title:"\u7528\u6237\u8BE6\u60C5",loading:L,extra:jsx(a$3,{code:"100003",onClick:()=>{C({initialValues:{name:s?.name,permissions:s?.permissions},extraValues:{id:s.id}});},children:o("global.update")}),children:jsxs(Descriptions,{bordered:true,column:1,children:[jsx(Descriptions.Item,{label:o("global.name"),children:s?.name}),jsx(Descriptions.Item,{label:"ID",children:s?.id}),jsx(Descriptions.Item,{label:o("global.role"),children:jsx(Table,{rowKey:"role",columns:U,dataSource:s?.permissions,pagination:false})})]})}),S]})},v=P;export{v as default};//# sourceMappingURL=userDetail-6XMOY3I4.js.map
|
|
2
|
+
//# sourceMappingURL=userDetail-6XMOY3I4.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/modules/permission/pages/userDetail/index.tsx"],"names":["UserDetail","params","useParams","t","useTranslation","useGameApiV2","permissionMode","useToolkitsStore","isGroupBased","get","useHttpGet","data","isLoading","refetch","useQuery","queryKeys","games","useGames","roleViewable","useAuth","show","modal","useUserModal","columns","value","item","jsx","Tag","matchedGame","game","Link","jsxs","Fragment","Breadcrumb","Card","AuthButton_default","Descriptions","Table","userDetail_default"],"mappings":"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","file":"userDetail-6XMOY3I4.js","sourcesContent":["import { useQuery } from '@tanstack/react-query'\nimport type { TableColumnsType } from 'antd'\nimport { Breadcrumb, Card, Descriptions, Table, Tag } from 'antd'\nimport { Link, useParams } from 'react-router-dom'\n\nimport { AuthButton, useToolkitsStore } from '@/components'\nimport { PermissionMode, WILDCARD } from '@/constants'\nimport { useHttpGet } from '@/libs'\nimport { useTranslation } from '@/locale'\nimport { queryKeys } from '@/queryKeys'\nimport { useAuth, useGames } from '@/services'\n\nimport { useUserModal } from '../../hooks'\nimport type { UserListItem } from '../../types'\n\nconst UserDetail = () => {\n const params = useParams<'id'>()\n const { t } = useTranslation()\n const {\n context: { useGameApiV2, permissionMode },\n } = useToolkitsStore()\n const isGroupBased = permissionMode === PermissionMode.GROUP_BASED\n const get = useHttpGet()\n\n const { data, isLoading, refetch } = useQuery({\n queryKey: queryKeys.users.detail(params.id || ''),\n queryFn: () => get<UserListItem>(`/api/usystem/user/info?id=${params.id}`),\n enabled: !!params.id,\n })\n const { data: games } = useGames()\n const { data: roleViewable } = useAuth('200005')\n\n const { show, modal } = useUserModal({\n mode: 'update',\n onSuccess() {\n refetch()\n },\n })\n\n const columns = [\n isGroupBased && {\n key: 'group',\n title: t('global.projectGroup'),\n dataIndex: 'game_group',\n render(value: string[]) {\n return value.map(item => {\n return <Tag key={item}>{item === WILDCARD ? '通用' : item}</Tag>\n })\n },\n },\n {\n key: 'game',\n title: t('global.game'),\n dataIndex: 'game_ids',\n render(value: string[]) {\n return value.map(item => {\n const matchedGame = games?.find(game => String(useGameApiV2 ? game.game_id : game.id) === item)\n return <Tag key={item}>{matchedGame?.name ?? (item === WILDCARD ? '通用' : item)}</Tag>\n })\n },\n },\n {\n key: 'role',\n title: t('global.role'),\n dataIndex: 'role',\n render(value: string) {\n return roleViewable ? (\n <Link to={`../../role/${value}`} relative=\"path\">\n {value}\n </Link>\n ) : (\n value\n )\n },\n },\n ].filter(Boolean) as TableColumnsType\n\n return (\n <>\n <Breadcrumb\n className=\"mb-6\"\n items={[\n {\n key: '1',\n title: (\n <Link to=\"..\" relative=\"path\">\n {t('global.user')}\n </Link>\n ),\n },\n {\n key: '2',\n title: '用户详情',\n },\n ]}\n />\n <Card\n title=\"用户详情\"\n loading={isLoading}\n extra={\n <AuthButton\n code=\"100003\"\n onClick={() => {\n show({\n initialValues: {\n name: data?.name,\n permissions: data?.permissions,\n },\n extraValues: {\n id: data!.id,\n },\n })\n }}\n >\n {t('global.update')}\n </AuthButton>\n }\n >\n <Descriptions bordered column={1}>\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.role')}>\n <Table rowKey=\"role\" columns={columns} dataSource={data?.permissions} pagination={false} />\n </Descriptions.Item>\n </Descriptions>\n </Card>\n {modal}\n </>\n )\n}\n\nexport default UserDetail\n"]}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { useUserModal } from './chunk-DBYHBFI6.js';
|
|
2
|
+
import './chunk-O7INKFFW.js';
|
|
3
|
+
import { AuthButton_default } from './chunk-QEUTBIBK.js';
|
|
4
|
+
import { useTranslation } from './chunk-6SMI25Y3.js';
|
|
5
|
+
import { useGames, useAuth } from './chunk-JJR5NJTU.js';
|
|
6
|
+
import { __name, useToolkitsStore, useHttpGet, queryKeys, WILDCARD } from './chunk-Z7GW3RVV.js';
|
|
7
|
+
import { useQuery } from '@tanstack/react-query';
|
|
8
|
+
import { Tag, Breadcrumb, Card, Descriptions, Table } from 'antd';
|
|
9
|
+
import { useParams, Link } from 'react-router-dom';
|
|
10
|
+
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
11
|
+
|
|
12
|
+
var UserDetail = /* @__PURE__ */ __name(() => {
|
|
13
|
+
const params = useParams();
|
|
14
|
+
const { t } = useTranslation();
|
|
15
|
+
const {
|
|
16
|
+
context: { useGameApiV2, permissionMode }
|
|
17
|
+
} = useToolkitsStore();
|
|
18
|
+
const isGroupBased = permissionMode === "group_based" /* GROUP_BASED */;
|
|
19
|
+
const get = useHttpGet();
|
|
20
|
+
const { data, isLoading, refetch } = useQuery({
|
|
21
|
+
queryKey: queryKeys.users.detail(params.id || ""),
|
|
22
|
+
queryFn: /* @__PURE__ */ __name(() => get(`/api/usystem/user/info?id=${params.id}`), "queryFn"),
|
|
23
|
+
enabled: !!params.id
|
|
24
|
+
});
|
|
25
|
+
const { data: games } = useGames();
|
|
26
|
+
const { data: roleViewable } = useAuth("200005");
|
|
27
|
+
const { show, modal } = useUserModal({
|
|
28
|
+
mode: "update",
|
|
29
|
+
onSuccess() {
|
|
30
|
+
refetch();
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
const columns = [
|
|
34
|
+
isGroupBased && {
|
|
35
|
+
key: "group",
|
|
36
|
+
title: t("global.projectGroup"),
|
|
37
|
+
dataIndex: "game_group",
|
|
38
|
+
render(value) {
|
|
39
|
+
return value.map((item) => {
|
|
40
|
+
return /* @__PURE__ */ jsx(Tag, { children: item === WILDCARD ? "\u901A\u7528" : item }, item);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
key: "game",
|
|
46
|
+
title: t("global.game"),
|
|
47
|
+
dataIndex: "game_ids",
|
|
48
|
+
render(value) {
|
|
49
|
+
return value.map((item) => {
|
|
50
|
+
const matchedGame = games?.find((game) => String(useGameApiV2 ? game.game_id : game.id) === item);
|
|
51
|
+
return /* @__PURE__ */ jsx(Tag, { children: matchedGame?.name ?? (item === WILDCARD ? "\u901A\u7528" : item) }, item);
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
key: "role",
|
|
57
|
+
title: t("global.role"),
|
|
58
|
+
dataIndex: "role",
|
|
59
|
+
render(value) {
|
|
60
|
+
return roleViewable ? /* @__PURE__ */ jsx(Link, { to: `../../role/${value}`, relative: "path", children: value }) : value;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
].filter(Boolean);
|
|
64
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
65
|
+
/* @__PURE__ */ jsx(
|
|
66
|
+
Breadcrumb,
|
|
67
|
+
{
|
|
68
|
+
className: "mb-6",
|
|
69
|
+
items: [
|
|
70
|
+
{
|
|
71
|
+
key: "1",
|
|
72
|
+
title: /* @__PURE__ */ jsx(Link, { to: "..", relative: "path", children: t("global.user") })
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
key: "2",
|
|
76
|
+
title: "\u7528\u6237\u8BE6\u60C5"
|
|
77
|
+
}
|
|
78
|
+
]
|
|
79
|
+
}
|
|
80
|
+
),
|
|
81
|
+
/* @__PURE__ */ jsx(
|
|
82
|
+
Card,
|
|
83
|
+
{
|
|
84
|
+
title: "\u7528\u6237\u8BE6\u60C5",
|
|
85
|
+
loading: isLoading,
|
|
86
|
+
extra: /* @__PURE__ */ jsx(
|
|
87
|
+
AuthButton_default,
|
|
88
|
+
{
|
|
89
|
+
code: "100003",
|
|
90
|
+
onClick: () => {
|
|
91
|
+
show({
|
|
92
|
+
initialValues: {
|
|
93
|
+
name: data?.name,
|
|
94
|
+
permissions: data?.permissions
|
|
95
|
+
},
|
|
96
|
+
extraValues: {
|
|
97
|
+
id: data.id
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
},
|
|
101
|
+
children: t("global.update")
|
|
102
|
+
}
|
|
103
|
+
),
|
|
104
|
+
children: /* @__PURE__ */ jsxs(Descriptions, { bordered: true, column: 1, children: [
|
|
105
|
+
/* @__PURE__ */ jsx(Descriptions.Item, { label: t("global.name"), children: data?.name }),
|
|
106
|
+
/* @__PURE__ */ jsx(Descriptions.Item, { label: "ID", children: data?.id }),
|
|
107
|
+
/* @__PURE__ */ jsx(Descriptions.Item, { label: t("global.role"), children: /* @__PURE__ */ jsx(Table, { rowKey: "role", columns, dataSource: data?.permissions, pagination: false }) })
|
|
108
|
+
] })
|
|
109
|
+
}
|
|
110
|
+
),
|
|
111
|
+
modal
|
|
112
|
+
] });
|
|
113
|
+
}, "UserDetail");
|
|
114
|
+
var userDetail_default = UserDetail;
|
|
115
|
+
|
|
116
|
+
export { userDetail_default as default };
|
|
117
|
+
//# sourceMappingURL=userDetail-MPTJGRMY.js.map
|
|
118
|
+
//# sourceMappingURL=userDetail-MPTJGRMY.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/modules/permission/pages/userDetail/index.tsx"],"names":[],"mappings":"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","file":"userDetail-MPTJGRMY.js","sourcesContent":["import { useQuery } from '@tanstack/react-query'\nimport type { TableColumnsType } from 'antd'\nimport { Breadcrumb, Card, Descriptions, Table, Tag } from 'antd'\nimport { Link, useParams } from 'react-router-dom'\n\nimport { AuthButton, useToolkitsStore } from '@/components'\nimport { PermissionMode, WILDCARD } from '@/constants'\nimport { useHttpGet } from '@/libs'\nimport { useTranslation } from '@/locale'\nimport { queryKeys } from '@/queryKeys'\nimport { useAuth, useGames } from '@/services'\n\nimport { useUserModal } from '../../hooks'\nimport type { UserListItem } from '../../types'\n\nconst UserDetail = () => {\n const params = useParams<'id'>()\n const { t } = useTranslation()\n const {\n context: { useGameApiV2, permissionMode },\n } = useToolkitsStore()\n const isGroupBased = permissionMode === PermissionMode.GROUP_BASED\n const get = useHttpGet()\n\n const { data, isLoading, refetch } = useQuery({\n queryKey: queryKeys.users.detail(params.id || ''),\n queryFn: () => get<UserListItem>(`/api/usystem/user/info?id=${params.id}`),\n enabled: !!params.id,\n })\n const { data: games } = useGames()\n const { data: roleViewable } = useAuth('200005')\n\n const { show, modal } = useUserModal({\n mode: 'update',\n onSuccess() {\n refetch()\n },\n })\n\n const columns = [\n isGroupBased && {\n key: 'group',\n title: t('global.projectGroup'),\n dataIndex: 'game_group',\n render(value: string[]) {\n return value.map(item => {\n return <Tag key={item}>{item === WILDCARD ? '通用' : item}</Tag>\n })\n },\n },\n {\n key: 'game',\n title: t('global.game'),\n dataIndex: 'game_ids',\n render(value: string[]) {\n return value.map(item => {\n const matchedGame = games?.find(game => String(useGameApiV2 ? game.game_id : game.id) === item)\n return <Tag key={item}>{matchedGame?.name ?? (item === WILDCARD ? '通用' : item)}</Tag>\n })\n },\n },\n {\n key: 'role',\n title: t('global.role'),\n dataIndex: 'role',\n render(value: string) {\n return roleViewable ? (\n <Link to={`../../role/${value}`} relative=\"path\">\n {value}\n </Link>\n ) : (\n value\n )\n },\n },\n ].filter(Boolean) as TableColumnsType\n\n return (\n <>\n <Breadcrumb\n className=\"mb-6\"\n items={[\n {\n key: '1',\n title: (\n <Link to=\"..\" relative=\"path\">\n {t('global.user')}\n </Link>\n ),\n },\n {\n key: '2',\n title: '用户详情',\n },\n ]}\n />\n <Card\n title=\"用户详情\"\n loading={isLoading}\n extra={\n <AuthButton\n code=\"100003\"\n onClick={() => {\n show({\n initialValues: {\n name: data?.name,\n permissions: data?.permissions,\n },\n extraValues: {\n id: data!.id,\n },\n })\n }}\n >\n {t('global.update')}\n </AuthButton>\n }\n >\n <Descriptions bordered column={1}>\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.role')}>\n <Table rowKey=\"role\" columns={columns} dataSource={data?.permissions} pagination={false} />\n </Descriptions.Item>\n </Descriptions>\n </Card>\n {modal}\n </>\n )\n}\n\nexport default UserDetail\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {a as a$1}from'./chunk-
|
|
2
|
-
//# sourceMappingURL=userList-
|
|
1
|
+
import {a as a$1}from'./chunk-56C2GQCB.js';import {c,b,e}from'./chunk-WFRMJYD3.js';import {h}from'./chunk-AFURMXX2.js';import {a as a$2}from'./chunk-NEOHLVWG.js';import {a}from'./chunk-7XR7V6IS.js';import'./chunk-LUVKLLW7.js';import {i}from'./chunk-UICHZXQP.js';import {UserAddOutlined}from'@ant-design/icons';import {App,Row,Col,Tag,Space,Card,Form,Input}from'antd';import {Link}from'react-router-dom';import {jsx,jsxs,Fragment}from'react/jsx-runtime';var z=()=>{let{modal:I,message:A}=App.useApp(),{t}=a(),L=h(),{refetch:l}=c(),{context:{permissionMode:a$3}}=i(),m=a$3==="group_based",d=a$3==="direct_game",{show:b$1,modal:w}=a$1({mode:"create",onSuccess(){l("user-list",{page:1});}}),{show:M,modal:S}=a$1({mode:"update",onSuccess(){l("user-list");}}),x=[{title:t("global.name"),dataIndex:"name",key:"name",render(o,r){return m||d?jsx(Link,{to:`./${r.id}`,children:o}):o}},{title:"ID",dataIndex:"id",key:"id"},{title:t("global.role"),dataIndex:"roles",key:"roles",width:"40%",render(o){return jsx(Row,{gutter:[4,4],children:(o||[]).map(r=>jsx(Col,{children:r==="root"?jsx(Tag,{color:"#f50",children:r}):jsx(Tag,{color:"#ff5a00",children:jsx(Link,{to:`../role/${r}`,children:r})})},r))})}},{title:t("global.creationTime"),dataIndex:"Ctime",key:"ctime"},{title:t("global.operation"),width:150,align:"center",render:(o,r)=>{let{name:s,permissions:B,roles:E,id:u}=r;return jsxs(Space,{children:[jsx(a$2,{size:"small",type:"link",code:"100003",onClick:()=>{M({initialValues:{name:s,...m||d?{permissions:B}:{roles:E}},extraValues:{id:u}});},children:t("global.update")}),jsx(a$2,{danger:true,size:"small",code:"100004",type:"link",onClick:()=>{I.confirm({title:t("User.deleteTitle"),content:jsx(b,{texts:[s],children:t("User.deleteContent",{user:s})}),async onOk(){await L.mutateAsync({id:u,name:s}),l("user-list"),A.success(t("User.deleteSuccessfully"));}});},children:t("global.delete")})]})}}].filter(Boolean);return jsxs(Fragment,{children:[jsx(Card,{title:t("global.user"),extra:jsx(a$2,{type:"primary",icon:jsx(UserAddOutlined,{}),code:"100002",onClick:()=>{b$1();},children:t("User.createTitle")}),children:jsx(e,{identifier:"user-list",code:"100001",request:{url:"/api/usystem/user/list",method:"GET"},rowKey:"id",columns:x,dataAdapter:o=>({total:o?.Total,items:o?.List}),renderForm:o=>jsx(Form,{form:o,children:jsx(Form.Item,{label:"\u540D\u79F0",name:"name",children:jsx(Input,{})})})})}),w,S]})},N=z;export{N as default};//# sourceMappingURL=userList-3WABI7V4.js.map
|
|
2
|
+
//# sourceMappingURL=userList-3WABI7V4.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/modules/permission/pages/userList/index.tsx"],"names":["UserList","modal","message","App","useTranslation","remove","useRemoveUser","refetch","useQueryListStore","permissionMode","useToolkitsStore","isGroupBased","isDirectGame","showCreateModal","createModal","useUserModal","showUpdateModal","updateModal","columns","value","record","jsx","Link","Row","item","Col","Tag","_","name","permissions","roles","id","jsxs","Space","AuthButton_default","Highlight_default","Fragment","Card","UserAddOutlined","QueryList_default","data","form","Form","Input","userList_default"],"mappings":"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","file":"userList-7CQLR3HK.js","sourcesContent":["import { UserAddOutlined } from '@ant-design/icons'\nimport type { TableColumnsType } from 'antd'\nimport { App, Card, Col, Form, Input, Row, Space, Tag } from 'antd'\nimport { type FC } from 'react'\nimport { Link } from 'react-router-dom'\n\nimport { AuthButton, Highlight, QueryList, useQueryListStore, useToolkitsStore } from '@/components'\nimport { PermissionMode } from '@/constants'\nimport { useTranslation } from '@/locale'\n\nimport { useUserModal } from '../../hooks'\nimport { useRemoveUser } from '../../services'\nimport type { UserListItem } from '../../types'\n\nconst UserList: FC = () => {\n const { modal, message } = App.useApp()\n const { t } = useTranslation()\n const remove = useRemoveUser()\n const { refetch } = useQueryListStore()\n const {\n context: { permissionMode },\n } = useToolkitsStore()\n const isGroupBased = permissionMode === PermissionMode.GROUP_BASED\n const isDirectGame = permissionMode === PermissionMode.DIRECT_GAME\n\n const { show: showCreateModal, modal: createModal } = useUserModal({\n mode: 'create',\n onSuccess() {\n refetch('user-list', { page: 1 })\n },\n })\n\n const { show: showUpdateModal, modal: updateModal } = useUserModal({\n mode: 'update',\n onSuccess() {\n refetch('user-list')\n },\n })\n\n const columns = (\n [\n {\n title: t('global.name'),\n dataIndex: 'name',\n key: 'name',\n render(value: string, record) {\n if (isGroupBased || isDirectGame) {\n return <Link to={`./${record.id}`}>{value}</Link>\n }\n return value\n },\n },\n {\n title: 'ID',\n dataIndex: 'id',\n key: 'id',\n },\n PermissionMode.GAME_SCOPED && {\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={`../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: (_, record) => {\n const { name, permissions, roles, id } = record\n return (\n <Space>\n <AuthButton\n size=\"small\"\n type=\"link\"\n code=\"100003\"\n onClick={() => {\n showUpdateModal({\n initialValues: {\n name,\n ...(isGroupBased || isDirectGame ? { permissions } : { roles }),\n },\n extraValues: {\n id,\n },\n })\n }}\n >\n {t('global.update')}\n </AuthButton>\n <AuthButton\n danger\n size=\"small\"\n code=\"100004\"\n type=\"link\"\n onClick={() => {\n modal.confirm({\n title: t('User.deleteTitle'),\n content: <Highlight texts={[name]}>{t('User.deleteContent', { user: name })}</Highlight>,\n async onOk() {\n await remove.mutateAsync({\n id,\n name,\n })\n refetch('user-list')\n message.success(t('User.deleteSuccessfully'))\n },\n })\n }}\n >\n {t('global.delete')}\n </AuthButton>\n </Space>\n )\n },\n },\n ] as TableColumnsType<UserListItem>\n ).filter(Boolean)\n\n return (\n <>\n <Card\n title={t('global.user')}\n extra={\n <AuthButton\n type=\"primary\"\n icon={<UserAddOutlined />}\n code=\"100002\"\n onClick={() => {\n showCreateModal()\n }}\n >\n {t('User.createTitle')}\n </AuthButton>\n }\n >\n <QueryList<UserListItem, { name?: string }, { List: UserListItem[]; Total: number }>\n identifier=\"user-list\"\n code=\"100001\"\n request={{\n url: '/api/usystem/user/list',\n method: 'GET',\n }}\n rowKey=\"id\"\n columns={columns}\n dataAdapter={data => ({\n total: data?.Total,\n items: data?.List,\n })}\n renderForm={form => (\n <Form form={form}>\n <Form.Item label=\"名称\" name=\"name\">\n <Input />\n </Form.Item>\n </Form>\n )}\n />\n </Card>\n {createModal}\n {updateModal}\n </>\n )\n}\n\nexport default UserList\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/modules/permission/pages/userList/index.tsx"],"names":["UserList","modal","message","App","useTranslation","remove","useRemoveUser","refetch","useQueryListStore","permissionMode","useToolkitsStore","isGroupBased","isDirectGame","showCreateModal","createModal","useUserModal","showUpdateModal","updateModal","columns","value","record","jsx","Link","Row","item","Col","Tag","_","name","permissions","roles","id","jsxs","Space","AuthButton_default","Highlight_default","Fragment","Card","UserAddOutlined","QueryList_default","data","form","Form","Input","userList_default"],"mappings":"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","file":"userList-3WABI7V4.js","sourcesContent":["import { UserAddOutlined } from '@ant-design/icons'\nimport type { TableColumnsType } from 'antd'\nimport { App, Card, Col, Form, Input, Row, Space, Tag } from 'antd'\nimport { type FC } from 'react'\nimport { Link } from 'react-router-dom'\n\nimport { AuthButton, Highlight, QueryList, useQueryListStore, useToolkitsStore } from '@/components'\nimport { PermissionMode } from '@/constants'\nimport { useTranslation } from '@/locale'\n\nimport { useUserModal } from '../../hooks'\nimport { useRemoveUser } from '../../services'\nimport type { UserListItem } from '../../types'\n\nconst UserList: FC = () => {\n const { modal, message } = App.useApp()\n const { t } = useTranslation()\n const remove = useRemoveUser()\n const { refetch } = useQueryListStore()\n const {\n context: { permissionMode },\n } = useToolkitsStore()\n const isGroupBased = permissionMode === PermissionMode.GROUP_BASED\n const isDirectGame = permissionMode === PermissionMode.DIRECT_GAME\n\n const { show: showCreateModal, modal: createModal } = useUserModal({\n mode: 'create',\n onSuccess() {\n refetch('user-list', { page: 1 })\n },\n })\n\n const { show: showUpdateModal, modal: updateModal } = useUserModal({\n mode: 'update',\n onSuccess() {\n refetch('user-list')\n },\n })\n\n const columns = (\n [\n {\n title: t('global.name'),\n dataIndex: 'name',\n key: 'name',\n render(value: string, record) {\n if (isGroupBased || isDirectGame) {\n return <Link to={`./${record.id}`}>{value}</Link>\n }\n return value\n },\n },\n {\n title: 'ID',\n dataIndex: 'id',\n key: 'id',\n },\n PermissionMode.GAME_SCOPED && {\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={`../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: (_, record) => {\n const { name, permissions, roles, id } = record\n return (\n <Space>\n <AuthButton\n size=\"small\"\n type=\"link\"\n code=\"100003\"\n onClick={() => {\n showUpdateModal({\n initialValues: {\n name,\n ...(isGroupBased || isDirectGame ? { permissions } : { roles }),\n },\n extraValues: {\n id,\n },\n })\n }}\n >\n {t('global.update')}\n </AuthButton>\n <AuthButton\n danger\n size=\"small\"\n code=\"100004\"\n type=\"link\"\n onClick={() => {\n modal.confirm({\n title: t('User.deleteTitle'),\n content: <Highlight texts={[name]}>{t('User.deleteContent', { user: name })}</Highlight>,\n async onOk() {\n await remove.mutateAsync({\n id,\n name,\n })\n refetch('user-list')\n message.success(t('User.deleteSuccessfully'))\n },\n })\n }}\n >\n {t('global.delete')}\n </AuthButton>\n </Space>\n )\n },\n },\n ] as TableColumnsType<UserListItem>\n ).filter(Boolean)\n\n return (\n <>\n <Card\n title={t('global.user')}\n extra={\n <AuthButton\n type=\"primary\"\n icon={<UserAddOutlined />}\n code=\"100002\"\n onClick={() => {\n showCreateModal()\n }}\n >\n {t('User.createTitle')}\n </AuthButton>\n }\n >\n <QueryList<UserListItem, { name?: string }, { List: UserListItem[]; Total: number }>\n identifier=\"user-list\"\n code=\"100001\"\n request={{\n url: '/api/usystem/user/list',\n method: 'GET',\n }}\n rowKey=\"id\"\n columns={columns}\n dataAdapter={data => ({\n total: data?.Total,\n items: data?.List,\n })}\n renderForm={form => (\n <Form form={form}>\n <Form.Item label=\"名称\" name=\"name\">\n <Input />\n </Form.Item>\n </Form>\n )}\n />\n </Card>\n {createModal}\n {updateModal}\n </>\n )\n}\n\nexport default UserList\n"]}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { useUserModal } from './chunk-DBYHBFI6.js';
|
|
2
|
+
import { useQueryListStore, Highlight_default, QueryList_default } from './chunk-R72QFX5M.js';
|
|
3
|
+
import { useRemoveUser } from './chunk-O7INKFFW.js';
|
|
4
|
+
import { AuthButton_default } from './chunk-QEUTBIBK.js';
|
|
5
|
+
import { useTranslation } from './chunk-6SMI25Y3.js';
|
|
6
|
+
import './chunk-JJR5NJTU.js';
|
|
7
|
+
import { __name, useToolkitsStore } from './chunk-Z7GW3RVV.js';
|
|
8
|
+
import { UserAddOutlined } from '@ant-design/icons';
|
|
9
|
+
import { App, Row, Col, Tag, Space, Card, Form, Input } from 'antd';
|
|
10
|
+
import { Link } from 'react-router-dom';
|
|
11
|
+
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
12
|
+
|
|
13
|
+
var UserList = /* @__PURE__ */ __name(() => {
|
|
14
|
+
const { modal, message } = App.useApp();
|
|
15
|
+
const { t } = useTranslation();
|
|
16
|
+
const remove = useRemoveUser();
|
|
17
|
+
const { refetch } = useQueryListStore();
|
|
18
|
+
const {
|
|
19
|
+
context: { permissionMode }
|
|
20
|
+
} = useToolkitsStore();
|
|
21
|
+
const isGroupBased = permissionMode === "group_based" /* GROUP_BASED */;
|
|
22
|
+
const isDirectGame = permissionMode === "direct_game" /* DIRECT_GAME */;
|
|
23
|
+
const { show: showCreateModal, modal: createModal } = useUserModal({
|
|
24
|
+
mode: "create",
|
|
25
|
+
onSuccess() {
|
|
26
|
+
refetch("user-list", { page: 1 });
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
const { show: showUpdateModal, modal: updateModal } = useUserModal({
|
|
30
|
+
mode: "update",
|
|
31
|
+
onSuccess() {
|
|
32
|
+
refetch("user-list");
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
const columns = [
|
|
36
|
+
{
|
|
37
|
+
title: t("global.name"),
|
|
38
|
+
dataIndex: "name",
|
|
39
|
+
key: "name",
|
|
40
|
+
render(value, record) {
|
|
41
|
+
if (isGroupBased || isDirectGame) {
|
|
42
|
+
return /* @__PURE__ */ jsx(Link, { to: `./${record.id}`, children: value });
|
|
43
|
+
}
|
|
44
|
+
return value;
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
title: "ID",
|
|
49
|
+
dataIndex: "id",
|
|
50
|
+
key: "id"
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
title: t("global.role"),
|
|
54
|
+
dataIndex: "roles",
|
|
55
|
+
key: "roles",
|
|
56
|
+
width: "40%",
|
|
57
|
+
render(value) {
|
|
58
|
+
return /* @__PURE__ */ jsx(Row, { gutter: [4, 4], children: (value || []).map((item) => /* @__PURE__ */ jsx(Col, { children: item === "root" ? /* @__PURE__ */ jsx(Tag, { color: "#f50", children: item }) : /* @__PURE__ */ jsx(Tag, { color: "#ff5a00", children: /* @__PURE__ */ jsx(Link, { to: `../role/${item}`, children: item }) }) }, item)) });
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
title: t("global.creationTime"),
|
|
63
|
+
dataIndex: "Ctime",
|
|
64
|
+
key: "ctime"
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
title: t("global.operation"),
|
|
68
|
+
width: 150,
|
|
69
|
+
align: "center",
|
|
70
|
+
render: /* @__PURE__ */ __name((_, record) => {
|
|
71
|
+
const { name, permissions, roles, id } = record;
|
|
72
|
+
return /* @__PURE__ */ jsxs(Space, { children: [
|
|
73
|
+
/* @__PURE__ */ jsx(
|
|
74
|
+
AuthButton_default,
|
|
75
|
+
{
|
|
76
|
+
size: "small",
|
|
77
|
+
type: "link",
|
|
78
|
+
code: "100003",
|
|
79
|
+
onClick: () => {
|
|
80
|
+
showUpdateModal({
|
|
81
|
+
initialValues: {
|
|
82
|
+
name,
|
|
83
|
+
...isGroupBased || isDirectGame ? { permissions } : { roles }
|
|
84
|
+
},
|
|
85
|
+
extraValues: {
|
|
86
|
+
id
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
},
|
|
90
|
+
children: t("global.update")
|
|
91
|
+
}
|
|
92
|
+
),
|
|
93
|
+
/* @__PURE__ */ jsx(
|
|
94
|
+
AuthButton_default,
|
|
95
|
+
{
|
|
96
|
+
danger: true,
|
|
97
|
+
size: "small",
|
|
98
|
+
code: "100004",
|
|
99
|
+
type: "link",
|
|
100
|
+
onClick: () => {
|
|
101
|
+
modal.confirm({
|
|
102
|
+
title: t("User.deleteTitle"),
|
|
103
|
+
content: /* @__PURE__ */ jsx(Highlight_default, { texts: [name], children: t("User.deleteContent", { user: name }) }),
|
|
104
|
+
async onOk() {
|
|
105
|
+
await remove.mutateAsync({
|
|
106
|
+
id,
|
|
107
|
+
name
|
|
108
|
+
});
|
|
109
|
+
refetch("user-list");
|
|
110
|
+
message.success(t("User.deleteSuccessfully"));
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
},
|
|
114
|
+
children: t("global.delete")
|
|
115
|
+
}
|
|
116
|
+
)
|
|
117
|
+
] });
|
|
118
|
+
}, "render")
|
|
119
|
+
}
|
|
120
|
+
].filter(Boolean);
|
|
121
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
122
|
+
/* @__PURE__ */ jsx(
|
|
123
|
+
Card,
|
|
124
|
+
{
|
|
125
|
+
title: t("global.user"),
|
|
126
|
+
extra: /* @__PURE__ */ jsx(
|
|
127
|
+
AuthButton_default,
|
|
128
|
+
{
|
|
129
|
+
type: "primary",
|
|
130
|
+
icon: /* @__PURE__ */ jsx(UserAddOutlined, {}),
|
|
131
|
+
code: "100002",
|
|
132
|
+
onClick: () => {
|
|
133
|
+
showCreateModal();
|
|
134
|
+
},
|
|
135
|
+
children: t("User.createTitle")
|
|
136
|
+
}
|
|
137
|
+
),
|
|
138
|
+
children: /* @__PURE__ */ jsx(
|
|
139
|
+
QueryList_default,
|
|
140
|
+
{
|
|
141
|
+
identifier: "user-list",
|
|
142
|
+
code: "100001",
|
|
143
|
+
request: {
|
|
144
|
+
url: "/api/usystem/user/list",
|
|
145
|
+
method: "GET"
|
|
146
|
+
},
|
|
147
|
+
rowKey: "id",
|
|
148
|
+
columns,
|
|
149
|
+
dataAdapter: (data) => ({
|
|
150
|
+
total: data?.Total,
|
|
151
|
+
items: data?.List
|
|
152
|
+
}),
|
|
153
|
+
renderForm: (form) => /* @__PURE__ */ jsx(Form, { form, children: /* @__PURE__ */ jsx(Form.Item, { label: "\u540D\u79F0", name: "name", children: /* @__PURE__ */ jsx(Input, {}) }) })
|
|
154
|
+
}
|
|
155
|
+
)
|
|
156
|
+
}
|
|
157
|
+
),
|
|
158
|
+
createModal,
|
|
159
|
+
updateModal
|
|
160
|
+
] });
|
|
161
|
+
}, "UserList");
|
|
162
|
+
var userList_default = UserList;
|
|
163
|
+
|
|
164
|
+
export { userList_default as default };
|
|
165
|
+
//# sourceMappingURL=userList-KXYDP7V5.js.map
|
|
166
|
+
//# sourceMappingURL=userList-KXYDP7V5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/modules/permission/pages/userList/index.tsx"],"names":[],"mappings":";;;;;;;;;;;;AAcA,IAAM,2BAAe,MAAA,CAAA,MAAM;AACzB,EAAA,MAAM,EAAE,KAAA,EAAO,OAAA,EAAQ,GAAI,IAAI,MAAA,EAAO;AACtC,EAAA,MAAM,EAAE,CAAA,EAAE,GAAI,cAAA,EAAe;AAC7B,EAAA,MAAM,SAAS,aAAA,EAAc;AAC7B,EAAA,MAAM,EAAE,OAAA,EAAQ,GAAI,iBAAA,EAAkB;AACtC,EAAA,MAAM;AAAA,IACJ,OAAA,EAAS,EAAE,cAAA;AAAe,MACxB,gBAAA,EAAiB;AACrB,EAAA,MAAM,YAAA,GAAe,cAAA,KAAA,aAAA;AACrB,EAAA,MAAM,YAAA,GAAe,cAAA,KAAA,aAAA;AAErB,EAAA,MAAM,EAAE,IAAA,EAAM,eAAA,EAAiB,KAAA,EAAO,WAAA,KAAgB,YAAA,CAAa;AAAA,IACjE,IAAA,EAAM,QAAA;AAAA,IACN,SAAA,GAAY;AACV,MAAA,OAAA,CAAQ,WAAA,EAAa,EAAE,IAAA,EAAM,CAAA,EAAG,CAAA;AAAA,IAClC;AAAA,GACD,CAAA;AAED,EAAA,MAAM,EAAE,IAAA,EAAM,eAAA,EAAiB,KAAA,EAAO,WAAA,KAAgB,YAAA,CAAa;AAAA,IACjE,IAAA,EAAM,QAAA;AAAA,IACN,SAAA,GAAY;AACV,MAAA,OAAA,CAAQ,WAAW,CAAA;AAAA,IACrB;AAAA,GACD,CAAA;AAED,EAAA,MAAM,OAAA,GACJ;AAAA,IACE;AAAA,MACE,KAAA,EAAO,EAAE,aAAa,CAAA;AAAA,MACtB,SAAA,EAAW,MAAA;AAAA,MACX,GAAA,EAAK,MAAA;AAAA,MACL,MAAA,CAAO,OAAe,MAAA,EAAQ;AAC5B,QAAA,IAAI,gBAAgB,YAAA,EAAc;AAChC,UAAA,2BAAQ,IAAA,EAAA,EAAK,EAAA,EAAI,KAAK,MAAA,CAAO,EAAE,IAAK,QAAA,EAAA,KAAA,EAAM,CAAA;AAAA,QAC5C;AACA,QAAA,OAAO,KAAA;AAAA,MACT;AAAA,KACF;AAAA,IACA;AAAA,MACE,KAAA,EAAO,IAAA;AAAA,MACP,SAAA,EAAW,IAAA;AAAA,MACX,GAAA,EAAK;AAAA,KACP;AAAA,IAC8B;AAAA,MAC5B,KAAA,EAAO,EAAE,aAAa,CAAA;AAAA,MACtB,SAAA,EAAW,OAAA;AAAA,MACX,GAAA,EAAK,OAAA;AAAA,MACL,KAAA,EAAO,KAAA;AAAA,MACP,OAAO,KAAA,EAAiB;AACtB,QAAA,2BACG,GAAA,EAAA,EAAI,MAAA,EAAQ,CAAC,CAAA,EAAG,CAAC,CAAA,EACd,QAAA,EAAA,CAAA,KAAA,IAAS,EAAC,EAAG,IAAI,CAAC,IAAA,yBACjB,GAAA,EAAA,EACE,QAAA,EAAA,IAAA,KAAS,yBACR,GAAA,CAAC,GAAA,EAAA,EAAI,KAAA,EAAM,MAAA,EAAQ,gBAAK,CAAA,mBAExB,GAAA,CAAC,GAAA,EAAA,EAAI,KAAA,EAAM,WACT,QAAA,kBAAA,GAAA,CAAC,IAAA,EAAA,EAAK,EAAA,EAAI,CAAA,QAAA,EAAW,IAAI,CAAA,CAAA,EAAK,QAAA,EAAA,IAAA,EAAK,GACrC,CAAA,EAAA,EANM,IAQV,CACD,CAAA,EACH,CAAA;AAAA,MAEJ;AAAA,KACF;AAAA,IACA;AAAA,MACE,KAAA,EAAO,EAAE,qBAAqB,CAAA;AAAA,MAC9B,SAAA,EAAW,OAAA;AAAA,MACX,GAAA,EAAK;AAAA,KACP;AAAA,IACA;AAAA,MACE,KAAA,EAAO,EAAE,kBAAkB,CAAA;AAAA,MAC3B,KAAA,EAAO,GAAA;AAAA,MACP,KAAA,EAAO,QAAA;AAAA,MACP,MAAA,kBAAQ,MAAA,CAAA,CAAC,CAAA,EAAG,MAAA,KAAW;AACrB,QAAA,MAAM,EAAE,IAAA,EAAM,WAAA,EAAa,KAAA,EAAO,IAAG,GAAI,MAAA;AACzC,QAAA,4BACG,KAAA,EAAA,EACC,QAAA,EAAA;AAAA,0BAAA,GAAA;AAAA,YAAC,kBAAA;AAAA,YAAA;AAAA,cACC,IAAA,EAAK,OAAA;AAAA,cACL,IAAA,EAAK,MAAA;AAAA,cACL,IAAA,EAAK,QAAA;AAAA,cACL,SAAS,MAAM;AACb,gBAAA,eAAA,CAAgB;AAAA,kBACd,aAAA,EAAe;AAAA,oBACb,IAAA;AAAA,oBACA,GAAI,YAAA,IAAgB,YAAA,GAAe,EAAE,WAAA,EAAY,GAAI,EAAE,KAAA;AAAM,mBAC/D;AAAA,kBACA,WAAA,EAAa;AAAA,oBACX;AAAA;AACF,iBACD,CAAA;AAAA,cACH,CAAA;AAAA,cAEC,YAAE,eAAe;AAAA;AAAA,WACpB;AAAA,0BACA,GAAA;AAAA,YAAC,kBAAA;AAAA,YAAA;AAAA,cACC,MAAA,EAAM,IAAA;AAAA,cACN,IAAA,EAAK,OAAA;AAAA,cACL,IAAA,EAAK,QAAA;AAAA,cACL,IAAA,EAAK,MAAA;AAAA,cACL,SAAS,MAAM;AACb,gBAAA,KAAA,CAAM,OAAA,CAAQ;AAAA,kBACZ,KAAA,EAAO,EAAE,kBAAkB,CAAA;AAAA,kBAC3B,OAAA,kBAAS,GAAA,CAAC,iBAAA,EAAA,EAAU,KAAA,EAAO,CAAC,IAAI,CAAA,EAAI,QAAA,EAAA,CAAA,CAAE,oBAAA,EAAsB,EAAE,IAAA,EAAM,IAAA,EAAM,CAAA,EAAE,CAAA;AAAA,kBAC5E,MAAM,IAAA,GAAO;AACX,oBAAA,MAAM,OAAO,WAAA,CAAY;AAAA,sBACvB,EAAA;AAAA,sBACA;AAAA,qBACD,CAAA;AACD,oBAAA,OAAA,CAAQ,WAAW,CAAA;AACnB,oBAAA,OAAA,CAAQ,OAAA,CAAQ,CAAA,CAAE,yBAAyB,CAAC,CAAA;AAAA,kBAC9C;AAAA,iBACD,CAAA;AAAA,cACH,CAAA;AAAA,cAEC,YAAE,eAAe;AAAA;AAAA;AACpB,SAAA,EACF,CAAA;AAAA,MAEJ,CAAA,EA9CQ,QAAA;AAAA;AA+CV,GACF,CACA,OAAO,OAAO,CAAA;AAEhB,EAAA,uBACE,IAAA,CAAA,QAAA,EAAA,EACE,QAAA,EAAA;AAAA,oBAAA,GAAA;AAAA,MAAC,IAAA;AAAA,MAAA;AAAA,QACC,KAAA,EAAO,EAAE,aAAa,CAAA;AAAA,QACtB,KAAA,kBACE,GAAA;AAAA,UAAC,kBAAA;AAAA,UAAA;AAAA,YACC,IAAA,EAAK,SAAA;AAAA,YACL,IAAA,sBAAO,eAAA,EAAA,EAAgB,CAAA;AAAA,YACvB,IAAA,EAAK,QAAA;AAAA,YACL,SAAS,MAAM;AACb,cAAA,eAAA,EAAgB;AAAA,YAClB,CAAA;AAAA,YAEC,YAAE,kBAAkB;AAAA;AAAA,SACvB;AAAA,QAGF,QAAA,kBAAA,GAAA;AAAA,UAAC,iBAAA;AAAA,UAAA;AAAA,YACC,UAAA,EAAW,WAAA;AAAA,YACX,IAAA,EAAK,QAAA;AAAA,YACL,OAAA,EAAS;AAAA,cACP,GAAA,EAAK,wBAAA;AAAA,cACL,MAAA,EAAQ;AAAA,aACV;AAAA,YACA,MAAA,EAAO,IAAA;AAAA,YACP,OAAA;AAAA,YACA,aAAa,CAAA,IAAA,MAAS;AAAA,cACpB,OAAO,IAAA,EAAM,KAAA;AAAA,cACb,OAAO,IAAA,EAAM;AAAA,aACf,CAAA;AAAA,YACA,YAAY,CAAA,IAAA,qBACV,GAAA,CAAC,IAAA,EAAA,EAAK,IAAA,EACJ,8BAAC,IAAA,CAAK,IAAA,EAAL,EAAU,KAAA,EAAM,gBAAK,IAAA,EAAK,MAAA,EACzB,QAAA,kBAAA,GAAA,CAAC,KAAA,EAAA,EAAM,GACT,CAAA,EACF;AAAA;AAAA;AAEJ;AAAA,KACF;AAAA,IACC,WAAA;AAAA,IACA;AAAA,GAAA,EACH,CAAA;AAEJ,CAAA,EAzKqB,UAAA,CAAA;AA2KrB,IAAO,gBAAA,GAAQ","file":"userList-KXYDP7V5.js","sourcesContent":["import { UserAddOutlined } from '@ant-design/icons'\nimport type { TableColumnsType } from 'antd'\nimport { App, Card, Col, Form, Input, Row, Space, Tag } from 'antd'\nimport { type FC } from 'react'\nimport { Link } from 'react-router-dom'\n\nimport { AuthButton, Highlight, QueryList, useQueryListStore, useToolkitsStore } from '@/components'\nimport { PermissionMode } from '@/constants'\nimport { useTranslation } from '@/locale'\n\nimport { useUserModal } from '../../hooks'\nimport { useRemoveUser } from '../../services'\nimport type { UserListItem } from '../../types'\n\nconst UserList: FC = () => {\n const { modal, message } = App.useApp()\n const { t } = useTranslation()\n const remove = useRemoveUser()\n const { refetch } = useQueryListStore()\n const {\n context: { permissionMode },\n } = useToolkitsStore()\n const isGroupBased = permissionMode === PermissionMode.GROUP_BASED\n const isDirectGame = permissionMode === PermissionMode.DIRECT_GAME\n\n const { show: showCreateModal, modal: createModal } = useUserModal({\n mode: 'create',\n onSuccess() {\n refetch('user-list', { page: 1 })\n },\n })\n\n const { show: showUpdateModal, modal: updateModal } = useUserModal({\n mode: 'update',\n onSuccess() {\n refetch('user-list')\n },\n })\n\n const columns = (\n [\n {\n title: t('global.name'),\n dataIndex: 'name',\n key: 'name',\n render(value: string, record) {\n if (isGroupBased || isDirectGame) {\n return <Link to={`./${record.id}`}>{value}</Link>\n }\n return value\n },\n },\n {\n title: 'ID',\n dataIndex: 'id',\n key: 'id',\n },\n PermissionMode.GAME_SCOPED && {\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={`../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: (_, record) => {\n const { name, permissions, roles, id } = record\n return (\n <Space>\n <AuthButton\n size=\"small\"\n type=\"link\"\n code=\"100003\"\n onClick={() => {\n showUpdateModal({\n initialValues: {\n name,\n ...(isGroupBased || isDirectGame ? { permissions } : { roles }),\n },\n extraValues: {\n id,\n },\n })\n }}\n >\n {t('global.update')}\n </AuthButton>\n <AuthButton\n danger\n size=\"small\"\n code=\"100004\"\n type=\"link\"\n onClick={() => {\n modal.confirm({\n title: t('User.deleteTitle'),\n content: <Highlight texts={[name]}>{t('User.deleteContent', { user: name })}</Highlight>,\n async onOk() {\n await remove.mutateAsync({\n id,\n name,\n })\n refetch('user-list')\n message.success(t('User.deleteSuccessfully'))\n },\n })\n }}\n >\n {t('global.delete')}\n </AuthButton>\n </Space>\n )\n },\n },\n ] as TableColumnsType<UserListItem>\n ).filter(Boolean)\n\n return (\n <>\n <Card\n title={t('global.user')}\n extra={\n <AuthButton\n type=\"primary\"\n icon={<UserAddOutlined />}\n code=\"100002\"\n onClick={() => {\n showCreateModal()\n }}\n >\n {t('User.createTitle')}\n </AuthButton>\n }\n >\n <QueryList<UserListItem, { name?: string }, { List: UserListItem[]; Total: number }>\n identifier=\"user-list\"\n code=\"100001\"\n request={{\n url: '/api/usystem/user/list',\n method: 'GET',\n }}\n rowKey=\"id\"\n columns={columns}\n dataAdapter={data => ({\n total: data?.Total,\n items: data?.List,\n })}\n renderForm={form => (\n <Form form={form}>\n <Form.Item label=\"名称\" name=\"name\">\n <Input />\n </Form.Item>\n </Form>\n )}\n />\n </Card>\n {createModal}\n {updateModal}\n </>\n )\n}\n\nexport default UserList\n"]}
|
package/locale/context.js
CHANGED
|
@@ -1,2 +1,8 @@
|
|
|
1
|
-
import {createContext}from'react';
|
|
1
|
+
import { createContext } from 'react';
|
|
2
|
+
|
|
3
|
+
const LocaleContext = createContext(void 0);
|
|
4
|
+
var context_default = LocaleContext;
|
|
5
|
+
|
|
6
|
+
export { context_default as default };
|
|
7
|
+
//# sourceMappingURL=context.js.map
|
|
2
8
|
//# sourceMappingURL=context.js.map
|
package/locale/context.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/locale/context.ts"],"names":[
|
|
1
|
+
{"version":3,"sources":["../src/locale/context.ts"],"names":[],"mappings":";;AAKA,MAAM,aAAA,GAAgB,cAA8C,MAAS,CAAA;AAE7E,IAAO,eAAA,GAAQ","file":"context.js","sourcesContent":["import { createContext } from 'react'\nimport type { Locale } from '.'\n\nexport type LocaleContextProps = Locale\n\nconst LocaleContext = createContext<LocaleContextProps | undefined>(undefined)\n\nexport default LocaleContext\n"]}
|