123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314 |
- <template>
- <div>
- <!--引用表格-->
- <BasicTable @register="registerTable" :rowSelection="rowSelection">
- <!--插槽:table标题-->
- <template #tableTitle>
- <a-button type="primary" preIcon="ant-design:plus-outlined" @click="handleCreate"> 新增</a-button>
- <a-button type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"
- :disabled="isDisabledAuth('system:user:export')"> 导出</a-button>
- <j-upload-button type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>
- <a-button type="primary" @click="openModal(true, {})" preIcon="ant-design:hdd-outlined"> 回收站</a-button>
- <a-dropdown v-if="selectedRowKeys.length > 0">
- <template #overlay>
- <a-menu>
- <a-menu-item key="1" @click="batchHandleDelete">
- <Icon icon="ant-design:delete-outlined"></Icon>
- 删除
- </a-menu-item>
- <a-menu-item key="2" @click="batchFrozen(2)">
- <Icon icon="ant-design:lock-outlined"></Icon>
- 冻结
- </a-menu-item>
- <a-menu-item key="3" @click="batchFrozen(1)">
- <Icon icon="ant-design:unlock-outlined"></Icon>
- 解冻
- </a-menu-item>
- </a-menu>
- </template>
- <a-button>批量操作
- <Icon icon="mdi:chevron-down"></Icon>
- </a-button>
- </a-dropdown>
- </template>
- <!--操作栏-->
- <template #action="{ record }">
- <TableAction :actions="getTableAction(record)" :dropDownActions="getDropDownAction(record)" />
- </template>
- </BasicTable>
- <!--用户抽屉-->
- <UserDrawer @register="registerDrawer" @success="handleSuccess" />
- <!--修改密码-->
- <PasswordModal @register="registerPasswordModal" @success="reload" />
- <!--用户代理-->
- <UserAgentModal @register="registerAgentModal" @success="reload" />
- <!--资源管理-->
- <UserResourceModal @register="registerUserResourceModal" @success="reload" />
- <!--回收站-->
- <UserRecycleBinModal @register="registerModal" @success="reload" />
- <!-- 离职受理人弹窗 -->
- <UserQuitAgentModal @register="registerQuitAgentModal" @success="reload" />
- <!-- 离职人员列弹窗 -->
- <UserQuitModal @register="registerQuitModal" @success="reload" />
- </div>
- </template>
- <script lang="ts" name="system-user" setup>
- //ts语法
- import { ref, computed, unref } from 'vue';
- import { BasicTable, TableAction, ActionItem } from '/@/components/Table';
- import UserDrawer from './UserDrawer.vue';
- import UserRecycleBinModal from './UserRecycleBinModal.vue';
- import PasswordModal from './PasswordModal.vue';
- import UserAgentModal from './UserAgentModal.vue';
- import JThirdAppButton from '/@/components/jeecg/thirdApp/JThirdAppButton.vue';
- import UserQuitAgentModal from './UserQuitAgentModal.vue';
- import UserQuitModal from './UserQuitModal.vue';
- import UserResourceModal from './UserResourceModal.vue';
- import { useDrawer } from '/@/components/Drawer';
- import { useListPage } from '/@/hooks/system/useListPage';
- import { useModal } from '/@/components/Modal';
- import { useMessage } from '/@/hooks/web/useMessage';
- import { columns, searchFormSchema } from './user.data';
- import { listNoCareTenant, deleteUser, batchDeleteUser, getImportUrl, getExportUrl, frozenBatch } from './user.api';
- import { usePermission } from "/@/hooks/web/usePermission";
- const { createMessage, createConfirm } = useMessage();
- const { isDisabledAuth } = usePermission();
- //注册drawer
- const [registerDrawer, { openDrawer }] = useDrawer();
- //回收站model
- const [registerModal, { openModal }] = useModal();
- //密码model
- const [registerPasswordModal, { openModal: openPasswordModal }] = useModal();
- //代理人model
- const [registerAgentModal, { openModal: openAgentModal }] = useModal();
- //离职代理人model
- const [registerQuitAgentModal, { openModal: openQuitAgentModal }] = useModal();
- //离职用户列表model
- const [registerQuitModal, { openModal: openQuitModal }] = useModal();
- //资源控制model
- const [registerUserResourceModal, { openModal: openUserResourceModal }] = useModal();
- // 列表页面公共参数、方法
- const { prefixCls, tableContext, onExportXls, onImportXls } = useListPage({
- designScope: 'user-list',
- tableProps: {
- title: '用户列表',
- api: listNoCareTenant,
- columns: columns,
- size: 'small',
- formConfig: {
- // labelWidth: 200,
- schemas: searchFormSchema,
- },
- actionColumn: {
- width: 120,
- },
- beforeFetch: (params) => {
- return Object.assign({ column: 'createTime', order: 'desc' }, params);
- },
- },
- exportConfig: {
- name: '用户列表',
- url: getExportUrl,
- },
- importConfig: {
- url: getImportUrl,
- },
- });
- //注册table数据
- const [registerTable, { reload, updateTableDataRecord }, { rowSelection, selectedRows, selectedRowKeys }] = tableContext;
- /**
- * 新增事件
- */
- function handleCreate() {
- openDrawer(true, {
- isUpdate: false,
- showFooter: true,
- tenantSaas: false,
- });
- }
- /**
- * 编辑事件
- */
- async function handleEdit(record: Recordable) {
- openDrawer(true, {
- record,
- isUpdate: true,
- showFooter: true,
- tenantSaas: false,
- });
- }
- /**
- * 详情
- */
- async function handleDetail(record: Recordable) {
- openDrawer(true, {
- record,
- isUpdate: true,
- showFooter: false,
- tenantSaas: false,
- });
- }
- /**
- * 删除事件
- */
- async function handleDelete(record) {
- if ('admin' == record.username) {
- createMessage.warning('管理员账号不允许此操作!');
- return;
- }
- await deleteUser({ id: record.id }, reload);
- }
- /**
- * 批量删除事件
- */
- async function batchHandleDelete() {
- let hasAdmin = unref(selectedRows).filter((item) => item.username == 'admin');
- if (unref(hasAdmin).length > 0) {
- createMessage.warning('管理员账号不允许此操作!');
- return;
- }
- await batchDeleteUser({ ids: selectedRowKeys.value }, () => {
- selectedRowKeys.value = [];
- reload();
- });
- }
- /**
- * 成功回调
- */
- function handleSuccess() {
- reload();
- }
- /**
- * 打开修改密码弹窗
- */
- function handleChangePassword(username) {
- openPasswordModal(true, { username });
- }
- /**
- * 打开代理人弹窗
- */
- function handleAgentSettings(userName) {
- openAgentModal(true, { userName });
- }
- /**
- * 打开资源控制弹窗
- */
- function handleUserResourceSettings(userName) {
- openUserResourceModal(true, { userName });
- }
- /**
- * 冻结解冻
- */
- async function handleFrozen(record, status) {
- if ('admin' == record.username) {
- createMessage.warning('管理员账号不允许此操作!');
- return;
- }
- await frozenBatch({ ids: record.id, status: status }, reload);
- }
- /**
- * 批量冻结解冻
- */
- function batchFrozen(status) {
- let hasAdmin = selectedRows.value.filter((item) => item.username == 'admin');
- if (unref(hasAdmin).length > 0) {
- createMessage.warning('管理员账号不允许此操作!');
- return;
- }
- createConfirm({
- iconType: 'warning',
- title: '确认操作',
- content: '是否' + (status == 1 ? '解冻' : '冻结') + '选中账号?',
- onOk: async () => {
- await frozenBatch({ ids: unref(selectedRowKeys).join(','), status: status }, reload);
- },
- });
- }
- /**
- *同步钉钉和微信回调
- */
- function onSyncFinally({ isToLocal }) {
- // 同步到本地时刷新下数据
- if (isToLocal) {
- reload();
- }
- }
- /**
- * 操作栏
- */
- function getTableAction(record): ActionItem[] {
- return [
- {
- label: '编辑',
- onClick: handleEdit.bind(null, record),
- // ifShow: () => hasPermission('system:user:edit'),
- },
- ];
- }
- /**
- * 下拉操作栏
- */
- function getDropDownAction(record): ActionItem[] {
- return [
- {
- label: '详情',
- onClick: handleDetail.bind(null, record),
- },
- {
- label: '密码',
- //auth: 'user:changepwd',
- onClick: handleChangePassword.bind(null, record.username),
- },
- {
- label: '删除',
- popConfirm: {
- title: '是否确认删除',
- confirm: handleDelete.bind(null, record),
- },
- },
- {
- label: '冻结',
- ifShow: record.status == 1,
- popConfirm: {
- title: '确定冻结吗?',
- confirm: handleFrozen.bind(null, record, 2),
- },
- },
- {
- label: '解冻',
- ifShow: record.status == 2,
- popConfirm: {
- title: '确定解冻吗?',
- confirm: handleFrozen.bind(null, record, 1),
- },
- },
- {
- label: '代理人',
- onClick: handleAgentSettings.bind(null, record.username),
- },
- {
- label: '资源',
- onClick: handleUserResourceSettings.bind(null, record.username),
- },
- ];
- }
- /**
- * 离职
- * @param userName
- */
- function handleQuit(userName) {
- //打开离职代理人弹窗
- openQuitAgentModal(true, { userName });
- }
- </script>
- <style scoped></style>
|