瀏覽代碼

添加细分小条页面

master
YF-yuan 3 年之前
父節點
當前提交
608e58f5da
共有 9 個文件被更改,包括 583 次插入73 次删除
  1. +17
    -1
      src/router/index.js
  2. +0
    -0
      src/views/second/search.vue
  3. +38
    -22
      src/views/second/segmentation/basicTable.vue
  4. +89
    -0
      src/views/second/segmentation/constraint.vue
  5. +90
    -10
      src/views/second/segmentation/contentDetail.vue
  6. +90
    -0
      src/views/second/segmentation/reward.vue
  7. +69
    -20
      src/views/second/taskSummary/basicTable.vue
  8. +94
    -9
      src/views/second/taskSummary/constraint.vue
  9. +96
    -11
      src/views/second/taskSummary/reward.vue

+ 17
- 1
src/router/index.js 查看文件

@@ -49,10 +49,26 @@ const routes = [
component: () => import('@/views/list/card/article'),
meta: {hide: true, title: '文章', uid: '/list/card'}
}

]
}
]
}
},
{
path: '/segmentation',
component: EleLayout,
meta: {hide: true, title: '分项信息'},
children: [
{
path: '',
component: () => import('@/views/second/segmentation/contentDetail'),
meta: {title: '分项'},
name:"segmentation",
props:true
}
],
},
];

// 404路由在动态路由后面加

src/views/second/taskSummary/search.vue → src/views/second/search.vue 查看文件


+ 38
- 22
src/views/second/segmentation/basicTable.vue 查看文件

@@ -1,30 +1,36 @@
<template>
<div class="assessing-content ele-body">
<el-card shadow="never" v-loading="loading" element-loading-background="rgba(255, 255, 255, 1)">
<search :search-params="searchParams" />
<search :type="1" :search-params="searchParams" />
<div class="operating">
<el-button size="small" type="warning">新增</el-button>
<el-button size="small" type="default">批量删除</el-button>
<el-button size="small" type="default">批量导入</el-button>
<el-button size="small" type="primary">导出</el-button>
</div>
<el-table highlight-current-row :data="dataList" :height="tableHeight" border>
<el-table-column type="index" width="50" align="center" label="编号"></el-table-column>
<el-table-column label="一级指标" min-width="150" align="center" prop="quota1"></el-table-column>
<el-table-column label="二级指标" min-width="150" align="center" prop="quota2"></el-table-column>
<el-table-column label="考核内容和计分细则" min-width="200" align="center" prop="content"></el-table-column>
<el-table-column label="小条内容" min-width="150" align="center" prop="littleContent"></el-table-column>
<el-table-column label="分值" min-width="60" align="center" prop="points"></el-table-column>
<el-table-column label="区牵头单位" min-width="80" align="center" prop="leaderUnit"></el-table-column>
<el-table-column label="牵头部门" min-width="80" align="center" prop="leaderDeptList"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center"></el-table-column>
<el-table-column label="配合部门" min-width="80" align="center" prop="cooperateDept"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center" prop="cooperateDeptList"></el-table-column>
<el-table-column
type="selection"
width="50"
label="操作"
width="125"
align="center"
></el-table-column>
<el-table-column type="index" width="50" align="center" label="序号"></el-table-column>
<el-table-column label="一级指标" min-width="150" align="center"></el-table-column>
<el-table-column label="二级指标" min-width="150" align="center"></el-table-column>
<el-table-column label="考核内容和计分细则" min-width="200" align="center"></el-table-column>
<el-table-column label="分值" min-width="60" align="center"></el-table-column>
<el-table-column label="区牵头单位" min-width="80" align="center"></el-table-column>
<el-table-column label="牵头部门" min-width="80" align="center"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center"></el-table-column>
<el-table-column label="配合部门" min-width="80" align="center"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center"></el-table-column>
:key="Math.random()"
>
<template slot-scope="{ row }">
<router-link
:to="{name:'segmentation', params:{row, type: 1}}"
>分项</router-link
>
</template>
</el-table-column>
</el-table>

<el-pagination
:current-page.sync="page.page"
:page-size="page.limit"
@@ -41,7 +47,8 @@
</template>

<script>
import search from "../../assessingTarget/search";
import search from "../search";

