EmailPanel.vue 4.41 KB
<template>
  <div :style="{ marginLeft: '0px' }">
    <BasicTable @register="registerTable">
      <template #toolbar>
        <!-- <a-button type="primary" class="my-4" @click="handleCreate"> 新增 </a-button> -->
        <a-button type="primary" @click="handleCreate">新建</a-button>
        <DrawerEdit @register="registerEdit" @success="handleSuccess" />
        <DrawerCreate @register="registerCreate" @success2="handleSuccessCreate" />
      </template>
      <template #bodyCell="{ column, record }">
        <template v-if="column.key === 'action'">
          <TableAction
            :actions="[
              {
                label: '编辑',
                onClick: handleEdit.bind(null, record),
                // auth: 'other', // 根据权限控制是否显示: 无权限,不显示
              },
              {
                label: '删除',
                popConfirm: {
                  title: '是否删除?',
                  confirm: handleDelete.bind(null, record),
                },
                // onClick: handleDelete.bind(null, record),
                // auth: 'super', // 根据权限控制是否显示: 有权限,会显示
              },
              {
                label: '启用',
                popConfirm: {
                  title: '是否启用?',
                  confirm: handleOpen.bind(null, record),
                },
                ifShow: (_action) => {
                  return record.enableFlag !== 10; // 根据业务控制是否显示: 非enable状态的不显示启用按钮
                },
              },
              {
                label: '禁用',
                popConfirm: {
                  title: '是否禁用?',
                  confirm: handleForbid.bind(null, record),
                },
                ifShow: () => {
                  return record.enableFlag === 10; // 根据业务控制是否显示: enable状态的显示禁用按钮
                },
              },
            ]"
            :dropDownActions="[
              // {
              //   label: '同时控制',
              //   popConfirm: {
              //     title: '是否动态显示?',
              //     confirm: handleOpen.bind(null, record),
              //   },
              //   auth: 'super', // 同时根据权限和业务控制是否显示
              //   ifShow: () => {
              //     return true;
              //   },
              // },
            ]"
          />
        </template>
      </template>
    </BasicTable>
  </div>
</template>
<script lang="ts" setup>
  import { BasicTable, useTable, BasicColumn, TableAction } from '@/components/Table';
  import DrawerEdit from './DrawerEdit.vue';
  import DrawerCreate from './DrawerCreate.vue';
  import { useDrawer } from '@/components/Drawer';
  import { columns } from './data';
  import {
    getEmailList,
    getList,
    emailCreate,
    emailDelete,
    emailEdit,
    emailOpt,
  } from '/@/api/sys/config';
  import { ref, reactive } from 'vue';

  const [registerEdit, { openDrawer: openDrawerEdit }] = useDrawer();
  const [registerCreate, { openDrawer: openDrawerCreate }] = useDrawer();

  const [registerTable, { reload }] = useTable({
    // title: 'TableAction组件及固定列示例',
    api: getEmailList,
    pagination: false,
    columns: columns,
    bordered: true,
    rowKey: 'id',
    actionColumn: {
      width: 180,
      title: '操作',
      dataIndex: 'action',
    },
  });
  //新增
  function handleCreate(record) {
    openDrawerCreate(true, {
      data: record,
      isUpdate: false,
    });
  }
  //编辑
  function handleEdit(record) {
    console.log('点击了编辑', record);
    openDrawerEdit(true, {
      data: record,
      isUpdate: true,
    });
  }
  //编辑完成后向接口传递数据
  async function handleSuccess({ values }) {
    await emailEdit({ ...values });
    reload();
  }
  //新增完成后向接口传递数据
  async function handleSuccessCreate({ values }) {
    await emailCreate({ ...values });
    reload();
  }
  //删除
  async function handleDelete(record: any) {
    await emailDelete({ id: record.id });
    reload();
  }
  //启用
  async function handleOpen(record) {
    await emailOpt({ id: record.id, enableflag: record.enableFlag === 10 ? 30 : 10 });
    reload();
  }
  //禁用
  async function handleForbid(record) {
    await emailOpt({ id: record.id, enableflag: record.enableFlag === 10 ? 30 : 10 });
    reload();
  }
</script>
<style></style>