删除
@@ -242,12 +253,16 @@ import {
delMaterialIssue,
addMaterialIssue,
updateMaterialIssue,
+ inventoryList,
getMaterialName
} from '@/api/materials/materialIssue';
import { MaterialIssueVO, MaterialIssueQuery, MaterialIssueForm } from '@/api/materials/materialIssue/types';
import { useUserStoreHook } from '@/store/modules/user';
import wordllssue from './word/index.vue';
+import { watch, onMounted, onUnmounted, ref, reactive, computed, getCurrentInstance } from 'vue';
+import type { ComponentInternalInstance, ElFormInstance, DialogOption } from 'element-plus';
+
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
// 获取用户 store
const userStore = useUserStoreHook();
@@ -265,6 +280,8 @@ const total = ref(0);
const wordllssueRef = ref
>();
const queryFormRef = ref();
const materialIssueFormRef = ref();
+// 存储每个条目的watch停止函数
+const itemWatchStopFns = ref void>>([]);
const dialog = reactive({
visible: false,
@@ -279,7 +296,7 @@ const getInitFormData = () => {
materialSource: '1',
formCode: undefined,
projectName: undefined,
- materialName: undefined,
+ materialName: '', // 初始化为空字符串
orderingUnit: undefined,
supplierUnit: undefined,
issueUnit: undefined,
@@ -302,13 +319,15 @@ const getInitFormData = () => {
stockQuantity: undefined,
issuedQuantity: undefined,
remainingQuantity: undefined,
- name: undefined,
- remark: undefined
+ name: undefined, // 数量验收的名称
+ remark: undefined,
+ materialsId: undefined
}
]
};
};
-const data = reactive>({
+
+const data = reactive({
form: getInitFormData(),
queryParams: {
pageNum: 1,
@@ -326,43 +345,127 @@ const data = reactive>({
params: {}
},
rules: {
- id: [{ required: true, message: '主键id不能为空', trigger: 'blur' }]
+ formCode: [{ required: true, message: '请输入表单编号', trigger: 'blur' }],
+ projectName: [{ required: true, message: '请输入工程名称', trigger: 'blur' }],
+ materialName: [{ required: true, message: '请先在数量验收列表中选择名称', trigger: 'blur' }], // 确保有名称生成
+ orderingUnit: [{ required: true, message: '请输入订货单位', trigger: 'blur' }],
+ supplierUnit: [{ required: true, message: '请输入供货单位', trigger: 'blur' }],
+ issueUnit: [{ required: true, message: '请输入领料单位', trigger: 'blur' }],
+ storageUnit: [{ required: true, message: '请输入保管单位', trigger: 'blur' }]
}
});
const { queryParams, form, rules } = toRefs(data);
+const optionsName: any = ref([]);
+
+/**
+ * 核心函数:从数量验收列表提取名称,用逗号拼接生成设备材料名称
+ */
+const computeMaterialName = () => {
+ if (!form.value.itemList || form.value.itemList.length === 0) {
+ form.value.materialName = '';
+ return;
+ }
+ // 过滤空名称,去重(可选,根据业务需求决定是否去重)
+ const validNames = form.value.itemList
+ .filter((item) => item.name && item.name.trim() !== '')
+ .map((item) => item.name.trim())
+ .filter((name, index, self) => self.indexOf(name) === index); // 去重(如需保留重复则删除这行)
+
+ form.value.materialName = validNames.join(',');
+};
/** 查询物料领料单列表 */
const getList = async () => {
loading.value = true;
- const res = await listMaterialIssue(queryParams.value);
- materialIssueList.value = res.rows;
- total.value = res.total;
- loading.value = false;
-};
-const optionsName: any = ref([]);
-
-//获取一起名称
-const getName = async () => {
- const res = await getMaterialName(currentProject.value.id);
- console.log(res);
- if (res.code == 200) {
- optionsName.value = res.data;
+ try {
+ const res = await listMaterialIssue(queryParams.value);
+ materialIssueList.value = res.rows;
+ total.value = res.total;
+ } finally {
+ loading.value = false;
}
};
+// 获取材料名称列表
+const getName = async () => {
+ try {
+ const res = await inventoryList(currentProject.value.id);
+ console.log(res);
+
+ if (res.code == 200) {
+ optionsName.value = res.data;
+ }
+ } catch (error) {
+ proxy?.$modal.msgError('获取材料名称失败');
+ }
+};
+
+// 材料名称选择变化处理(修改select的value为名称,而非ID)
const getNameChange = (value, index, item) => {
- // 这里可以添加处理逻辑
- console.log(value);
+ const selected = optionsName.value.find((opt) => opt.id === value);
+ if (selected) {
+ item.name = selected.materialsName; // 直接赋值名称
+ item.materialsId = selected.id; // 保留ID用于后端
+ item.specification = selected.typeSpecificationName;
+ item.unit = selected.weightId;
+ item.issuedQuantity = selected.number;
+ item.stockQuantity = Number(selected.inventoryNumber) || 0;
+ // calculateRemaining(index); // 计算剩余数量
+ }
+};
- const data = optionsName.value.find((item) => item.id == value);
- console.log(data);
+/** 验证领取数量不能超过库存 */
+const validateIssuedQuantity = (rule, value, callback, index) => {
+ const item = form.value.itemList[index];
+ const stock = Number(item.stockQuantity) || 0;
+ const issued = Number(value) || 0;
- form.value.itemList[index].name = data.materialsName;
- form.value.itemList[index].materialsId = data.id;
- form.value.itemList[index].specification = data.typeSpecificationName;
- form.value.itemList[index].unit = data.weightId;
- form.value.itemList[index].stockQuantity = data.inventoryNumber;
+ if (stock === 0) {
+ callback();
+ return;
+ }
+
+ if (issued > stock) {
+ callback(new Error(`领取数量不能超过库存(${stock})`));
+ } else {
+ callback();
+ }
+};
+
+/** 计算剩余数量(库存 - 领取数量) */
+const calculateRemaining = (index: number) => {
+ const item = form.value.itemList[index];
+ const stock = Number(item.stockQuantity) || 0;
+ const issued = Number(item.issuedQuantity) || 0;
+
+ // 确保领取数量不超过库存
+ if (issued > stock) {
+ item.issuedQuantity = stock;
+ proxy?.$modal.msgWarning(`领取数量不能超过库存(${stock}),已自动调整`);
+ }
+
+ // 计算剩余数量
+ item.remainingQuantity = stock - (item.issuedQuantity || 0);
+};
+
+/** 库存变化时重新计算剩余数量 */
+const handleStockChange = (index: number) => {
+ calculateRemaining(index);
+ // 触发验证
+ if (materialIssueFormRef.value) {
+ materialIssueFormRef.value.validateField(`itemList.${index}.issuedQuantity`);
+ materialIssueFormRef.value.validateField(`itemList.${index}.remainingQuantity`);
+ }
+};
+
+/** 领取数量变化时重新计算剩余数量 */
+const handleIssuedChange = (index: number) => {
+ calculateRemaining(index);
+ // 触发验证
+ if (materialIssueFormRef.value) {
+ materialIssueFormRef.value.validateField(`itemList.${index}.remainingQuantity`);
+ }
};
/** 取消按钮 */
@@ -373,8 +476,38 @@ const cancel = () => {
/** 表单重置 */
const reset = () => {
+ // 停止所有监听
+ itemWatchStopFns.value.forEach((stop) => stop());
+ itemWatchStopFns.value = [];
+
form.value = getInitFormData();
materialIssueFormRef.value?.resetFields();
+
+ // 重新监听初始条目
+ if (form.value.itemList.length > 0) {
+ watchItemChanges(0);
+ }
+ // 初始计算一次材料名称
+ computeMaterialName();
+};
+
+/** 监听条目变化,自动计算剩余数量 */
+const watchItemChanges = (index: number) => {
+ // 停止已有监听
+ if (itemWatchStopFns.value[index]) {
+ itemWatchStopFns.value[index]();
+ }
+
+ // // 监听库存和领取数量变化
+ // const stop = watch(
+ // () => [form.value.itemList[index].stockQuantity, form.value.itemList[index].issuedQuantity],
+ // () => {
+ // calculateRemaining(index);
+ // },
+ // { immediate: true }
+ // );
+
+ itemWatchStopFns.value[index] = stop;
};
/** 搜索按钮操作 */
@@ -401,16 +534,58 @@ const handleAdd = () => {
reset();
dialog.visible = true;
dialog.title = '添加物料领料单';
+ // 新增时初始计算材料名称
+ computeMaterialName();
};
/** 修改按钮操作 */
const handleUpdate = async (row?: MaterialIssueVO) => {
reset();
const _id = row?.id || ids.value[0];
- const res = await getMaterialIssue(_id);
- Object.assign(form.value, res.data);
- dialog.visible = true;
- dialog.title = '修改物料领料单';
+ try {
+ const res = await getMaterialIssue(_id);
+ Object.assign(form.value, res.data);
+
+ // 确保itemList存在且格式正确
+ if (!form.value.itemList) {
+ form.value.itemList = [];
+ }
+
+ // 转换数据类型并计算剩余数量
+ form.value.itemList = form.value.itemList.map((item) => ({
+ ...item,
+ stockQuantity: Number(item.stockQuantity) || 0,
+ issuedQuantity: Number(item.issuedQuantity) || 0,
+ remainingQuantity: Number(item.remainingQuantity) || 0,
+ name: item.name || '' // 确保名称不为undefined
+ }));
+
+ // 为每个条目添加监听并强制计算剩余数量
+ form.value.itemList.forEach((_, index) => {
+ watchItemChanges(index);
+ calculateRemaining(index);
+ });
+
+ // 关键:编辑时从itemList重新计算设备材料名称(覆盖后端返回的旧值)
+ computeMaterialName();
+
+ // 手动触发一次验证
+ setTimeout(() => {
+ if (materialIssueFormRef.value) {
+ form.value.itemList.forEach((_, index) => {
+ materialIssueFormRef.value.validateField(`itemList.${index}.issuedQuantity`);
+ materialIssueFormRef.value.validateField(`itemList.${index}.remainingQuantity`);
+ });
+ // 验证设备材料名称
+ materialIssueFormRef.value.validateField('materialName');
+ }
+ }, 0);
+
+ dialog.visible = true;
+ dialog.title = '修改物料领料单';
+ } catch (error) {
+ proxy?.$modal.msgError('获取详情失败');
+ }
};
/** 提交按钮 */
@@ -418,21 +593,38 @@ const submitForm = () => {
materialIssueFormRef.value?.validate(async (valid: boolean) => {
if (valid) {
buttonLoading.value = true;
- if (form.value.id) {
- await updateMaterialIssue(form.value).finally(() => (buttonLoading.value = false));
- } else {
- await addMaterialIssue(form.value).finally(() => (buttonLoading.value = false));
+ try {
+ // 处理提交数据,确保数量为数字类型
+ const submitData = {
+ ...form.value,
+ itemList: form.value.itemList.map((item) => ({
+ ...item,
+ stockQuantity: Number(item.stockQuantity),
+ issuedQuantity: Number(item.issuedQuantity),
+ remainingQuantity: Number(item.remainingQuantity)
+ }))
+ };
+
+ if (form.value.id) {
+ await updateMaterialIssue(submitData);
+ } else {
+ await addMaterialIssue(submitData);
+ }
+ proxy?.$modal.msgSuccess('操作成功');
+ dialog.visible = false;
+ await getList();
+ } catch (error) {
+ proxy?.$modal.msgError('操作失败');
+ } finally {
+ buttonLoading.value = false;
}
- proxy?.$modal.msgSuccess('操作成功');
- dialog.visible = false;
- await getList();
}
});
};
// 添加数量验收条目
const addItem = () => {
- form.value.itemList.push({
+ const newItem = {
id: undefined,
specification: undefined,
unit: undefined,
@@ -440,46 +632,81 @@ const addItem = () => {
issuedQuantity: undefined,
remainingQuantity: undefined,
name: undefined,
- remark: undefined
- });
+ remark: undefined,
+ materialsId: undefined
+ };
+ form.value.itemList.push(newItem);
+ // 监听新条目
+ watchItemChanges(form.value.itemList.length - 1);
+ // 添加后重新计算材料名称
+ computeMaterialName();
};
// 删除数量验收条目
const removeItem = (index: number) => {
if (form.value.itemList.length > 1) {
+ // 停止该条目的监听
+ if (itemWatchStopFns.value[index]) {
+ itemWatchStopFns.value[index]();
+ }
form.value.itemList.splice(index, 1);
+ itemWatchStopFns.value.splice(index, 1);
+ // 删除后重新计算材料名称
+ computeMaterialName();
} else {
proxy?.$modal.msgWarning('至少需要保留一条数量验收记录');
}
};
+
/** 删除按钮操作 */
const handleDelete = async (row?: MaterialIssueVO) => {
const _ids = row?.id || ids.value;
- await proxy?.$modal.confirm('是否确认删除物料领料单编号为"' + _ids + '"的数据项?').finally(() => (loading.value = false));
- await delMaterialIssue(_ids);
- proxy?.$modal.msgSuccess('删除成功');
- await getList();
+ try {
+ await proxy?.$modal.confirm(`是否确认删除物料领料单编号为"${_ids}"的数据项?`);
+ await delMaterialIssue(_ids);
+ proxy?.$modal.msgSuccess('删除成功');
+ await getList();
+ } catch (error) {
+ // 取消删除不提示
+ } finally {
+ loading.value = false;
+ }
};
+
const handleView = (row) => {
// 查看详情
wordllssueRef.value?.openDialog(row);
};
+
+// 关键:监听数量验收列表变化,实时更新设备材料名称
+watch(
+ () => form.value.itemList,
+ () => {
+ computeMaterialName();
+ },
+ { deep: true, immediate: true } // deep监听数组内部变化,immediate初始执行
+);
+
onMounted(() => {
getList();
getName();
});
-//监听项目id刷新数据
+
+// 监听项目id刷新数据
const listeningProject = watch(
() => currentProject.value?.id,
- (nid, oid) => {
+ (nid) => {
queryParams.value.projectId = nid;
form.value.projectId = nid;
getList();
+ getName();
}
);
onUnmounted(() => {
listeningProject();
+ // 清理所有监听
+ itemWatchStopFns.value.forEach((stop) => stop());
});
diff --git a/src/views/system/dept/index.vue b/src/views/system/dept/index.vue
index c9d9247..e8c763e 100644
--- a/src/views/system/dept/index.vue
+++ b/src/views/system/dept/index.vue
@@ -1,7 +1,6 @@
-
+
@@ -9,13 +8,11 @@
-
+
-
+
@@ -31,8 +28,7 @@
- 新增
-
+ 新增
展开/折叠
@@ -41,8 +37,14 @@
-
+
@@ -64,16 +66,13 @@
-
+
-
-
+
+
-
+
@@ -85,9 +84,14 @@
-
+
@@ -108,8 +112,7 @@
-
+
@@ -126,32 +129,17 @@
- {{ dict.label
- }}
+ {{ dict.label }}
-
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
@@ -336,16 +324,6 @@ const handleUpdate = async (row: DeptVO) => {
dialog.title = '修改部门';
};
-const changeProject = async (val: any) => {
- if (val == '4' && (!projectList.value || !projectList.value.length)) {
- const res = await getDeptList();
- projectList.value = res.data;
- } else if (val == '5' && (!contractorList.value || !contractorList.value.length)) {
- const res = await optionProjectSelect(form.value.rowProjectId);
- contractorList.value = res;
- }
-};
-
/** 提交按钮 */
const submitForm = () => {
deptFormRef.value?.validate(async (valid: boolean) => {
diff --git a/src/views/system/user/index.vue b/src/views/system/user/index.vue
index 4eb7e57..da397cf 100644
--- a/src/views/system/user/index.vue
+++ b/src/views/system/user/index.vue
@@ -174,8 +174,6 @@
/>
-
-
@@ -186,8 +184,6 @@
-
-
@@ -198,8 +194,6 @@
-
-
@@ -207,15 +201,6 @@
-
-
-
- {{ dict.label }}
-
-
-
-
-
@@ -229,21 +214,41 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
+
+
+ {{ dict.label }}
+
-
-
@@ -317,8 +322,9 @@ import { RoleVO } from '@/api/system/role/types';
import { PostVO } from '@/api/system/post/types';
import { globalHeaders } from '@/utils/request';
import { to } from 'await-to-js';
-import { getRoleList, optionselect } from '@/api/system/post';
+import { getProjectByDeptId, getRoleList, optionselect } from '@/api/system/post';
import ShuttleFrame from '../../project/projectRelevancy/component/ShuttleFrame.vue';
+import { listProject } from '@/api/project/project';
const router = useRouter();
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
@@ -337,6 +343,8 @@ const enabledDeptOptions = ref([]);
const initPassword = ref('');
const postOptions = ref([]);
const roleOptions = ref([]);
+const projectOptions = ref([]);
+
/*** 用户导入参数 */
const upload = reactive({
// 是否显示弹出层(用户导入)
@@ -383,10 +391,15 @@ const initFormData: UserForm = {
phonenumber: undefined,
email: undefined,
sex: undefined,
+ projectRoles: [
+ {
+ projectId: '',
+ roleIds: []
+ }
+ ],
status: '0',
remark: '',
postIds: [],
- roleIds: [],
filePath: undefined
};
@@ -436,8 +449,7 @@ const initData: PageData = {
message: '请输入正确的手机号码',
trigger: 'blur'
}
- ],
- roleIds: [{ required: true, message: '用户角色不能为空', trigger: 'blur' }]
+ ]
}
};
const data = reactive>(initData);
@@ -473,6 +485,8 @@ const getDeptTree = async () => {
const res = await api.deptTreeSelect({ isShow: '1' });
deptOptions.value = res.data;
enabledDeptOptions.value = filterDisabledDept(res.data);
+ const projectList = await listProject();
+ projectOptions.value = projectList.rows;
};
/** 过滤禁用的部门 */
@@ -494,6 +508,19 @@ const handleNodeClick = (data: DeptVO) => {
handleQuery();
};
+/** 部门选择变化 */
+const handleAddProject = () => {
+ form.value.projectRoles.push({
+ projectId: '',
+ roleIds: []
+ });
+};
+
+/** 删除项目 */
+const delProject = (index: number) => {
+ form.value.projectRoles.splice(index, 1);
+};
+
/** 搜索按钮操作 */
const handleQuery = () => {
queryParams.value.pageNum = 1;
@@ -609,6 +636,13 @@ function submitFileForm() {
/** 重置操作表单 */
const reset = () => {
form.value = { ...initFormData };
+ form.value.projectRoles = [
+ {
+ projectId: '',
+ roleIds: []
+ }
+ ];
+
userFormRef.value?.resetFields();
};
/** 取消按钮 */
@@ -638,12 +672,32 @@ const handleUpdate = async (row?: UserForm) => {
postOptions.value = data.posts;
roleOptions.value = data.roles;
form.value.postIds = data.postIds;
- form.value.roleIds = data.user.roleIds;
+ form.value.projectRoles = data.projectRoles;
form.value.password = '';
+ const roleList = await getRoleList(form.value.deptId);
+
+ roleOptions.value = roleList.data;
+};
+
+const validate = () => {
+ for (let i = 0; i < form.value.projectRoles.length; i++) {
+ const item = form.value.projectRoles[i];
+ if (!item.projectId || item.projectId.length === 0) {
+ proxy?.$modal.msgError(`第 ${i + 1} 行“项目列表”未填写`);
+ return false; // 阻止提交
+ }
+ if (!item.roleIds || item.roleIds.length === 0) {
+ proxy?.$modal.msgError(`第 ${i + 1} 行“角色”未填写`);
+ return false; // 阻止提交
+ }
+ }
+ return true;
};
/** 提交按钮 */
const submitForm = () => {
+ const isValid = validate();
+ if (!isValid) return;
userFormRef.value?.validate(async (valid: boolean) => {
if (valid) {
form.value.userId ? await api.updateUser(form.value) : await api.addUser(form.value);
@@ -683,10 +737,16 @@ onMounted(() => {
async function handleDeptChange(value: number | string) {
const response = await optionselect(value);
const roleList = await getRoleList(value);
+
roleOptions.value = roleList.data;
postOptions.value = response.data;
form.value.postIds = [];
- form.value.roleIds = [];
+ form.value.projectRoles = [
+ {
+ projectId: [],
+ roleIds: []
+ }
+ ];
}
const shuttleVisible = ref(false);
diff --git a/src/views/tender/bidd/index.vue b/src/views/tender/bidd/index.vue
index f06a0c7..27afe21 100644
--- a/src/views/tender/bidd/index.vue
+++ b/src/views/tender/bidd/index.vue
@@ -15,12 +15,14 @@
+
一键展开
一键收起
+
审核
- 查看流程
@@ -58,12 +65,21 @@
-
+
+
+ {{ scope.row.children.length > 0 ? '' : scope.row.quantity }}
+
+
(scope.row.unitPrice = val)"
+ @change="
+ (val) => {
+ scope.row.unitPrice = val;
+ changePrice(scope.row);
+ }
+ "
:precision="2"
:step="0.1"
:controls="false"
@@ -82,7 +98,7 @@
{
activeTab.value = tab;
+ tableData.value = [];
+ versionsData.value = {};
getVersionNums();
};
//切换版本
@@ -205,6 +223,8 @@ const getSheetName = async () => {
//获取表格数据
const getTableData = async () => {
try {
+ loading.value = true;
+
const params = {
projectId: currentProject.value?.id,
versions: queryForm.value.versions,
@@ -217,6 +237,8 @@ const getTableData = async () => {
}
} catch (error) {
console.log(error);
+ } finally {
+ loading.value = false;
}
};
//导入
@@ -257,29 +279,51 @@ const handleExport = () => {
`招标一览表${queryForm.value.sheet}.xlsx`
);
};
-//确认修改
-const handleSave = (row: any) => {
+const modifyPrice = new Map();
+
+const changePrice = (row: any) => {
+ modifyPrice.set(row.id, row);
+ // if (!row.unitPrice) {
+ // modifyPrice.delete(row.id);
+ // }
+};
+//修改单价
+const handleSave = (row?: any, type?: any) => {
try {
- if (!row.unitPrice) {
- ElMessage({
- message: '请输入单价',
- type: 'warning'
+ if (type == 'single') {
+ loading.value = true;
+ const list = [{ ...row, type: activeTab.value }];
+ updatePrice(list).then((res) => {
+ if (res.code == 200) {
+ ElMessage({
+ message: '修改成功',
+ type: 'success'
+ });
+ getTableData();
+ }
+ });
+ }
+ if (type == 'all') {
+ loading.value = true;
+ const list = [];
+ modifyPrice.forEach((item) => {
+ list.push({ ...item, type: activeTab.value });
+ });
+ updatePrice(list).then((res) => {
+ if (res.code == 200) {
+ ElMessage({
+ message: '修改成功',
+ type: 'success'
+ });
+ getTableData();
+ }
});
- return;
}
- loading.value = true;
- updatePrice(row).then((res) => {
- if (res.code == 200) {
- ElMessage({
- message: '修改成功',
- type: 'success'
- });
- getTableData();
- }
- });
} catch (error) {
- console.log(error);
- loading.value = false;
+ ElMessage({
+ message: '修改失败',
+ type: 'error'
+ });
} finally {
loading.value = false;
}
diff --git a/src/views/tender/plan/comm/planPage.vue b/src/views/tender/plan/comm/planPage.vue
index b4b156c..4562ebc 100644
--- a/src/views/tender/plan/comm/planPage.vue
+++ b/src/views/tender/plan/comm/planPage.vue
@@ -1,245 +1,78 @@
-
-
-
-
-
-
-
-
-
-
- {{ isExpandAll ? '一键收起' : '一键展开' }}
-
-
-
-
- 导入excel
-
-
-
-
- 导出excel
-
-
-
-
-
-
-
-
-
-
-
-
- (scope.row.unitPrice = val)"
- :precision="2"
- :step="0.1"
- :controls="false"
- v-if="scope.row.quantity && scope.row.quantity != 0"
- />
-
-
-
-
- {{ scope.row.price }}
-
-
-
-
- 修改
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
-
+
diff --git a/src/views/tender/plan/comm/winTheBid.vue b/src/views/tender/plan/comm/winTheBid.vue
new file mode 100644
index 0000000..f0056d8
--- /dev/null
+++ b/src/views/tender/plan/comm/winTheBid.vue
@@ -0,0 +1,99 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/tender/plan/index.vue b/src/views/tender/plan/index.vue
index 8265b8c..dfc29b3 100644
--- a/src/views/tender/plan/index.vue
+++ b/src/views/tender/plan/index.vue
@@ -189,7 +189,8 @@
-
+
+
-
-
+
+
+
+
+
+ {{
+ ((scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0)) *
+ Number(scope.row.unitPrice) ==
+ 0
+ ? ''
+ : (
+ ((scope.row.quantity ? Number(scope.row.quantity) : 0) - (scope.row.useQuantity ? Number(scope.row.useQuantity) : 0)) *
+ Number(scope.row.unitPrice)
+ ).toFixed(2)
+ }}
+
+
@@ -266,6 +287,9 @@ import { useUserStoreHook } from '@/store/modules/user';
import { getDicts } from '@/api/system/dict/data';
import { Plus } from '@element-plus/icons-vue';
import { FormInstance } from 'element-plus';
+import winTheBid from './comm/winTheBid.vue';
+import information from './comm/planPage.vue';
+
import {
sheetList,
tenderPlanList,
@@ -279,7 +303,6 @@ import {
delBiddView,
editStatus
} from '@/api/tender/index';
-import { it } from 'element-plus/es/locale/index.mjs';
const userStore = useUserStoreHook();
const currentProject = computed(() => userStore.selectedProject);
diff --git a/src/views/tender/supplierInput/index.vue b/src/views/tender/supplierInput/index.vue
index bbebc86..680aaf1 100644
--- a/src/views/tender/supplierInput/index.vue
+++ b/src/views/tender/supplierInput/index.vue
@@ -275,6 +275,7 @@
+ * 入库资料
-
+
diff --git a/vite.config.ts.timestamp-1756395377501-e6f009967ecc8.mjs b/vite.config.ts.timestamp-1756395377501-e6f009967ecc8.mjs
new file mode 100644
index 0000000..ec49d52
--- /dev/null
+++ b/vite.config.ts.timestamp-1756395377501-e6f009967ecc8.mjs
@@ -0,0 +1,230 @@
+// vite.config.ts
+import { loadEnv, defineConfig } from "file:///E:/XNY/new-project/node_modules/vite/dist/node/index.js";
+
+// vite/plugins/index.ts
+import vue from "file:///E:/XNY/new-project/node_modules/@vitejs/plugin-vue/dist/index.mjs";
+
+// vite/plugins/unocss.ts
+import UnoCss from "file:///E:/XNY/new-project/node_modules/unocss/dist/vite.mjs";
+var unocss_default = () => {
+ return UnoCss({
+ hmrTopLevelAwait: false
+ // unocss默认是true,低版本浏览器是不支持的,启动后会报错
+ });
+};
+
+// vite/plugins/auto-import.ts
+import AutoImport from "file:///E:/XNY/new-project/node_modules/unplugin-auto-import/dist/vite.js";
+import { ElementPlusResolver } from "file:///E:/XNY/new-project/node_modules/unplugin-vue-components/dist/resolvers.js";
+import IconsResolver from "file:///E:/XNY/new-project/node_modules/unplugin-icons/dist/resolver.js";
+var __vite_injected_original_dirname = "E:\\XNY\\new-project\\vite\\plugins";
+var auto_import_default = (path3) => {
+ return AutoImport({
+ // 自动导入 Vue 相关函数
+ imports: ["vue", "vue-router", "@vueuse/core", "pinia"],
+ eslintrc: {
+ enabled: false,
+ filepath: "./.eslintrc-auto-import.json",
+ globalsPropValue: true
+ },
+ resolvers: [
+ // 自动导入 Element Plus 相关函数ElMessage, ElMessageBox... (带样式)
+ ElementPlusResolver(),
+ IconsResolver({
+ prefix: "Icon"
+ })
+ ],
+ vueTemplate: true,
+ // 是否在 vue 模板中自动导入
+ dts: path3.resolve(path3.resolve(__vite_injected_original_dirname, "../../src"), "types", "auto-imports.d.ts")
+ });
+};
+
+// vite/plugins/components.ts
+import Components from "file:///E:/XNY/new-project/node_modules/unplugin-vue-components/dist/vite.js";
+import { ElementPlusResolver as ElementPlusResolver2 } from "file:///E:/XNY/new-project/node_modules/unplugin-vue-components/dist/resolvers.js";
+import IconsResolver2 from "file:///E:/XNY/new-project/node_modules/unplugin-icons/dist/resolver.js";
+var __vite_injected_original_dirname2 = "E:\\XNY\\new-project\\vite\\plugins";
+var components_default = (path3) => {
+ return Components({
+ resolvers: [
+ // 自动导入 Element Plus 组件
+ ElementPlusResolver2(),
+ // 自动注册图标组件
+ IconsResolver2({
+ enabledCollections: ["ep"]
+ })
+ ],
+ dts: path3.resolve(path3.resolve(__vite_injected_original_dirname2, "../../src"), "types", "components.d.ts")
+ });
+};
+
+// vite/plugins/icons.ts
+import Icons from "file:///E:/XNY/new-project/node_modules/unplugin-icons/dist/vite.js";
+var icons_default = () => {
+ return Icons({
+ // 自动安装图标库
+ autoInstall: true
+ });
+};
+
+// vite/plugins/svg-icon.ts
+import { createSvgIconsPlugin } from "file:///E:/XNY/new-project/node_modules/vite-plugin-svg-icons/dist/index.mjs";
+var __vite_injected_original_dirname3 = "E:\\XNY\\new-project\\vite\\plugins";
+var svg_icon_default = (path3, isBuild) => {
+ return createSvgIconsPlugin({
+ // 指定需要缓存的图标文件夹
+ iconDirs: [path3.resolve(path3.resolve(__vite_injected_original_dirname3, "../../src"), "assets/icons/svg")],
+ // 指定symbolId格式
+ symbolId: "icon-[dir]-[name]",
+ svgoOptions: isBuild
+ });
+};
+
+// vite/plugins/compression.ts
+import compression from "file:///E:/XNY/new-project/node_modules/vite-plugin-compression/dist/index.mjs";
+var compression_default = (env) => {
+ const { VITE_BUILD_COMPRESS } = env;
+ const plugin = [];
+ if (VITE_BUILD_COMPRESS) {
+ const compressList = VITE_BUILD_COMPRESS.split(",");
+ if (compressList.includes("gzip")) {
+ plugin.push(
+ compression({
+ ext: ".gz",
+ deleteOriginFile: false
+ })
+ );
+ }
+ if (compressList.includes("brotli")) {
+ plugin.push(
+ compression({
+ ext: ".br",
+ algorithm: "brotliCompress",
+ deleteOriginFile: false
+ })
+ );
+ }
+ }
+ return plugin;
+};
+
+// vite/plugins/setup-extend.ts
+import setupExtend from "file:///E:/XNY/new-project/node_modules/unplugin-vue-setup-extend-plus/dist/vite.js";
+var setup_extend_default = () => {
+ return setupExtend({});
+};
+
+// vite/plugins/index.ts
+import path from "path";
+var plugins_default = (viteEnv, isBuild = false) => {
+ const vitePlugins = [];
+ vitePlugins.push(vue());
+ vitePlugins.push(unocss_default());
+ vitePlugins.push(auto_import_default(path));
+ vitePlugins.push(components_default(path));
+ vitePlugins.push(compression_default(viteEnv));
+ vitePlugins.push(icons_default());
+ vitePlugins.push(svg_icon_default(path, isBuild));
+ vitePlugins.push(setup_extend_default());
+ return vitePlugins;
+};
+
+// vite.config.ts
+import path2 from "path";
+var __vite_injected_original_dirname4 = "E:\\XNY\\new-project";
+var vite_config_default = defineConfig(({ mode, command }) => {
+ const env = loadEnv(mode, process.cwd());
+ return {
+ // 部署生产环境和开发环境下的URL。
+ // 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上
+ // 例如 https://www.ruoyi.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.ruoyi.vip/admin/,则设置 baseUrl 为 /admin/。
+ base: env.VITE_APP_CONTEXT_PATH,
+ resolve: {
+ alias: {
+ "~": path2.resolve(__vite_injected_original_dirname4, "./"),
+ "@": path2.resolve(__vite_injected_original_dirname4, "./src")
+ },
+ extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json", ".vue", ".tif"]
+ },
+ // https://cn.vitejs.dev/config/#resolve-extensions
+ plugins: plugins_default(env, command === "build"),
+ server: {
+ host: "0.0.0.0",
+ port: Number(env.VITE_APP_PORT),
+ open: true,
+ proxy: {
+ [env.VITE_APP_BASE_API]: {
+ target: "http://localhost:8899",
+ changeOrigin: true,
+ ws: true,
+ rewrite: (path3) => path3.replace(new RegExp("^" + env.VITE_APP_BASE_API), "")
+ },
+ "/warm-flow-ui": {
+ target: env.VITE_APP_BASE_API,
+ changeOrigin: true,
+ ws: true,
+ rewrite: (path3) => path3.replace(new RegExp("^" + env.VITE_APP_BASE_API), "")
+ },
+ "/warm-flow": {
+ target: env.VITE_APP_BASE_API,
+ changeOrigin: true,
+ ws: true,
+ rewrite: (path3) => path3.replace(new RegExp("^" + env.VITE_APP_BASE_API), "")
+ },
+ "/workflow": {
+ target: env.VITE_APP_BASE_API,
+ changeOrigin: true,
+ ws: true,
+ rewrite: (path3) => path3.replace(new RegExp("^" + env.VITE_APP_BASE_API), "")
+ },
+ "/auth": {
+ target: env.VITE_APP_BASE_API,
+ changeOrigin: true,
+ ws: true,
+ rewrite: (path3) => path3.replace(new RegExp("^" + env.VITE_APP_BASE_API), "")
+ }
+ }
+ },
+ css: {
+ preprocessorOptions: {
+ scss: {
+ javascriptEnabled: true
+ }
+ },
+ postcss: {
+ plugins: [
+ {
+ postcssPlugin: "internal:charset-removal",
+ AtRule: {
+ charset: (atRule) => {
+ if (atRule.name === "charset") {
+ atRule.remove();
+ }
+ }
+ }
+ }
+ ]
+ }
+ },
+ // 预编译
+ optimizeDeps: {
+ include: [
+ "vue",
+ "vue-router",
+ "pinia",
+ "axios",
+ "@vueuse/core",
+ "echarts",
+ "vue-i18n",
+ "@vueup/vue-quill",
+ "image-conversion",
+ "element-plus/es/components/**/css"
+ ]
+ }
+ };
+});
+export {
+ vite_config_default as default
+};
+//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.ts", "vite/plugins/index.ts", "vite/plugins/unocss.ts", "vite/plugins/auto-import.ts", "vite/plugins/components.ts", "vite/plugins/icons.ts", "vite/plugins/svg-icon.ts", "vite/plugins/compression.ts", "vite/plugins/setup-extend.ts"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite.config.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite.config.ts\";import { UserConfig, ConfigEnv, loadEnv, defineConfig } from 'vite';\r\n\r\nimport createPlugins from './vite/plugins';\r\n\r\nimport path from 'path';\r\nexport default defineConfig(({ mode, command }: ConfigEnv): UserConfig => {\r\n  const env = loadEnv(mode, process.cwd());\r\n  return {\r\n    // \u90E8\u7F72\u751F\u4EA7\u73AF\u5883\u548C\u5F00\u53D1\u73AF\u5883\u4E0B\u7684URL\u3002\r\n    // \u9ED8\u8BA4\u60C5\u51B5\u4E0B\uFF0Cvite \u4F1A\u5047\u8BBE\u4F60\u7684\u5E94\u7528\u662F\u88AB\u90E8\u7F72\u5728\u4E00\u4E2A\u57DF\u540D\u7684\u6839\u8DEF\u5F84\u4E0A\r\n    // \u4F8B\u5982 https://www.ruoyi.vip/\u3002\u5982\u679C\u5E94\u7528\u88AB\u90E8\u7F72\u5728\u4E00\u4E2A\u5B50\u8DEF\u5F84\u4E0A\uFF0C\u4F60\u5C31\u9700\u8981\u7528\u8FD9\u4E2A\u9009\u9879\u6307\u5B9A\u8FD9\u4E2A\u5B50\u8DEF\u5F84\u3002\u4F8B\u5982\uFF0C\u5982\u679C\u4F60\u7684\u5E94\u7528\u88AB\u90E8\u7F72\u5728 https://www.ruoyi.vip/admin/\uFF0C\u5219\u8BBE\u7F6E baseUrl \u4E3A /admin/\u3002\r\n    base: env.VITE_APP_CONTEXT_PATH,\r\n    resolve: {\r\n      alias: {\r\n        '~': path.resolve(__dirname, './'),\r\n        '@': path.resolve(__dirname, './src')\r\n      },\r\n      extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue', '.tif']\r\n    },\r\n    // https://cn.vitejs.dev/config/#resolve-extensions\r\n    plugins: createPlugins(env, command === 'build'),\r\n    server: {\r\n      host: '0.0.0.0',\r\n      port: Number(env.VITE_APP_PORT),\r\n      open: true,\r\n      proxy: {\r\n        [env.VITE_APP_BASE_API]: {\r\n          target: 'http://localhost:8899',\r\n          changeOrigin: true,\r\n          ws: true,\r\n          rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')\r\n        },\r\n        '/warm-flow-ui': {\r\n          target: env.VITE_APP_BASE_API,\r\n          changeOrigin: true,\r\n          ws: true,\r\n          rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')\r\n        },\r\n        '/warm-flow': {\r\n          target: env.VITE_APP_BASE_API,\r\n          changeOrigin: true,\r\n          ws: true,\r\n          rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')\r\n        },\r\n        '/workflow': {\r\n          target: env.VITE_APP_BASE_API,\r\n          changeOrigin: true,\r\n          ws: true,\r\n          rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')\r\n        },\r\n         '/auth': {\r\n          target: env.VITE_APP_BASE_API,\r\n          changeOrigin: true,\r\n          ws: true,\r\n          rewrite: (path) => path.replace(new RegExp('^' + env.VITE_APP_BASE_API), '')\r\n        }\r\n      }\r\n    },\r\n    css: {\r\n      preprocessorOptions: {\r\n        scss: {\r\n          javascriptEnabled: true\r\n        }\r\n      },\r\n      postcss: {\r\n        plugins: [\r\n          {\r\n            postcssPlugin: 'internal:charset-removal',\r\n            AtRule: {\r\n              charset: (atRule) => {\r\n                if (atRule.name === 'charset') {\r\n                  atRule.remove();\r\n                }\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    // \u9884\u7F16\u8BD1\r\n    optimizeDeps: {\r\n      include: [\r\n        'vue',\r\n        'vue-router',\r\n        'pinia',\r\n        'axios',\r\n        '@vueuse/core',\r\n        'echarts',\r\n        'vue-i18n',\r\n        '@vueup/vue-quill',\r\n        'image-conversion',\r\n        'element-plus/es/components/**/css'\r\n      ]\r\n    }\r\n  };\r\n});\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\index.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/index.ts\";import vue from '@vitejs/plugin-vue';\r\nimport createUnoCss from './unocss';\r\nimport createAutoImport from './auto-import';\r\nimport createComponents from './components';\r\nimport createIcons from './icons';\r\nimport createSvgIconsPlugin from './svg-icon';\r\nimport createCompression from './compression';\r\nimport createSetupExtend from './setup-extend';\r\nimport path from 'path';\r\n\r\nexport default (viteEnv: any, isBuild = false): [] => {\r\n  const vitePlugins: any = [];\r\n  vitePlugins.push(vue());\r\n  vitePlugins.push(createUnoCss());\r\n  vitePlugins.push(createAutoImport(path));\r\n  vitePlugins.push(createComponents(path));\r\n  vitePlugins.push(createCompression(viteEnv));\r\n  vitePlugins.push(createIcons());\r\n  vitePlugins.push(createSvgIconsPlugin(path, isBuild));\r\n  vitePlugins.push(createSetupExtend());\r\n  return vitePlugins;\r\n};\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\unocss.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/unocss.ts\";import UnoCss from 'unocss/vite';\r\n\r\nexport default () => {\r\n  return UnoCss({\r\n    hmrTopLevelAwait: false // unocss\u9ED8\u8BA4\u662Ftrue\uFF0C\u4F4E\u7248\u672C\u6D4F\u89C8\u5668\u662F\u4E0D\u652F\u6301\u7684\uFF0C\u542F\u52A8\u540E\u4F1A\u62A5\u9519\r\n  });\r\n};\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\auto-import.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/auto-import.ts\";import AutoImport from 'unplugin-auto-import/vite';\r\nimport { ElementPlusResolver } from 'unplugin-vue-components/resolvers';\r\nimport IconsResolver from 'unplugin-icons/resolver';\r\n\r\nexport default (path: any) => {\r\n  return AutoImport({\r\n    // \u81EA\u52A8\u5BFC\u5165 Vue \u76F8\u5173\u51FD\u6570\r\n    imports: ['vue', 'vue-router', '@vueuse/core', 'pinia'],\r\n    eslintrc: {\r\n      enabled: false,\r\n      filepath: './.eslintrc-auto-import.json',\r\n      globalsPropValue: true\r\n    },\r\n    resolvers: [\r\n      // \u81EA\u52A8\u5BFC\u5165 Element Plus \u76F8\u5173\u51FD\u6570ElMessage, ElMessageBox... (\u5E26\u6837\u5F0F)\r\n      ElementPlusResolver(),\r\n      IconsResolver({\r\n        prefix: 'Icon'\r\n      })\r\n    ],\r\n    vueTemplate: true, // \u662F\u5426\u5728 vue \u6A21\u677F\u4E2D\u81EA\u52A8\u5BFC\u5165\r\n    dts: path.resolve(path.resolve(__dirname, '../../src'), 'types', 'auto-imports.d.ts')\r\n  });\r\n};\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\components.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/components.ts\";import Components from 'unplugin-vue-components/vite';\r\nimport { ElementPlusResolver } from 'unplugin-vue-components/resolvers';\r\nimport IconsResolver from 'unplugin-icons/resolver';\r\n\r\nexport default (path: any) => {\r\n  return Components({\r\n    resolvers: [\r\n      // \u81EA\u52A8\u5BFC\u5165 Element Plus \u7EC4\u4EF6\r\n      ElementPlusResolver(),\r\n      // \u81EA\u52A8\u6CE8\u518C\u56FE\u6807\u7EC4\u4EF6\r\n      IconsResolver({\r\n        enabledCollections: ['ep']\r\n      })\r\n    ],\r\n    dts: path.resolve(path.resolve(__dirname, '../../src'), 'types', 'components.d.ts')\r\n  });\r\n};\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\icons.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/icons.ts\";import Icons from 'unplugin-icons/vite';\r\n\r\nexport default () => {\r\n  return Icons({\r\n    // \u81EA\u52A8\u5B89\u88C5\u56FE\u6807\u5E93\r\n    autoInstall: true\r\n  });\r\n};\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\svg-icon.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/svg-icon.ts\";import { createSvgIconsPlugin } from 'vite-plugin-svg-icons';\r\nexport default (path: any, isBuild: boolean) => {\r\n  return createSvgIconsPlugin({\r\n    // \u6307\u5B9A\u9700\u8981\u7F13\u5B58\u7684\u56FE\u6807\u6587\u4EF6\u5939\r\n    iconDirs: [path.resolve(path.resolve(__dirname, '../../src'), 'assets/icons/svg')],\r\n    // \u6307\u5B9AsymbolId\u683C\u5F0F\r\n    symbolId: 'icon-[dir]-[name]',\r\n    svgoOptions: isBuild\r\n  });\r\n};\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\compression.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/compression.ts\";import compression from 'vite-plugin-compression';\r\n\r\nexport default (env: any) => {\r\n  const { VITE_BUILD_COMPRESS } = env;\r\n  const plugin: any[] = [];\r\n  if (VITE_BUILD_COMPRESS) {\r\n    const compressList = VITE_BUILD_COMPRESS.split(',');\r\n    if (compressList.includes('gzip')) {\r\n      // http://doc.ruoyi.vip/ruoyi-vue/other/faq.html#\u4F7F\u7528gzip\u89E3\u538B\u7F29\u9759\u6001\u6587\u4EF6\r\n      plugin.push(\r\n        compression({\r\n          ext: '.gz',\r\n          deleteOriginFile: false\r\n        })\r\n      );\r\n    }\r\n    if (compressList.includes('brotli')) {\r\n      plugin.push(\r\n        compression({\r\n          ext: '.br',\r\n          algorithm: 'brotliCompress',\r\n          deleteOriginFile: false\r\n        })\r\n      );\r\n    }\r\n  }\r\n  return plugin;\r\n};\r\n", "const __vite_injected_original_dirname = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"E:\\\\XNY\\\\new-project\\\\vite\\\\plugins\\\\setup-extend.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/XNY/new-project/vite/plugins/setup-extend.ts\";import setupExtend from 'unplugin-vue-setup-extend-plus/vite';\r\n\r\nexport default () => {\r\n  return setupExtend({});\r\n};\r\n"],
  "mappings": "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",
  "names": ["path", "ElementPlusResolver", "IconsResolver", "__vite_injected_original_dirname", "path", "ElementPlusResolver", "IconsResolver", "__vite_injected_original_dirname", "__vite_injected_original_dirname", "path", "__vite_injected_original_dirname", "path", "__vite_injected_original_dirname", "path", "__vite_injected_original_dirname"]
}