export default {
components: {
search,
@@ -49,14 +56,19 @@ export default {
data() {
return {
searchParams: {},
dataList: [],
dataList: [
{quota1:'sdewfdewd',quota2: 'xsuifewhdnix'}
],
loading: false,
form: {},
quota1List:[],
quota2List:[],
count: 0,
tableHeight: document.documentElement.clientHeight - 305,
tableHeight: document.documentElement.clientHeight - 355,
page: {
page: 1,
limit: Math.floor(
(document.documentElement.clientHeight - 305 - 45) / 45
(document.documentElement.clientHeight - 355 - 45) / 45
),
},
};
@@ -71,4 +83,8 @@ export default {
</script>

<style scoped>
a {
text-decoration:none;
color:#66B1FF;
}
</style>

+ 89
- 0
src/views/second/segmentation/constraint.vue 查看文件

@@ -0,0 +1,89 @@
<template>
<div class="assessing-content ele-body">
<el-card shadow="never" v-loading="loading" element-loading-background="rgba(255, 255, 255, 1)">
<search :type="3" :search-params="searchParams" />
<div class="operating">
<el-button size="small" type="primary">导出</el-button>
</div>
<el-table highlight-current-row :data="dataList" :height="tableHeight" border>
<el-table-column type="index" width="50" align="center" label="编号"></el-table-column>
<el-table-column label="考核指标" min-width="150" align="center"></el-table-column>
<el-table-column label="考核内容和计分细则" min-width="200" align="center" prop="content"></el-table-column>
<el-table-column label="小条内容" min-width="150" align="center" prop="littleContent"></el-table-column>
<el-table-column label="分值" min-width="60" align="center" prop="points"></el-table-column>
<el-table-column label="区牵头单位" min-width="80" align="center" prop="leaderUnit"></el-table-column>
<el-table-column label="牵头部门" min-width="80" align="center" prop="leaderDeptList"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center"></el-table-column>
<el-table-column label="配合部门" min-width="80" align="center" prop="cooperateDept"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center" prop="cooperateDeptList"></el-table-column>
<el-table-column
label="操作"
width="125"
align="center"
:key="Math.random()"
>
<template slot-scope="{ row }">
<router-link
:to="{name:'segmentation', params:{row, type: 3}}"
>分项</router-link
>
</template>
</el-table-column>
</el-table>
<el-pagination
:current-page.sync="page.page"
:page-size="page.limit"
:total="count"
:background="true"
layout="total, prev, pager, next, jumper"
:pager-count="5"
class="ele-pagination-circle"
:flat="true"
@current-change="getDataList()"
/>
</el-card>
</div>
</template>

<script>
import search from "../search";

export default {
components: {
search,
},
data() {
return {
searchParams: {},
dataList: [
{quota1:'sdewfdewd',}
],
loading: false,
form: {},
quota1List:[],
quota2List:[],
count: 0,
tableHeight: document.documentElement.clientHeight - 355,
page: {
page: 1,
limit: Math.floor(
(document.documentElement.clientHeight - 355 - 45) / 45
),
},
};
},
created() {
this.getDataList();
},
methods: {
getDataList() {},
}
};
</script>

<style scoped>
a {
text-decoration:none;
color:#66B1FF;
}
</style>

src/views/assessingTarget/assessingContent/contentDetail.vue → src/views/second/segmentation/contentDetail.vue 查看文件

@@ -1,13 +1,18 @@
<template>
<div class="content-detail content-box">
<div class="base-info">
<div class="content-detail content-box ele-body">
<el-card shadow="never" element-loading-background="rgba(255, 255, 255, 1)">
<div class="base-info">
<div class="title">基础信息:</div>
<div class="body">
<el-row>
<el-row v-if="type==1 || type == 2">
<el-col :span="5" class="grey">一级指标</el-col>
<el-col :span="7"></el-col>
<el-col :span="5" class="grey">二级指标</el-col>
<el-col :span="7"></el-col>
</el-row>
<el-row v-if="type==3">
<el-col :span="5" class="grey">考核指标</el-col>
<el-col :span="19"></el-col>
</el-row>
<el-row>
<el-col :span="5" class="grey">区牵头单位</el-col>
@@ -52,7 +57,7 @@
label="小项内容"
align="center"
min-width="150"
max-width="250"
max-width="200"
></el-table-column>
<el-table-column
label="分值"
@@ -62,8 +67,25 @@
<el-table-column
label="牵头部门"
align="center"
width="100"
></el-table-column>
width="180"
>
<treeselect
v-model="dataList.leaderDept"
:options="formatDep"
placeholder="请选择牵头部门"
:defaultExpandLevel="1"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0 ? d.children : undefined,
};
}
"
/>
</el-table-column>
<el-table-column
label="责任领导"
align="center"
@@ -72,8 +94,27 @@
<el-table-column
label="配合部门"
align="center"
width="100"
></el-table-column>
width="180"
>
<template>
<treeselect
v-model="dataList.cooperateDept"
:options="formatDep"
placeholder="请选择配合部门"
:defaultExpandLevel="1"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0 ? d.children : undefined,
};
}
"
/>
</template>
</el-table-column>
<el-table-column
label="责任领导"
align="center"
@@ -87,17 +128,52 @@
</el-table-column>
</el-table>
</div>
<div slot="footer" class="footer">
<el-button type="primary" @click="save">确定</el-button>
<el-button @click="close">取消</el-button>&nbsp;
</div>
</div>
</el-card>
</div>
</template>

<script>
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
import Treeselect from "@riophae/vue-treeselect";
import { mapGetters } from "vuex";
export default {
props:{
row:{
type: Object
},
type: {
type: Number
}
},
components: {
Treeselect
},
data() {
return {
dataList: [],
dataList: [
{}
],
};
},
computed: {
...mapGetters(["formatDep"]),
},
created() {
},
methods: {
save() {
this.$router.back(-1)
},
close() {
this.$router.back(-1)
}
}
};
</script>

@@ -123,6 +199,10 @@ export default {
text-align: center;
}
.grey {
background: #e0e0e0;
background: #eeeeee;
}
.footer {
margin-top: 20px;
text-align: center;
}
</style>

+ 90
- 0
src/views/second/segmentation/reward.vue 查看文件

@@ -0,0 +1,90 @@
<template>
<div class="assessing-content ele-body">
<el-card shadow="never" v-loading="loading" element-loading-background="rgba(255, 255, 255, 1)">
<search :type="1" :search-params="searchParams" />
<div class="operating">
<el-button size="small" type="primary">导出</el-button>
</div>
<el-table highlight-current-row :data="dataList" :height="tableHeight" border>
<el-table-column type="index" width="50" align="center" label="编号"></el-table-column>
<el-table-column label="一级指标" min-width="150" align="center" prop="quota1"></el-table-column>
<el-table-column label="二级指标" min-width="150" align="center" prop="quota2"></el-table-column>
<el-table-column label="考核内容和计分细则" min-width="200" align="center" prop="content"></el-table-column>
<el-table-column label="小条内容" min-width="150" align="center" prop="littleContent"></el-table-column>
<el-table-column label="分值" min-width="60" align="center" prop="points"></el-table-column>
<el-table-column label="区牵头单位" min-width="80" align="center" prop="leaderUnit"></el-table-column>
<el-table-column label="牵头部门" min-width="80" align="center" prop="leaderDeptList"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center"></el-table-column>
<el-table-column label="配合部门" min-width="80" align="center" prop="cooperateDept"></el-table-column>
<el-table-column label="责任领导" min-width="80" align="center" prop="cooperateDeptList"></el-table-column>
<el-table-column
label="操作"
width="125"
align="center"
:key="Math.random()"
>
<template slot-scope="{ row }">
<router-link
:to="{name:'segmentation', params:{row, type: 2}}"
>分项</router-link
>
</template>
</el-table-column>
</el-table>
<el-pagination
:current-page.sync="page.page"
:page-size="page.limit"
:total="count"
:background="true"
layout="total, prev, pager, next, jumper"
:pager-count="5"
class="ele-pagination-circle"
:flat="true"
@current-change="getDataList()"
/>
</el-card>
</div>
</template>

<script>
import search from "../search";

export default {
components: {
search,
},
data() {
return {
searchParams: {},
dataList: [
{quota1:'sdewfdewd',}
],
loading: false,
form: {},
quota1List:[],
quota2List:[],
count: 0,
tableHeight: document.documentElement.clientHeight - 355,
page: {
page: 1,
limit: Math.floor(
(document.documentElement.clientHeight - 355 - 45) / 45
),
},
};
},
created() {
this.getDataList();
},
methods: {
getDataList() {},
}
};
</script>

<style scoped>
a {
text-decoration:none;
color:#66B1FF;
}
</style>

+ 69
- 20
src/views/second/taskSummary/basicTable.vue 查看文件

@@ -6,12 +6,7 @@
<el-button size="small" type="primary">导出</el-button>
</div>
<el-table highlight-current-row :data="dataList" :height="tableHeight" border>
<el-table-column
type="selection"
width="50"
align="center"
></el-table-column>
<el-table-column type="index" width="50" align="center" label="序号"></el-table-column>
<el-table-column type="index" width="50" align="center" label="编号"></el-table-column>
<el-table-column label="一级指标" min-width="150" align="center" prop="quota1"></el-table-column>
<el-table-column label="二级指标" min-width="150" align="center" prop="quota2"></el-table-column>
<el-table-column label="考核内容和计分细则" min-width="200" align="center" prop="content"></el-table-column>
@@ -52,7 +47,7 @@
/>
</el-card>

<el-dialog
<el-dialog
title="编辑考核内容"
:visible.sync="showEdit"
width="400px"
@@ -69,6 +64,59 @@
@submit.native.prevent
ref="editForm"
>
<el-form-item label="小条内容:" prop="">
<el-input
type="textarea"
:rows="5"
placeholder="请输入考核内容"
></el-input>
</el-form-item>
<el-form-item label="分值:" prop="">
<el-input placeholder="请输入分值"></el-input>
</el-form-item>

<el-form-item label="牵头部门:" prop="">
<treeselect
:flat="true"
:options="formatDep"
:multiple="true"
placeholder="请选择牵头部门"
:defaultExpandLevel="2"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0
? d.children
: undefined,
};
}
"
/>
</el-form-item>
<el-form-item label="配合部门:" prop="">
<treeselect
:flat="true"
:options="formatDep"
:multiple="true"
placeholder="请选择牵头部门"
:defaultExpandLevel="2"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0
? d.children
: undefined,
};
}
"
/>
</el-form-item>
</el-form>
<div slot="footer">
<el-button type="primary" @click="save">确定</el-button>
@@ -79,26 +127,24 @@
</template>

