index.vue 7.75 KB
<template>
  <div>
    <PageWrapper dense contentFullHeight contentClass="flex">
      <OrganizationIdTree
        class="w-1/4 xl:w-1/5"
        @select="handleSelect"
        ref="organizationIdTreeRef"
      />
      <BasicTable
        @register="registerTable"
        :searchInfo="searchInfo"
        @selection-change="useSelectionChange"
        :rowSelection="{ type: 'checkbox' }"
        class="w-3/4 xl:w-4/5"
        :clickToRowSelect="false"
      >
        <template #toolbar>
          <a-button type="primary" @click="handleCreateOrEdit(null)"> 新增告警配置 </a-button>
          <a-button
            type="primary"
            color="error"
            @click="handleDeleteOrBatchDelete(null)"
            :disabled="hasBatchDelete"
          >
            批量删除
          </a-button>
        </template>
        <template #alarmContact="{ record }">
          <a-button type="link" class="ml-2" @click="showAlarmContact(record)">
            查看联系人
          </a-button>
        </template>
        <template #messageMode="{ record }">
          <a-button type="link" class="ml-2" @click="showMessageMode(record)">
            查看联系方式
          </a-button>
        </template>
        <template #action="{ record }">
          <TableAction
            :actions="[
              {
                label: '编辑',
                icon: 'clarity:note-edit-line',
                onClick: handleCreateOrEdit.bind(null, record),
                ifShow: () => {
                  return record.status === 0;
                },
              },
              {
                label: '删除',
                icon: 'ant-design:delete-outlined',
                color: 'error',
                ifShow: () => {
                  return record.status === 0;
                },
                popConfirm: {
                  title: '是否确认删除',
                  confirm: handleDeleteOrBatchDelete.bind(null, record),
                },
              },
            ]"
          />
        </template>
      </BasicTable>
    </PageWrapper>
    <ContactDrawer @register="registerDrawer" @success="handleSuccess" />
  </div>
</template>

<script lang="ts">
  import { defineComponent, reactive, ref, h } from 'vue';
  import { BasicTable, useTable, TableAction } from '/@/components/Table';
  import { PageWrapper } from '/@/components/Page';
  import { useMessage } from '/@/hooks/web/useMessage';
  import { useDrawer } from '/@/components/Drawer';
  import ContactDrawer from './ContactDrawer.vue';
  import { useResetOrganizationTree, OrganizationIdTree } from '/@/views/common/organizationIdTree';
  import { deleteAlarmConfig, queryAlarmConfig } from '/@/api/alarm/config/alarmConfig';
  import { searchFormSchema, columns } from './config.data';
  import { Modal } from 'ant-design-vue';
  import { JsonPreview } from '/@/components/CodeEditor';
  import { findDictItemByCode } from '/@/api/system/dict';
  import { alarmContactGetPage } from '/@/api/device/deviceConfigApi';

  export default defineComponent({
    components: {
      PageWrapper,
      OrganizationIdTree,
      BasicTable,
      TableAction,
      ContactDrawer,
    },
    setup() {
      let selectArray: any = [];
      const hasBatchDelete = ref(true);
      const searchInfo = reactive<Recordable>({});
      const { organizationIdTreeRef, resetFn } = useResetOrganizationTree(searchInfo);
      // 表格hooks
      const [registerTable, { reload, getSelectRows, getSelectRowKeys }] = useTable({
        title: '告警配置列表',
        api: queryAlarmConfig,
        columns,
        clickToRowSelect: false,
        showIndexColumn: false,
        formConfig: {
          labelWidth: 120,
          schemas: searchFormSchema,
          resetFunc: resetFn,
        },
        useSearchForm: true,
        showTableSetting: true,
        bordered: true,
        rowKey: 'id',
        actionColumn: {
          width: 200,
          title: '操作',
          dataIndex: 'action',
          slots: { customRender: 'action' },
          fixed: 'right',
        },
      });
      // 弹框
      const [registerDrawer, { openDrawer }] = useDrawer();
      const { createMessage } = useMessage();

      // 刷新
      const handleSuccess = () => {
        reload();
      };
      // 新增或编辑
      const handleCreateOrEdit = (record: Recordable | null) => {
        if (record) {
          openDrawer(true, {
            isUpdate: true,
            record,
          });
        } else {
          openDrawer(true, {
            isUpdate: false,
          });
        }
      };
      const useSelectionChange = () => {
        selectArray = getSelectRowKeys();
        if (selectArray.length > 0) {
          hasBatchDelete.value = false;
        }
        let getRows = getSelectRows();
        const isJudge = getRows.map((m) => m.status);
        if (isJudge.length === 0) {
          hasBatchDelete.value = true;
        }
        if (isJudge.includes(1) && isJudge.includes(0)) {
          hasBatchDelete.value = true;
        } else if (isJudge.includes(1) && !isJudge.includes(0)) {
          hasBatchDelete.value = true;
        } else if (!isJudge.includes(1) && isJudge.includes(0)) {
          hasBatchDelete.value = false;
        }
      };
      // 删除或批量删除
      const handleDeleteOrBatchDelete = async (record: Recordable | null) => {
        if (record) {
          try {
            await deleteAlarmConfig([record.id]);
            createMessage.success('删除成功');
            handleSuccess();
          } catch (e: any) {}
        } else {
          try {
            await deleteAlarmConfig(selectArray);
            createMessage.success('批量删除成功');
            handleSuccess();
            selectArray.length = 0;
          } catch (e: any) {
            selectArray.length = 0;
          } finally {
            selectArray.length = 0;
          }
        }
      };

      // 树形选择器
      const handleSelect = (organizationId: string) => {
        searchInfo.organizationId = organizationId;
        handleSuccess();
      };
      const showAlarmContact = async (record) => {
        const { items } = await alarmContactGetPage();
        const joinArray = record.alarmContactId.split(',');
        let findName = [];
        findName = items.map((m) => {
          return {
            username: m.username,
            id: m.id,
          };
        });
        let arr3 = findName.filter((obj: any) => joinArray.some((obj1) => obj1 == obj.id));
        let arr4 = arr3.map((m: any) => {
          return m.username;
        });
        Modal.info({
          title: '当前告警通知联系人',
          width: 600,
          content: h(JsonPreview, { data: JSON.parse(JSON.stringify(arr4)) }),
        });
      };
      const showMessageMode = async (record) => {
        const data1: any = await findDictItemByCode({ dictCode: 'message_type' });
        const joinArray = record.messageMode.split(',');
        let findName = [];
        findName = data1.map((m: any) => {
          return {
            itemValue: m.itemValue,
            itemText: m.itemText,
          };
        });
        let arr3 = findName.filter((obj: any) => joinArray.some((obj1) => obj1 == obj.itemValue));
        let arr4 = arr3.map((m: any) => {
          return m.itemText;
        });

        Modal.info({
          title: '当前告警联系方式',
          width: 600,
          content: h(JsonPreview, { data: JSON.parse(JSON.stringify(arr4)) }),
        });
      };
      return {
        useSelectionChange,
        searchInfo,
        hasBatchDelete,
        handleCreateOrEdit,
        handleDeleteOrBatchDelete,
        handleSelect,
        handleSuccess,
        registerTable,
        registerDrawer,
        organizationIdTreeRef,
        showAlarmContact,
        showMessageMode,
      };
    },
  });
</script>