zhangwei
2025-08-29 e1b04baf60478e3de9e41e1fc39e1e4346321817
src/views/system/dept/utils/hook.tsx
@@ -1,4 +1,4 @@
import dayjs from "dayjs";
// import dayjs from "dayjs";
import editForm from "../form.vue";
import { handleTree } from "@/utils/tree";
import { message } from "@/utils/message";
@@ -10,17 +10,31 @@
  getOrderStatusList,
  getRegionList,
  getDaimaleixingList,
  addgetcontact,
  caigourenAdd,
  caigourenUpdate,
  caigourenDelete
  caigourenDelete,
  caigourenBatchDelete
} from "@/api/item/index";
import { usePublicHooks } from "../../hooks";
// import { usePublicHooks } from "../../hooks";
import { addDialog } from "@/components/ReDialog";
import { reactive, ref, onMounted, h } from "vue";
import type { FormItemProps } from "../utils/types";
import { cloneDeep, isAllEmpty, deviceDetection } from "@pureadmin/utils";
import { type Ref, reactive, ref, onMounted, h, computed } from "vue";
import type { FormItemProps } from "./types";
import { cloneDeep, deviceDetection, getKeyList } from "@pureadmin/utils";
// import { useUserStoreHook } from "@/store/modules/user";
import type { PaginationProps } from "@pureadmin/table";
import { useUserStoreHook } from "@/store/modules/user";
export function useDept() {
import pdfPreview from "../../component/pdfPreview2.vue";
// const nowRole = computed(() => {
//   return useUserStoreHook().nowRole;
// });
const selectedNum = ref(0);
export function useDept(tableRef: Ref) {
  const nowRole = computed(() => {
    return useUserStoreHook().nowRole;
  });
  const form = reactive({
    // 新增日期范围,可为 null,类型为数组
    createDateRange: null,
@@ -38,6 +52,7 @@
    projectName: null,
    // 代理机构名称,可为 null,类型为字符串
    dailijigoumingcheng: null,
    caigourenmingcheng: null,
    // 中标供应商姓名,可为 null,类型为字符串
    zhongbiaoName: null,
    // 专家姓名,可为 null,类型为字符串
@@ -88,14 +103,25 @@
  const formRef = ref();
  const dataList = ref([]);
  const loading = ref(true);
  const { tagStyle } = usePublicHooks();
  // const { tagStyle } = usePublicHooks();
  const getOrderStatus = row => {
    const res = state.orderStatusList.find(item => {
      return row.orderStatus == item.status;
      return row.orderStatus == item.value;
    });
    return res?.label;
  };
  const columns: TableColumnList = [
    {
      label: "勾选列", // 如果需要表格多选,此处label必须设置
      type: "selection",
      fixed: "left",
      reserveSelection: true // 数据刷新后保留选项
    },
    {
      label: "采购人",
      prop: "caigourenmingcheng",
      minWidth: 120
    },
    {
      label: "项目名称",
      prop: "projectName",
@@ -103,15 +129,10 @@
      align: "left"
    },
    {
      label: "代理机构",
      prop: "dailijigoumingcheng",
      minWidth: 70
    },
    {
      label: "项目进度",
      prop: "orderStatus",
      minWidth: 70,
      cellRenderer: ({ row, props }) => getOrderStatus(row)
      cellRenderer: ({ row }) => getOrderStatus(row)
    },
    {
      label: "报名费",
@@ -126,7 +147,7 @@
    {
      label: "中标供应商",
      prop: "zhongbiaoName",
      minWidth: 70
      minWidth: 180
    },
    {
      label: "评审专家",
@@ -137,15 +158,13 @@
      label: "质疑",
      prop: "zhiyi",
      minWidth: 100,
      cellRenderer: ({ row, props }) => (
        <span>{row.status === 1 ? "有" : "无"}</span>
      )
      cellRenderer: ({ row }) => <span>{row.status === 1 ? "有" : "无"}</span>
    },
    {
      label: "投诉",
      prop: "tousu",
      minWidth: 100,
      cellRenderer: ({ row, props }) => (
      cellRenderer: ({ row }) => (
        // <el-tag size={props.size} style={tagStyle.value(row.status)}>
        <span>{row.status === 1 ? "有" : "无"}</span>
        // </el-tag>
@@ -154,13 +173,115 @@
    {
      label: "操作",
      fixed: "right",
      width: 210,
      width: 80,
      slot: "operation"
    }
  ];
  const CGRcolumns: TableColumnList = [
    {
      label: "勾选列", // 如果需要表格多选,此处label必须设置
      type: "selection",
      fixed: "left",
      reserveSelection: true // 数据刷新后保留选项
    },
    {
      label: "代理机构",
      prop: "dailijigoumingcheng",
      minWidth: 70
    },
    {
      label: "项目名称",
      prop: "projectName",
      width: 180,
      align: "left"
    },
    {
      label: "项目进度",
      prop: "orderStatus",
      minWidth: 70,
      cellRenderer: ({ row }) => getOrderStatus(row)
    },
    {
      label: "报名费",
      prop: "baomingfei",
      minWidth: 70
    },
    {
      label: "投标保证金",
      prop: "toubiaobaozhengjin",
      minWidth: 70
    },
    {
      label: "中标供应商",
      prop: "zhongbiaoName",
      minWidth: 180
    },
    {
      label: "评审专家",
      prop: "zhuanjiaName",
      minWidth: 70
    },
    {
      label: "质疑",
      prop: "zhiyi",
      minWidth: 100,
      cellRenderer: ({ row }) => <span>{row.status === 1 ? "有" : "无"}</span>
    },
    {
      label: "投诉",
      prop: "tousu",
      minWidth: 100,
      cellRenderer: ({ row }) => (
        // <el-tag size={props.size} style={tagStyle.value(row.status)}>
        <span>{row.status === 1 ? "有" : "无"}</span>
        // </el-tag>
      )
    },
    {
      label: "操作",
      fixed: "right",
      width: 80,
      slot: "operation"
    }
  ];
  /** 当CheckBox选择项发生变化时会触发该事件 */
  function handleSelectionChange(val) {
    console.log("handleSelectionChange", val);
    selectedNum.value = val.length;
    // 重置表格高度
    tableRef.value.setAdaptive();
  }
  /** 取消选择 */
  function onSelectionCancel() {
    selectedNum.value = 0;
    // 用于多选表格,清空用户的选择
    tableRef.value.getTableRef().clearSelection();
  }
  /** 批量删除 */
  async function onbatchDel() {
    // 返回当前选中的行
    const curSelected = tableRef.value.getTableRef().getSelectionRows();
    const data = [];
    curSelected.forEach(item => {
      data.push({ id: item.id });
    });
    const res = await caigourenBatchDelete(data);
    if (res.code == "200") {
      // 接下来根据实际业务,通过选中行的某项数据,比如下面的id,调用接口进行批量删除
      message(
        `已删除项目名称为 ${getKeyList(curSelected, "projectName")} 的数据`,
        {
          type: "success"
        }
      );
      onSearch();
    } else {
      message(res.message, {
        type: "error"
      });
    }
    tableRef.value.getTableRef().clearSelection();
    onSearch();
  }
  function handleSizeChange(val: number) {
    console.log(`${val} items per page`);
@@ -170,10 +291,23 @@
    console.log(`current page: ${val}`);
  }
  function resetForm(formEl) {
    if (!formEl) return;
    formEl.resetFields();
    onSearch();
  function resetForm() {
    // if (!formEl) return;
    // formEl.resetFields();
    // onSearch();
    addDialog({
      title: `预览pdf`,
      props: {},
      width: "60%",
      draggable: true,
      fullscreen: deviceDetection(),
      fullscreenIcon: true,
      sureBtnLoading: true,
      closeOnClickModal: false,
      contentRenderer: () => h(pdfPreview, { ref: formRef, formInline: null })
      // jsx 语法 (注意在.vue文件启用jsx语法,需要在script开启lang="tsx")
    });
  }
  const checkboxAsRadio = data => {
    if (data.length > 1) {
@@ -193,7 +327,7 @@
    pagination.pageSize = result.pageSize;
    pagination.currentPage = result.page;
    // if (!isAllEmpty(form.name)) {
    //   // 前端搜索部门名称
    //   // 前端搜索项目名称
    //   newData = newData.filter(item => item.name.includes(form.name));
    // }
    // if (!isAllEmpty(form.status)) {
@@ -204,7 +338,7 @@
  }
  function formatHigherDeptOptions(treeList) {
    // 根据返回数据的status字段值判断追加是否禁用disabled字段,返回处理后的树结构,用于上级部门级联选择器的展示(实际开发中也是如此,不可能前端需要的每个字段后端都会返回,这时需要前端自行根据后端返回的某些字段做逻辑处理)
    // 根据返回数据的status字段值判断追加是否禁用disabled字段,返回处理后的树结构,用于上级项目级联选择器的展示(实际开发中也是如此,不可能前端需要的每个字段后端都会返回,这时需要前端自行根据后端返回的某些字段做逻辑处理)
    if (!treeList || !treeList.length) return;
    const newTreeList = [];
    for (let i = 0; i < treeList.length; i++) {
@@ -215,14 +349,15 @@
    return newTreeList;
  }
  function openDialog(title = "新增", row?: FormItemProps) {
    console.log(row,'-');
  async function openDialog(title = "新增", row?: FormItemProps) {
    const { result } = title == "新增" ? await addgetcontact() : {};
    addDialog({
      title: `${title}项目`,
      props: {
        formInline: {
          higherDeptOptions: formatHigherDeptOptions(cloneDeep(dataList.value)),
          id: row?.id ?? "",
          projectCode: row?.projectCode ?? "", // 项目编号(必填)
          projectName: row?.projectName ?? "", // 项目名称(必填)
          hangyepinmu: row?.hangyepinmu ?? null, // 行业品目(可选)
@@ -232,28 +367,36 @@
          baomingfei: row?.baomingfei ?? null, // 报名费(可选)
          toubiaobaozhengjin: row?.toubiaobaozhengjin ?? null, // 投标保证金(可选)
          lianhetitoubiao: row?.lianhetitoubiao ?? null, // 联合体投标(可选)
          kaibiaofangshi: row?.kaibiaofangshi ?? null, // 开标方式(可选)
          kaibiaofangshi: row?.kaibiaofangshi ?? "纸质标", // 开标方式(可选)
          shifoufenbao: row?.shifoufenbao ?? "false", // 是否分包(可选)
          shifoutuisongxuanchuan: row?.shifoutuisongxuanchuan ?? "true", // 是否推送宣传(可选)
          caigourenmingcheng: row?.caigourenmingcheng ?? null, // 采购人名称(可选)
          caigourenmingcheng:
            row?.caigourenmingcheng ?? result?.caigourenmingcheng, // 采购人名称(可选)
          xingzhengquyu: row?.xingzhengquyu.split(",") ?? [], // 行政区域(可选)
          xingzhengquyuName: row?.xingzhengquyuName ?? null, // 行政区域名称(可选)
          jigoudaima: row?.jigoudaima ?? null, // 机构代码(可选)
          jigoudaima: row?.jigoudaima ?? result?.jigoudaima, // 机构代码(可选)
          daimaleixing: row?.daimaleixing ?? null, // 代码类型(可选)
          lianxiren: row?.lianxiren ?? null, // 联系人(可选)
          lianxidianhua: row?.lianxidianhua ?? null, // 联系电话(可选)
          tongxindizhi: row?.tongxindizhi ?? null, // 通信地址(可选)
          dianziyoujian: row?.dianziyoujian ?? null, // 电子邮件(可选)
          xiangmujingbanren: row?.xiangmujingbanren ?? null, // 项目经办人(可选)
          lianxiren: row?.lianxiren ?? result?.lianxiren, // 联系人(可选)
          lianxidianhua: row?.lianxidianhua ?? result?.lianxidianhua, // 联系电话(可选)
          tongxindizhi: row?.tongxindizhi ?? result?.tongxindizhi, // 通信地址(可选)
          dianziyoujian: row?.dianziyoujian ?? result?.dianziyoujian, // 电子邮件(可选)
          xiangmujingbanren:
            row?.xiangmujingbanren ?? result?.xiangmujingbanren, // 项目经办人(可选)
          zhiwu: row?.zhiwu ?? null, // 职务(可选)
          jingbanrendianhua: row?.jingbanrendianhua ?? null, // 经办人电话(可选)
          dailijigoumingcheng: row?.dailijigoumingcheng ?? null, // 代理机构名称(可选)
          dailiLianxiren: row?.dailiLianxiren ?? null, // 代理机构联系人(可选)
          dailiLianxidianhua: row?.dailiLianxidianhua ?? null, // 代理机构联系电话(可选)
          dailiDianziyoujian: row?.dailiDianziyoujian ?? null, // 代理机构电子邮件(可选)
          dailiTongxindizhi: row?.dailiTongxindizhi ?? null, // 代理机构通信地址(可选)
          dailiXiangmujingli: row?.dailiXiangmujingli ?? null, // 代理机构项目经理(可选
          dailijingliLianxidianhua: row?.dailijingliLianxidianhua ?? null // 代理机构项目经理联系电话(可选)
          dailijigoumingcheng:
            row?.dailijigoumingcheng ?? result?.dailijigoumingcheng, // 代理机构名称(可选)
          dailiLianxiren: row?.dailiLianxiren ?? result?.dailiLianxiren, // 代理机构联系人(可选)
          dailiLianxidianhua:
            row?.dailiLianxidianhua ?? result?.dailiLianxidianhua, // 代理机构联系电话(可选)
          dailiDianziyoujian:
            row?.dailiDianziyoujian ?? result?.dailiDianziyoujian, // 代理机构电子邮件(可选)
          dailiTongxindizhi:
            row?.dailiTongxindizhi ?? result?.dailiTongxindizhi, // 代理机构通信地址(可选)
          dailiXiangmujingli:
            row?.dailiXiangmujingli ?? result?.dailiXiangmujingli, // 代理机构项目经理(可选
          dailijingliLianxidianhua:
            row?.dailijingliLianxidianhua ?? result?.dailijingliLianxidianhua // 代理机构项目经理联系电话(可选)
        }
      },
      width: "80%",
@@ -267,9 +410,6 @@
        const FormRef = formRef.value.getRef();
        const curData = cloneDeep(options.props.formInline as FormItemProps);
        async function chores() {
          message(`您${title}了项目名称为${curData.projectName}的这条数据`, {
            type: "success"
          });
          // curData.dingbiaoguize = curData.dingbiaoguize.join("");
          curData.xingzhengquyu = curData.xingzhengquyu.join(",");
          let res;
@@ -281,6 +421,9 @@
          if (res.code == "200") {
            done(); // 关闭弹框
            onSearch(); // 刷新表格数据
            message(`您${title}了项目名称为${curData.projectName}的这条数据`, {
              type: "success"
            });
          } else {
            closeLoading();
            message(res.message, {
@@ -301,8 +444,6 @@
          } else {
            closeLoading();
            const fail = [];
            console.log(obj);
            for (const key in obj) {
              fail.push(obj[key][0].message);
            }
@@ -344,19 +485,24 @@
    state,
    loading,
    columns,
    CGRcolumns,
    dataList,
    selectedNum,
    /** 搜索 */
    onSearch,
    /** 重置 */
    resetForm,
    /** 新增、修改部门 */
    /** 新增、修改项目 */
    openDialog,
    /** 删除部门 */
    /** 删除项目 */
    handleDelete,
    handleSelectionChange,
    handleSizeChange,
    handleCurrentChange,
    pagination,
    checkboxAsRadio
    checkboxAsRadio,
    onSelectionCancel,
    onbatchDel,
    nowRole
  };
}