<script>
import search from "./search";
import search from "../search";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
import Treeselect from "@riophae/vue-treeselect";
import { mapGetters } from "vuex";
export default {
components: {
search,
Treeselect
},
data() {
return {
searchParams: {},
dataList: [],
dataList: [
{quota1:'sdewfdewd',}
],
loading: false,
showEdit: false,
form: {
quota1: "",
quota2: "",
leaderDept: undefined,
cooperateDept: undefined,
quota: "",
content: "",
leaderUnit: "",
},
form: {},
quota1List:[],
quota2List:[],
count: 0,
@@ -114,13 +160,16 @@ export default {
created() {
this.getDataList();
},
computed: {
...mapGetters(["formatDep"]),
},
methods: {
getDataList() {},
edit(row) {
this.showEdit = true
},
save() {
this.showEdit = false
}
}
};

+ 94
- 9
src/views/second/taskSummary/constraint.vue 查看文件

@@ -6,12 +6,7 @@
<el-button size="small" type="primary">导出</el-button>
</div>
<el-table highlight-current-row :data="dataList" :height="tableHeight" border>
<el-table-column
type="selection"
width="50"
align="center"
></el-table-column>
<el-table-column type="index" width="50" align="center" label="序号"></el-table-column>
<el-table-column type="index" width="50" align="center" label="编号"></el-table-column>
<el-table-column label="考核指标" min-width="150" align="center"></el-table-column>
<el-table-column label="考核内容和计分细则" min-width="200" align="center"></el-table-column>
<el-table-column label="小条内容" min-width="150" align="center"></el-table-column>
@@ -51,20 +46,104 @@
@current-change="getDataList()"
/>
</el-card>
<el-dialog
title="编辑考核内容"
:visible.sync="showEdit"
width="400px"
custom-class="ele-dialog-form"
:lock-scroll="false"
:destroy-on-close="true"
@closed="form = {}"
>
<el-form
:model="form"
label-width="82px"
custom-class="editForm"
@keyup.enter.native="save"
@submit.native.prevent
ref="editForm"
>
<el-form-item label="小条内容:" prop="">
<el-input
type="textarea"
:rows="5"
placeholder="请输入考核内容"
></el-input>
</el-form-item>
<el-form-item label="分值:" prop="">
<el-input placeholder="请输入分值"></el-input>
</el-form-item>

<el-form-item label="牵头部门:" prop="">
<treeselect
:flat="true"
:options="formatDep"
:multiple="true"
placeholder="请选择牵头部门"
:defaultExpandLevel="2"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0
? d.children
: undefined,
};
}
"
/>
</el-form-item>
<el-form-item label="配合部门:" prop="">
<treeselect
:flat="true"
:options="formatDep"
:multiple="true"
placeholder="请选择牵头部门"
:defaultExpandLevel="2"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0
? d.children
: undefined,
};
}
"
/>
</el-form-item>
</el-form>
<div slot="footer">
<el-button type="primary" @click="save">确定</el-button>
<el-button @click="showEdit = false">取消</el-button>&nbsp;
</div>
</el-dialog>
</div>
</template>

