| | |
| | | import dayjs from "dayjs"; |
| | | // import dayjs from "dayjs"; |
| | | import editForm from "../form.vue"; |
| | | import { handleTree } from "@/utils/tree"; |
| | | import { message } from "@/utils/message"; |
| | |
| | | getDaimaleixingList, |
| | | 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 } 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"; |
| | | |
| | | export function useDept() { |
| | | // const nowRole = computed(() => { |
| | | // return useUserStoreHook().nowRole; |
| | | // }); |
| | | const selectedNum = ref(0); |
| | | |
| | | export function useDept(tableRef: Ref) { |
| | | const form = reactive({ |
| | | // 新增日期范围,可为 null,类型为数组 |
| | | createDateRange: null, |
| | |
| | | projectName: null, |
| | | // 代理机构名称,可为 null,类型为字符串 |
| | | dailijigoumingcheng: null, |
| | | caigourenmingcheng: null, |
| | | // 中标供应商姓名,可为 null,类型为字符串 |
| | | zhongbiaoName: null, |
| | | // 专家姓名,可为 null,类型为字符串 |
| | |
| | | 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; |
| | |
| | | }; |
| | | const columns: TableColumnList = [ |
| | | { |
| | | label: "勾选列", // 如果需要表格多选,此处label必须设置 |
| | | type: "selection", |
| | | fixed: "left", |
| | | reserveSelection: true // 数据刷新后保留选项 |
| | | }, |
| | | { |
| | | label: "采购人", |
| | | prop: "caigourenmingcheng", |
| | | minWidth: 70 |
| | | }, |
| | | { |
| | | label: "项目名称", |
| | | prop: "projectName", |
| | | width: 180, |
| | | align: "left" |
| | | }, |
| | | { |
| | | label: "代理机构", |
| | | prop: "dailijigoumingcheng", |
| | | minWidth: 70 |
| | | }, |
| | | { |
| | | label: "项目进度", |
| | | prop: "orderStatus", |
| | | minWidth: 70, |
| | | cellRenderer: ({ row, props }) => getOrderStatus(row) |
| | | cellRenderer: ({ row }) => getOrderStatus(row) |
| | | }, |
| | | { |
| | | label: "报名费", |
| | |
| | | { |
| | | label: "中标供应商", |
| | | prop: "zhongbiaoName", |
| | | minWidth: 70 |
| | | minWidth: 180 |
| | | }, |
| | | { |
| | | label: "评审专家", |
| | |
| | | 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> |
| | |
| | | { |
| | | 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`); |
| | |
| | | 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)) { |
| | |
| | | } |
| | | |
| | | function formatHigherDeptOptions(treeList) { |
| | | // 根据返回数据的status字段值判断追加是否禁用disabled字段,返回处理后的树结构,用于上级部门级联选择器的展示(实际开发中也是如此,不可能前端需要的每个字段后端都会返回,这时需要前端自行根据后端返回的某些字段做逻辑处理) |
| | | // 根据返回数据的status字段值判断追加是否禁用disabled字段,返回处理后的树结构,用于上级项目级联选择器的展示(实际开发中也是如此,不可能前端需要的每个字段后端都会返回,这时需要前端自行根据后端返回的某些字段做逻辑处理) |
| | | if (!treeList || !treeList.length) return; |
| | | const newTreeList = []; |
| | | for (let i = 0; i < treeList.length; i++) { |
| | |
| | | } |
| | | |
| | | function openDialog(title = "新增", row?: FormItemProps) { |
| | | console.log(row,'-'); |
| | | |
| | | console.log(row, "-"); |
| | | |
| | | addDialog({ |
| | | title: `${title}项目`, |
| | | props: { |
| | | formInline: { |
| | | higherDeptOptions: formatHigherDeptOptions(cloneDeep(dataList.value)), |
| | | id: row?.id ?? "", |
| | | projectCode: row?.projectCode ?? "", // 项目编号(必填) |
| | | projectName: row?.projectName ?? "", // 项目名称(必填) |
| | | hangyepinmu: row?.hangyepinmu ?? null, // 行业品目(可选) |
| | |
| | | } else { |
| | | closeLoading(); |
| | | const fail = []; |
| | | console.log(obj); |
| | | |
| | | for (const key in obj) { |
| | | fail.push(obj[key][0].message); |
| | | } |
| | |
| | | state, |
| | | loading, |
| | | columns, |
| | | CGRcolumns, |
| | | dataList, |
| | | selectedNum, |
| | | /** 搜索 */ |
| | | onSearch, |
| | | /** 重置 */ |
| | | resetForm, |
| | | /** 新增、修改部门 */ |
| | | /** 新增、修改项目 */ |
| | | openDialog, |
| | | /** 删除部门 */ |
| | | /** 删除项目 */ |
| | | handleDelete, |
| | | handleSelectionChange, |
| | | handleSizeChange, |
| | | handleCurrentChange, |
| | | pagination, |
| | | checkboxAsRadio |
| | | checkboxAsRadio, |
| | | onSelectionCancel, |
| | | onbatchDel |
| | | }; |
| | | } |