You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1 line
5.7 KiB

import{n as e}from"./axios-CiYFffbI.js";import{I as t,N as n,V as r,Y as i,_ as a,d as o,i as s,it as c,kt as l,l as u,nt as d,p as f,ut as p,v as m,y as h,z as g}from"./runtime-core.esm-bundler-CnFWH3R5.js";import{n as _}from"./http-LCi9aT1G.js";import{t as v}from"./listTableRowIndex-Bl-nc9Qt.js";var y=920,b=h({__name:`Admins`,setup(h){let b=c(!1),x=c([]),S=c([]),C=c([]),w=c(!1),T=c(null),E=d({username:``,name:``,email:``,password:``,role:`venue_admin`,is_active:!0,venue_ids:[]}),D={maxHeight:`70vh`,overflow:`auto`},O=d({current:1,pageSize:10}),k=u(()=>T.value!==null);function A(){T.value=null,E.username=``,E.name=``,E.email=``,E.password=``,E.role=`venue_admin`,E.is_active=!0,E.venue_ids=[]}async function j(){b.value=!0;try{let[e,t,n]=await Promise.all([_.get(`/admin-users`),_.get(`/venues`),_.get(`/admin-roles`)]);x.value=e.data,S.value=t.data,C.value=(n.data||[]).map(e=>({slug:e.slug,name:e.name})),O.current=1}catch(t){e.error(t?.response?.data?.message??`加载失败`)}finally{b.value=!1}}function M(){A(),w.value=!0}function N(e){T.value=e.id,E.username=e.username,E.name=e.name,E.email=e.email??``,E.password=``,E.role=e.role,E.is_active=e.is_active,E.venue_ids=e.venues.map(e=>e.id),w.value=!0}async function P(){try{return k.value?(await _.put(`/admin-users/${T.value}`,{name:E.name,email:E.email.trim()||void 0,password:E.password||void 0,role:E.role,is_active:E.is_active,venue_ids:E.venue_ids}),e.success(`更新管理员成功`)):(await _.post(`/admin-users`,{username:E.username,name:E.name,email:E.email.trim()||void 0,password:E.password,role:E.role,is_active:E.is_active,venue_ids:E.venue_ids}),e.success(`创建管理员成功`)),w.value=!1,await j(),!0}catch(t){return e.error(t?.response?.data?.message??`保存失败`),!1}}function F(e){return e?.length?e.map(e=>e.name).join(``):`-`}function I(e){return C.value.find(t=>t.slug===e)?.name??e}function L(e){return e===`super_admin`?`arcoblue`:e===`venue_admin`?`orangered`:`purple`}return n(j),(e,n)=>{let c=r(`a-button`),u=r(`a-space`),d=r(`a-alert`),h=r(`a-table-column`),_=r(`a-tag`),T=r(`a-table`),A=r(`a-card`),R=r(`a-input`),z=r(`a-form-item`),B=r(`a-input-password`),V=r(`a-option`),H=r(`a-select`),U=r(`a-switch`),W=r(`a-form`),G=r(`a-modal`);return t(),f(s,null,[m(A,{title:`用户与权限 / 管理员账号`},{extra:i(()=>[m(u,null,{default:i(()=>[m(c,{onClick:j},{default:i(()=>[...n[10]||=[a(`刷新`,-1)]]),_:1}),m(c,{type:`primary`,onClick:M},{default:i(()=>[...n[11]||=[a(`新建管理员`,-1)]]),_:1})]),_:1})]),default:i(()=>[m(d,{style:{"margin-bottom":`12px`}},{default:i(()=>[...n[12]||=[a(` 场馆管理员可绑定多个场馆;后续将用于限制“仅查看/编辑自己的场馆”及“仅核销自己场馆预约二维码”。 `,-1)]]),_:1}),m(T,{class:`list-data-table`,scroll:{x:y},data:x.value,loading:b.value,"row-key":`id`,pagination:{current:O.current,pageSize:O.pageSize,total:x.value.length,showTotal:!0},onPageChange:n[0]||=e=>O.current=e},{columns:i(()=>[m(h,{title:``,width:50,ellipsis:!0,tooltip:!0},{cell:i(({rowIndex:e})=>[a(l(p(v)(e,O.current,O.pageSize)),1)]),_:1}),m(h,{title:`用户名`,"data-index":`username`,width:140,"min-width":120,ellipsis:!0,tooltip:!0}),m(h,{title:`姓名`,"data-index":`name`,width:120,ellipsis:!0,tooltip:!0}),m(h,{title:`角色`,width:130},{cell:i(({record:e})=>[m(_,{color:L(e.role)},{default:i(()=>[a(l(I(e.role)),1)]),_:2},1032,[`color`])]),_:1}),m(h,{title:`绑定场馆`,width:220,"min-width":160,ellipsis:!0,tooltip:!0},{cell:i(({record:e})=>[a(l(F(e.venues)),1)]),_:1}),m(h,{title:`状态`,width:100},{cell:i(({record:e})=>[m(_,{color:e.is_active?`green`:`gray`},{default:i(()=>[a(l(e.is_active?`启用`:`禁用`),1)]),_:2},1032,[`color`])]),_:1}),m(h,{title:`操作`,width:120,fixed:`right`,align:`center`},{cell:i(({record:e})=>[m(c,{type:`text`,onClick:t=>N(e)},{default:i(()=>[...n[13]||=[a(`编辑`,-1)]]),_:1},8,[`onClick`])]),_:1})]),_:1},8,[`scroll`,`data`,`loading`,`pagination`])]),_:1}),m(G,{visible:w.value,"onUpdate:visible":n[8]||=e=>w.value=e,title:k.value?`编辑管理员`:`新建管理员`,width:`70%`,"body-style":D,"on-before-ok":P,onCancel:n[9]||=e=>w.value=!1},{default:i(()=>[m(W,{model:E,layout:`vertical`,class:`admin-modal-form`},{default:i(()=>[m(z,{label:`用户名`,required:``},{default:i(()=>[m(R,{modelValue:E.username,"onUpdate:modelValue":n[1]||=e=>E.username=e,disabled:k.value},null,8,[`modelValue`,`disabled`])]),_:1}),m(z,{label:`姓名`,required:``},{default:i(()=>[m(R,{modelValue:E.name,"onUpdate:modelValue":n[2]||=e=>E.name=e},null,8,[`modelValue`])]),_:1}),m(z,{label:`邮箱(选填)`},{default:i(()=>[m(R,{modelValue:E.email,"onUpdate:modelValue":n[3]||=e=>E.email=e,placeholder:`可留空`},null,8,[`modelValue`])]),_:1}),m(z,{label:k.value?`密码(留空不修改)`:`密码`,required:!k.value},{default:i(()=>[m(B,{modelValue:E.password,"onUpdate:modelValue":n[4]||=e=>E.password=e},null,8,[`modelValue`])]),_:1},8,[`label`,`required`]),m(z,{label:`角色`,required:``},{default:i(()=>[m(H,{modelValue:E.role,"onUpdate:modelValue":n[5]||=e=>E.role=e},{default:i(()=>[(t(!0),f(s,null,g(C.value,e=>(t(),o(V,{key:e.slug,value:e.slug},{default:i(()=>[a(l(e.name),1)]),_:2},1032,[`value`]))),128))]),_:1},8,[`modelValue`])]),_:1}),m(z,{label:`绑定场馆`,class:`admin-modal-form__full`},{default:i(()=>[m(H,{modelValue:E.venue_ids,"onUpdate:modelValue":n[6]||=e=>E.venue_ids=e,multiple:``,"allow-clear":``},{default:i(()=>[(t(!0),f(s,null,g(S.value,e=>(t(),o(V,{key:e.id,value:e.id},{default:i(()=>[a(l(e.name),1)]),_:2},1032,[`value`]))),128))]),_:1},8,[`modelValue`])]),_:1}),m(z,{label:`状态`},{default:i(()=>[m(U,{modelValue:E.is_active,"onUpdate:modelValue":n[7]||=e=>E.is_active=e},null,8,[`modelValue`])]),_:1})]),_:1},8,[`model`])]),_:1},8,[`visible`,`title`])],64)}}});export{b as default};