index.vue 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. <template>
  2. <div>
  3. <!--引用表格-->
  4. <BasicTable @register="registerTable" :rowSelection="rowSelection">
  5. <!--插槽:table标题-->
  6. <template #tableTitle>
  7. <a-button type="primary" preIcon="ant-design:plus-outlined" @click="handleCreate"> 新增</a-button>
  8. <a-button type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"
  9. :disabled="isDisabledAuth('system:user:export')"> 导出</a-button>
  10. <j-upload-button type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>
  11. <a-button type="primary" @click="openModal(true, {})" preIcon="ant-design:hdd-outlined"> 回收站</a-button>
  12. <a-dropdown v-if="selectedRowKeys.length > 0">
  13. <template #overlay>
  14. <a-menu>
  15. <a-menu-item key="1" @click="batchHandleDelete">
  16. <Icon icon="ant-design:delete-outlined"></Icon>
  17. 删除
  18. </a-menu-item>
  19. <a-menu-item key="2" @click="batchFrozen(2)">
  20. <Icon icon="ant-design:lock-outlined"></Icon>
  21. 冻结
  22. </a-menu-item>
  23. <a-menu-item key="3" @click="batchFrozen(1)">
  24. <Icon icon="ant-design:unlock-outlined"></Icon>
  25. 解冻
  26. </a-menu-item>
  27. </a-menu>
  28. </template>
  29. <a-button>批量操作
  30. <Icon icon="mdi:chevron-down"></Icon>
  31. </a-button>
  32. </a-dropdown>
  33. </template>
  34. <!--操作栏-->
  35. <template #action="{ record }">
  36. <TableAction :actions="getTableAction(record)" :dropDownActions="getDropDownAction(record)" />
  37. </template>
  38. </BasicTable>
  39. <!--用户抽屉-->
  40. <UserDrawer @register="registerDrawer" @success="handleSuccess" />
  41. <!--修改密码-->
  42. <PasswordModal @register="registerPasswordModal" @success="reload" />
  43. <!--用户代理-->
  44. <UserAgentModal @register="registerAgentModal" @success="reload" />
  45. <!--资源管理-->
  46. <UserResourceModal @register="registerUserResourceModal" @success="reload" />
  47. <!--回收站-->
  48. <UserRecycleBinModal @register="registerModal" @success="reload" />
  49. <!-- 离职受理人弹窗 -->
  50. <UserQuitAgentModal @register="registerQuitAgentModal" @success="reload" />
  51. <!-- 离职人员列弹窗 -->
  52. <UserQuitModal @register="registerQuitModal" @success="reload" />
  53. </div>
  54. </template>
  55. <script lang="ts" name="system-user" setup>
  56. //ts语法
  57. import { ref, computed, unref } from 'vue';
  58. import { BasicTable, TableAction, ActionItem } from '/@/components/Table';
  59. import UserDrawer from './UserDrawer.vue';
  60. import UserRecycleBinModal from './UserRecycleBinModal.vue';
  61. import PasswordModal from './PasswordModal.vue';
  62. import UserAgentModal from './UserAgentModal.vue';
  63. import JThirdAppButton from '/@/components/jeecg/thirdApp/JThirdAppButton.vue';
  64. import UserQuitAgentModal from './UserQuitAgentModal.vue';
  65. import UserQuitModal from './UserQuitModal.vue';
  66. import UserResourceModal from './UserResourceModal.vue';
  67. import { useDrawer } from '/@/components/Drawer';
  68. import { useListPage } from '/@/hooks/system/useListPage';
  69. import { useModal } from '/@/components/Modal';
  70. import { useMessage } from '/@/hooks/web/useMessage';
  71. import { columns, searchFormSchema } from './user.data';
  72. import { listNoCareTenant, deleteUser, batchDeleteUser, getImportUrl, getExportUrl, frozenBatch } from './user.api';
  73. import { usePermission } from "/@/hooks/web/usePermission";
  74. const { createMessage, createConfirm } = useMessage();
  75. const { isDisabledAuth } = usePermission();
  76. //注册drawer
  77. const [registerDrawer, { openDrawer }] = useDrawer();
  78. //回收站model
  79. const [registerModal, { openModal }] = useModal();
  80. //密码model
  81. const [registerPasswordModal, { openModal: openPasswordModal }] = useModal();
  82. //代理人model
  83. const [registerAgentModal, { openModal: openAgentModal }] = useModal();
  84. //离职代理人model
  85. const [registerQuitAgentModal, { openModal: openQuitAgentModal }] = useModal();
  86. //离职用户列表model
  87. const [registerQuitModal, { openModal: openQuitModal }] = useModal();
  88. //资源控制model
  89. const [registerUserResourceModal, { openModal: openUserResourceModal }] = useModal();
  90. // 列表页面公共参数、方法
  91. const { prefixCls, tableContext, onExportXls, onImportXls } = useListPage({
  92. designScope: 'user-list',
  93. tableProps: {
  94. title: '用户列表',
  95. api: listNoCareTenant,
  96. columns: columns,
  97. size: 'small',
  98. formConfig: {
  99. // labelWidth: 200,
  100. schemas: searchFormSchema,
  101. },
  102. actionColumn: {
  103. width: 120,
  104. },
  105. beforeFetch: (params) => {
  106. return Object.assign({ column: 'createTime', order: 'desc' }, params);
  107. },
  108. },
  109. exportConfig: {
  110. name: '用户列表',
  111. url: getExportUrl,
  112. },
  113. importConfig: {
  114. url: getImportUrl,
  115. },
  116. });
  117. //注册table数据
  118. const [registerTable, { reload, updateTableDataRecord }, { rowSelection, selectedRows, selectedRowKeys }] = tableContext;
  119. /**
  120. * 新增事件
  121. */
  122. function handleCreate() {
  123. openDrawer(true, {
  124. isUpdate: false,
  125. showFooter: true,
  126. tenantSaas: false,
  127. });
  128. }
  129. /**
  130. * 编辑事件
  131. */
  132. async function handleEdit(record: Recordable) {
  133. openDrawer(true, {
  134. record,
  135. isUpdate: true,
  136. showFooter: true,
  137. tenantSaas: false,
  138. });
  139. }
  140. /**
  141. * 详情
  142. */
  143. async function handleDetail(record: Recordable) {
  144. openDrawer(true, {
  145. record,
  146. isUpdate: true,
  147. showFooter: false,
  148. tenantSaas: false,
  149. });
  150. }
  151. /**
  152. * 删除事件
  153. */
  154. async function handleDelete(record) {
  155. if ('admin' == record.username) {
  156. createMessage.warning('管理员账号不允许此操作!');
  157. return;
  158. }
  159. await deleteUser({ id: record.id }, reload);
  160. }
  161. /**
  162. * 批量删除事件
  163. */
  164. async function batchHandleDelete() {
  165. let hasAdmin = unref(selectedRows).filter((item) => item.username == 'admin');
  166. if (unref(hasAdmin).length > 0) {
  167. createMessage.warning('管理员账号不允许此操作!');
  168. return;
  169. }
  170. await batchDeleteUser({ ids: selectedRowKeys.value }, () => {
  171. selectedRowKeys.value = [];
  172. reload();
  173. });
  174. }
  175. /**
  176. * 成功回调
  177. */
  178. function handleSuccess() {
  179. reload();
  180. }
  181. /**
  182. * 打开修改密码弹窗
  183. */
  184. function handleChangePassword(username) {
  185. openPasswordModal(true, { username });
  186. }
  187. /**
  188. * 打开代理人弹窗
  189. */
  190. function handleAgentSettings(userName) {
  191. openAgentModal(true, { userName });
  192. }
  193. /**
  194. * 打开资源控制弹窗
  195. */
  196. function handleUserResourceSettings(userName) {
  197. openUserResourceModal(true, { userName });
  198. }
  199. /**
  200. * 冻结解冻
  201. */
  202. async function handleFrozen(record, status) {
  203. if ('admin' == record.username) {
  204. createMessage.warning('管理员账号不允许此操作!');
  205. return;
  206. }
  207. await frozenBatch({ ids: record.id, status: status }, reload);
  208. }
  209. /**
  210. * 批量冻结解冻
  211. */
  212. function batchFrozen(status) {
  213. let hasAdmin = selectedRows.value.filter((item) => item.username == 'admin');
  214. if (unref(hasAdmin).length > 0) {
  215. createMessage.warning('管理员账号不允许此操作!');
  216. return;
  217. }
  218. createConfirm({
  219. iconType: 'warning',
  220. title: '确认操作',
  221. content: '是否' + (status == 1 ? '解冻' : '冻结') + '选中账号?',
  222. onOk: async () => {
  223. await frozenBatch({ ids: unref(selectedRowKeys).join(','), status: status }, reload);
  224. },
  225. });
  226. }
  227. /**
  228. *同步钉钉和微信回调
  229. */
  230. function onSyncFinally({ isToLocal }) {
  231. // 同步到本地时刷新下数据
  232. if (isToLocal) {
  233. reload();
  234. }
  235. }
  236. /**
  237. * 操作栏
  238. */
  239. function getTableAction(record): ActionItem[] {
  240. return [
  241. {
  242. label: '编辑',
  243. onClick: handleEdit.bind(null, record),
  244. // ifShow: () => hasPermission('system:user:edit'),
  245. },
  246. ];
  247. }
  248. /**
  249. * 下拉操作栏
  250. */
  251. function getDropDownAction(record): ActionItem[] {
  252. return [
  253. {
  254. label: '详情',
  255. onClick: handleDetail.bind(null, record),
  256. },
  257. {
  258. label: '密码',
  259. //auth: 'user:changepwd',
  260. onClick: handleChangePassword.bind(null, record.username),
  261. },
  262. {
  263. label: '删除',
  264. popConfirm: {
  265. title: '是否确认删除',
  266. confirm: handleDelete.bind(null, record),
  267. },
  268. },
  269. {
  270. label: '冻结',
  271. ifShow: record.status == 1,
  272. popConfirm: {
  273. title: '确定冻结吗?',
  274. confirm: handleFrozen.bind(null, record, 2),
  275. },
  276. },
  277. {
  278. label: '解冻',
  279. ifShow: record.status == 2,
  280. popConfirm: {
  281. title: '确定解冻吗?',
  282. confirm: handleFrozen.bind(null, record, 1),
  283. },
  284. },
  285. {
  286. label: '代理人',
  287. onClick: handleAgentSettings.bind(null, record.username),
  288. },
  289. {
  290. label: '资源',
  291. onClick: handleUserResourceSettings.bind(null, record.username),
  292. },
  293. ];
  294. }
  295. /**
  296. * 离职
  297. * @param userName
  298. */
  299. function handleQuit(userName) {
  300. //打开离职代理人弹窗
  301. openQuitAgentModal(true, { userName });
  302. }
  303. </script>
  304. <style scoped></style>