index.vue 4.4 KB
<template>
  <div>
    <!-- register 用于注册 useTable,如果需要使用useTable提供的 api,必须将 register 传入组件的 onRegister-->
    <!-- @fetch-success接口请求成功后触发 -->
    <BasicTable @register="registerTable" @fetch-success="onFetchSuccess">

      <!-- 通过模板,加载工具栏 -->
      <template #toolbar>
        <a-button type="primary" @click="handleCreate">
          {{ getI18nCreateMenu }}
        </a-button> <!-- 新增菜单-->
      </template>

      <!-- 表格单项,操作 -->
      <template #action="{ record }">
        <TableAction
          :actions="[
            {
              icon: 'clarity:note-edit-line',
              onClick: handleEdit.bind(null, record),
            },
            {
              icon: 'ant-design:delete-outlined',
              color: 'error',
              popConfirm: {
                title: getDeleteTitle(),//是否确认删除//getDeleteTitle()
                confirm: handleDelete.bind(null, record),
              },
            },
          ]"
        />
      </template>
    </BasicTable>

    <!-- 弹出框 -->
    <MenuDrawer @register="registerDrawer" @success="handleSuccess"/>
  </div>
</template>
<script lang="ts">
//导入所需插件
import {computed, defineComponent, nextTick} from 'vue';

// 导入表格组件,表格事件
import {BasicTable, useTable, TableAction} from '/@/components/Table';

// 加载表格数据
import {getMenuList, delMenu} from '/@/api/sys/menu';
// 加载自定义侧边弹出框 组件
import {useDrawer} from '/@/components/Drawer';

// 导入子页面【新增、修改】
import MenuDrawer from './MenuDrawer.vue';

// 导入列 属性,和搜索栏内容
import {columns, searchFormSchema} from './menu.data';
import {useI18n} from "/@/hooks/web/useI18n";
import {notification} from "ant-design-vue";

// 自定义表格组件和属性
export default defineComponent({
  name: 'MenuManagement',
  components: {BasicTable, MenuDrawer, TableAction},
  setup() {
    const [registerDrawer, {openDrawer}] = useDrawer();//使用右侧弹出框
    const {t} = useI18n(); //加载国际化
    // 新增菜单
    const getI18nCreateMenu = computed(() => t('routes.common.system.pageSystemTitleCreateMenu'));

    const [registerTable, {reload, expandAll}] = useTable({
      title: t('routes.common.system.pageSystemTitleMenuList'),//'菜单列表'
      api: getMenuList, //加载数据
      columns,          //加载列
      // formConfig: {
      //   labelWidth: 120,
      //   schemas: searchFormSchema,
      // },
      isTreeTable: true,
      pagination: false,
      striped: false,
      // useSearchForm: true,
      showTableSetting: true,
      bordered: true,
      showIndexColumn: false,
      canResize: false,
      actionColumn: {
        width: 80,
        title: t('routes.common.system.pageSystemTitleOperation'),//操作
        dataIndex: 'action',
        slots: {customRender: 'action'},
        fixed: undefined,
      },
    });

    /**
     * 获得删除提示框的文字
     */
    function getDeleteTitle(): string {
      let labelText = t('routes.common.system.pageSystemTitleWhetherDelete');
      return labelText
    }

    /**
     * 打开新增菜单
     */
    function handleCreate() {
      openDrawer(true, {
        isUpdate: false,
      });
    }

    /**
     * 打开 编辑菜单
     * @param record
     */
    function handleEdit(record: Recordable) {
      console.log("----------------------------333-------------"+record.parentId);
      openDrawer(true, {
        record,
        isUpdate: true,
      });
    }

    /**
     * 执行 删除操作
     * @param record
     */
    async function handleDelete(record: Recordable) {
      try {
        let ids = [record.id,];
        await delMenu(ids);
        notification.success({
          message: "成功",
          description: "删除菜单成功",
          duration: 3,
        });
        await reload();
      } catch (e) {
        return Promise.reject(e);
      }
    }

    /**
     * 操作成功,重新加载页面
     */
    function handleSuccess() {
      reload();
    }

    function onFetchSuccess() {
      // 演示默认展开所有表项
      nextTick(expandAll);
    }

    return {
      getDeleteTitle,
      getI18nCreateMenu,
      registerTable,
      registerDrawer,
      handleCreate,
      handleEdit,
      handleDelete,
      handleSuccess,
      onFetchSuccess,
    };
  },
});
</script>