| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242 |
- <template>
- <div class="device-manager-box">
- <!--引用表格-->
- <BasicTable @register="registerTable">
- <!--插槽: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"> 导出</a-button>
- <j-upload-button type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button> -->
- <!-- <a-button type="primary" @click="handleSyncUser" preIcon="ant-design:sync-outlined"> 同步流程</a-button> -->
- <!-- <a-button type="primary" @click="openModal(true, {})" preIcon="ant-design:hdd-outlined"> 回收站</a-button> -->
- <JThirdAppButton biz-type="user" :selected-row-keys="selectedRowKeys" syncToApp syncToLocal @sync-finally="onSyncFinally" />
- <a-dropdown v-if="selectedRowKeys.length > 0">
- <template #overlay>
- <a-menu>
- <a-menu-item key="1" @click="batchHandleDelete">
- <Icon icon="ant-design:delete-outlined" />
- 删除
- </a-menu-item>
- </a-menu>
- </template>
- <a-button
- >批量操作
- <Icon icon="mdi:chevron-down" />
- </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" />
- <!--授权弹窗-->
- <UserPermModal @register="registerPermModal" @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 { 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 { list, deleteUser, batchDeleteUser, frozenBatch, syncUser } from './user.api';
- import UserPermModal from './UserPermModal.vue';
- // import { usePermission } from '/@/hooks/web/usePermission'
- // const { hasPermission } = usePermission();
- const { createMessage, createConfirm } = useMessage();
- //注册drawer
- const [registerDrawer, { openDrawer }] = useDrawer();
- //回收站model
- // const [registerModal, { openModal }] = useModal();
- //密码model
- const [registerPasswordModal, { openModal: openPasswordModal }] = useModal();
- //代理人model
- const [registerAgentModal, { openModal: openAgentModal }] = useModal();
- // 授权model
- const [registerPermModal, { openModal: openPermissionModal }] = useModal();
- // 列表页面公共参数、方法
- const { prefixCls, tableContext } = useListPage({
- designScope: 'user-list',
- tableProps: {
- title: '用户列表',
- api: list,
- columns: columns,
- size: 'small',
- formConfig: {
- // labelWidth: 200,
- schemas: searchFormSchema,
- },
- actionColumn: {
- width: 120,
- },
- beforeFetch(params) {
- return Object.assign(
- {
- column: 'createTime',
- order: 'desc',
- thirdType: '_thirdPartyUser',
- },
- params
- );
- },
- },
- // exportConfig: {
- // name: '用户列表',
- // url: getExportUrl,
- // },
- // importConfig: {
- // url: getImportUrl,
- // },
- });
- //注册table数据
- const [registerTable, { reload }, { selectedRows, selectedRowKeys }] = tableContext;
- /**
- * 新增事件
- */
- function handleCreate() {
- openDrawer(true, {
- isUpdate: false,
- showFooter: true,
- });
- }
- /**
- * 编辑事件
- */
- async function handleEdit(record: Recordable) {
- openDrawer(true, {
- record,
- isUpdate: true,
- showFooter: true,
- });
- }
- /**
- * 详情
- */
- async function handleDetail(record: Recordable) {
- openDrawer(true, {
- record,
- isUpdate: true,
- showFooter: 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 handlePermissionModel(userID) {
- openPermissionModal(true, { userID });
- }
- /**
- *同步钉钉和微信回调
- */
- function onSyncFinally({ isToLocal }) {
- // 同步到本地时刷新下数据
- if (isToLocal) {
- reload();
- }
- }
- /**
- * 操作栏
- */
- function getTableAction(record): ActionItem[] {
- return [
- {
- label: '编辑',
- onClick: handleEdit.bind(null, record),
- // ifShow: () => hasPermission('system:user:edit'),
- },
- {
- label: '授权',
- onClick: handlePermissionModel.bind(null, record.username),
- // ifShow: () => hasPermission('system:user:edit'),
- },
- ];
- }
- /**
- * 下拉操作栏
- */
- function getDropDownAction(record): ActionItem[] {
- return [
- {
- label: '详情',
- onClick: handleDetail.bind(null, record),
- },
- {
- label: '密码',
- onClick: handleChangePassword.bind(null, record.username),
- },
- {
- label: '删除',
- popConfirm: {
- title: '是否确认删除',
- confirm: handleDelete.bind(null, record),
- },
- },
- ];
- }
- </script>
- <style scoped></style>
|