招标
This commit is contained in:
@ -5,7 +5,7 @@ VITE_APP_TITLE = 煤科建管平台
|
|||||||
VITE_APP_ENV = 'development'
|
VITE_APP_ENV = 'development'
|
||||||
|
|
||||||
# 开发环境
|
# 开发环境
|
||||||
VITE_APP_BASE_API = 'http://192.168.110.180:8899'
|
VITE_APP_BASE_API = 'http://192.168.110.149:8899'
|
||||||
|
|
||||||
# 无人机接口地址
|
# 无人机接口地址
|
||||||
|
|
||||||
|
@ -44,7 +44,6 @@ export const importExcelFile = (query: any, data: any): AxiosPromise<any> => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
//招标计划列表
|
//招标计划列表
|
||||||
|
|
||||||
export const tenderPlanList = (query: any): AxiosPromise<any> => {
|
export const tenderPlanList = (query: any): AxiosPromise<any> => {
|
||||||
return request({
|
return request({
|
||||||
url: '/tender/biddingPlan/list',
|
url: '/tender/biddingPlan/list',
|
||||||
@ -106,3 +105,11 @@ export const delBiddView = (query: any): AxiosPromise<any> => {
|
|||||||
method: 'delete'
|
method: 'delete'
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
//获取招标单位
|
||||||
|
export const getUnitList = (query: any): AxiosPromise<any> => {
|
||||||
|
return request({
|
||||||
|
url: '/supplierInput/supplierInput/getList',
|
||||||
|
method: 'get',
|
||||||
|
params: query
|
||||||
|
});
|
||||||
|
};
|
||||||
|
@ -31,7 +31,6 @@
|
|||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { useUserStoreHook } from '@/store/modules/user';
|
import { useUserStoreHook } from '@/store/modules/user';
|
||||||
import { id } from 'element-plus/es/locale/index.mjs';
|
|
||||||
const userStore = useUserStoreHook();
|
const userStore = useUserStoreHook();
|
||||||
const currentProject = computed(() => userStore.selectedProject);
|
const currentProject = computed(() => userStore.selectedProject);
|
||||||
const dialogVisible = ref(false);
|
const dialogVisible = ref(false);
|
||||||
@ -42,7 +41,12 @@ const ruleForm = ref<any>();
|
|||||||
const rules = ref({
|
const rules = ref({
|
||||||
costEstimationFile: [{ required: true, message: '请上传招标文件', trigger: ['blur'] }]
|
costEstimationFile: [{ required: true, message: '请上传招标文件', trigger: ['blur'] }]
|
||||||
});
|
});
|
||||||
|
const emit = defineProps({
|
||||||
|
success: {
|
||||||
|
type: Function
|
||||||
|
// required: true
|
||||||
|
}
|
||||||
|
});
|
||||||
const form = ref({
|
const form = ref({
|
||||||
costEstimationFile: ''
|
costEstimationFile: ''
|
||||||
});
|
});
|
||||||
@ -64,6 +68,7 @@ const submitForm = () => {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
dialogVisible.value = false;
|
dialogVisible.value = false;
|
||||||
|
emit.success();
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
defineExpose({
|
defineExpose({
|
||||||
|
104
src/views/tender/plan/comm/winTheBid.vue
Normal file
104
src/views/tender/plan/comm/winTheBid.vue
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
<template>
|
||||||
|
<el-dialog v-model="dialogVisible" title="招标文件" width="500" draggable>
|
||||||
|
<el-form ref="ruleFormRef" style="max-width: 600px" :model="form" :rules="rules" label-width="auto">
|
||||||
|
<el-form-item label="中标单位" prop="winningBidder">
|
||||||
|
<el-select v-model="form.winningBidder" filterable placeholder="请选择单位" style="width: 240px">
|
||||||
|
<el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" />
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="招标文件" prop="name">
|
||||||
|
<file-upload
|
||||||
|
v-model="form.costEstimationFile"
|
||||||
|
:fileSize="100"
|
||||||
|
:auto-upload="false"
|
||||||
|
uploadUrl="/tender/biddingPlan/uploadBiddingDocuments"
|
||||||
|
method="put"
|
||||||
|
ref="fileUploadRef"
|
||||||
|
:data="{
|
||||||
|
projectId: currentProject?.id,
|
||||||
|
planType: planType,
|
||||||
|
fileType: '0',
|
||||||
|
bidStatus: '0',
|
||||||
|
id: row.id,
|
||||||
|
winningBidderId: form.winningBidder
|
||||||
|
}"
|
||||||
|
showFileList
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<template #footer>
|
||||||
|
<div class="dialog-footer">
|
||||||
|
<el-button @click="resetForm()"> 取消 </el-button>
|
||||||
|
<el-button type="primary" @click="submitForm()">确定</el-button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-dialog>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
import { getUnitList } from '@/api/tender/index';
|
||||||
|
import { useUserStoreHook } from '@/store/modules/user';
|
||||||
|
const userStore = useUserStoreHook();
|
||||||
|
const currentProject = computed(() => userStore.selectedProject);
|
||||||
|
const dialogVisible = ref(false);
|
||||||
|
const row = ref<any>();
|
||||||
|
const planType = ref<any>('');
|
||||||
|
const fileUploadRef = ref<any>();
|
||||||
|
const ruleForm = ref<any>();
|
||||||
|
const options = ref<any>([]);
|
||||||
|
|
||||||
|
const rules = ref({
|
||||||
|
costEstimationFile: [{ required: true, message: '请上传招标文件', trigger: ['blur'] }]
|
||||||
|
});
|
||||||
|
const emit = defineProps({
|
||||||
|
success: {
|
||||||
|
type: Function
|
||||||
|
// required: true
|
||||||
|
}
|
||||||
|
});
|
||||||
|
const form = ref({
|
||||||
|
costEstimationFile: '',
|
||||||
|
winningBidder: ''
|
||||||
|
});
|
||||||
|
|
||||||
|
const open = (rows: any, type: string) => {
|
||||||
|
dialogVisible.value = true;
|
||||||
|
console.log(rows, type);
|
||||||
|
row.value = rows;
|
||||||
|
planType.value = type;
|
||||||
|
getUnitListData();
|
||||||
|
};
|
||||||
|
const getUnitListData = async () => {
|
||||||
|
let res = await getUnitList({
|
||||||
|
projectId: currentProject.value?.id
|
||||||
|
});
|
||||||
|
if (res.code == 200) {
|
||||||
|
options.value = res.data.map((item: any) => {
|
||||||
|
return {
|
||||||
|
label: item.supplierName,
|
||||||
|
value: item.id
|
||||||
|
};
|
||||||
|
});
|
||||||
|
}
|
||||||
|
console.log(res);
|
||||||
|
};
|
||||||
|
const resetForm = () => {};
|
||||||
|
const submitForm = () => {
|
||||||
|
fileUploadRef.value.submitUpload().then((res) => {
|
||||||
|
if (res == 'noFile') {
|
||||||
|
ElMessage({
|
||||||
|
message: '请上传招标文件',
|
||||||
|
type: 'warning'
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
dialogVisible.value = false;
|
||||||
|
emit.success();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
defineExpose({
|
||||||
|
open
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss"></style>
|
@ -28,33 +28,77 @@
|
|||||||
<el-table-column prop="content" label="内容" />
|
<el-table-column prop="content" label="内容" />
|
||||||
<el-table-column prop="bidd" label="招标文件">
|
<el-table-column prop="bidd" label="招标文件">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-button type="primary" link v-hasPermi="['tender:segmentedIndicatorPlanning:getMore']" @click="biddView(scope.row)"
|
<el-button
|
||||||
|
type="primary"
|
||||||
|
:disabled="scope.row.bidStatus == 1"
|
||||||
|
link
|
||||||
|
v-hasPermi="['tender:segmentedIndicatorPlanning:getMore']"
|
||||||
|
@click="biddView(scope.row)"
|
||||||
>查看文件</el-button
|
>查看文件</el-button
|
||||||
>
|
>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
<el-table-column prop="winningBidder" label="中标单位" />
|
||||||
|
<el-table-column prop="bidFileName" label="中标文件">
|
||||||
|
<template #default="scope">
|
||||||
|
<el-button type="primary" link :disabled="scope.row.bidStatus == 1">{{ scope.row.bidFileName }} </el-button>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
<el-table-column prop="plannedBiddingTime" label="计划招标时间" align="center">
|
<el-table-column prop="plannedBiddingTime" label="计划招标时间" align="center">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-date-picker v-model="scope.row.plannedBiddingTime" type="date" value-format="YYYY-MM-DD" placeholder="选择时间" />
|
<el-date-picker
|
||||||
|
v-model="scope.row.plannedBiddingTime"
|
||||||
|
@change="
|
||||||
|
(val: any) => {
|
||||||
|
changeBiddingTime(val, scope.row);
|
||||||
|
}
|
||||||
|
"
|
||||||
|
type="date"
|
||||||
|
value-format="YYYY-MM-DD"
|
||||||
|
placeholder="选择时间"
|
||||||
|
:disabled="scope.row.bidStatus == 1"
|
||||||
|
/>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="price" label="操作" align="center">
|
<el-table-column prop="price" label="操作" align="center">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-button type="primary" link icon="View" @click="handleDetail(scope.row)" v-hasPermi="['tender:segmentedIndicatorPlanning:getMore']"
|
|
||||||
>详情</el-button
|
|
||||||
>
|
|
||||||
<el-button
|
<el-button
|
||||||
type="primary"
|
type="primary"
|
||||||
link
|
link
|
||||||
icon="FolderOpened"
|
icon="FolderOpened"
|
||||||
@click="handleSave(scope.row)"
|
@click="handleSave(scope.row)"
|
||||||
v-hasPermi="['tender:segmentedIndicatorPlanning:edit']"
|
v-hasPermi="['tender:segmentedIndicatorPlanning:edit']"
|
||||||
|
:disabled="scope.row.bidStatus == 1"
|
||||||
>上传投标资料
|
>上传投标资料
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button type="primary" link icon="Edit" @click="handleSave(scope.row)" v-hasPermi="['tender:segmentedIndicatorPlanning:edit']"
|
<el-button
|
||||||
>信息
|
type="primary"
|
||||||
|
link
|
||||||
|
icon="FolderOpened"
|
||||||
|
@click="handleWinTheBid(scope.row)"
|
||||||
|
v-hasPermi="['tender:segmentedIndicatorPlanning:edit']"
|
||||||
|
:disabled="scope.row.bidStatus == 1"
|
||||||
|
>上传中标资料
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button type="primary" link icon="Delete" @click="delHandle(scope.row)" v-hasPermi="['tender:segmentedIndicatorPlanning:remove']"
|
<!-- <el-button type="primary" link icon="Edit" @click="handleSave(scope.row)" v-hasPermi="['tender:segmentedIndicatorPlanning:edit']"
|
||||||
|
>信息
|
||||||
|
</el-button> -->
|
||||||
|
<el-button
|
||||||
|
type="primary"
|
||||||
|
link
|
||||||
|
icon="View"
|
||||||
|
@click="handleDetail(scope.row)"
|
||||||
|
:disabled="scope.row.bidStatus == 1"
|
||||||
|
v-hasPermi="['tender:segmentedIndicatorPlanning:getMore']"
|
||||||
|
>详情</el-button
|
||||||
|
>
|
||||||
|
<el-button
|
||||||
|
type="primary"
|
||||||
|
link
|
||||||
|
icon="Delete"
|
||||||
|
@click="delHandle(scope.row)"
|
||||||
|
:disabled="scope.row.bidStatus == 1"
|
||||||
|
v-hasPermi="['tender:segmentedIndicatorPlanning:remove']"
|
||||||
>删除</el-button
|
>删除</el-button
|
||||||
>
|
>
|
||||||
</template>
|
</template>
|
||||||
@ -142,7 +186,7 @@
|
|||||||
</el-row>
|
</el-row>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="closeDialog">取消</el-button>
|
<el-button @click="closeDialog">取消</el-button>
|
||||||
<el-button type="primary" @click="submitForm(formRef)">确定</el-button>
|
<el-button type="primary" @click="submitForm(formRef)" :loading="subLoading">确定</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
<el-dialog title="详情" v-model="detailDialog" width="75%" draggable>
|
<el-dialog title="详情" v-model="detailDialog" width="75%" draggable>
|
||||||
@ -159,18 +203,21 @@
|
|||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
<information ref="informationRef" />
|
|
||||||
<el-dialog title="查看文件" v-model="biddDialog" width="45%" draggable>
|
<el-dialog title="查看文件" v-model="biddDialog" width="45%" draggable>
|
||||||
<el-table :data="biddViewData" border>
|
<el-table :data="biddViewData" border>
|
||||||
<el-table-column prop="name" label="文件名" />
|
<el-table-column prop="name" label="文件名" />
|
||||||
<el-table-column prop="price" label="操作" align="center">
|
<el-table-column prop="price" label="操作" align="center">
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-button type="primary" link icon="View" @click="openPdf(scope.row)">查看</el-button>
|
<el-button type="primary" link icon="View" @click="openPdf(scope.row.url)">查看</el-button>
|
||||||
<el-button type="primary" link icon="Delete" @click="delHandlebidd(scope.row)">删除</el-button>
|
<el-button type="primary" link icon="Delete" @click="delHandlebidd(scope.row)">删除</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
|
<information ref="informationRef" @success="getList()" />
|
||||||
|
|
||||||
|
<winTheBid ref="winTheBidRef" @success="getList()" />
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -180,6 +227,7 @@ import { getDicts } from '@/api/system/dict/data';
|
|||||||
import { Plus } from '@element-plus/icons-vue';
|
import { Plus } from '@element-plus/icons-vue';
|
||||||
import { FormInstance } from 'element-plus';
|
import { FormInstance } from 'element-plus';
|
||||||
import information from './comm/planPage.vue';
|
import information from './comm/planPage.vue';
|
||||||
|
import winTheBid from './comm/winTheBid.vue';
|
||||||
import {
|
import {
|
||||||
sheetList,
|
sheetList,
|
||||||
tenderPlanList,
|
tenderPlanList,
|
||||||
@ -436,12 +484,14 @@ const getTreeList = async () => {
|
|||||||
treeLoading.value = false;
|
treeLoading.value = false;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
const subLoading = ref(false);
|
||||||
|
|
||||||
const submitForm = async (formEl: FormInstance | undefined) => {
|
const submitForm = async (formEl: FormInstance | undefined) => {
|
||||||
if (!formEl) return;
|
if (!formEl) return;
|
||||||
await formEl.validate(async (valid, fields) => {
|
await formEl.validate(async (valid, fields) => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
try {
|
try {
|
||||||
|
subLoading.value = true;
|
||||||
if (selectionData.value.length == 0) {
|
if (selectionData.value.length == 0) {
|
||||||
ElMessage({
|
ElMessage({
|
||||||
message: '请选择项目材料',
|
message: '请选择项目材料',
|
||||||
@ -476,8 +526,10 @@ const submitForm = async (formEl: FormInstance | undefined) => {
|
|||||||
});
|
});
|
||||||
closeDialog();
|
closeDialog();
|
||||||
getList();
|
getList();
|
||||||
|
subLoading.value = false;
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
subLoading.value = false;
|
||||||
console.log(error);
|
console.log(error);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -485,10 +537,28 @@ const submitForm = async (formEl: FormInstance | undefined) => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
//确定修改
|
const changeBiddingTime = (value: any, row: any) => {
|
||||||
|
updateTenderPlan({
|
||||||
|
...row
|
||||||
|
}).then((res) => {
|
||||||
|
if (res.code == 200) {
|
||||||
|
ElMessage({
|
||||||
|
message: '修改成功',
|
||||||
|
type: 'success'
|
||||||
|
});
|
||||||
|
getList();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
//上传投标文件
|
||||||
const handleSave = (row: any) => {
|
const handleSave = (row: any) => {
|
||||||
informationRef.value.open(row, planType.value);
|
informationRef.value.open(row, planType.value);
|
||||||
};
|
};
|
||||||
|
const winTheBidRef = ref();
|
||||||
|
//上传中标文件
|
||||||
|
const handleWinTheBid = (row: any) => {
|
||||||
|
winTheBidRef.value.open(row, planType.value);
|
||||||
|
};
|
||||||
//删除
|
//删除
|
||||||
const delHandle = (row: any) => {
|
const delHandle = (row: any) => {
|
||||||
try {
|
try {
|
||||||
@ -558,9 +628,10 @@ const delHandlebidd = (row: any) => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
//查看文件
|
//查看文件
|
||||||
const openPdf = (row: any) => {
|
const openPdf = (url: any) => {
|
||||||
window.open(row.url);
|
window.open(url);
|
||||||
};
|
};
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
|
Reference in New Issue
Block a user