|
@@ -3,7 +3,10 @@
|
|
|
<el-row>
|
|
|
<el-col :span="4">
|
|
|
<el-form-item label="项目名称">
|
|
|
- <el-input placeholder="请输入项目名称" />
|
|
|
+ <el-input
|
|
|
+ v-model="filterProjects.name"
|
|
|
+ placeholder="请输入项目名称"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col
|
|
@@ -12,9 +15,11 @@
|
|
|
>
|
|
|
<el-form-item label="立项时间">
|
|
|
<el-date-picker
|
|
|
- v-model="approvalTime"
|
|
|
+ v-model="filterProjects.time"
|
|
|
type="month"
|
|
|
placeholder="请选择立项时间"
|
|
|
+ format="YYYY-MM"
|
|
|
+ value-format="YYYY-MM"
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
@@ -23,34 +28,53 @@
|
|
|
:offset="1"
|
|
|
>
|
|
|
<el-form-item label="项目状态">
|
|
|
- <el-select />
|
|
|
+ <el-select
|
|
|
+ v-model="currentlyState"
|
|
|
+ @change="changeState"
|
|
|
+ >
|
|
|
+ <el-option
|
|
|
+ v-for="item in stateList"
|
|
|
+ :key="item.value"
|
|
|
+ :label="item.label"
|
|
|
+ :value="item.value"
|
|
|
+ />
|
|
|
+ </el-select>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col
|
|
|
- :span="2"
|
|
|
- :offset="1"
|
|
|
- >
|
|
|
- <el-button
|
|
|
- type="primary"
|
|
|
- :icon="Search"
|
|
|
- @click="initializedData"
|
|
|
- >查询</el-button>
|
|
|
- </el-col>
|
|
|
- <el-col
|
|
|
- :span="2"
|
|
|
+ :span="5"
|
|
|
+ style="margin-left: 40px"
|
|
|
>
|
|
|
- <el-button
|
|
|
- type="primary"
|
|
|
- :icon="DocumentCopy"
|
|
|
- @click="initializedData"
|
|
|
- >立项</el-button>
|
|
|
+ <el-row justify="space-around">
|
|
|
+ <el-button
|
|
|
+ type="primary"
|
|
|
+ :icon="Search"
|
|
|
+ @click="queryProject"
|
|
|
+ >查询
|
|
|
+ </el-button>
|
|
|
+ <el-button
|
|
|
+ type="primary"
|
|
|
+ :icon="DocumentCopy"
|
|
|
+ @click="queryProject"
|
|
|
+ >立项
|
|
|
+ </el-button>
|
|
|
+ <el-button
|
|
|
+ type="primary"
|
|
|
+ :icon="RefreshLeft"
|
|
|
+ @click="listData(initialCondition)"
|
|
|
+ >重置
|
|
|
+ </el-button>
|
|
|
+ </el-row>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
|
<el-row>
|
|
|
<el-col :span="23">
|
|
|
<el-row justify="space-between">
|
|
|
<el-col :span="5">
|
|
|
- <div class="bg-white h-24">
|
|
|
+ <div
|
|
|
+ class="bg-white h-24"
|
|
|
+ style="box-shadow: -7px 0 7px #e5e5e5"
|
|
|
+ >
|
|
|
<el-row
|
|
|
style="height: 40%"
|
|
|
align="middle"
|
|
@@ -58,7 +82,8 @@
|
|
|
<el-col :offset="2">
|
|
|
<el-text
|
|
|
style="font-family: 黑体;"
|
|
|
- >项目总数</el-text>
|
|
|
+ >项目总数
|
|
|
+ </el-text>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
|
<el-row
|
|
@@ -72,20 +97,24 @@
|
|
|
</div>
|
|
|
</el-col>
|
|
|
<el-col :span="5">
|
|
|
- <div class="bg-white h-24">
|
|
|
+ <div
|
|
|
+ class="bg-white h-24"
|
|
|
+ style="box-shadow: -7px 0 7px #e5e5e5"
|
|
|
+ >
|
|
|
<el-row
|
|
|
- style="height: 40%"
|
|
|
- align="middle"
|
|
|
+ style="height: 40%"
|
|
|
+ align="middle"
|
|
|
>
|
|
|
<el-col :offset="2">
|
|
|
<el-text
|
|
|
- style="font-family: 黑体;"
|
|
|
- >执行中项目</el-text>
|
|
|
+ style="font-family: 黑体;"
|
|
|
+ >执行中项目
|
|
|
+ </el-text>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
|
<el-row
|
|
|
- style="height: 60%"
|
|
|
- align="middle"
|
|
|
+ style="height: 60%"
|
|
|
+ align="middle"
|
|
|
>
|
|
|
<el-col :offset="2">
|
|
|
<span class="dataStyle">{{ screenData.unCompleteProject }}</span>
|
|
@@ -94,20 +123,24 @@
|
|
|
</div>
|
|
|
</el-col>
|
|
|
<el-col :span="5">
|
|
|
- <div class="bg-white h-24">
|
|
|
+ <div
|
|
|
+ class="bg-white h-24"
|
|
|
+ style="box-shadow: -7px 0 7px #e5e5e5"
|
|
|
+ >
|
|
|
<el-row
|
|
|
- style="height: 40%"
|
|
|
- align="middle"
|
|
|
+ style="height: 40%"
|
|
|
+ align="middle"
|
|
|
>
|
|
|
<el-col :offset="2">
|
|
|
<el-text
|
|
|
- style="font-family: 黑体;"
|
|
|
- >已完成项目</el-text>
|
|
|
+ style="font-family: 黑体;"
|
|
|
+ >已完成项目
|
|
|
+ </el-text>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
|
<el-row
|
|
|
- style="height: 60%"
|
|
|
- align="middle"
|
|
|
+ style="height: 60%"
|
|
|
+ align="middle"
|
|
|
>
|
|
|
<el-col :offset="2">
|
|
|
<span class="dataStyle">{{ screenData.completeProject }}</span>
|
|
@@ -116,20 +149,24 @@
|
|
|
</div>
|
|
|
</el-col>
|
|
|
<el-col :span="5">
|
|
|
- <div class="bg-white h-24">
|
|
|
+ <div
|
|
|
+ class="bg-white h-24"
|
|
|
+ style="box-shadow: -7px 0 7px #e5e5e5"
|
|
|
+ >
|
|
|
<el-row
|
|
|
- style="height: 40%"
|
|
|
- align="middle"
|
|
|
+ style="height: 40%"
|
|
|
+ align="middle"
|
|
|
>
|
|
|
<el-col :offset="2">
|
|
|
<el-text
|
|
|
- style="font-family: 黑体;"
|
|
|
- >项目总金额</el-text>
|
|
|
+ style="font-family: 黑体;"
|
|
|
+ >项目总金额
|
|
|
+ </el-text>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
|
<el-row
|
|
|
- style="height: 60%"
|
|
|
- align="middle"
|
|
|
+ style="height: 60%"
|
|
|
+ align="middle"
|
|
|
>
|
|
|
<el-col :offset="2">
|
|
|
<span class="dataStyle">{{ screenData.sum }}元</span>
|
|
@@ -148,6 +185,7 @@
|
|
|
<el-table
|
|
|
:data="projectListData"
|
|
|
height="580"
|
|
|
+ stripe
|
|
|
>
|
|
|
<el-table-column
|
|
|
prop="code"
|
|
@@ -185,13 +223,11 @@
|
|
|
>
|
|
|
<template #default="scope">
|
|
|
<el-button
|
|
|
- size="small"
|
|
|
@click="projectEdit(scope.$index, scope.row)"
|
|
|
>
|
|
|
详情
|
|
|
</el-button>
|
|
|
<el-button
|
|
|
- size="small"
|
|
|
type="danger"
|
|
|
@click="projectDelete(scope.$index, scope.row)"
|
|
|
>
|
|
@@ -221,18 +257,34 @@
|
|
|
</template>
|
|
|
|
|
|
<script setup>
|
|
|
-import { DocumentCopy, Search } from '@element-plus/icons-vue'
|
|
|
-import { getProjectList, projectDataScreen } from '@/api/project'
|
|
|
+import { DocumentCopy, RefreshLeft, Search } from '@element-plus/icons-vue'
|
|
|
+import { getProjectList, projectDataScreen, deleteProject } from '@/api/project'
|
|
|
import { reactive, ref, onMounted } from 'vue'
|
|
|
+import { ElMessage, ElMessageBox } from 'element-plus'
|
|
|
|
|
|
defineOptions({
|
|
|
name: 'ProjectList'
|
|
|
})
|
|
|
const screenData = reactive({})
|
|
|
-const approvalTime = ref('')
|
|
|
const projectListData = reactive([])
|
|
|
const listTotal = ref(0)
|
|
|
-const data = {
|
|
|
+const stateList = [
|
|
|
+ { label: '立项', value: 1 },
|
|
|
+ { label: '施工', value: 2 },
|
|
|
+ { label: '收款', value: 3 },
|
|
|
+ { label: '完成', value: 4 },
|
|
|
+ { label: '失效', value: 5 },
|
|
|
+]
|
|
|
+const initialCondition = {
|
|
|
+ pageInfo: {
|
|
|
+ page: 1,
|
|
|
+ pageSize: 10
|
|
|
+ },
|
|
|
+ name: '',
|
|
|
+ time: '',
|
|
|
+ state: 0
|
|
|
+}
|
|
|
+const filterProjects = reactive({
|
|
|
pageInfo: {
|
|
|
page: 1,
|
|
|
pageSize: 10
|
|
@@ -241,21 +293,62 @@ const data = {
|
|
|
time: '',
|
|
|
state: 0
|
|
|
}
|
|
|
+)
|
|
|
+
|
|
|
+const currentlyState = ref('')
|
|
|
+const changeState = (value) => {
|
|
|
+ filterProjects.state = value
|
|
|
+ stateList.forEach(item => {
|
|
|
+ if (value === item.value) {
|
|
|
+ currentlyState.value = item.label
|
|
|
+ }
|
|
|
+ })
|
|
|
+}
|
|
|
const projectEdit = (index, row) => {
|
|
|
}
|
|
|
const projectDelete = (index, row) => {
|
|
|
+ ElMessageBox.confirm(
|
|
|
+ '确定要删除该项目吗?',
|
|
|
+ '项目删除',
|
|
|
+ {
|
|
|
+ confirmButtonText: '确认',
|
|
|
+ cancelButtonText: '取消',
|
|
|
+ type: 'warning',
|
|
|
+ }
|
|
|
+ )
|
|
|
+ .then(() => {
|
|
|
+ deleteProject(row.code).then(res => {
|
|
|
+ if (res.code === 0) {
|
|
|
+ ElMessage({
|
|
|
+ type: 'success',
|
|
|
+ message: '删除成功',
|
|
|
+ })
|
|
|
+ listData(initialCondition)
|
|
|
+ dataScreen()
|
|
|
+ } else {
|
|
|
+ ElMessage({
|
|
|
+ type: 'error',
|
|
|
+ message: res.msg,
|
|
|
+ })
|
|
|
+ }
|
|
|
+ })
|
|
|
+ })
|
|
|
+ .catch(() => {
|
|
|
+ ElMessage({
|
|
|
+ type: 'info',
|
|
|
+ message: '取消删除',
|
|
|
+ })
|
|
|
+ })
|
|
|
}
|
|
|
-// 项目数据总览
|
|
|
onMounted(() => {
|
|
|
- projectDataScreen().then(res => {
|
|
|
- console.log(res.data)
|
|
|
- const obj = res.data
|
|
|
- Object.keys(obj).forEach(key => {
|
|
|
- screenData[key] = obj[key]
|
|
|
- })
|
|
|
- })
|
|
|
+ // 项目数据总览
|
|
|
+ dataScreen()
|
|
|
// 获取项目列表
|
|
|
- getProjectList(data).then(res => {
|
|
|
+ listData(initialCondition)
|
|
|
+})
|
|
|
+const listData = (condition) => {
|
|
|
+ projectListData.length = 0
|
|
|
+ getProjectList(condition).then(res => {
|
|
|
if (res.code === 0 && res.data.total > 0) {
|
|
|
const list = res.data.list
|
|
|
list.forEach(item => {
|
|
@@ -266,8 +359,16 @@ onMounted(() => {
|
|
|
listTotal.value = res.data.total
|
|
|
}
|
|
|
})
|
|
|
-})
|
|
|
-function formatDate(dateString, locale = 'en-US', timezone = 'Asia/Shanghai') {
|
|
|
+}
|
|
|
+const dataScreen = () => {
|
|
|
+ projectDataScreen().then(res => {
|
|
|
+ const obj = res.data
|
|
|
+ Object.keys(obj).forEach(key => {
|
|
|
+ screenData[key] = obj[key]
|
|
|
+ })
|
|
|
+ })
|
|
|
+}
|
|
|
+const formatDate = (dateString, locale = 'en-US', timezone = 'Asia/Shanghai') => {
|
|
|
// 使用 Date 构造函数解析日期字符串
|
|
|
const date = new Date(dateString)
|
|
|
|
|
@@ -292,8 +393,8 @@ const projectState = (state) => {
|
|
|
}
|
|
|
return obj[state]
|
|
|
}
|
|
|
-const initializedData = () => {
|
|
|
- console.log(screenData.totalProject)
|
|
|
+const queryProject = () => {
|
|
|
+ listData(filterProjects)
|
|
|
}
|
|
|
const changePage = (value) => {
|
|
|
console.log(value)
|
|
@@ -301,8 +402,8 @@ const changePage = (value) => {
|
|
|
</script>
|
|
|
|
|
|
<style scoped lang="less">
|
|
|
- .dataStyle{
|
|
|
- font-size: 25px;
|
|
|
- font-weight: 500;
|
|
|
- }
|
|
|
+.dataStyle {
|
|
|
+ font-size: 25px;
|
|
|
+ font-weight: 500;
|
|
|
+}
|
|
|
</style>
|