react-toolkits 2.22.20 → 2.22.21
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-YJOSVS5W.js → chunk-4LG4V23K.js} +2 -2
- package/lib/{chunk-YJOSVS5W.js.map → chunk-4LG4V23K.js.map} +1 -1
- package/lib/chunk-A32VE3TQ.js +2 -0
- package/lib/{chunk-4BZYS36Z.js.map → chunk-A32VE3TQ.js.map} +1 -1
- package/lib/{chunk-R4T34HAU.js → chunk-F6U4XQKJ.js} +2 -2
- package/lib/{chunk-R4T34HAU.js.map → chunk-F6U4XQKJ.js.map} +1 -1
- package/lib/{chunk-2DH3PEC6.js → chunk-GD42VZYO.js} +2 -2
- package/lib/{chunk-2DH3PEC6.js.map → chunk-GD42VZYO.js.map} +1 -1
- package/lib/{chunk-2SVZ4R6R.js → chunk-GUZYFAYW.js} +2 -2
- package/lib/{chunk-2SVZ4R6R.js.map → chunk-GUZYFAYW.js.map} +1 -1
- package/lib/chunk-KXTBMJYF.js +3 -0
- package/lib/chunk-KXTBMJYF.js.map +1 -0
- package/lib/{chunk-BNOSXCTC.js → chunk-LGVGDPRR.js} +2 -2
- package/lib/{chunk-BNOSXCTC.js.map → chunk-LGVGDPRR.js.map} +1 -1
- package/lib/{chunk-FW4SKA4Z.js → chunk-WF6CQ4VD.js} +2 -2
- package/lib/{chunk-FW4SKA4Z.js.map → chunk-WF6CQ4VD.js.map} +1 -1
- package/lib/{chunk-KRREFZ3O.js → chunk-XQWJ5ZAA.js} +2 -2
- package/lib/{chunk-KRREFZ3O.js.map → chunk-XQWJ5ZAA.js.map} +1 -1
- package/lib/{createMenuItem-QRKOB732.js → createMenuItem-STIQZAS2.js} +2 -2
- package/lib/{createMenuItem-QRKOB732.js.map → createMenuItem-STIQZAS2.js.map} +1 -1
- package/lib/index.css +0 -7
- package/lib/index.d.ts +0 -1
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/lib/{menuItemList-IUIU3FXR.js → menuItemList-FO2YJKSU.js} +2 -2
- package/lib/{menuItemList-IUIU3FXR.js.map → menuItemList-FO2YJKSU.js.map} +1 -1
- package/lib/{roleDetail-6MFJRLH6.js → roleDetail-BTJNVKA3.js} +2 -2
- package/lib/{roleDetail-6MFJRLH6.js.map → roleDetail-BTJNVKA3.js.map} +1 -1
- package/lib/{roleList-4GUUSBYT.js → roleList-JLF5HIXG.js} +2 -2
- package/lib/{roleList-4GUUSBYT.js.map → roleList-JLF5HIXG.js.map} +1 -1
- package/lib/{updateMenuItem-ZIDN5ZBF.js → updateMenuItem-W62ZGTDH.js} +2 -2
- package/lib/{updateMenuItem-ZIDN5ZBF.js.map → updateMenuItem-W62ZGTDH.js.map} +1 -1
- package/lib/{userDetail-Y2ILANHP.js → userDetail-UNBXTXAK.js} +2 -2
- package/lib/{userDetail-Y2ILANHP.js.map → userDetail-UNBXTXAK.js.map} +1 -1
- package/lib/{userList-VWOI56CK.js → userList-PD5SOROE.js} +2 -2
- package/lib/{userList-VWOI56CK.js.map → userList-PD5SOROE.js.map} +1 -1
- package/locale/en_GB.js +1 -1
- package/locale/en_GB.js.map +1 -1
- package/locale/index.d.ts +0 -1
- package/locale/ja_JP.js +1 -1
- package/locale/ja_JP.js.map +1 -1
- package/locale/ko_KR.js +1 -1
- package/locale/ko_KR.js.map +1 -1
- package/locale/zh_CN.js +1 -1
- package/locale/zh_CN.js.map +1 -1
- package/package.json +2 -2
- package/lib/chunk-4BZYS36Z.js +0 -2
- package/lib/chunk-MQWH2XBX.js +0 -3
- package/lib/chunk-MQWH2XBX.js.map +0 -1
package/locale/zh_CN.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/locale/zh_CN.ts"],"names":["locale","zh_CN_default"],"mappings":"AAEA,MAAMA,EAAiB,CACrB,MAAA,CAAQ,CACN,aAAA,CAAe,+DACf,IAAM,CAAA,cAAA,CACN,YAAc,CAAA,0BAAA,CACd,UAAW,cACX,CAAA,MAAA,CAAQ,eACR,IAAM,CAAA,cAAA,CACN,OAAQ,cACR,CAAA,SAAA,CAAW,cACX,CAAA,IAAA,CAAM,eACN,IAAM,CAAA,cAAA,CACN,
|
|
1
|
+
{"version":3,"sources":["../src/locale/zh_CN.ts"],"names":["locale","zh_CN_default"],"mappings":"AAEA,MAAMA,EAAiB,CACrB,MAAA,CAAQ,CACN,aAAA,CAAe,+DACf,IAAM,CAAA,cAAA,CACN,YAAc,CAAA,0BAAA,CACd,UAAW,cACX,CAAA,MAAA,CAAQ,eACR,IAAM,CAAA,cAAA,CACN,OAAQ,cACR,CAAA,SAAA,CAAW,cACX,CAAA,IAAA,CAAM,eACN,IAAM,CAAA,cAAA,CACN,IAAM,CAAA,cAAA,CACN,SAAU,oBACV,CAAA,QAAA,CAAU,cACV,CAAA,KAAA,CAAO,eACP,MAAQ,CAAA,cAAA,CACR,MAAO,cACP,CAAA,OAAA,CAAS,eACT,QAAU,CAAA,cAAA,CACV,GAAK,CAAA,cAAA,CACL,OAAQ,cACR,CAAA,YAAA,CAAc,oBACd,CAAA,IAAA,CAAM,eACN,IAAM,CAAA,cACR,CACA,CAAA,MAAA,CAAQ,CACN,KAAO,CAAA,0BAAA,CACP,gBAAiB,oBACjB,CAAA,YAAA,CAAc,6FACd,OAAS,CAAA,cACX,CACA,CAAA,QAAA,CAAU,CACR,QAAU,CAAA,kDAAA,CACV,WAAY,0BACd,CAAA,CACA,kBAAmB,CACjB,WAAA,CAAa,cACb,CAAA,SAAA,CAAW,cACb,CACA,CAAA,SAAA,CAAW,CACT,WAAa,CAAA,cAAA,CACb,WAAY,cACd,CAAA,CACA,UAAY,CAAA,CACV,MAAO,0BACP,CAAA,WAAA,CAAa,gCACf,CAAA,CACA,YAAa,CACX,WAAA,CAAa,gCACf,CAAA,CACA,WAAY,CACV,WAAA,CAAa,cACf,CACA,CAAA,IAAA,CAAM,CACJ,WAAa,CAAA,0BAAA,CACb,kBAAoB,CAAA,sCAAA,CACpB,YAAa,0BACb,CAAA,kBAAA,CAAoB,uCACpB,WAAa,CAAA,0BAAA,CACb,cAAe,qEACf,CAAA,kBAAA,CAAoB,sCACtB,CAAA,CACA,KAAM,CACJ,WAAA,CAAa,2BACb,kBAAoB,CAAA,sCAAA,CACpB,YAAa,0BACb,CAAA,kBAAA,CAAoB,sCACpB,CAAA,WAAA,CAAa,2BACb,aAAe,CAAA,qEAAA,CACf,kBAAoB,CAAA,sCACtB,EACA,cAAgB,CAAA,CACd,iBAAmB,CAAA,kDAAA,CACnB,iBAAkB,sCAClB,CAAA,gBAAA,CAAkB,2BAClB,sBAAwB,CAAA,sCAAA,CACxB,sBAAuB,sCACvB,CAAA,UAAA,CAAY,cACZ,CAAA,OAAA,CAAS,sCACX,CACA,CAAA,UAAA,CAAY,CACV,KAAO,CAAA,0BACT,EACA,YAAc,CAAA,CACZ,WAAa,CAAA,oBAAA,CACb,aAAc,gCACd,CAAA,YAAA,CAAc,0BAChB,CACF,CAAA,KAEOC,CAAQD,CAAAA","file":"zh_CN.js","sourcesContent":["import type { Locale } from '.'\n\nconst locale: Locale = {\n global: {\n noEntitlement: '无权限,请联系管理员',\n name: '名称',\n creationTime: '创建时间',\n operation: '操作',\n update: '更新',\n edit: '编辑',\n delete: '删除',\n selectAll: '全选',\n game: '游戏',\n user: '用户',\n role: '角色',\n username: '用户名',\n password: '密码',\n label: '标签',\n method: '方法',\n route: '路由',\n request: '请求',\n response: '响应',\n add: '添加',\n signIn: '登录',\n projectGroup: '项目组',\n view: '查看',\n back: '返回',\n },\n SignIn: {\n title: '登录方式',\n signInWithIDass: 'IDass 登录',\n unregistered: '您还未在平台注册,请联系管理员',\n welcome: '欢迎',\n },\n NotFound: {\n subTitle: '访问的页面不存在',\n buttonText: '返回首页',\n },\n FilterFormWrapper: {\n confirmText: '查询',\n resetText: '重置',\n },\n FormModal: {\n confirmText: '确认',\n cancelText: '取消',\n },\n GameSelect: {\n label: '当前游戏',\n placeholder: '请选择游戏',\n },\n RequireGame: {\n description: '请选择游戏',\n },\n UserWidget: {\n signOutText: '登出',\n },\n User: {\n createTitle: '创建用户',\n createSuccessfully: '用户创建成功',\n updateTitle: '更新用户',\n updateSuccessfully: '用户更新成功',\n deleteTitle: '删除用户',\n deleteContent: '确定要删除用户 <%= user %> 吗?',\n deleteSuccessfully: '用户删除成功',\n },\n Role: {\n createTitle: '创建角色',\n createSuccessfully: '角色创建成功',\n updateTitle: '更新角色',\n updateSuccessfully: '角色更新成功',\n deleteTitle: '删除角色',\n deleteContent: '确定要删除角色 <%= role %> 吗?',\n deleteSuccessfully: '角色删除成功',\n },\n PermissionList: {\n failedDescription: '获取权限列表失败',\n baseSectionTitle: '平台基础权限',\n gameSectionTitle: '游戏权限',\n gameSectionDescription: '请先选择游戏',\n gameSelectPlaceholder: '请先选择游戏',\n removeText: '移除',\n addText: '添加游戏权限',\n },\n RoleDetail: {\n title: '角色详情',\n },\n InfiniteList: {\n loadingText: '加载中',\n reachEndText: '已经到底了',\n loadMoreText: '加载更多',\n },\n}\n\nexport default locale\n"]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-toolkits",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "2.22.
|
|
4
|
+
"version": "2.22.21",
|
|
5
5
|
"sideEffects": [
|
|
6
6
|
"*.css"
|
|
7
7
|
],
|
|
@@ -68,7 +68,7 @@
|
|
|
68
68
|
"ts-essentials": "^10.0.3",
|
|
69
69
|
"tsup": "^8.3.5",
|
|
70
70
|
"typescript": "^5.6.3",
|
|
71
|
-
"@flow97/eslint-config-react": "1.1.
|
|
71
|
+
"@flow97/eslint-config-react": "1.1.2",
|
|
72
72
|
"tailwind-config": "0.1.3",
|
|
73
73
|
"tsconfig": "0.0.6"
|
|
74
74
|
},
|
package/lib/chunk-4BZYS36Z.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import {i}from'./chunk-MQWH2XBX.js';import {has,template,get}from'lodash-es';import {useMemo}from'react';function l(){let t=i(e=>e.locale);return {t:useMemo(()=>(e,r)=>has(t,e)?template(get(t,e))(r):e,[t])}}export{l as a};//# sourceMappingURL=chunk-4BZYS36Z.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-4BZYS36Z.js.map
|
package/lib/chunk-MQWH2XBX.js
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import {create,useStore,createStore}from'zustand';import {App}from'antd';import {createContext,useContext,useMemo,useRef}from'react';import {persist,createJSONStorage}from'zustand/middleware';import {jwtDecode}from'jwt-decode';import {jsx}from'react/jsx-runtime';import ne from'ky';import {useNavigate}from'react-router-dom';function K(){return create((e,t)=>({open:new Map,usedIds:new Set,isOpen:o=>t().open.get(o)??!1,show(o){e({open:new Map(t().open).set(o,!0)});},hide(o){e({open:new Map(t().open).set(o,!1)});},hideAll(){e({open:new Map});},checkUniqueness(o){let{usedIds:n}=t();return !n.has(o)},registerIds(o){let{usedIds:n}=t();return n.has(o)?!1:(e({usedIds:new Set(n).add(o)}),!0)},cleanup(o){let{open:n,usedIds:a}=t(),p=new Map(n),T=new Set(a);p.delete(o),T.delete(o),e({open:p,usedIds:T});}}))}var j=0,H=()=>{let e=Date.now(),t=Math.floor(Math.random()*1e3),o=++j%1e3;return e*1e6+t*1e3+o};var k={getItem:e=>sessionStorage.getItem(e)||localStorage.getItem(e),setItem:(e,t)=>{sessionStorage.setItem(e,t),localStorage.setItem(e,t);},removeItem(e){sessionStorage.removeItem(e),localStorage.removeItem(e);}};var we="https://idaas.ifunplus.cn/enduser/api/application/plugin_FunPlus/sso/v1",S="App-ID",Ee="/console/",v=(a=>(a.V1="v1",a.V2="v2",a.V3="v3",a.V4="v4",a))(v||{}),Ue="*";var W={global:{noEntitlement:"No permission, please contact the administrator.",name:"Name",creationTime:"Creation Time",operation:"Operation",update:"Update",edit:"Edit",delete:"Delete",selectAll:"Select All",game:"Game",user:"User",role:"Role",username:"Username",password:"Password",label:"Label",method:"Method",route:"Route",request:"Request",response:"Response",add:"Add",signIn:"Sign In",projectGroup:"Project Group",view:"View",back:"Back"},SignIn:{title:"Sign In Method",thirdParty:"Third party sign in",signInWithIDass:"Sign in with IDass",unregistered:"You are not yet registered on the platform, please contact the administrator",welcome:"Welcome"},NotFound:{subTitle:"The page you visited does not exist",buttonText:"Return to homepage"},FilterFormWrapper:{confirmText:"Search",resetText:"Reset"},FormModal:{confirmText:"Confirm",cancelText:"Cancel"},GameSelect:{label:"Current Game",placeholder:"Please select a game"},RequireGame:{description:"Please select a game"},UserWidget:{signOutText:"Sign Out"},User:{createTitle:"Create User",createSuccessfully:"User created successfully",updateTitle:"Update User",updateSuccessfully:"User updated successfully",deleteTitle:"Delete User",deleteContent:"Are you sure you want to delete user <%= user %>?",deleteSuccessfully:"User deleted successfully"},Role:{createTitle:"Create Role",createSuccessfully:"Role created successfully",updateTitle:"Update Role",updateSuccessfully:"Role updated successfully",deleteTitle:"Delete Role",deleteContent:"Are you sure you want to delete role <%= role %>?",deleteSuccessfully:"Role deleted successfully"},PermissionList:{failedDescription:"Failed to get permission list",baseSectionTitle:"Platform Basic Permissions",gameSectionTitle:"Game Permissions",gameSectionDescription:"Please select a game first",gameSelectPlaceholder:"Please select a game first",removeText:"Remove",addText:"Add Game Permissions"},RoleDetail:{title:"Role Details"},InfiniteList:{loadingText:"Loading...",reachEndText:"You've reached the end",loadMoreText:"Load more"}},w=W;var E=e=>({locale:w,gameApiV2:!1,isGlobal:!1,loginPath:"/sign_in",mainPagePath:"/",permissionVersion:"v1",setContext(t){e(o=>({...o,...t}));}});var U=e=>({setGameId:t=>{e({gameId:t});}});var Y=e=>{if(!e)return null;try{return jwtDecode(e)}catch{return null}},A=e=>({token:void 0,user:null,setToken:t=>{let o=Y(t);e({token:t,user:o});}});var D=e=>createStore()(persist((...t)=>{let[o,,n]=t;return {...A(...t),...U(...t),...E(...t),clear:()=>{let a=n.getInitialState();o(a),n.persist.clearStorage();},...e}},{name:"toolkits",storage:createJSONStorage(()=>k),partialize:t=>({token:t.token,gameId:t.gameId,collapsed:t.collapsed,user:t.user})}));var b=createContext(null);function C(e){let t=useContext(b);if(!t)throw new Error("Missing ToolkitsProvider in the tree");return useStore(t,e||(o=>o))}var G=e=>{let{children:t,...o}=e,n=useRef(),a=useContext(b)?.getState();if(n.current||(n.current=D({...a,...o})),!n.current.getState().loginPath)throw new Error('ToolkitsProvider: \u8BF7\u914D\u7F6E "loginPath"');return jsx(b.Provider,{value:n.current,children:jsx(App,{children:t})})},oe=(e,t)=>{let o=n=>jsx(G,{...t,children:jsx(e,{...n})});return o.displayName=`withContext(${e.displayName||e.name||"Component"})`,o},se=G;var O=[0,1,200],h={OK:200,UNAUTHORIZED:401,FORBIDDEN:403,UNREGISTERED:412},le=3e4;var N=e=>!e||typeof e!="object"?"Unknown error":e.msg||e.message||e.error||"Unknown error",ce=e=>{let{value:t,allowedCodes:o}=e;return t==null||typeof t!="number"?!1:o.includes(t)},ue=(e,t)=>{if(t<h.OK||t>=300)return !1;if(!e||typeof e!="object")return !0;let o=[{field:"code",value:e.code,allowedCodes:O},{field:"status",value:e.status,allowedCodes:O},{field:"errno",value:e.errno,allowedCodes:O}];return o.some(a=>a.value!==void 0&&a.value!==null)?o.every(a=>a.value===void 0||a.value===null||ce(a)):!0},pe=async(e,t)=>{switch(t){case"blob":return e.blob();case"text":return e.text();case"arrayBuffer":return e.arrayBuffer();case"formData":return e.formData();case"json":default:return e.json()}},de=e=>{let{baseURL:t}=e||{},{notification:o}=App.useApp(),n=useNavigate(),a=C(),{token:p,isGlobal:T,gameId:R,permissionVersion:I,loginPath:y,clear:x}=a,F=()=>{x(),n(y);},M=()=>{if(x(),y){let s=new URL(y,window.location.origin);s.searchParams.set("unregistered","true"),n(s.toString());}},_=()=>{o.error({message:"\u8BBF\u95EE\u88AB\u7981\u6B62",description:"\u60A8\u6CA1\u6709\u6743\u9650\u8BBF\u95EE\u6B64\u8D44\u6E90\u3002"});},B=s=>async(r,i,l)=>{if(s==="blob"||s==="arrayBuffer"||s==="text"||s==="formData")return l;let c;try{c=await l.clone().json();}catch{return l}if(ue(c,l.status)){let f=c.data!==void 0?c.data:c;return new Response(JSON.stringify(f),{status:l.status,statusText:l.statusText,headers:l.headers})}let d=N(c);o.error({message:"Request failed",description:d});let m=new Error(d);throw m.response=l,m.data=c,m},V=(s,r)=>{switch(s){case h.UNAUTHORIZED:F();break;case h.UNREGISTERED:M();break;case h.FORBIDDEN:_();break;default:{let i=N(r)||`HTTP ${s} Error`;o.error({message:"Request failed",description:i});break}}},P=useMemo(()=>ne.create({prefixUrl:t,retry:0,timeout:le,headers:{Accept:"application/json","Content-Type":"application/json"},hooks:{beforeRequest:[s=>{p&&s.headers.set("Authorization",`Bearer ${p}`),!s.headers.has(S)&&I!=="v1"&&(T||!R?s.headers.set(S,"global"):s.headers.set(S,encodeURIComponent(String(R))));}],beforeError:[async s=>{let{response:r}=s;if(r){let i=r.status,l;try{let c=r.headers.get("content-type")||"";(c.includes("application/json")||c.startsWith("text/"))&&(l=await r.clone().json());}catch{}V(i,l);}else o.error({message:"Network Error",description:s.message||"Network request failed"});return s}]}}),[t,p,T,R,I,o,y,x]),u=async(s,r,i,l)=>{let{responseType:c,...d}=l||{},m={...d,hooks:{...d.hooks,afterResponse:[...d.hooks?.afterResponse||[],B(c)]}},f;return i?f=await P(r,{method:s,json:i,...m}):f=await P(r,{method:s,...m}),pe(f,c)};return {get:(s,r)=>u("GET",s,void 0,r),post:(s,r,i)=>u("POST",s,r,i),put:(s,r,i)=>u("PUT",s,r,i),delete:(s,r)=>u("DELETE",s,void 0,r),patch:(s,r,i)=>u("PATCH",s,r,i),options:(s,r)=>u("OPTIONS",s,void 0,r),head:(s,r)=>u("HEAD",s,void 0,r),request:s=>{let{url:r,...i}=s;return u(i.method||"GET",r,void 0,i)},instance:P}};var ct={permissions:{check:(e,t)=>["permissions","check",e,t],allPermissions:["permissions","all"],allPermissionsV2:["permissions","allV2"]},users:{all:["users"],detail:e=>["users","detail",e],create:["users","create"],update:["users","update"],delete:["users","delete"]},roles:{all:["roles"],detail:(e,t)=>["roles","detail",e,t],create:e=>["roles","create",e],update:e=>["roles","update",e],delete:["roles","delete"]},menus:{all:["menus"],navbar:e=>["menus","navbar",e],detail:e=>["menus","detail",e],create:["menus","create"],update:["menus","update"],delete:["menus","delete"]},enums:{gameGroups:["enums","gameGroups"],gameIds:e=>["enums","gameIds",e]},games:{all:["games","all"]}};
|
|
2
|
-
export{K as a,H as b,k as c,we as d,S as e,Ee as f,v as g,Ue as h,C as i,oe as j,se as k,de as l,ct as m};//# sourceMappingURL=chunk-MQWH2XBX.js.map
|
|
3
|
-
//# sourceMappingURL=chunk-MQWH2XBX.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils/createVisibilityStore.ts","../src/utils/generateId.ts","../src/utils/mixedStorage.ts","../src/constants/index.ts","../src/locale/en_GB.ts","../src/stores/context.ts","../src/stores/game.ts","../src/stores/token.ts","../src/stores/index.ts","../src/components/toolkitsProvider/ToolkitsProvider.tsx","../src/libs/ky.ts","../src/queryKeys.ts"],"names":["createVisibilityStore","create","set","get","uuid","usedIds","open","newOpen","newUsedIds","globalCounter","generateId","timestamp","random","counter","mixedStorage","name","value","SSO_URL","APP_ID_HEADER","FRONTEND_ROUTE_PREFIX","PermissionVersion","WILDCARD","locale","en_GB_default","createContextSlice","state","prev","createGameSlice","id","decodeToken","token","jwtDecode","createTokenSlice","user","createToolkitsStore","initProps","createStore","persist","args","store","initialState","createJSONStorage","ToolkitsContext","createContext","useToolkitsStore","selector","useContext","useStore","ToolkitsProvider","props","children","restProps","storeRef","useRef","parentState","jsx","App","withContext","Component","providerProps","WrappedComponent","ToolkitsProvider_default","SUCCESS_RESPONSE_CODES","HTTP_STATUS","REQUEST_TIMEOUT","extractErrorMessage","data","isStatusCodeSuccess","config","allowedCodes","isSuccessResponse","status","statusChecks","processResponseByType","response","responseType","useKy","baseURL","notification","navigate","useNavigate","toolkitsStore","isGlobal","gameId","permissionVersion","loginPath","clear","handleUnauthorized","handleUnregistered","url","handleForbidden","createResponseHandler","_request","_options","responseData","errorMessage","error","handleHttpStatusError","instance","useMemo","ky","request","contentType","makeRequest","method","requestOptions","kyOptions","finalOptions","options","requestOpts","queryKeys","permissions","version","gameGroups"],"mappings":"qUAmBO,SAASA,GAAwB,CACtC,OAAOC,OAAwB,CAACC,CAAAA,CAAKC,KAAS,CAC5C,IAAA,CAAM,IAAI,GACV,CAAA,OAAA,CAAS,IAAI,GACb,CAAA,MAAA,CAAQC,CAAQD,EAAAA,CAAAA,EAAM,CAAA,IAAA,CAAK,IAAIC,CAAI,CAAA,EAAK,GACxC,IAAKA,CAAAA,CAAAA,CAAM,CACTF,CAAI,CAAA,CACF,IAAM,CAAA,IAAI,GAAIC,CAAAA,CAAAA,GAAM,IAAI,CAAA,CAAE,IAAIC,CAAM,CAAA,CAAA,CAAI,CAC1C,CAAC,EACH,CACA,CAAA,IAAA,CAAKA,CAAM,CAAA,CACTF,EAAI,CAAE,IAAA,CAAM,IAAI,GAAIC,CAAAA,CAAAA,GAAM,IAAI,CAAA,CAAE,GAAIC,CAAAA,CAAAA,CAAM,CAAK,CAAA,CAAE,CAAC,EACpD,CAAA,CACA,SAAU,CACRF,CAAAA,CAAI,CAAE,IAAM,CAAA,IAAI,GAAM,CAAC,EACzB,CAAA,CACA,gBAAgBE,CAAM,CAAA,CACpB,GAAM,CAAE,OAAA,CAAAC,CAAQ,CAAIF,CAAAA,CAAAA,EACpB,CAAA,OAAO,CAACE,CAAAA,CAAQ,IAAID,CAAI,CAC1B,EACA,WAAYA,CAAAA,CAAAA,CAAM,CAChB,GAAM,CAAE,OAAAC,CAAAA,CAAQ,CAAIF,CAAAA,CAAAA,GACpB,OAAIE,CAAAA,CAAQ,IAAID,CAAI,CAAA,CACX,IAETF,CAAI,CAAA,CAAE,OAAS,CAAA,IAAI,GAAIG,CAAAA,CAAO,EAAE,GAAID,CAAAA,CAAI,CAAE,CAAC,CAAA,CACpC,GACT,CACA,CAAA,OAAA,CAAQA,CAAM,CAAA,CACZ,GAAM,CAAE,KAAAE,CAAM,CAAA,OAAA,CAAAD,CAAQ,CAAIF,CAAAA,CAAAA,GACpBI,CAAU,CAAA,IAAI,GAAID,CAAAA,CAAI,CACtBE,CAAAA,CAAAA,CAAa,IAAI,GAAIH,CAAAA,CAAO,EAClCE,CAAQ,CAAA,MAAA,CAAOH,CAAI,CACnBI,CAAAA,CAAAA,CAAW,MAAOJ,CAAAA,CAAI,CACtBF,CAAAA,CAAAA,CAAI,CAAE,IAAMK,CAAAA,CAAAA,CAAS,QAASC,CAAW,CAAC,EAC5C,CACF,CAAA,CAAE,CACJ,CCpDIC,IAAAA,CAAAA,CAAgB,EAEPC,CAAa,CAAA,IAAc,CACtC,IAAMC,CAAAA,CAAY,KAAK,GAAI,EAAA,CACrBC,CAAS,CAAA,IAAA,CAAK,KAAM,CAAA,IAAA,CAAK,QAAW,CAAA,GAAI,EACxCC,CAAU,CAAA,EAAEJ,EAAgB,GAIlC,CAAA,OAAOE,CAAY,CAAA,GAAA,CAAUC,CAAS,CAAA,GAAA,CAAOC,CAC/C,ECVO,IAAMC,EAA6B,CACxC,OAAA,CAAUC,GACD,cAAe,CAAA,OAAA,CAAQA,CAAI,CAAA,EAAK,YAAa,CAAA,OAAA,CAAQA,CAAI,CAElE,CAAA,OAAA,CAAS,CAACA,CAAcC,CAAAA,CAAAA,GAAkB,CACxC,cAAe,CAAA,OAAA,CAAQD,CAAMC,CAAAA,CAAK,CAClC,CAAA,YAAA,CAAa,QAAQD,CAAMC,CAAAA,CAAK,EAClC,CACA,CAAA,UAAA,CAAWD,EAAc,CACvB,cAAA,CAAe,UAAWA,CAAAA,CAAI,CAC9B,CAAA,YAAA,CAAa,WAAWA,CAAI,EAC9B,CACF,EChBO,IAAME,GAAU,yEAEVC,CAAAA,CAAAA,CAAgB,QAEhBC,CAAAA,EAAAA,CAAwB,WAEzBC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,GACVA,EAAA,EAAK,CAAA,IAAA,CACLA,EAAA,EAAK,CAAA,IAAA,CACLA,EAAA,EAAK,CAAA,IAAA,CACLA,CAAA,CAAA,EAAA,CAAK,IAJKA,CAAAA,CAAAA,CAAAA,EAAAA,CAAAA,EAAA,IAOCC,EAAW,CAAA,ICXxB,IAAMC,CAAiB,CAAA,CACrB,OAAQ,CACN,aAAA,CAAe,kDACf,CAAA,IAAA,CAAM,MACN,CAAA,YAAA,CAAc,gBACd,SAAW,CAAA,WAAA,CACX,OAAQ,QACR,CAAA,IAAA,CAAM,OACN,MAAQ,CAAA,QAAA,CACR,SAAW,CAAA,YAAA,CACX,IAAM,CAAA,MAAA,CACN,KAAM,MACN,CAAA,IAAA,CAAM,OACN,QAAU,CAAA,UAAA,CACV,SAAU,UACV,CAAA,KAAA,CAAO,OACP,CAAA,MAAA,CAAQ,QACR,CAAA,KAAA,CAAO,QACP,OAAS,CAAA,SAAA,CACT,SAAU,UACV,CAAA,GAAA,CAAK,MACL,MAAQ,CAAA,SAAA,CACR,YAAc,CAAA,eAAA,CACd,IAAM,CAAA,MAAA,CACN,KAAM,MACR,CAAA,CACA,OAAQ,CACN,KAAA,CAAO,iBACP,UAAY,CAAA,qBAAA,CACZ,eAAiB,CAAA,oBAAA,CACjB,YAAc,CAAA,8EAAA,CACd,QAAS,SACX,CAAA,CACA,SAAU,CACR,QAAA,CAAU,sCACV,UAAY,CAAA,oBACd,CACA,CAAA,iBAAA,CAAmB,CACjB,WAAA,CAAa,SACb,SAAW,CAAA,OACb,EACA,SAAW,CAAA,CACT,YAAa,SACb,CAAA,UAAA,CAAY,QACd,CAAA,CACA,UAAY,CAAA,CACV,MAAO,cACP,CAAA,WAAA,CAAa,sBACf,CACA,CAAA,WAAA,CAAa,CACX,WAAa,CAAA,sBACf,CACA,CAAA,UAAA,CAAY,CACV,WAAA,CAAa,UACf,CACA,CAAA,IAAA,CAAM,CACJ,WAAa,CAAA,aAAA,CACb,mBAAoB,2BACpB,CAAA,WAAA,CAAa,aACb,CAAA,kBAAA,CAAoB,2BACpB,CAAA,WAAA,CAAa,cACb,aAAe,CAAA,mDAAA,CACf,mBAAoB,2BACtB,CAAA,CACA,KAAM,CACJ,WAAA,CAAa,aACb,CAAA,kBAAA,CAAoB,2BACpB,CAAA,WAAA,CAAa,cACb,kBAAoB,CAAA,2BAAA,CACpB,YAAa,aACb,CAAA,aAAA,CAAe,oDACf,kBAAoB,CAAA,2BACtB,EACA,cAAgB,CAAA,CACd,kBAAmB,+BACnB,CAAA,gBAAA,CAAkB,6BAClB,gBAAkB,CAAA,kBAAA,CAClB,uBAAwB,4BACxB,CAAA,qBAAA,CAAuB,4BACvB,CAAA,UAAA,CAAY,QACZ,CAAA,OAAA,CAAS,sBACX,CACA,CAAA,UAAA,CAAY,CACV,KAAO,CAAA,cACT,EACA,YAAc,CAAA,CACZ,WAAa,CAAA,YAAA,CACb,YAAc,CAAA,wBAAA,CACd,aAAc,WAChB,CACF,EAEOC,CAAQD,CAAAA,CAAAA,CC1ER,IAAME,CAAuEtB,CAAAA,CAAAA,GAAQ,CAC1F,MAAA,CAAQqB,CACR,CAAA,SAAA,CAAW,GACX,QAAU,CAAA,CAAA,CAAA,CACV,UAAW,UACX,CAAA,YAAA,CAAc,IACd,iBACA,CAAA,IAAA,CAAA,UAAA,CAAWE,CAAO,CAAA,CAChBvB,CAAIwB,CAAAA,CAAAA,GAAS,CAAE,GAAGA,CAAAA,CAAM,GAAGD,CAAM,CAAA,CAAE,EACrC,CACF,CAAA,CAAA,CCvBO,IAAME,CAAAA,CAA8DzB,CAAQ,GAAA,CACjF,UAAW0B,CAAM,EAAA,CACf1B,EAAI,CAAE,MAAA,CAAQ0B,CAAG,CAAC,EACpB,CACF,CAAA,CAAA,CCOA,IAAMC,EAAeC,CAAoC,EAAA,CACvD,GAAI,CAACA,CAAAA,CAAO,OAAO,IAAA,CAEnB,GAAI,CACF,OAAOC,SAAoBD,CAAAA,CAAK,CAClC,CAAQ,KAAA,CACN,OAAO,IACT,CACF,CAEaE,CAAAA,CAAAA,CAAqD9B,CAAQ,GAAA,CACxE,MAAO,KACP,CAAA,CAAA,IAAA,CAAM,KACN,QAAU4B,CAAAA,CAAAA,EAAS,CACjB,IAAMG,CAAAA,CAAOJ,CAAYC,CAAAA,CAAK,CAC9B5B,CAAAA,CAAAA,CAAI,CAAE,KAAA4B,CAAAA,CAAAA,CAAO,KAAAG,CAAK,CAAC,EACrB,CACF,CAAA,CAAA,CClBO,IAAMC,CAAAA,CAAuBC,CAC3BC,EAAAA,WAAAA,GACLC,OACE,CAAA,CAAA,GAAIC,IAAS,CACX,GAAM,CAACpC,CAAK,EAAEqC,CAAK,CAAA,CAAID,CACvB,CAAA,OAAO,CACL,GAAGN,CAAAA,CAAiB,GAAGM,CAAI,CAAA,CAC3B,GAAGX,CAAgB,CAAA,GAAGW,CAAI,CAAA,CAC1B,GAAGd,CAAAA,CAAmB,GAAGc,CAAI,CAAA,CAC7B,MAAO,IAAM,CACX,IAAME,CAAeD,CAAAA,CAAAA,CAAM,eAAgB,EAAA,CAC3CrC,CAAIsC,CAAAA,CAAY,EAChBD,CAAM,CAAA,OAAA,CAAQ,eAChB,CAAA,CACA,GAAGJ,CACL,CACF,CACA,CAAA,CACE,IAAM,CAAA,UAAA,CACN,QAASM,iBAAkB,CAAA,IAAM3B,CAAY,CAC7C,CAAA,UAAA,CAAYW,IAAU,CACpB,KAAA,CAAOA,CAAM,CAAA,KAAA,CACb,MAAQA,CAAAA,CAAAA,CAAM,OACd,SAAWA,CAAAA,CAAAA,CAAM,UACjB,IAAMA,CAAAA,CAAAA,CAAM,IACd,CACF,CAAA,CACF,CACF,CAAA,CCjCF,IAAMiB,CAAAA,CAAkBC,cAAoC,IAAI,CAAA,CAKzD,SAASC,CAAoBC,CAAAA,CAAAA,CAA2D,CAC7F,IAAMN,CAAQO,CAAAA,UAAAA,CAAWJ,CAAe,CACxC,CAAA,GAAI,CAACH,CAAO,CAAA,MAAM,IAAI,KAAM,CAAA,sCAAsC,CAGlE,CAAA,OAAOQ,QAASR,CAAAA,CAAAA,CAAOM,IAAcpB,CAAyBA,EAAAA,CAAAA,CAAW,CAC3E,CAIA,IAAMuB,EAA8CC,CAAS,EAAA,CAC3D,GAAM,CAAE,QAAAC,CAAAA,CAAAA,CAAU,GAAGC,CAAU,CAAA,CAAIF,EAC7BG,CAAWC,CAAAA,MAAAA,GACXC,CAAcR,CAAAA,UAAAA,CAAWJ,CAAe,CAAA,EAAG,QAAS,EAAA,CAM1D,GAJKU,CAAS,CAAA,OAAA,GACZA,EAAS,OAAUlB,CAAAA,CAAAA,CAAoB,CAAE,GAAGoB,CAAAA,CAAa,GAAGH,CAAU,CAAC,CAAA,CAAA,CAGrE,CAACC,CAAS,CAAA,OAAA,CAAQ,UAAW,CAAA,SAAA,CAC/B,MAAM,IAAI,KAAA,CAAM,kDAAmC,CAAA,CAGrD,OACEG,GAAAA,CAACb,EAAgB,QAAhB,CAAA,CAAyB,MAAOU,CAAS,CAAA,OAAA,CACxC,SAAAG,GAACC,CAAAA,GAAAA,CAAA,CAAK,QAAA,CAAAN,CAAS,CAAA,CAAA,CACjB,CAEJ,CAEaO,CAAAA,EAAAA,CAAc,CAACC,CAA0BC,CAAAA,CAAAA,GAA2D,CAC/G,IAAMC,CAAAA,CAAoBX,CAEtBM,EAAAA,GAAAA,CAACP,CAAA,CAAA,CAAkB,GAAGW,CACpB,CAAA,QAAA,CAAAJ,IAACG,CAAA,CAAA,CAAW,GAAGT,CAAO,CAAA,CAAA,CACxB,CAIJ,CAAA,OAAAW,CAAiB,CAAA,WAAA,CAAc,eAAeF,CAAU,CAAA,WAAA,EAAeA,EAAU,IAAQ,EAAA,WAAW,IAE7FE,CACT,CAAA,CAMOC,EAAQb,CAAAA,ECvDf,IAAMc,CAAyB,CAAA,CAAC,EAAG,CAAG,CAAA,GAAG,EAGnCC,CAAc,CAAA,CAClB,EAAI,CAAA,GAAA,CACJ,YAAc,CAAA,GAAA,CACd,UAAW,GACX,CAAA,YAAA,CAAc,GAChB,CAGMC,CAAAA,EAAAA,CAAkB,IA6ClBC,IAAAA,CAAAA,CAAuBC,CACvB,EAAA,CAACA,CAAQ,EAAA,OAAOA,GAAS,QACpB,CAAA,eAAA,CAGFA,EAAK,GAAOA,EAAAA,CAAAA,CAAK,SAAWA,CAAK,CAAA,KAAA,EAAS,eAQ7CC,CAAAA,EAAAA,CAAuBC,CAAuC,EAAA,CAClE,GAAM,CAAE,KAAA,CAAApD,EAAO,YAAAqD,CAAAA,CAAa,EAAID,CAMhC,CAAA,OAJ2BpD,CAAU,EAAA,IAAA,EAIjC,OAAOA,CAAAA,EAAU,SACZ,CAGFqD,CAAAA,CAAAA,CAAAA,CAAa,SAASrD,CAAK,CACpC,EAQMsD,EAAoB,CAAA,CAACJ,EAAWK,CAA4B,GAAA,CAEhE,GAAIA,CAASR,CAAAA,CAAAA,CAAY,IAAMQ,CAAU,EAAA,GAAA,CACvC,OAAO,CAIT,CAAA,CAAA,GAAI,CAACL,CAAAA,EAAQ,OAAOA,CAAAA,EAAS,SAC3B,OAAO,CAAA,CAAA,CAIT,IAAMM,CAAoC,CAAA,CACxC,CAAE,KAAO,CAAA,MAAA,CAAQ,KAAON,CAAAA,CAAAA,CAAK,IAAM,CAAA,YAAA,CAAcJ,CAAuB,CACxE,CAAA,CAAE,MAAO,QAAU,CAAA,KAAA,CAAOI,EAAK,MAAQ,CAAA,YAAA,CAAcJ,CAAuB,CAAA,CAC5E,CAAE,KAAA,CAAO,QAAS,KAAOI,CAAAA,CAAAA,CAAK,MAAO,YAAcJ,CAAAA,CAAuB,CAC5E,CAMA,CAAA,OAH8BU,CAAa,CAAA,IAAA,CAAKJ,CAAUA,EAAAA,CAAAA,CAAO,QAAU,KAAaA,CAAAA,EAAAA,CAAAA,CAAO,QAAU,IAAI,CAAA,CAIpGI,EAAa,KAClBJ,CAAAA,CAAAA,EAAUA,CAAO,CAAA,KAAA,GAAU,KAAaA,CAAAA,EAAAA,CAAAA,CAAO,QAAU,IAAQD,EAAAA,EAAAA,CAAoBC,CAAM,CAC7F,CAAA,CAIK,EACT,CAQMK,CAAAA,EAAAA,CAAwB,MAAOC,CAAAA,CAAoBC,CAA8C,GAAA,CACrG,OAAQA,CAAc,EACpB,IAAK,MACH,CAAA,OAAOD,EAAS,IAAK,EAAA,CACvB,IAAK,MAAA,CACH,OAAOA,CAAAA,CAAS,MAClB,CAAA,IAAK,cACH,OAAOA,CAAAA,CAAS,aAClB,CAAA,IAAK,UACH,CAAA,OAAOA,CAAS,CAAA,QAAA,GAClB,IAAK,MAAA,CACL,QACE,OAAOA,CAAAA,CAAS,MACpB,CACF,CAOaE,CAAAA,EAAAA,CAASR,CAAqC,EAAA,CACzD,GAAM,CAAE,OAAA,CAAAS,CAAQ,CAAIT,CAAAA,CAAAA,EAAU,EACxB,CAAA,CAAE,YAAAU,CAAAA,CAAa,CAAItB,CAAAA,GAAAA,CAAI,QACvBuB,CAAAA,CAAAA,CAAWC,aAGXC,CAAAA,CAAAA,CAAgBrC,GAChB,CAAA,CAAE,KAAAd,CAAAA,CAAAA,CAAO,QAAAoD,CAAAA,CAAAA,CAAU,OAAAC,CAAQ,CAAA,iBAAA,CAAAC,EAAmB,SAAAC,CAAAA,CAAAA,CAAW,MAAAC,CAAM,CAAA,CAAIL,CAGnEM,CAAAA,CAAAA,CAAqB,IAAM,CAC/BD,GACAP,CAAAA,CAAAA,CAASM,CAAS,EACpB,CAAA,CAGMG,EAAqB,IAAM,CAE/B,GADAF,CAAAA,EACID,CAAAA,CAAAA,CAAW,CAEb,IAAMI,CAAAA,CAAM,IAAI,GAAIJ,CAAAA,CAAAA,CAAW,OAAO,QAAS,CAAA,MAAM,CACrDI,CAAAA,CAAAA,CAAI,YAAa,CAAA,GAAA,CAAI,eAAgB,MAAM,CAAA,CAC3CV,EAASU,CAAI,CAAA,QAAA,EAAU,EACzB,CACF,CAGMC,CAAAA,CAAAA,CAAkB,IAAM,CAC5BZ,EAAa,KAAM,CAAA,CACjB,QAAS,gCACT,CAAA,WAAA,CAAa,oEACf,CAAC,EACH,CAGMa,CAAAA,CAAAA,CAAyBhB,CACtB,EAAA,MAAOiB,EAAeC,CAAenB,CAAAA,CAAAA,GAA0C,CAEpF,GACEC,CAAAA,GAAiB,QACjBA,CAAiB,GAAA,aAAA,EACjBA,CAAiB,GAAA,MAAA,EACjBA,CAAiB,GAAA,UAAA,CAEjB,OAAOD,CAIT,CAAA,IAAIR,EACJ,GAAI,CACFA,EAAO,MAAMQ,CAAAA,CAAS,KAAM,EAAA,CAAE,IAAK,GACrC,MAAQ,CAEN,OAAOA,CACT,CAEA,GAAIJ,GAAkBJ,CAAMQ,CAAAA,CAAAA,CAAS,MAAM,CAAA,CAAG,CAC5C,IAAMoB,EAAe5B,CAAK,CAAA,IAAA,GAAS,OAAYA,CAAK,CAAA,IAAA,CAAOA,EAC3D,OAAO,IAAI,QAAS,CAAA,IAAA,CAAK,SAAU4B,CAAAA,CAAY,EAAG,CAChD,MAAA,CAAQpB,EAAS,MACjB,CAAA,UAAA,CAAYA,EAAS,UACrB,CAAA,OAAA,CAASA,CAAS,CAAA,OACpB,CAAC,CACH,CAEA,IAAMqB,CAAAA,CAAe9B,EAAoBC,CAAI,CAAA,CAE7CY,EAAa,KAAM,CAAA,CACjB,OAAS,CAAA,gBAAA,CACT,WAAaiB,CAAAA,CACf,CAAC,CAED,CAAA,IAAMC,EAAQ,IAAI,KAAA,CAAMD,CAAY,CACnC,CAAA,MAACC,CAAc,CAAA,QAAA,CAAWtB,CACzBsB,CAAAA,CAAAA,CAAc,KAAO9B,CACjB8B,CAAAA,CACR,EAIIC,CAAwB,CAAA,CAAC1B,EAAgBL,CAAc,GAAA,CAC3D,OAAQK,CAAAA,EACN,KAAKR,EAAY,YACfwB,CAAAA,CAAAA,GACA,MAEF,KAAKxB,EAAY,YACfyB,CAAAA,CAAAA,EACA,CAAA,MAEF,KAAKzB,CAAAA,CAAY,UACf2B,CAAgB,EAAA,CAChB,MAEF,QAAS,CAEP,IAAMK,CAAe9B,CAAAA,CAAAA,CAAoBC,CAAI,CAAA,EAAK,CAAQK,KAAAA,EAAAA,CAAM,SAChEO,CAAa,CAAA,KAAA,CAAM,CACjB,OAAS,CAAA,gBAAA,CACT,YAAaiB,CACf,CAAC,CACD,CAAA,KACF,CACF,CACF,EAGMG,CAAWC,CAAAA,OAAAA,CAAQ,IAChBC,EAAG,CAAA,MAAA,CAAO,CACf,SAAWvB,CAAAA,CAAAA,CACX,KAAO,CAAA,CAAA,CACP,OAASb,CAAAA,EAAAA,CACT,QAAS,CACP,MAAA,CAAQ,mBACR,cAAgB,CAAA,kBAClB,EACA,KAAO,CAAA,CACL,aAAe,CAAA,CACbqC,CAAW,EAAA,CAELvE,GACFuE,CAAQ,CAAA,OAAA,CAAQ,IAAI,eAAiB,CAAA,CAAA,OAAA,EAAUvE,CAAK,CAAE,CAAA,CAAA,CAIpD,CAACuE,CAAAA,CAAQ,OAAQ,CAAA,GAAA,CAAInF,CAAa,CAAKkE,EAAAA,CAAAA,GAAsB,OAC3DF,CAAY,EAAA,CAACC,EACfkB,CAAQ,CAAA,OAAA,CAAQ,GAAInF,CAAAA,CAAAA,CAAe,QAAQ,CAAA,CAG3CmF,EAAQ,OAAQ,CAAA,GAAA,CAAInF,EAAe,kBAAmB,CAAA,MAAA,CAAOiE,CAAM,CAAC,CAAC,CAG3E,EAAA,CACF,CACA,CAAA,WAAA,CAAa,CACX,MAAMa,CAAAA,EAAS,CACb,GAAM,CAAE,SAAAtB,CAAS,CAAA,CAAIsB,CAErB,CAAA,GAAItB,CAAU,CAAA,CACZ,IAAMH,CAASG,CAAAA,CAAAA,CAAS,OACpBR,CAEJ,CAAA,GAAI,CACF,IAAMoC,CAAAA,CAAc5B,CAAS,CAAA,OAAA,CAAQ,GAAI,CAAA,cAAc,GAAK,EACxD4B,CAAAA,CAAAA,CAAAA,CAAY,SAAS,kBAAkB,CAAA,EAAKA,EAAY,UAAW,CAAA,OAAO,CAC5EpC,IAAAA,CAAAA,CAAO,MAAMQ,CAAAA,CAAS,OAAQ,CAAA,IAAA,IAElC,CAAQ,KAAA,EAIRuB,CAAsB1B,CAAAA,CAAAA,CAAQL,CAAI,EACpC,CAEEY,KAAAA,CAAAA,CAAa,MAAM,CACjB,OAAA,CAAS,gBACT,WAAakB,CAAAA,CAAAA,CAAM,SAAW,wBAChC,CAAC,CAGH,CAAA,OAAOA,CACT,CACF,CACF,CACF,CAAC,EACA,CAACnB,CAAAA,CAAS/C,EAAOoD,CAAUC,CAAAA,CAAAA,CAAQC,CAAmBN,CAAAA,CAAAA,CAAcO,CAAWC,CAAAA,CAAK,CAAC,CAGlFiB,CAAAA,CAAAA,CAAc,MAClBC,CACAf,CAAAA,CAAAA,CACAvB,EACAuC,CACe,GAAA,CACf,GAAM,CAAE,YAAA9B,CAAAA,CAAAA,CAAc,GAAG+B,CAAU,CAAA,CAAID,GAAkB,EAAC,CAGpDE,EAA0B,CAC9B,GAAGD,CACH,CAAA,KAAA,CAAO,CACL,GAAGA,EAAU,KACb,CAAA,aAAA,CAAe,CAAC,GAAIA,CAAAA,CAAU,OAAO,aAAiB,EAAA,EAAKf,CAAAA,CAAAA,CAAsBhB,CAAY,CAAC,CAChG,CACF,CAAA,CAEID,EAEJ,OAAIR,CAAAA,CACFQ,EAAW,MAAMwB,CAAAA,CAAST,CAAK,CAAA,CAAE,MAAAe,CAAAA,CAAAA,CAAQ,KAAMtC,CAAM,CAAA,GAAGyC,CAAa,CAAC,CAAA,CAEtEjC,EAAW,MAAMwB,CAAAA,CAAST,CAAK,CAAA,CAAE,MAAAe,CAAAA,CAAAA,CAAQ,GAAGG,CAAa,CAAC,EAIrDlC,EAAsBC,CAAAA,CAAAA,CAAUC,CAAY,CACrD,CAAA,CAoCA,OAAO,CACL,GAlCU,CAAA,CAAUc,EAAamB,CAC1BL,GAAAA,CAAAA,CAAe,MAAOd,CAAK,CAAA,KAAA,CAAA,CAAWmB,CAAO,CAkCpD,CAAA,IAAA,CA/BW,CAAUnB,CAAAA,CAAavB,CAAY0C,CAAAA,CAAAA,GACvCL,EAAe,MAAQd,CAAAA,CAAAA,CAAKvB,EAAM0C,CAAO,CAAA,CA+BhD,IA5BU,CAAUnB,CAAAA,CAAavB,CAAY0C,CAAAA,CAAAA,GACtCL,CAAe,CAAA,KAAA,CAAOd,EAAKvB,CAAM0C,CAAAA,CAAO,EA4B/C,MAzBU,CAAA,CAAUnB,EAAamB,CAC1BL,GAAAA,CAAAA,CAAe,QAAUd,CAAAA,CAAAA,CAAK,KAAWmB,CAAAA,CAAAA,CAAO,EAyBvD,KAtBY,CAAA,CAAUnB,EAAavB,CAAY0C,CAAAA,CAAAA,GACxCL,EAAe,OAASd,CAAAA,CAAAA,CAAKvB,CAAM0C,CAAAA,CAAO,CAsBjD,CAAA,OAAA,CAnBc,CAAUnB,CAAagB,CAAAA,CAAAA,GAC9BF,EAAe,SAAWd,CAAAA,CAAAA,CAAK,OAAWgB,CAAc,CAAA,CAmB/D,IAhBW,CAAA,CAAUhB,CAAagB,CAAAA,CAAAA,GAC3BF,EAAe,MAAQd,CAAAA,CAAAA,CAAK,OAAWgB,CAAc,CAAA,CAgB5D,QAbwBA,CAAiE,EAAA,CACzF,GAAM,CAAE,GAAAhB,CAAAA,CAAAA,CAAK,GAAGoB,CAAY,CAAA,CAAIJ,EAChC,OAAOF,CAAAA,CAAeM,EAAY,MAAU,EAAA,KAAA,CAAOpB,CAAK,CAAA,KAAA,CAAA,CAAWoB,CAAW,CAChF,EAWE,QAAAX,CAAAA,CACF,CACF,EChZO,IAAMY,GAAY,CAEvB,WAAA,CAAa,CACX,KAAA,CAAO,CAACC,CAAAA,CAAuBC,IAAyB,CAAC,aAAA,CAAe,QAASD,CAAaC,CAAAA,CAAO,EACrG,cAAgB,CAAA,CAAC,aAAe,CAAA,KAAK,CACrC,CAAA,gBAAA,CAAkB,CAAC,aAAe,CAAA,OAAO,CAC3C,CAEA,CAAA,KAAA,CAAO,CACL,GAAK,CAAA,CAAC,OAAO,CAAA,CACb,MAASpF,CAAAA,CAAAA,EAAe,CAAC,OAAS,CAAA,QAAA,CAAUA,CAAE,CAC9C,CAAA,MAAA,CAAQ,CAAC,OAAS,CAAA,QAAQ,CAC1B,CAAA,MAAA,CAAQ,CAAC,OAAA,CAAS,QAAQ,CAC1B,CAAA,MAAA,CAAQ,CAAC,OAAS,CAAA,QAAQ,CAC5B,CAEA,CAAA,KAAA,CAAO,CACL,GAAA,CAAK,CAAC,OAAO,EACb,MAAQ,CAAA,CAACb,EAAciG,CAAyB,GAAA,CAAC,QAAS,QAAUjG,CAAAA,CAAAA,CAAMiG,CAAO,CAAA,CACjF,MAASA,CAAAA,CAAAA,EAAyB,CAAC,OAAS,CAAA,QAAA,CAAUA,CAAO,CAC7D,CAAA,MAAA,CAASA,GAAyB,CAAC,OAAA,CAAS,QAAUA,CAAAA,CAAO,CAC7D,CAAA,MAAA,CAAQ,CAAC,OAAS,CAAA,QAAQ,CAC5B,CAEA,CAAA,KAAA,CAAO,CACL,GAAK,CAAA,CAAC,OAAO,CAAA,CACb,MAAS7B,CAAAA,CAAAA,EAAoB,CAAC,OAAS,CAAA,QAAA,CAAUA,CAAM,CACvD,CAAA,MAAA,CAASvD,GAAe,CAAC,OAAA,CAAS,QAAUA,CAAAA,CAAE,CAC9C,CAAA,MAAA,CAAQ,CAAC,OAAS,CAAA,QAAQ,EAC1B,MAAQ,CAAA,CAAC,QAAS,QAAQ,CAAA,CAC1B,MAAQ,CAAA,CAAC,OAAS,CAAA,QAAQ,CAC5B,CAEA,CAAA,KAAA,CAAO,CACL,UAAY,CAAA,CAAC,QAAS,YAAY,CAAA,CAClC,OAAUqF,CAAAA,CAAAA,EAAyB,CAAC,OAAA,CAAS,UAAWA,CAAU,CACpE,EAEA,KAAO,CAAA,CACL,IAAK,CAAC,OAAA,CAAS,KAAK,CACtB,CACF","file":"chunk-MQWH2XBX.js","sourcesContent":["import { create } from 'zustand'\n\nexport interface VisibilityState {\n open: Map<number, boolean>\n usedIds: Set<number>\n isOpen: (uuid: number) => boolean\n show: (uuid: number) => void\n hide: (uuid: number) => void\n hideAll: () => void\n checkUniqueness: (uuid: number) => boolean\n registerIds: (uuid: number) => boolean\n cleanup: (uuid: number) => void\n}\n\n/**\n * 创建一个可见性管理的 Zustand store\n * 用于管理 Modal、Drawer 等组件的显示/隐藏状态\n * 每次调用都会创建一个独立的 store 实例,确保不同组件间的状态隔离\n */\nexport function createVisibilityStore() {\n return create<VisibilityState>((set, get) => ({\n open: new Map(),\n usedIds: new Set(),\n isOpen: uuid => get().open.get(uuid) ?? false,\n show(uuid) {\n set({\n open: new Map(get().open).set(uuid, true),\n })\n },\n hide(uuid) {\n set({ open: new Map(get().open).set(uuid, false) })\n },\n hideAll() {\n set({ open: new Map() })\n },\n checkUniqueness(uuid) {\n const { usedIds } = get()\n return !usedIds.has(uuid)\n },\n registerIds(uuid) {\n const { usedIds } = get()\n if (usedIds.has(uuid)) {\n return false // ID 已被使用\n }\n set({ usedIds: new Set(usedIds).add(uuid) })\n return true // 注册成功\n },\n cleanup(uuid) {\n const { open, usedIds } = get()\n const newOpen = new Map(open)\n const newUsedIds = new Set(usedIds)\n newOpen.delete(uuid)\n newUsedIds.delete(uuid)\n set({ open: newOpen, usedIds: newUsedIds })\n },\n }))\n}\n","/**\n * 生成唯一 ID 的函数\n * 使用时间戳 + 随机数 + 计数器的组合来确保唯一性\n */\nlet globalCounter = 0\n\nexport const generateId = (): number => {\n const timestamp = Date.now()\n const random = Math.floor(Math.random() * 1000)\n const counter = ++globalCounter % 1000\n\n // 组合:时间戳(毫秒) * 1000000 + 随机数 * 1000 + 计数器\n // 这样可以确保即使在同一毫秒内生成多个ID也不会重复\n return timestamp * 1000000 + random * 1000 + counter\n}\n","import type { StateStorage } from 'zustand/middleware'\n\n// 通过 SessionStorage 隔离数据,防止多开页面时的数据冲突。\n// 当 SessionStorage 不存在时,使用 LocalStorage。\nexport const mixedStorage: StateStorage = {\n getItem: (name: string): string | null => {\n return sessionStorage.getItem(name) || localStorage.getItem(name)\n },\n setItem: (name: string, value: string) => {\n sessionStorage.setItem(name, value)\n localStorage.setItem(name, value)\n },\n removeItem(name: string) {\n sessionStorage.removeItem(name)\n localStorage.removeItem(name)\n },\n}\n","export const SSO_URL = 'https://idaas.ifunplus.cn/enduser/api/application/plugin_FunPlus/sso/v1'\n\nexport const APP_ID_HEADER = 'App-ID'\n\nexport const FRONTEND_ROUTE_PREFIX = '/console/'\n\nexport enum PermissionVersion {\n V1 = 'v1',\n V2 = 'v2',\n V3 = 'v3',\n V4 = 'v4',\n}\n\nexport const WILDCARD = '*'\n","import type { Locale } from '.'\n\nconst locale: Locale = {\n global: {\n noEntitlement: 'No permission, please contact the administrator.',\n name: 'Name',\n creationTime: 'Creation Time',\n operation: 'Operation',\n update: 'Update',\n edit: 'Edit',\n delete: 'Delete',\n selectAll: 'Select All',\n game: 'Game',\n user: 'User',\n role: 'Role',\n username: 'Username',\n password: 'Password',\n label: 'Label',\n method: 'Method',\n route: 'Route',\n request: 'Request',\n response: 'Response',\n add: 'Add',\n signIn: 'Sign In',\n projectGroup: 'Project Group',\n view: 'View',\n back: 'Back',\n },\n SignIn: {\n title: 'Sign In Method',\n thirdParty: 'Third party sign in',\n signInWithIDass: 'Sign in with IDass',\n unregistered: 'You are not yet registered on the platform, please contact the administrator',\n welcome: 'Welcome',\n },\n NotFound: {\n subTitle: 'The page you visited does not exist',\n buttonText: 'Return to homepage',\n },\n FilterFormWrapper: {\n confirmText: 'Search',\n resetText: 'Reset',\n },\n FormModal: {\n confirmText: 'Confirm',\n cancelText: 'Cancel',\n },\n GameSelect: {\n label: 'Current Game',\n placeholder: 'Please select a game',\n },\n RequireGame: {\n description: 'Please select a game',\n },\n UserWidget: {\n signOutText: 'Sign Out',\n },\n User: {\n createTitle: 'Create User',\n createSuccessfully: 'User created successfully',\n updateTitle: 'Update User',\n updateSuccessfully: 'User updated successfully',\n deleteTitle: 'Delete User',\n deleteContent: 'Are you sure you want to delete user <%= user %>?',\n deleteSuccessfully: 'User deleted successfully',\n },\n Role: {\n createTitle: 'Create Role',\n createSuccessfully: 'Role created successfully',\n updateTitle: 'Update Role',\n updateSuccessfully: 'Role updated successfully',\n deleteTitle: 'Delete Role',\n deleteContent: 'Are you sure you want to delete role <%= role %>?',\n deleteSuccessfully: 'Role deleted successfully',\n },\n PermissionList: {\n failedDescription: 'Failed to get permission list',\n baseSectionTitle: 'Platform Basic Permissions',\n gameSectionTitle: 'Game Permissions',\n gameSectionDescription: 'Please select a game first',\n gameSelectPlaceholder: 'Please select a game first',\n removeText: 'Remove',\n addText: 'Add Game Permissions',\n },\n RoleDetail: {\n title: 'Role Details',\n },\n InfiniteList: {\n loadingText: 'Loading...',\n reachEndText: \"You've reached the end\",\n loadMoreText: 'Load more',\n },\n}\n\nexport default locale\n","// import type { AxiosInterceptorManager, AxiosResponse, InternalAxiosRequestConfig } from 'axios'\nimport type { StateCreator } from 'zustand'\n\nimport { PermissionVersion } from '@/constants'\nimport type { Locale } from '@/locale'\nimport enGb from '@/locale/en_GB'\n\nexport interface ContextSlice {\n locale: Locale\n permissionVersion: PermissionVersion // 权限版本\n gameApiV2: boolean\n loginPath: string // 登录页路径\n isGlobal: boolean // 为 true 时,APP-ID header 为 'global',否则为当前的游戏的 id。\n navWidth?: number // 侧边栏宽度\n collapsed?: boolean\n collapsible?: boolean // 菜单是否可折叠\n mainPagePath: string // 首页地址\n setContext(state: Partial<Omit<ContextSlice, 'setContext'>>): void\n}\n\nexport const createContextSlice: StateCreator<ContextSlice, [], [], ContextSlice> = set => ({\n locale: enGb,\n gameApiV2: false,\n isGlobal: false,\n loginPath: '/sign_in',\n mainPagePath: '/',\n permissionVersion: PermissionVersion.V1,\n setContext(state) {\n set(prev => ({ ...prev, ...state }))\n },\n})\n","import type { StateCreator } from 'zustand'\n\nexport interface GameSlice {\n gameId?: string | number\n setGameId: (id?: string | number) => void\n}\n\nexport const createGameSlice: StateCreator<GameSlice, [], [], GameSlice> = set => ({\n setGameId: id => {\n set({ gameId: id })\n },\n})\n","import { jwtDecode } from 'jwt-decode'\nimport type { StateCreator } from 'zustand'\n\n/**\n * JWT Token 解码后的用户信息\n */\nexport interface UserInfo {\n authorityId: string\n exp: number\n}\n\nexport interface TokenSlice {\n /** JWT Token */\n token?: string\n user: UserInfo | null\n setToken: (token: string) => void\n}\n\nconst decodeToken = (token?: string): UserInfo | null => {\n if (!token) return null\n\n try {\n return jwtDecode<UserInfo>(token)\n } catch {\n return null\n }\n}\n\nexport const createTokenSlice: StateCreator<TokenSlice, [], []> = set => ({\n token: undefined,\n user: null,\n setToken: token => {\n const user = decodeToken(token)\n set({ token, user })\n },\n})\n","import { createStore } from 'zustand'\nimport { createJSONStorage, persist } from 'zustand/middleware'\n\nimport { mixedStorage } from '@/utils'\n\nimport { type ContextSlice, createContextSlice } from './context'\nimport type { GameSlice } from './game'\nimport { createGameSlice } from './game'\nimport type { TokenSlice } from './token'\nimport { createTokenSlice } from './token'\n\nexport type ToolkitsState = TokenSlice &\n GameSlice &\n ContextSlice & {\n clear: () => void\n }\n\nexport const createToolkitsStore = (initProps?: Partial<ContextSlice>) => {\n return createStore<ToolkitsState>()(\n persist(\n (...args) => {\n const [set, , store] = args\n return {\n ...createTokenSlice(...args),\n ...createGameSlice(...args),\n ...createContextSlice(...args),\n clear: () => {\n const initialState = store.getInitialState()\n set(initialState)\n store.persist.clearStorage()\n },\n ...initProps,\n }\n },\n {\n name: 'toolkits',\n storage: createJSONStorage(() => mixedStorage),\n partialize: state => ({\n token: state.token,\n gameId: state.gameId,\n collapsed: state.collapsed,\n user: state.user,\n }),\n },\n ),\n )\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { App } from 'antd'\nimport type { ComponentType, FC, PropsWithChildren } from 'react'\nimport { createContext, useContext, useRef } from 'react'\nimport { useStore } from 'zustand'\n\nimport type { ToolkitsState } from '@/stores'\nimport { createToolkitsStore } from '@/stores'\nimport type { ContextSlice } from '@/stores/context'\n\ntype ToolkitsStore = ReturnType<typeof createToolkitsStore>\n\nconst ToolkitsContext = createContext<ToolkitsStore | null>(null)\n\n// 重载函数签名:支持有 selector 和无 selector 两种调用方式\nexport function useToolkitsStore(): ToolkitsState\nexport function useToolkitsStore<T>(selector: (state: ToolkitsState) => T): T\nexport function useToolkitsStore<T>(selector?: (state: ToolkitsState) => T): T | ToolkitsState {\n const store = useContext(ToolkitsContext)\n if (!store) throw new Error('Missing ToolkitsProvider in the tree')\n\n // 总是调用 useStore,根据是否有 selector 决定使用什么选择器\n return useStore(store, selector || ((state: ToolkitsState) => state as T))\n}\n\nexport type ToolkitsProviderProps = PropsWithChildren<Partial<Omit<ContextSlice, 'setContext'>>>\n\nconst ToolkitsProvider: FC<ToolkitsProviderProps> = props => {\n const { children, ...restProps } = props\n const storeRef = useRef<ToolkitsStore>()\n const parentState = useContext(ToolkitsContext)?.getState()\n\n if (!storeRef.current) {\n storeRef.current = createToolkitsStore({ ...parentState, ...restProps })\n }\n\n if (!storeRef.current.getState().loginPath) {\n throw new Error('ToolkitsProvider: 请配置 \"loginPath\"')\n }\n\n return (\n <ToolkitsContext.Provider value={storeRef.current}>\n <App>{children}</App>\n </ToolkitsContext.Provider>\n )\n}\n\nexport const withContext = (Component: ComponentType, providerProps: Omit<ToolkitsProviderProps, 'children'>) => {\n const WrappedComponent = (props: any) => {\n return (\n <ToolkitsProvider {...providerProps}>\n <Component {...props} />\n </ToolkitsProvider>\n )\n }\n\n WrappedComponent.displayName = `withContext(${Component.displayName || Component.name || 'Component'})`\n\n return WrappedComponent\n}\n\nif (process.env.NODE_ENV !== 'production') {\n ToolkitsProvider.displayName = 'ToolkitsProvider'\n}\n\nexport default ToolkitsProvider\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { App } from 'antd'\nimport ky, { type KyInstance, type Options as KyOptions } from 'ky'\nimport { useMemo } from 'react'\nimport { useNavigate } from 'react-router-dom'\n\nimport { useToolkitsStore } from '@/components/toolkitsProvider'\nimport { APP_ID_HEADER, PermissionVersion } from '@/constants'\n\n// 响应成功状态码常量\nconst SUCCESS_RESPONSE_CODES = [0, 1, 200] as const\n\n// HTTP 状态码常量\nconst HTTP_STATUS = {\n OK: 200,\n UNAUTHORIZED: 401,\n FORBIDDEN: 403,\n UNREGISTERED: 412,\n} as const\n\n// 请求超时时间(毫秒)\nconst REQUEST_TIMEOUT = 30000\n\n// 成功响应状态码字段类型\ntype StatusField = 'code' | 'status' | 'errno'\n\n// 状态码检查配置\ninterface StatusCheckConfig {\n field: StatusField\n value: unknown\n allowedCodes: readonly number[]\n}\n\n// 响应类型枚举\nexport enum ResponseType {\n JSON = 'json',\n BLOB = 'blob',\n TEXT = 'text',\n ARRAY_BUFFER = 'arrayBuffer',\n FORM_DATA = 'formData',\n}\n\n// 通用请求选项接口\ninterface RequestOptions extends KyOptions {\n responseType?: ResponseType\n}\n\n// useKy Hook 配置选项\nexport interface UseKyOptions {\n baseURL?: string\n}\n\n// HTTP客户端方法接口 - 支持泛型响应类型\ninterface KyMethods {\n get: <T = any>(url: string, options?: RequestOptions) => Promise<T>\n post: <T = any>(url: string, data?: any, options?: RequestOptions) => Promise<T>\n put: <T = any>(url: string, data?: any, options?: RequestOptions) => Promise<T>\n delete: <T = any>(url: string, options?: RequestOptions) => Promise<T>\n patch: <T = any>(url: string, data?: any, options?: RequestOptions) => Promise<T>\n options: <T = any>(url: string, options?: RequestOptions) => Promise<T>\n head: <T = any>(url: string, options?: RequestOptions) => Promise<T>\n request: <T = any>(options: RequestOptions & { url: string }) => Promise<T>\n instance: KyInstance\n}\n\n// 错误消息提取工具函数\nconst extractErrorMessage = (data: any): string => {\n if (!data || typeof data !== 'object') {\n return 'Unknown error'\n }\n\n return data.msg || data.message || data.error || 'Unknown error'\n}\n\n/**\n * 检查单个状态码字段是否成功\n * @param config 状态码检查配置\n * @returns 是否成功\n */\nconst isStatusCodeSuccess = (config: StatusCheckConfig): boolean => {\n const { value, allowedCodes } = config\n\n if (value === undefined || value === null) {\n return false\n }\n\n if (typeof value !== 'number') {\n return false\n }\n\n return allowedCodes.includes(value)\n}\n\n/**\n * 判断响应是否成功\n * @param data 响应数据\n * @param status HTTP状态码\n * @returns 是否成功\n */\nconst isSuccessResponse = (data: any, status: number): boolean => {\n // 如果HTTP状态码不在2xx范围,直接返回失败\n if (status < HTTP_STATUS.OK || status >= 300) {\n return false\n }\n\n // 如果没有响应数据或不是对象,认为成功(可能是空响应)\n if (!data || typeof data !== 'object') {\n return true\n }\n\n // 定义状态码检查配置\n const statusChecks: StatusCheckConfig[] = [\n { field: 'code', value: data.code, allowedCodes: SUCCESS_RESPONSE_CODES },\n { field: 'status', value: data.status, allowedCodes: SUCCESS_RESPONSE_CODES },\n { field: 'errno', value: data.errno, allowedCodes: SUCCESS_RESPONSE_CODES },\n ]\n\n // 检查是否有任何业务状态码字段存在且表示成功\n const hasBusinessStatusCode = statusChecks.some(config => config.value !== undefined && config.value !== null)\n\n // 如果存在业务状态码字段,则必须检查它们是否都表示成功\n if (hasBusinessStatusCode) {\n return statusChecks.every(\n config => config.value === undefined || config.value === null || isStatusCodeSuccess(config),\n )\n }\n\n // 如果没有业务状态码字段,HTTP 2xx 就认为成功\n return true\n}\n\n/**\n * 根据响应类型处理响应数据\n * @param response 响应对象\n * @param responseType 响应类型\n * @returns 处理后的响应数据\n */\nconst processResponseByType = async (response: Response, responseType?: ResponseType): Promise<any> => {\n switch (responseType) {\n case ResponseType.BLOB:\n return response.blob()\n case ResponseType.TEXT:\n return response.text()\n case ResponseType.ARRAY_BUFFER:\n return response.arrayBuffer()\n case ResponseType.FORM_DATA:\n return response.formData()\n case ResponseType.JSON:\n default:\n return response.json()\n }\n}\n\n/**\n * HTTP客户端Hook (基于 Ky) - 内部使用版本\n * @param config 配置选项\n * @returns HTTP客户端方法集合\n */\nexport const useKy = (config?: UseKyOptions): KyMethods => {\n const { baseURL } = config || {}\n const { notification } = App.useApp()\n const navigate = useNavigate()\n\n // 获取工具包状态\n const toolkitsStore = useToolkitsStore()\n const { token, isGlobal, gameId, permissionVersion, loginPath, clear } = toolkitsStore\n\n // 处理未授权错误\n const handleUnauthorized = () => {\n clear()\n navigate(loginPath)\n }\n\n // 处理未注册错误\n const handleUnregistered = () => {\n clear()\n if (loginPath) {\n // 添加未注册参数到登录页 URL\n const url = new URL(loginPath, window.location.origin)\n url.searchParams.set('unregistered', 'true')\n navigate(url.toString())\n }\n }\n\n // 处理禁止访问错误\n const handleForbidden = () => {\n notification.error({\n message: '访问被禁止',\n description: '您没有权限访问此资源。',\n })\n }\n\n // 创建响应处理函数\n const createResponseHandler = (responseType?: ResponseType) => {\n return async (_request: any, _options: any, response: Response): Promise<Response> => {\n // 非 JSON 类型直接交由调用方按响应类型读取\n if (\n responseType === ResponseType.BLOB ||\n responseType === ResponseType.ARRAY_BUFFER ||\n responseType === ResponseType.TEXT ||\n responseType === ResponseType.FORM_DATA\n ) {\n return response\n }\n\n // 默认 JSON\n let data: any\n try {\n data = await response.clone().json()\n } catch {\n // 非 JSON 或空响应体,直接返回原响应\n return response\n }\n\n if (isSuccessResponse(data, response.status)) {\n const responseData = data.data !== undefined ? data.data : data\n return new Response(JSON.stringify(responseData), {\n status: response.status,\n statusText: response.statusText,\n headers: response.headers,\n })\n }\n\n const errorMessage = extractErrorMessage(data)\n\n notification.error({\n message: 'Request failed',\n description: errorMessage,\n })\n\n const error = new Error(errorMessage)\n ;(error as any).response = response\n ;(error as any).data = data\n throw error\n }\n }\n\n // 处理HTTP状态码错误\n const handleHttpStatusError = (status: number, data: any) => {\n switch (status) {\n case HTTP_STATUS.UNAUTHORIZED:\n handleUnauthorized()\n break\n\n case HTTP_STATUS.UNREGISTERED:\n handleUnregistered()\n break\n\n case HTTP_STATUS.FORBIDDEN:\n handleForbidden()\n break\n\n default: {\n // 安全地提取错误消息\n const errorMessage = extractErrorMessage(data) || `HTTP ${status} Error`\n notification.error({\n message: 'Request failed',\n description: errorMessage,\n })\n break\n }\n }\n }\n\n // 创建ky实例\n const instance = useMemo(() => {\n return ky.create({\n prefixUrl: baseURL,\n retry: 0,\n timeout: REQUEST_TIMEOUT,\n headers: {\n Accept: 'application/json',\n 'Content-Type': 'application/json',\n },\n hooks: {\n beforeRequest: [\n request => {\n // 设置认证 headers\n if (token) {\n request.headers.set('Authorization', `Bearer ${token}`)\n }\n\n // 设置应用 ID headers\n if (!request.headers.has(APP_ID_HEADER) && permissionVersion !== PermissionVersion.V1) {\n if (isGlobal || !gameId) {\n request.headers.set(APP_ID_HEADER, 'global')\n } else {\n // 对 gameId 进行 URL 编码以避免非 ASCII 字符导致的 XMLHttpRequest 错误\n request.headers.set(APP_ID_HEADER, encodeURIComponent(String(gameId)))\n }\n }\n },\n ],\n beforeError: [\n async error => {\n const { response } = error\n\n if (response) {\n const status = response.status\n let data: any\n\n try {\n const contentType = response.headers.get('content-type') || ''\n if (contentType.includes('application/json') || contentType.startsWith('text/')) {\n data = await response.clone().json()\n }\n } catch {\n // 忽略 JSON 解析错误\n }\n\n handleHttpStatusError(status, data)\n } else {\n // 网络错误或请求超时等情况\n notification.error({\n message: 'Network Error',\n description: error.message || 'Network request failed',\n })\n }\n\n return error\n },\n ],\n },\n })\n }, [baseURL, token, isGlobal, gameId, permissionVersion, notification, loginPath, clear])\n\n // 通用请求处理函数\n const makeRequest = async <T = any>(\n method: string,\n url: string,\n data?: any,\n requestOptions?: RequestOptions,\n ): Promise<T> => {\n const { responseType, ...kyOptions } = requestOptions || {}\n\n // 创建带有响应类型处理器的请求选项\n const finalOptions: KyOptions = {\n ...kyOptions,\n hooks: {\n ...kyOptions.hooks,\n afterResponse: [...(kyOptions.hooks?.afterResponse || []), createResponseHandler(responseType)],\n },\n }\n\n let response: Response\n\n if (data) {\n response = await instance(url, { method, json: data, ...finalOptions })\n } else {\n response = await instance(url, { method, ...finalOptions })\n }\n\n // 根据响应类型返回相应数据\n return processResponseByType(response, responseType)\n }\n\n // HTTP方法\n const get = <T = any>(url: string, options?: RequestOptions): Promise<T> => {\n return makeRequest<T>('GET', url, undefined, options)\n }\n\n const post = <T = any>(url: string, data?: any, options?: RequestOptions): Promise<T> => {\n return makeRequest<T>('POST', url, data, options)\n }\n\n const put = <T = any>(url: string, data?: any, options?: RequestOptions): Promise<T> => {\n return makeRequest<T>('PUT', url, data, options)\n }\n\n const del = <T = any>(url: string, options?: RequestOptions): Promise<T> => {\n return makeRequest<T>('DELETE', url, undefined, options)\n }\n\n const patch = <T = any>(url: string, data?: any, options?: RequestOptions): Promise<T> => {\n return makeRequest<T>('PATCH', url, data, options)\n }\n\n const options = <T = any>(url: string, requestOptions?: RequestOptions): Promise<T> => {\n return makeRequest<T>('OPTIONS', url, undefined, requestOptions)\n }\n\n const head = <T = any>(url: string, requestOptions?: RequestOptions): Promise<T> => {\n return makeRequest<T>('HEAD', url, undefined, requestOptions)\n }\n\n const request = <T = any>(requestOptions: RequestOptions & { url: string }): Promise<T> => {\n const { url, ...requestOpts } = requestOptions\n return makeRequest<T>(requestOpts.method || 'GET', url, undefined, requestOpts)\n }\n\n return {\n get,\n post,\n put,\n delete: del,\n patch,\n options,\n head,\n request,\n instance,\n }\n}\n","// 查询键工厂 - 使用简单的对象和函数来生成查询键\nexport const queryKeys = {\n // 权限相关\n permissions: {\n check: (permissions: string[], version: 'v1' | 'v2') => ['permissions', 'check', permissions, version] as const,\n allPermissions: ['permissions', 'all'] as const,\n allPermissionsV2: ['permissions', 'allV2'] as const,\n },\n // 用户相关\n users: {\n all: ['users'] as const,\n detail: (id: string) => ['users', 'detail', id] as const,\n create: ['users', 'create'] as const,\n update: ['users', 'update'] as const,\n delete: ['users', 'delete'] as const,\n },\n // 角色相关\n roles: {\n all: ['roles'] as const,\n detail: (name: string, version: 'v1' | 'v2') => ['roles', 'detail', name, version] as const,\n create: (version: 'v1' | 'v2') => ['roles', 'create', version] as const,\n update: (version: 'v1' | 'v2') => ['roles', 'update', version] as const,\n delete: ['roles', 'delete'] as const,\n },\n // 菜单相关\n menus: {\n all: ['menus'] as const,\n navbar: (gameId?: string) => ['menus', 'navbar', gameId] as const,\n detail: (id: number) => ['menus', 'detail', id] as const,\n create: ['menus', 'create'] as const,\n update: ['menus', 'update'] as const,\n delete: ['menus', 'delete'] as const,\n },\n // 枚举相关\n enums: {\n gameGroups: ['enums', 'gameGroups'] as const,\n gameIds: (gameGroups: string[]) => ['enums', 'gameIds', gameGroups] as const,\n },\n // 游戏相关\n games: {\n all: ['games', 'all'] as const,\n },\n}\n\nexport type QueryKeys = typeof queryKeys\n"]}
|