FieldDetail.vue 4.84 KB
<template>
  <BasicDrawer
    @register="register"
    v-bind="$attrs"
    title="title"
    width="60%"
    :isDetail="true"
    :showDetailBack="false"
  >
    <div>
      <BasicTable @register="registerTable" @edit-change="handleEditChange">
        <template #bodyCell="{ column, record }">
          <template v-if="column.key === 'action'">
            <TableAction :actions="createActions(record, column)" />
          </template>
        </template>
      </BasicTable>
      <a-button block class="mt-5" type="dashed" @click="handleAdd"> 新增选项 </a-button>
    </div>
    <!-- <template #titleToolbar> <a-button type="primary"> 申请编辑权限 </a-button></template> -->
  </BasicDrawer>
</template>
<script lang="ts">
  import { defineComponent, ref, toRaw } from 'vue';
  import {
    BasicTable,
    useTable,
    TableAction,
    BasicColumn,
    ActionItem,
    EditRecordRow,
  } from '/@/components/Table';
  import { BasicDrawer, useDrawerInner } from '/@/components/Drawer';
  import { useOrderStoreWithOut } from '/@/store/modules/order';
  import { dictCreate, dictDelete, dictList, dictUpdate } from '/@/api/project/order';

  const orderStore = useOrderStoreWithOut();

  const columns: BasicColumn[] = [
    {
      title: '筛选项',
      dataIndex: 'dictValue',
      editRow: true,
    },
  ];

  export default defineComponent({
    components: { BasicDrawer, BasicTable, TableAction },
    props: {
      onGoFormDetail: {
        type: Function,
      },
    },
    setup() {
      const dataSource = ref([]);
      const key = ref('');
      const title = ref('');

      const [registerTable, { getDataSource, reload }] = useTable({
        columns: columns,
        showIndexColumn: false,
        dataSource: toRaw(dataSource),
        actionColumn: {
          width: 160,
          title: '操作',
          dataIndex: 'action',
          // slots: { customRender: 'action' },
        },
        scroll: { y: '100%' },
        pagination: false,
      });

      const [register] = useDrawerInner((data) => {
        const { dataIndex, customTitle } = data;
        const dicts = orderStore.getDictInfo;
        const dict = dicts[dataIndex];
        dataSource.value = dict;
        title.value = customTitle;
        key.value = dataIndex;
      });

      function handleEdit(record: EditRecordRow) {
        record.onEdit?.(true);
      }

      function handleCancel(record: EditRecordRow) {
        record.onEdit?.(false);
        if (record.isNew) {
          const data = getDataSource();
          const index = data.findIndex((item) => item.key === record.key);
          data.splice(index, 1);
        }
      }

      async function handleSave(record: EditRecordRow) {
        if (record.id) {
          await dictUpdate({ dictCode: key.value, dictValue: record.dictValue });
        } else {
          await dictCreate({
            dictName: title.value,
            dictCode: key.value,
            dictValue: record.dictValue,
            sort: dataSource.value.length + 1,
          });
        }

        await orderStore.getDict();

        setTimeout(async () => {
          const res = await dictList({ dictCode: key.value });
          dataSource.value = res.records;
          reload();
        }, 300);
      }

      async function handleDelete(record) {
        await dictDelete({ ids: [record.id] });
        await orderStore.getDict();
        record.onEdit?.(false, true);
        setTimeout(async () => {
          const res = await dictList({ dictCode: key.value });
          dataSource.value = res.records;
          reload();
        }, 300);
      }

      function handleEditChange(data) {
        console.log(data);
      }

      function handleAdd() {
        const data = getDataSource();
        const addRow: EditRecordRow = {
          name: '',
          no: '',
          dept: '',
          editable: true,
          isNew: true,
          key: `${Date.now()}`,
        };
        data.push(addRow);
      }

      function createActions(record: EditRecordRow, column: BasicColumn): ActionItem[] {
        if (!record.editable) {
          return [
            {
              label: '编辑',
              onClick: handleEdit.bind(null, record),
            },
            {
              label: '删除',
              onClick: handleDelete.bind(null, record),
            },
          ];
        }
        return [
          {
            label: '保存',
            onClick: handleSave.bind(null, record, column),
          },
          {
            label: '取消',
            popConfirm: {
              title: '是否取消编辑',
              confirm: handleCancel.bind(null, record, column),
            },
          },
        ];
      }
      return {
        title,
        register,
        registerTable,
        handleEdit,
        createActions,
        handleAdd,
        getDataSource,
        handleEditChange,
      };
    },
  });
</script>