| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- <template>
- <BasicDrawer @register="registerBaseDrawer" title="角色用户" width="800" destroyOnClose>
- <BasicTable @register="registerTable" :rowSelection="rowSelection" >
- <template #tableTitle>
- <a-button type="primary" @click="handleCreate"> 新增用户</a-button>
- <a-button type="primary" @click="handleSelect"> 已有用户</a-button>
- <a-dropdown v-if="checkedKeys.length > 0">
- <template #overlay>
- <a-menu>
- <a-menu-item key="1" @click="batchHandleDelete">
- <Icon icon="bx:bx-unlink"></Icon>
- 取消关联
- </a-menu-item>
- </a-menu>
- </template>
- <a-button>批量操作
- <Icon icon="ant-design:down-outlined"></Icon>
- </a-button>
- </a-dropdown>
- </template>
- <template #action="{ record }">
- <TableAction :actions="getTableAction(record)"/>
- </template>
- </BasicTable>
- <!--用户操作抽屉-->
- <UserDrawer @register="registerDrawer" @success="handleSuccess"/>
- <!--用户选择弹窗-->
- <UseSelectModal @register="registerModal" @select="selectOk"/>
- </BasicDrawer>
- </template>
- <script lang="ts" setup>
- import { ref, defineProps, watch, unref } from 'vue';
- import {BasicTable, useTable, TableAction} from '/src/components/Table';
- import { BasicDrawer,useDrawer, useDrawerInner } from '/src/components/Drawer';
- import {useModal} from '/src/components/Modal';
- import UserDrawer from '../../user/UserDrawer.vue';
- import UseSelectModal from './UseSelectModal.vue';
- import {userList, deleteUserRole, batchDeleteUserRole, addUserRole} from '../role.api';
- import {userColumns, searchUserFormSchema} from '../role.data';
- import {getUserRoles} from '../../user/user.api';
- const emit = defineEmits(['register','hideUserList']);
- const checkedKeys = ref<Array<string | number>>([]);
- const roleId = ref('');
- const [registerBaseDrawer, {setDrawerProps, closeDrawer}] = useDrawerInner(async (data) => {
- roleId.value = data.id
- setProps({searchInfo:{roleId:data.id}});
- reload()
- });
- //注册drawer
- const [registerDrawer, {openDrawer}] = useDrawer();
- //注册drawer
- const [registerModal, {openModal}] = useModal();
- const [registerTable, {reload, updateTableDataRecord,setProps}] = useTable({
- title: '用户列表',
- api: userList,
- columns: userColumns,
- formConfig: {
- labelWidth: 120,
- schemas: searchUserFormSchema,
- autoSubmitOnEnter:true,
- actionColOptions: { pull:1 }
- },
- striped: true,
- useSearchForm: true,
- showTableSetting: true,
- clickToRowSelect: false,
- bordered: true,
- showIndexColumn: false,
- tableSetting: {fullScreen: true},
- canResize: false,
- rowKey: 'id',
- actionColumn: {
- width: 180,
- title: '操作',
- dataIndex: 'action',
- slots: {customRender: 'action'},
- fixed: undefined,
- },
- });
- /**
- * 选择列配置
- */
- const rowSelection = {
- type: 'checkbox',
- columnWidth: 50,
- selectedRowKeys: checkedKeys,
- onChange: onSelectChange
- }
- /**
- * 选择事件
- */
- function onSelectChange(selectedRowKeys: (string | number)[], selectionRows) {
- checkedKeys.value = selectedRowKeys;
- }
- /**
- * 新增
- */
- function handleCreate() {
- openDrawer(true, {
- isUpdate: false,
- selectedroles: [roleId.value],
- isRole: true
- });
- }
- /**
- * 编辑
- */
- async function handleEdit(record: Recordable) {
- try {
- const userRoles = await getUserRoles({userid: record.id});
- if (userRoles && userRoles.length > 0) {
- record.selectedroles = userRoles;
- }
- } catch (e) {
- console.log(e)
- }
- openDrawer(true, {
- record,
- isUpdate: true,
- isRole: true,
- });
- }
- /**
- * 删除事件
- */
- async function handleDelete(record) {
- await deleteUserRole({userId: record.id, roleId: roleId.value}, reload);
- }
- /**
- * 批量删除事件
- */
- async function batchHandleDelete() {
- await batchDeleteUserRole({userIds: checkedKeys.value.join(','), roleId:roleId.value}, reload);
- }
- /**
- * 成功回调
- */
- function handleSuccess({isUpdate, values}) {
- isUpdate ? updateTableDataRecord(values.id, values) : reload();
- }
- /**
- * 选择已有用户
- */
- function handleSelect() {
- openModal(true);
- }
- /**
- * 添加已有用户
- */
- async function selectOk(val) {
- await addUserRole({roleId:roleId.value,userIdList:val},reload)
- }
- /**
- * 操作栏
- */
- function getTableAction(record) {
- return [
- {
- label: '编辑',
- onClick: handleEdit.bind(null, record),
- },
- {
- label: '取消关联',
- popConfirm: {
- title: '是否确认取消关联',
- confirm: handleDelete.bind(null, record),
- }
- }
- ]
- }
- </script>
|