Browse Source

任务优化

master
陈裕财 4 years ago
parent
commit
3489ae9370
  1. 1
      src/styles/mdp.scss
  2. 52
      src/views/xm/core/xmTask/XmPhase.vue
  3. 12
      src/views/xm/core/xmTask/XmPlan.vue

1
src/styles/mdp.scss

@ -247,6 +247,7 @@ table tr.hover-row{
} }
.el-table__row td:hover{ .el-table__row td:hover{
cursor: pointer;
.cell-bar{ .cell-bar{
display: inline; display: inline;
.u-btn{ .u-btn{

52
src/views/xm/core/xmTask/XmPhase.vue

@ -15,7 +15,7 @@
placement="top-start" placement="top-start"
title="选择创建计划/任务的方式" title="选择创建计划/任务的方式"
width="300" width="300"
trigger="hover"
trigger="click"
> >
<el-row> <el-row>
<el-col :span="24" style="padding-top: 5px"> <el-col :span="24" style="padding-top: 5px">
@ -67,7 +67,7 @@
v-loading="load.edit" v-loading="load.edit"
> </el-button> > </el-button>
<el-button type="danger" <el-button type="danger"
v-if="isTaskCenter != '1' && isMy != '1'"
class="hidden-md-and-down"
@click="batchDel" @click="batchDel"
v-loading="load.del" v-loading="load.del"
icon="el-icon-delete" icon="el-icon-delete"
@ -79,9 +79,14 @@
placement="top-start" placement="top-start"
title="" title=""
width="400" width="400"
trigger="click"
trigger="manual"
v-model="moreVisible"
> >
<el-row> <el-row>
<el-col :span="24" style="padding-top: 5px" v-if="editForm && editForm.id">
<font class="more-label-font">当前选中的计划:</font>
<el-tag closable @close="unselectRow()">{{editForm.name}}</el-tag>
</el-col>
<el-col :span="24" style="padding-top: 5px"> <el-col :span="24" style="padding-top: 5px">
<font class="more-label-font">产品:</font <font class="more-label-font">产品:</font
> <xm-product-select :auto-select="false" :link-project-id="filters.selProject && filters.selProject.id?filters.selProject.id:null" @row-click="onProductSelected" @clear="onProductClearSelect"></xm-product-select> > <xm-product-select :auto-select="false" :link-project-id="filters.selProject && filters.selProject.id?filters.selProject.id:null" @row-click="onProductSelected" @clear="onProductClearSelect"></xm-product-select>
@ -132,9 +137,15 @@
@click="searchXmTasks" @click="searchXmTasks"
>查询</el-button >查询</el-button
> >
<el-button
type="text"
icon="el-icon-close"
@click="moreVisible=false"
>关闭</el-button
>
</el-col> </el-col>
</el-row> </el-row>
<el-button style="margin-top: 10px;" slot="reference">更多</el-button>
<el-button style="margin-top: 10px;" slot="reference" @click="moreVisible=true">更多</el-button>
</el-popover> </el-popover>
</span> </span>
</el-row> </el-row>
@ -172,9 +183,11 @@
min-width="300" min-width="300"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<!--
<div class="icon" :style="{backgroundColor: scope.row.ntype==='1'?'#E6A23C':'#409EFF'}"> <div class="icon" :style="{backgroundColor: scope.row.ntype==='1'?'#E6A23C':'#409EFF'}">
<i :class="scope.row.ntype==='1'?'el-icon-odometer':'el-icon-s-operation'" ></i> <i :class="scope.row.ntype==='1'?'el-icon-odometer':'el-icon-s-operation'" ></i>
</div> </div>
-->
<span> <span>
{{ scope.row.sortLevel }}&nbsp; {{ scope.row.name }} {{ scope.row.sortLevel }}&nbsp; {{ scope.row.name }}
</span> </span>
@ -185,14 +198,14 @@
class="el-icon-refresh" class="el-icon-refresh"
> >
{{ (scope.row.rate != null ? scope.row.rate : 0) + "%" }} {{ (scope.row.rate != null ? scope.row.rate : 0) + "%" }}
</el-link>
</el-link> <el-tag v-for="(item,index) in formatDictsWithClass(dicts,'taskState',scope.row.taskState)" :key="index" :type="item.className">{{item.name}}</el-tag>
<div class="tool-bar"> <div class="tool-bar">
<span class="u-btn"> <span class="u-btn">
<el-popover <el-popover
placement="top-start" placement="top-start"
title="选择创建计划/任务的方式" title="选择创建计划/任务的方式"
width="300" width="300"
trigger="hover"
trigger="click"
> >
<el-row> <el-row>
<el-col :span="24" style="padding-top: 5px"> <el-col :span="24" style="padding-top: 5px">
@ -232,24 +245,6 @@
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column
label="状态"
type="taskState"
width="100"
>
<template slot-scope="scope"
>
<div class="cell-text">
<el-tag v-for="(item,index) in formatDictsWithClass(dicts,'taskState',scope.row.taskState)" :key="index" :type="item.className">{{item.name}}</el-tag>
</div>
<span class="cell-bar">
<el-select @visible-change="selectVisible(scope.row,$event)" v-model="scope.row.taskState" placeholder="任务状态" style="display:block;" @change="editXmTaskSomeFields(scope.row,'taskState',$event)">
<el-option :value="item.id" :label="item.name" v-for="(item,index) in dicts.taskState" :key="index"></el-option>
</el-select>
</span>
</template>
</el-table-column>
</el-table> </el-table>
<el-pagination <el-pagination
ref="pagination" ref="pagination"
@ -546,6 +541,7 @@ export default {
selectParentTaskVisible:false, selectParentTaskVisible:false,
execUserVisible:false, execUserVisible:false,
epicFeaturesForImportTaskVisible:false, epicFeaturesForImportTaskVisible:false,
moreVisible:false,
}; };
}, //end data }, //end data
methods: { methods: {
@ -709,6 +705,11 @@ export default {
this.onTaskTemplatesSelected(menus2); this.onTaskTemplatesSelected(menus2);
this.epicFeaturesForImportTaskVisible = false; this.epicFeaturesForImportTaskVisible = false;
}, },
unselectRow(){
this.$refs.table.setCurrentRow();
this.editForm=null;
this.$emit("row-click",null)
},
// XmTask xm_task // XmTask xm_task
showEdit: function (row, index) { showEdit: function (row, index) {
@ -867,9 +868,6 @@ export default {
}, },
rowClick: function (row,column) { rowClick: function (row,column) {
if(this.editForm && row.id===this.editForm.id){ if(this.editForm && row.id===this.editForm.id){
this.$emit('row-click',null)
this.editForm=null
this.$refs.table.setCurrentRow();
return; return;
} }
this.editForm = row; this.editForm = row;

12
src/views/xm/core/xmTask/XmPlan.vue

@ -1,7 +1,7 @@
<template> <template>
<section> <section>
<el-row>
<el-col :span="8">
<el-row class="box">
<el-col :span="8" class="left">
<xm-phase :xm-product="xmProduct" :sel-project="selProject" queryScope="plan" @row-click="onPhaseRowClick"></xm-phase> <xm-phase :xm-product="xmProduct" :sel-project="selProject" queryScope="plan" @row-click="onPhaseRowClick"></xm-phase>
</el-col> </el-col>
<el-col :span="16"> <el-col :span="16">
@ -55,6 +55,10 @@
</script> </script>
<style scoped>
<style lang="less" scoped>
.box{
.left{
background-color:#f4f5f8;
}
}
</style> </style>
Loading…
Cancel
Save