<script>
import search from "./search";
import search from "../search";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
import Treeselect from "@riophae/vue-treeselect";
import { mapGetters } from "vuex";
export default {
components: {
search,
Treeselect
},
data() {
return {
searchParams: {},
dataList: [],
dataList: [
{}
],
loading: false,
showEdit: false,
form: {},
count: 0,
tableHeight: document.documentElement.clientHeight - 305,
page: {
@@ -78,10 +157,16 @@ export default {
created() {
this.getDataList();
},
computed: {
...mapGetters(["formatDep"]),
},
methods: {
getDataList() {},
edit(row) {

this.showEdit = true
},
save() {
this.showEdit = false
}
}
};

+ 96
- 11
src/views/second/taskSummary/reward.vue 查看文件

@@ -6,13 +6,8 @@
<el-button size="small" type="primary">导出</el-button>
</div>
<el-table highlight-current-row :data="dataList" :height="tableHeight" border>
<el-table-column
type="selection"
width="50"
align="center"
></el-table-column>
<el-table-column type="index" width="50" align="center" label="序号"></el-table-column>
<el-table-column label="一级指标" min-width="150" align="center" prop=""></el-table-column>
<el-table-column type="index" width="50" align="center" label="编号"></el-table-column>
<el-table-column label="一级指标" min-width="150" align="center" prop="quota1"></el-table-column>
<el-table-column label="二级指标" min-width="150" align="center" prop=""></el-table-column>
<el-table-column label="考核内容和计分细则" min-width="200" align="center" prop=""></el-table-column>
<el-table-column label="小条内容" min-width="150" align="center" prop=""></el-table-column>
@@ -51,20 +46,104 @@
:flat="true"
@current-change="getDataList()"
/>
<el-dialog
title="编辑考核内容"
:visible.sync="showEdit"
width="400px"
custom-class="ele-dialog-form"
:lock-scroll="false"
:destroy-on-close="true"
@closed="form = {}"
>
<el-form
:model="form"
label-width="82px"
custom-class="editForm"
@keyup.enter.native="save"
@submit.native.prevent
ref="editForm"
>
<el-form-item label="小条内容:" prop="">
<el-input
type="textarea"
:rows="5"
placeholder="请输入考核内容"
></el-input>
</el-form-item>
<el-form-item label="分值:" prop="">
<el-input placeholder="请输入分值"></el-input>
</el-form-item>

<el-form-item label="牵头部门:" prop="">
<treeselect
:flat="true"
:options="formatDep"
:multiple="true"
placeholder="请选择牵头部门"
:defaultExpandLevel="2"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0
? d.children
: undefined,
};
}
"
/>
</el-form-item>
<el-form-item label="配合部门:" prop="">
<treeselect
:flat="true"
:options="formatDep"
:multiple="true"
placeholder="请选择牵头部门"
:defaultExpandLevel="2"
:normalizer="
(d) => {
return {
id: d.id,
label: d.name,
children:
d.children && d.children.length > 0
? d.children
: undefined,
};
}
"
/>
</el-form-item>
</el-form>
<div slot="footer">
<el-button type="primary" @click="save">确定</el-button>
<el-button @click="showEdit = false">取消</el-button>&nbsp;
</div>
</el-dialog>
</el-card>
</div>
</template>

<script>
import search from "./search";
import search from "../search";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
import Treeselect from "@riophae/vue-treeselect";
import { mapGetters } from "vuex";
export default {
components: {
search,
Treeselect
},
data() {
return {
searchParams: {},
dataList: [],
dataList: [
{quota1:'sdewfdewd',}
],
showEdit: false,
form: {},
loading: false,
count: 0,
tableHeight: document.documentElement.clientHeight - 355,
@@ -79,10 +158,16 @@ export default {
created() {
this.getDataList();
},
computed: {
...mapGetters(["formatDep"]),
},
methods: {
getDataList() {},
edit (row) {

edit(row) {
this.showEdit = true
},
save() {
this.showEdit = false
}
}
};

Loading…
取消
儲存