提交 4b59616c 编写于 作者: bo.dang's avatar bo.dang

Merge remote-tracking branch 'origin/dev-followUp-20190312' into dev-followUp-20190312

...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
"build": "node build/build.js", "build": "node build/build.js",
"build:dev": "cross-env BUILD_ENV=dev node build/build.js", "build:dev": "cross-env BUILD_ENV=dev node build/build.js",
"build:test": "cross-env BUILD_ENV=test node build/build.js", "build:test": "cross-env BUILD_ENV=test node build/build.js",
"build:test2": "cross-env BUILD_ENV=test node build/build.js",
"build:uat": "cross-env BUILD_ENV=uat node build/build.js", "build:uat": "cross-env BUILD_ENV=uat node build/build.js",
"build:pro": "cross-env BUILD_ENV=pro node build/build.js" "build:pro": "cross-env BUILD_ENV=pro node build/build.js"
}, },
......
...@@ -136,6 +136,9 @@ export default { ...@@ -136,6 +136,9 @@ export default {
...payload ...payload
}).then(({data}) => { }).then(({data}) => {
context.commit('GET_RESIDENT_LIST', data); context.commit('GET_RESIDENT_LIST', data);
context.dispatch('getSelectResident',{
planId: payload.planId
})
}); });
}, },
getGroupList(context, payload) { getGroupList(context, payload) {
...@@ -159,6 +162,9 @@ export default { ...@@ -159,6 +162,9 @@ export default {
getPlanDetail(context, payload) { getPlanDetail(context, payload) {
getPlanDetail(payload).then(({data}) => { getPlanDetail(payload).then(({data}) => {
context.commit('GET_PLAN_DETAIL', data); context.commit('GET_PLAN_DETAIL', data);
context.dispatch('getSelectResident',{
planId: data.id
})
}); });
}, },
getRemarkOption(context, payload) { getRemarkOption(context, payload) {
...@@ -261,6 +267,7 @@ export default { ...@@ -261,6 +267,7 @@ export default {
}, },
getSelectResident(context, payload) { getSelectResident(context, payload) {
getResidentList({ getResidentList({
needEnd: 1,
...payload ...payload
}).then(({data}) => { }).then(({data}) => {
context.commit('GET_SELECT_RESIDENT', data); context.commit('GET_SELECT_RESIDENT', data);
......
...@@ -42,6 +42,17 @@ export const envConfig = { ...@@ -42,6 +42,17 @@ export const envConfig = {
yuequeyiIndexUrl: 'https://test1.yunqueyi.com/pica_index.html', yuequeyiIndexUrl: 'https://test1.yunqueyi.com/pica_index.html',
saasDomainUrl: 'https://test1.yunqueyi.com/', saasDomainUrl: 'https://test1.yunqueyi.com/',
}, },
test2: {
baseUrl: 'https://test1-sc.yunqueyi.com/',
qiniuFileUrl: "https://test1-sc.yunqueyi.com/contents/admin/qiniu/token1",
qiniuResourceUrl: "https://test1-videos.yunqueyi.com",
qiniuImgUrl: "https://test1-file.yunqueyi.com",
loginUrl: 'https://test1.yunqueyi.com/pica-login/work_station.html',
innerLoginUrl: 'https://test1-sso.yunqueyi.com/PICA_SSO_FE/html/pica_index.html',
followUpSC: 'https://test2-work.yunqueyi.com/sc',
yuequeyiIndexUrl: 'https://test1.yunqueyi.com/pica_index.html',
saasDomainUrl: 'https://test1.yunqueyi.com/',
},
uat: { uat: {
baseUrl: 'https://uat-sc.yunqueyi.com/', baseUrl: 'https://uat-sc.yunqueyi.com/',
qiniuFileUrl: "https://uat-sc.yunqueyi.com/contents/admin/qiniu/token1", qiniuFileUrl: "https://uat-sc.yunqueyi.com/contents/admin/qiniu/token1",
......
...@@ -10,7 +10,13 @@ ...@@ -10,7 +10,13 @@
width="65%" width="65%"
center> center>
<div class="finish-content"> <div class="finish-content">
<el-form ref="searchData" :model="searchData" :inline="true" class="select-width" size="small"> <el-form
ref="searchData"
:model="searchData"
:inline="true"
class="select-width"
size="small">
<el-form-item> <el-form-item>
<el-select v-model="searchData.sex" @change="changeSex"> <el-select v-model="searchData.sex" @change="changeSex">
<el-option <el-option
...@@ -62,10 +68,13 @@ ...@@ -62,10 +68,13 @@
ref="multipleTable" ref="multipleTable"
center center
style="width: 100%;margin-top: 20px;" style="width: 100%;margin-top: 20px;"
:row-key="getRowKeys"
@selection-change="handleSelectionChange"> @selection-change="handleSelectionChange">
<el-table-column <el-table-column
type="selection" type="selection"
align="center"> align="center"
:reserve-selection="true"
:selectable="checkboxInit">
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="nickname" prop="nickname"
...@@ -89,13 +98,13 @@ ...@@ -89,13 +98,13 @@
min-width="150px"> min-width="150px">
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="diseaseId" prop="showDiseaseNames"
label="基础疾病" label="基础疾病"
align="center" align="center"
:show-overflow-tooltip="true"> :show-overflow-tooltip="true">
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="labelId" prop="showLabelName"
label="分组" label="分组"
align="center" align="center"
:show-overflow-tooltip="true"> :show-overflow-tooltip="true">
...@@ -124,7 +133,7 @@ ...@@ -124,7 +133,7 @@
</template> </template>
<script> <script>
import { mapState, mapActions } from 'vuex'
import { getBasicData, getPlanPatientsList, getAllDiseases, getAllLabels } from '@/utils/followup/followapis' import { getBasicData, getPlanPatientsList, getAllDiseases, getAllLabels } from '@/utils/followup/followapis'
export default { export default {
components: {}, components: {},
...@@ -133,7 +142,7 @@ ...@@ -133,7 +142,7 @@
return { return {
showSelectPatient: true, showSelectPatient: true,
allSelects: [], allSelects: [],
eachSelects: [],//仅仅是操作选择的总人员 // eachSelects: [],//仅仅是操作选择的总人员
// totalSelect: [],// 当前所选的人 // totalSelect: [],// 当前所选的人
labelId: '', labelId: '',
diseaseId: '', diseaseId: '',
...@@ -143,7 +152,6 @@ ...@@ -143,7 +152,6 @@
ageEnd: '', ageEnd: '',
srvPackageId: '', srvPackageId: '',
searchCondition: '', searchCondition: '',
patientsData: [], patientsData: [],
searchData: { searchData: {
sex: '性别', sex: '性别',
...@@ -175,12 +183,22 @@ ...@@ -175,12 +183,22 @@
labelId: '', labelId: '',
labelName: '分组' labelName: '分组'
}], }],
trueAdd:[], //真正新加 newSelects: [], //新选中的人
getRowKeys(row) {
// console.log('sshkdhdk',row)
return row.patientId;
},
} }
}, },
computed: {
...mapState('planManage', {
eachSelects: state => state.eachSelects,
})
},
props: { props: {
isShowSelectPatient: Boolean, //是否显示model, isShowSelectPatient: Boolean, //是否显示model,
patientIdList: Array,// 确定已经选过的居民 patientIdList: Array,// 确定已经选过的居民
oldPatientIdList: Array,// 确定已经选过的居民
}, },
watch: { watch: {
isShowSelectPatient(val){ isShowSelectPatient(val){
...@@ -221,31 +239,16 @@ ...@@ -221,31 +239,16 @@
}) })
} }
}, },
eachSelects(val, oldVal){
if(val.length&&oldVal.length) {
console.log('新',val);
console.log('新',oldVal);
if(val.length>oldVal.length) {
let add = val.filter(function(n) {
return oldVal.indexOf(n) == -1
});
this.trueAdd.push(add)
console.log('加人',this.trueAdd)
} else if(val.length<=oldVal.length) {
let reduce = oldVal.filter(function(n) {
return val.indexOf(n) == -1
});
/*this.trueAdd = this.trueAdd.filter(function(n) {
return reduce.indexOf(n) == -1
});*/
console.log('减人',reduce)
} else {
}
}
}
}, },
methods: { methods: {
checkboxInit(row,index){
if(row.disableNum == undefined) {
return 1
} else {
return row.disableNum
}
},
getPatientsList(){ getPatientsList(){
const data = { const data = {
pageSize: this.paginationSet.pageSize, pageSize: this.paginationSet.pageSize,
...@@ -265,15 +268,53 @@ ...@@ -265,15 +268,53 @@
this.getSex() this.getSex()
this.paginationSet.total = res.data.totalRows this.paginationSet.total = res.data.totalRows
// 设置所请求的当页人员是否成为选中状态 // 设置所请求的当页人员是否成为选中状态
if(this.patientIdList.length > 0){ // console.log('传入的已选居民',this.patientIdList)
this.patientsData.forEach((item)=>{
this.patientsData.forEach((item)=>{
item.disableNum = 1;
let diseaseNames = [];
let groupNames = []
//转化分组
if(item.labelModels) {
item.labelModels.forEach(item => {
groupNames.push(item.label)
});
item.showLabelName = groupNames.join('、');
} else {
item.showLabelName = '-';
}
//转化疾病
if(item.patientTypeModels) {
item.patientTypeModels.forEach(item => {
diseaseNames.push(item.name)
})
item.showDiseaseNames = diseaseNames.join('、');
}else {
item.showDiseaseNames = '-';
}
if(this.patientIdList.length > 0){
if(this.patientIdList.includes(item.patientId)){// 如果已经选过居民 if(this.patientIdList.includes(item.patientId)){// 如果已经选过居民
this.$nextTick(()=>{ this.$nextTick(()=>{
this.$refs.multipleTable.toggleRowSelection(item,true); this.$refs.multipleTable.toggleRowSelection(item,true);
}) })
} }
}) }
} if(this.oldPatientIdList!=undefined&&this.oldPatientIdList.length) {
this.patientsData.forEach((item)=>{
if(this.oldPatientIdList.includes(item.patientId)){// 如果已经选过居民
item.disableNum = 0
} else {
item.disableNum = 1
}
})
}
})
// console.log(this.oldPatientIdList)
}else{ }else{
this.patientsData = [] this.patientsData = []
} }
...@@ -296,12 +337,16 @@ ...@@ -296,12 +337,16 @@
}, },
// 选择居民 // 选择居民
handleSelectionChange(val) { handleSelectionChange(val) {
console.log('每次选中居民',val) const _this = this;
this.eachSelects = val _this.newSelects = [];
val.forEach(item => {
if(item.disableNum == 1) {
_this.newSelects.push(item)
}
})
}, },
// 切换分页 // 切换分页
handleCurrentChangePre(val) { handleCurrentChangePre(val) {
// console.log('handleCurrentChangePre')
this.paginationSet.pageNum = val this.paginationSet.pageNum = val
this.getPatientsList() this.getPatientsList()
}, },
...@@ -309,7 +354,7 @@ ...@@ -309,7 +354,7 @@
this.$emit('closeSelectPatient',false) this.$emit('closeSelectPatient',false)
}, },
sureClick(){ sureClick(){
this.$emit('sureSelectPatient',false,this.eachSelects) this.$emit('sureSelectPatient',false,this.newSelects)
}, },
handleSizeChangePre(val) { handleSizeChangePre(val) {
// console.log('handleSizeChangePre') // console.log('handleSizeChangePre')
......
...@@ -101,11 +101,11 @@ ...@@ -101,11 +101,11 @@
</el-option> </el-option>
</el-select> </el-select>
<el-button plain class="ml20" @click="goSelectCartoon" v-if="showConment(itemTimeForm.change,itemTimeForm.hasSelected)">选择健康漫画</el-button> <el-button plain class="ml20" @click="goSelectCartoon" v-if="showChoseComtent(itemTimeForm)">选择健康漫画</el-button>
<div class="selected-div ml20" v-if="itemTimeForm.hasSelected"> <div class="selected-div ml20" v-if="itemTimeForm.hasSelected">
<span>{{itemTimeForm.comentMsg.header_name}}</span> <span>{{itemTimeForm.comentMsg.header_name}}</span>
<el-button type="text" @click="goSelectCartoon" v-if="!isStandedTemplate">重选</el-button> <el-button type="text" @click="goSelectCartoon" v-if="showRechoseDelete(itemTimeForm)">重选</el-button>
<el-button type="text" @click="deleteClick" v-if="!isStandedTemplate">删除</el-button> <el-button type="text" @click="deleteClick" v-if="showRechoseDelete(itemTimeForm)">删除</el-button>
</div> </div>
</div> </div>
</el-form-item> </el-form-item>
...@@ -311,22 +311,29 @@ ...@@ -311,22 +311,29 @@
}, },
created() { created() {
this.setTimeNodeList = this.standedTimeNodeList
this.initNewForm();
this.getConstData(); this.getConstData();
// 如果是固定模板 // 如果是固定模板
// console.log(this.planId) if(!this.isStandedTemplate && !this.planId){//新建计划并且是自定义模板
if(this.isStandedTemplate || this.planId){ this.initNewForm();
this.activeTab = 0;
} }
}, },
watch: { watch: {
standedTimeNodeList(val){ standedTimeNodeList(val){
this.setTimeNodeList = val this.setTimeNodeList = val
if(this.planId){//这一步,是处理新建计划选择固定模板,或者修改计划(无论固定还是自定义模板)监听传递进来的list
this.activeTab = 0;
this.timeForm = this.setTimeNodeList[this.activeTab]
this.timeForm.formRef = 'form' + this.activeTab;
}
this.$forceUpdate(); this.$forceUpdate();
}, },
isStandedTemplate(val){ isStandedTemplate(val){
this.isStandedTemplate = val this.isStandedTemplate = val
console.log('是否固定模板',this.isStandedTemplate)
if(this.isStandedTemplate){
this.setTimeNodeList = this.standedTimeNodeList
this.activeTab = 0;
}
}, },
setTimeNodeList(val){ setTimeNodeList(val){
this.setTimeNodeList = val this.setTimeNodeList = val
...@@ -424,6 +431,7 @@ ...@@ -424,6 +431,7 @@
}else{ //自定义模板 }else{ //自定义模板
// 如果直接点击保存,需要进行对当前填写的表单进行校验 // 如果直接点击保存,需要进行对当前填写的表单进行校验
console.log(this.timeForm)
const isValied = this.checkCurrentForm(this.timeForm.formRef); const isValied = this.checkCurrentForm(this.timeForm.formRef);
this.isValied = isValied this.isValied = isValied
if(isValied){ if(isValied){
...@@ -439,14 +447,12 @@ ...@@ -439,14 +447,12 @@
// 新增成功之后 // 新增成功之后
this.setTimeNodeList = this.sortKey(this.setTimeNodeList,'timeNo') this.setTimeNodeList = this.sortKey(this.setTimeNodeList,'timeNo')
}
if(this.isValied){
this.$emit('addListenSave',{ this.$emit('addListenSave',{
status: true, status: true,
setTimeNodeList: this.setTimeNodeList setTimeNodeList: this.setTimeNodeList
}) })
}else{ }else{
this.$emit('addListenSave',{ this.$emit('addListenSave',{
status: false, status: false,
...@@ -611,20 +617,42 @@ ...@@ -611,20 +617,42 @@
}) })
} }
}, },
showConment(change,hasSelected){ // 是否显示选择添加漫画按钮
showChoseComtent(timeObj){
let flag; let flag;
if(this.isStandedTemplate){ if(this.isStandedTemplate){
flag = false flag = false
}else{ }else{
if(this.planId){ if(this.planId){
flag = (change && !hasSelected) ? true : false flag = (timeObj.change && !timeObj.id) ? true : false
}else{ }else{
flag = (!hasSelected) ? true : false flag = (!timeObj.id) ? true : false
}
}
return flag
},
// 是否显示删除重选漫画按钮
showRechoseDelete(timeObj){
let flag;
if(this.isStandedTemplate){
flag = false
}else{
if(this.planId){
if(timeObj.change){
if(timeObj.id){
flag = true
}else{
flag = false
}
}else{
flag = false
}
}else{
flag = (!timeObj.id) ? true : false
} }
} }
return flag return flag
}, },
// 初始化新的表单 // 初始化新的表单
initNewForm(){ initNewForm(){
const timeFormInit = { const timeFormInit = {
...@@ -703,16 +731,24 @@ ...@@ -703,16 +731,24 @@
this.$forceUpdate(); this.$forceUpdate();
}, },
deleteTimeNode(item, index) { deleteTimeNode(item, index) {
this.setTimeNodeList.splice(index, 1)
this.$confirm('是否删除该时间节点?', '', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
this.setTimeNodeList.splice(index, 1)
// this.activeTab = 0; // this.activeTab = 0;
// this.timeForm = this.setTimeNodeList[0]; // this.timeForm = this.setTimeNodeList[0];
if(this.setTimeNodeList.length == 0) { if(this.setTimeNodeList.length == 0) {
//新增一个form //新增一个form
this.activeTab = 'setNewRef'; this.activeTab = 'setNewRef';
this.showSetBtn = true; this.showSetBtn = true;
this.initNewForm(); this.initNewForm();
} }
this.$forceUpdate(); this.$forceUpdate();
})
}, },
deleteAddNode() { deleteAddNode() {
this.showSetBtn = false; this.showSetBtn = false;
......
...@@ -82,7 +82,6 @@ ...@@ -82,7 +82,6 @@
ref="getTimeNodeList" ref="getTimeNodeList"
:standedTimeNodeList="standedTimeNodeList" :standedTimeNodeList="standedTimeNodeList"
:isStandedTemplate="isStandedTemplate" :isStandedTemplate="isStandedTemplate"
@setTimeNodeListOnCom="setTimeNodeListOnCom"
:patientIdList="baseInfo.patientIdList" :patientIdList="baseInfo.patientIdList"
:checkForm="checkForm" :checkForm="checkForm"
@addListenSave="addListenSave" @addListenSave="addListenSave"
...@@ -175,7 +174,6 @@ ...@@ -175,7 +174,6 @@
}, },
computed: { computed: {
...mapState('planManage',{ ...mapState('planManage',{
// setTimeNodeList: state => state.setTimeNodeList,
remarkOption: state => state.remarkOption, remarkOption: state => state.remarkOption,
templateOptions: state => state.templateOptions, templateOptions: state => state.templateOptions,
}) })
...@@ -219,9 +217,6 @@ ...@@ -219,9 +217,6 @@
}) })
} }
}, },
setTimeNodeListOnCom(val){
this.getTimeNodeList(val)
},
selectPatientHandler() { selectPatientHandler() {
this.isShowSelectPatient = true; this.isShowSelectPatient = true;
}, },
...@@ -238,13 +233,13 @@ ...@@ -238,13 +233,13 @@
let getArguments = arguments[0]; let getArguments = arguments[0];
this.isShowSelectPatient = getArguments[0]; this.isShowSelectPatient = getArguments[0];
const selectPatients = getArguments[1]; // 每次选中获取的人 const selectPatients = getArguments[1]; // 每次选中获取的人
this.hasSelectedList = selectPatients;
console.log('呵呵呵呵',arguments)
this.baseInfo.patientIdList = [];
selectPatients.forEach((item)=>{ selectPatients.forEach((item)=>{
if(!this.baseInfo.patientIdList.includes(item.patientId)){ this.baseInfo.patientIdList.push(item.patientId);
this.hasSelectedList.push(item)
this.baseInfo.patientIdList.push(item.patientId); // 页面中数据存储所有选择的人,没有去重
}
}) })
this.baseInfo.hasSelectedNum = this.baseInfo.patientIdList.length; this.baseInfo.hasSelectedNum = this.hasSelectedList.length;
}, },
continueAdd(val) { continueAdd(val) {
this.isShowSelectedDialog = val; this.isShowSelectedDialog = val;
...@@ -277,6 +272,7 @@ ...@@ -277,6 +272,7 @@
if (valid) { if (valid) {
console.log('当前选择的随访模板id为',this.baseInfo.resourceId) console.log('当前选择的随访模板id为',this.baseInfo.resourceId)
this.resourceId = this.baseInfo.resourceId this.resourceId = this.baseInfo.resourceId
console.log( this.baseInfo.resourceId)
if(this.baseInfo.resourceId){ if(this.baseInfo.resourceId){
this.isStandedTemplate = true this.isStandedTemplate = true
getFollowupTableTemplate(this.baseInfo.resourceId).then(res=>{ getFollowupTableTemplate(this.baseInfo.resourceId).then(res=>{
......
...@@ -149,7 +149,7 @@ ...@@ -149,7 +149,7 @@
href: `#/followup/plan-manage/plan-detail?planId=${this.$route.query.planId}` href: `#/followup/plan-manage/plan-detail?planId=${this.$route.query.planId}`
}, },
{ {
name: '居民列表', name: '查看居民',
href: null href: null
} }
] ]
......
...@@ -196,7 +196,7 @@ ...@@ -196,7 +196,7 @@
href: `#/followup/plan-manage/plan-list` href: `#/followup/plan-manage/plan-list`
}, },
{ {
name: '居民列表', name: '查看居民',
href: null href: null
} }
] ]
......
<template> <template>
<div class="plan-modify"> <div class="plan-modify">
<div class="bread-crumb"> <div class="bread-crumb">
<el-breadcrumb separator-class="el-icon-arrow-right" > <el-breadcrumb separator="/" >
<el-breadcrumb-item v-for="item in planModifyCrumb"> <el-breadcrumb-item v-for="item in planModifyCrumb">
<a v-if="item.href" :href="item.href">{{item.name}}</a> <a v-if="item.href" :href="item.href">{{item.name}}</a>
<span v-else >{{item.name}}</span> <span v-else >{{item.name}}</span>
...@@ -54,7 +54,6 @@ ...@@ -54,7 +54,6 @@
:isStandedTemplate="isStandedTemplate" :isStandedTemplate="isStandedTemplate"
:standedTimeNodeList="setTimeNodeList" :standedTimeNodeList="setTimeNodeList"
:patientIdList="planDetailData.patientIdList" :patientIdList="planDetailData.patientIdList"
@setTimeNodeListOnCom="setTimeNodeListOnCom"
:checkForm="checkForm" :checkForm="checkForm"
:planId="planId" :planId="planId"
@addListenSave="addListenSave" @addListenSave="addListenSave"
...@@ -64,6 +63,7 @@ ...@@ -64,6 +63,7 @@
<select-patient <select-patient
:isShowSelectPatient="isShowSelectPatient" :isShowSelectPatient="isShowSelectPatient"
:patientIdList="planDetailData.patientIdList" :patientIdList="planDetailData.patientIdList"
:oldPatientIdList="selectResidentIdList"
@closeSelectPatient="closeSelectPatient" @closeSelectPatient="closeSelectPatient"
@sureSelectPatient="sureSelectPatient(arguments)"> @sureSelectPatient="sureSelectPatient(arguments)">
</select-patient> </select-patient>
...@@ -135,10 +135,12 @@ ...@@ -135,10 +135,12 @@
showFollowTime: false, //是否展示全部时间 showFollowTime: false, //是否展示全部时间
showAddPatientTime: false,//是否展示添加居民选择时间 showAddPatientTime: false,//是否展示添加居民选择时间
addPatientData: {}, //选择时间数据 addPatientData: {}, //选择时间数据
/*joinSelectedList: [], //新添加居民
joinPatientIdList: [], //新添加居民id oldSelect:[],
joinSelectedNames: [], //新添加居民名字*/ selectResidentIdList: [], //oldID
selectPatients: [], //选择居民列表已选人 newHasSelectedList: [],
initResidentList: [], //重置需要的居民列表
initResidentIdList: [], //重置需要的id
} }
}, },
created() { created() {
...@@ -146,9 +148,7 @@ ...@@ -146,9 +148,7 @@
this.getPlanDetail(this.$route.query.planId); //获取计划详情 this.getPlanDetail(this.$route.query.planId); //获取计划详情
this.getRemarkOption() this.getRemarkOption()
this.getNodeTimeList(this.$route.query.planId); // 获取随访时间列表 this.getNodeTimeList(this.$route.query.planId); // 获取随访时间列表
this.getSelectResident({
planId: this.$route.query.planId
}); //已选居民
let planModifyCrumbList = sessionStorage.getItem('planModifyCrumb'); let planModifyCrumbList = sessionStorage.getItem('planModifyCrumb');
this.planModifyCrumb = JSON.parse(planModifyCrumbList); this.planModifyCrumb = JSON.parse(planModifyCrumbList);
}, },
...@@ -158,7 +158,6 @@ ...@@ -158,7 +158,6 @@
nodeTimeList: state => state.nodeTimeList, nodeTimeList: state => state.nodeTimeList,
residentList: state => state.residentList, residentList: state => state.residentList,
remarkOption: state => state.remarkOption, remarkOption: state => state.remarkOption,
// setTimeNodeList: state => state.setTimeNodeList,
selectResidentList: state => state.selectResidentList selectResidentList: state => state.selectResidentList
}) })
}, },
...@@ -185,37 +184,39 @@ ...@@ -185,37 +184,39 @@
this.isShowSelectedDialog = val; this.isShowSelectedDialog = val;
}, },
sureSelectPatient() { sureSelectPatient() {
console.log('getArguments',arguments[0])
let getArguments = arguments[0]; let getArguments = arguments[0];
// alert(this.selectResidentList.length+'-'+getArguments[1].length)
this.isShowSelectPatient = getArguments[0]; this.isShowSelectPatient = getArguments[0];
this.selectPatients = getArguments[1]; // 每次选中获取的人 const newAddPatientList = getArguments[1]; // 新选中的人
let selectPeople = []; let showNames = [];
let selectPeopleIds = []; const newIds = [];
let selectNames = [] newAddPatientList.forEach(item => {
this.hasSelectedList.forEach(function (item) { showNames.push(item.nickname)
selectPeople.push(item) newIds.push(item.patientId)
});
this.patientIdList.forEach(function (item) {
selectPeopleIds.push(item)
}) })
this.selectPatients.forEach((item)=>{ this.newHasSelectedList = JSON.parse(JSON.stringify(this.initResidentList));
if(!this.planDetailData.patientIdList.includes(item.patientId)){// 页面中数据存储所有选择的人,没有去重 this.newHasSelectedList = this.newHasSelectedList.concat(newAddPatientList);
selectPeople.push(item); if(this.newHasSelectedList.length > this.hasSelectedList.length) {
selectPeopleIds.push(item.id) this.showAddPatientTime = true;
selectNames.push(item.nickname) if(showNames.length>4) {
const le = showNames.length
showNames = showNames.slice(0,4)
showNames = `${showNames.join('、')}${le}人`
} else {
showNames = showNames.join('、')
} }
}) this.addPatientData = {
this.addPatientData = { id: this.$route.query.planId,
id: this.$route.query.planId, addPatients: true,
addPatients: true, patientNames: showNames,
patientIdList: selectPeopleIds, }
patientNames: selectNames.join('、'), } else {
this.hasSelectedList = JSON.parse(JSON.stringify(this.newHasSelectedList));
this.planDetailData.patientIdList = JSON.parse(JSON.stringify(this.initResidentIdList));
const _this = this;
newAddPatientList.forEach(item => {
_this.planDetailData.patientIdList.push(item.patientId)
})
} }
this.showAddPatientTime = true
}, },
continueAdd(val) { continueAdd(val) {
this.isShowSelectedDialog = val; this.isShowSelectedDialog = val;
...@@ -294,43 +295,37 @@ ...@@ -294,43 +295,37 @@
closeFollowTime(isShow) { closeFollowTime(isShow) {
this.showFollowTime = isShow this.showFollowTime = isShow
}, },
setTimeNodeListOnCom(val){
this.getTimeNodeList(val)
},
closeAddPatientTime(isShow) { closeAddPatientTime(isShow) {
this.showAddPatientTime = isShow this.showAddPatientTime = isShow
}, },
sendJoinTime(joinData) { sendJoinTime(joinData) {
console.log('this.hasSelectedList new',this.hasSelectedList) const _this = this;
if(joinData) { if(joinData) {
// alert(joinData) _this.hasSelectedList = [];
_this.planDetailData.patientIdList = [];
this.planDetailData.joinTime =joinData; _this.newHasSelectedList.forEach(item => {
console.log('新添加时间',this.planDetailData.joinTime) _this.hasSelectedList.push(item)
this.selectPatients.forEach((item)=>{ _this.planDetailData.patientIdList.push(item.patientId)
if(!this.planDetailData.patientIdList.includes(item.patientId)){// 页面中数据存储所有选择的人,没有去重
this.hasSelectedList.push(item)
this.planDetailData.patientIdList.push(item.patientId);
}
}) })
this.planDetailData.hasSelectedNum = this.patientIdList.length; this.planDetailData.joinTime = joinData;
} else {
} }
}, },
}, },
watch: { watch: {
planDetail(val) { planDetail(val) {
// console.log(val) this.planDetailData = val;
this.planDetailData = val
this.setTimeNodeList = val.fPlanTimeReqList this.setTimeNodeList = val.fPlanTimeReqList
if(this.planDetailData.resourceId){ if(this.planDetailData.resourceId){
this.isStandedTemplate = true this.isStandedTemplate = true
}else{ }else{
this.isStandedTemplate = false this.isStandedTemplate = false
} }
}, },
selectResidentList(val) { selectResidentList(val) {
const _this = this const _this = this
_this.planDetailData.patientIdList = []
let people = {} let people = {}
if(val) { if(val) {
val.forEach(function (item, index) { val.forEach(function (item, index) {
...@@ -341,10 +336,14 @@ ...@@ -341,10 +336,14 @@
mobilePhone: item.mobilePhone, mobilePhone: item.mobilePhone,
labelId: item.labelName, labelId: item.labelName,
patientId: item.patientId patientId: item.patientId
} };
_this.patientIdList.push(item.patientId) _this.hasSelectedList.push(people);
_this.hasSelectedList.push(people) _this.planDetailData.patientIdList.push(item.patientId)
_this.selectResidentIdList.push(item.patientId)
_this.initResidentList.push(people);
_this.initResidentIdList.push(item.patientId);
}) })
_this.newHasSelectedList = JSON.parse(JSON.stringify(_this.initResidentIdList));
} }
} }
} }
...@@ -354,6 +353,23 @@ ...@@ -354,6 +353,23 @@
<style lang="scss" scoped> <style lang="scss" scoped>
@import '../../../style/followup/followup-common'; @import '../../../style/followup/followup-common';
@import '../../../style/followup/element-reset.css'; @import '../../../style/followup/element-reset.css';
.bread-crumb {
position: fixed;
left: 255px;
top: 64px;
width: 100%;
background: #fff;
height: 61px;
padding: 20px 20px 30px;
z-index: 99;
border-top: 3px solid #F0F2F5;
.el-breadcrumb__inner {
font-size: 14px;
}
a:hover {
color: #449284;
}
}
.header{ .header{
display: flex; display: flex;
align-items: center; align-items: center;
......
<template> <template>
<div class="resident-detail"> <div class="resident-detail">
<div class="bread-crumb"> <div class="bread-crumb">
<el-breadcrumb separator-class="el-icon-arrow-right" > <el-breadcrumb separator="/">
<el-breadcrumb-item v-for="item in residentCrumb"> <el-breadcrumb-item v-for="item in residentCrumb">
<a v-if="item.href" :href="item.href">{{item.name}}</a> <a v-if="item.href" :href="item.href">{{item.name}}</a>
<span v-else >{{item.name}}</span> <span v-else >{{item.name}}</span>
......
<template> <template>
<div class="resident-list"> <div class="resident-list">
<div class="bread-crumb"> <div class="bread-crumb">
<el-breadcrumb separator-class="el-icon-arrow-right" > <el-breadcrumb separator="/" >
<el-breadcrumb-item v-for="item in residentCrumb"> <el-breadcrumb-item v-for="item in residentCrumb">
<a v-if="item.href" :href="item.href">{{item.name}}</a> <a v-if="item.href" :href="item.href">{{item.name}}</a>
<span v-else >{{item.name}}</span> <span v-else >{{item.name}}</span>
...@@ -129,6 +129,7 @@ ...@@ -129,6 +129,7 @@
<select-patient <select-patient
:isShowSelectPatient="isShowSelectPatient" :isShowSelectPatient="isShowSelectPatient"
:patientIdList="initialPatientIdList" :patientIdList="initialPatientIdList"
:oldPatientIdList="initialPatientIdList"
@closeSelectPatient="closeSelectPatient" @closeSelectPatient="closeSelectPatient"
@sureSelectPatient="sureSelectPatient(arguments)"> @sureSelectPatient="sureSelectPatient(arguments)">
</select-patient> </select-patient>
...@@ -195,20 +196,20 @@ ...@@ -195,20 +196,20 @@
this.getFollowStartTimeList(this.$route.query.planId);// 获取随访时间列表 this.getFollowStartTimeList(this.$route.query.planId);// 获取随访时间列表
let residentCrumbList = sessionStorage.getItem('residentCrumb'); let residentCrumbList = sessionStorage.getItem('residentCrumb');
residentCrumbList = JSON.parse(residentCrumbList); residentCrumbList = JSON.parse(residentCrumbList);
if(residentCrumbList.length==4&&residentCrumbList[residentCrumbList.length-1].name!='居民列表') { if(residentCrumbList.length==4&&residentCrumbList[residentCrumbList.length-1].name!='查看居民') {
this.residentCrumb = residentCrumbList.slice(0,2) this.residentCrumb = residentCrumbList.slice(0,2)
this.residentCrumb.push( this.residentCrumb.push(
{ {
name: '居民列表', name: '查看居民',
href: null href: null
} }
) )
} else if(residentCrumbList.length>4&&residentCrumbList[residentCrumbList.length-1].name!='居民列表') { } else if(residentCrumbList.length>4&&residentCrumbList[residentCrumbList.length-1].name!='查看居民') {
this.residentCrumb = residentCrumbList.slice(0,3) this.residentCrumb = residentCrumbList.slice(0,3)
this.residentCrumb.push( this.residentCrumb.push(
{ {
name: '居民列表', name: '查看居民',
href: null href: null
} }
) )
...@@ -223,6 +224,7 @@ ...@@ -223,6 +224,7 @@
groupList: state => state.groupList, groupList: state => state.groupList,
planStatusOption: state => state.planStatusOption, planStatusOption: state => state.planStatusOption,
followStartTimeList: state => state.followStartTimeList, followStartTimeList: state => state.followStartTimeList,
selectResidentList: state => state.selectResidentList
}) })
}, },
methods: { methods: {
...@@ -256,7 +258,7 @@ ...@@ -256,7 +258,7 @@
href: `#/followup/plan-manage/plan-list` href: `#/followup/plan-manage/plan-list`
}, },
{ {
name: '居民列表', name: '查看居民',
href: `#/followup/plan-manage/resident-list?planId=${this.$route.query.planId}` href: `#/followup/plan-manage/resident-list?planId=${this.$route.query.planId}`
}, },
{ {
...@@ -279,7 +281,7 @@ ...@@ -279,7 +281,7 @@
href: `#/followup/plan-manage/plan-detail??planId=${this.$route.query.planId}` href: `#/followup/plan-manage/plan-detail??planId=${this.$route.query.planId}`
}, },
{ {
name: '居民列表', name: '查看居民',
href: `#/followup/plan-manage/resident-list?planId=${this.$route.query.planId}` href: `#/followup/plan-manage/resident-list?planId=${this.$route.query.planId}`
}, },
{ {
...@@ -334,10 +336,17 @@ ...@@ -334,10 +336,17 @@
patientNames.push(item.patientName) patientNames.push(item.patientName)
}); });
console.log(patientIds) console.log(patientIds)
if(patientNames.length>4) {
const le = patientNames.length
patientNames = patientNames.slice(0,4)
patientNames = `${patientNames.join('、')}${le}人`
} else {
patientNames = patientNames.join('、')
}
this.finishData = { this.finishData = {
changeCode: this.status, changeCode: this.status,
planId: this.$route.query.planId, planId: this.$route.query.planId,
patientName: patientNames.join('、'), patientName: patientNames,
patientIdList: patientIds, patientIdList: patientIds,
title: this.status==3?'恢复随访':'结束随访', title: this.status==3?'恢复随访':'结束随访',
reasonName: this.status==3?'恢复原因:':'结束原因:', reasonName: this.status==3?'恢复原因:':'结束原因:',
...@@ -369,30 +378,32 @@ ...@@ -369,30 +378,32 @@
this.showAddPatientTime = isShow this.showAddPatientTime = isShow
}, },
sureSelectPatient() { sureSelectPatient() {
console.log('arguments',arguments)
let getArguments = arguments[0]; let getArguments = arguments[0];
this.isShowSelectPatient = getArguments[0]; this.isShowSelectPatient = getArguments[0];
const selectPatients = getArguments[1]; // 每次选中获取的人 const selectPatients = getArguments[1]; // 每次选中获取的人
// this.hasSelectedList = selectPatients;
console.log(selectPatients)
let patientIds = [] let patientIds = []
let patientNames = [] let patientNames = []
selectPatients.forEach((item)=>{ selectPatients.forEach((item)=>{
if(!this.initialPatientIdList.includes(item.patientId)){ patientIds.push(item.patientId)
patientIds.push(item.patientId) patientNames.push(item.nickname)
patientNames.push(item.nickname)
}
}) })
if(patientNames.length>4) {
const le = patientNames.length
patientNames = patientNames.slice(0,4)
patientNames = `${patientNames.join('、')}${le}人`
} else {
patientNames = patientNames.join('、')
}
this.addPatientData = { this.addPatientData = {
id: this.$route.query.planId, id: this.$route.query.planId,
addPatients: true, addPatients: true,
patientIdList: patientIds, patientIdList: patientIds,
patientNames: patientNames.join('、'), patientNames: patientNames,
status: this.status status: this.status
} }
this.showAddPatientTime = true this.showAddPatientTime = true
// this.baseInfo.hasSelectedNum = this.baseInfo.patientIdList.length;
}, },
handleSelectionChange(val) { handleSelectionChange(val) {
console.log('已选居民',val) console.log('已选居民',val)
...@@ -408,21 +419,21 @@ ...@@ -408,21 +419,21 @@
}) })
}, },
residentList(val) { residentList(val) {
const _this = this if(this.status == 1) {
if(val.fPlanPatientInfoDtoList) { this.statusTotal = val.notCount
val.fPlanPatientInfoDtoList.forEach(function (item,index) { } else if (this.status == 2) {
_this.initialPatientIdList.push(item.patientId) this.statusTotal = val.handCount
})
}
if(_this.status == 1) {
_this.statusTotal = val.notCount
} else if (_this.status == 2) {
_this.statusTotal = val.handCount
} else if (_this.status == 3) { } else if (_this.status == 3) {
_this.statusTotal = val.yesCount this.statusTotal = val.yesCount
} }
} },
selectResidentList(val) {
const _this = this
val.forEach(function (item,index) {
_this.initialPatientIdList.push(item.patientId)
});
},
}, },
beforeRouteEnter(to, from, next) { beforeRouteEnter(to, from, next) {
next(vm=> { next(vm=> {
......
...@@ -61,10 +61,13 @@ ...@@ -61,10 +61,13 @@
:data="reservationList.enteringDtos" :data="reservationList.enteringDtos"
center center
style="width: 100%;margin-top: 20px;" style="width: 100%;margin-top: 20px;"
@selection-change="handleSelectionChange"> @selection-change="handleSelectionChange"
:row-key="getRowKeys"
ref="multipleReservation">
<el-table-column <el-table-column
type="selection" type="selection"
align="center"> align="center"
:reserve-selection="true">
</el-table-column> </el-table-column>
<el-table-column <el-table-column
prop="nickname" prop="nickname"
...@@ -190,6 +193,9 @@ ...@@ -190,6 +193,9 @@
needPara: {}, needPara: {},
dialogDetailShow: false, dialogDetailShow: false,
validContents: [], validContents: [],
getRowKeys(row) {
return row.fuPlanPatientTimesId;
},
} }
}, },
created() { created() {
...@@ -295,17 +301,18 @@ ...@@ -295,17 +301,18 @@
} }
}, },
sendReservation() { sendReservation() {
if(this.selectionData.length > 0){ // console.log('选择人员长度',this.selectionData.length)
this.selectList = this.selectionData; if(this.selectionData.length > 100) {
// 发送预约校验 this.$message.warning('每次最多选择100条单条随访进行预约!');
this.initCheck(); return;
}else if(this.selectionData.length > 100){ }else if(this.selectionData.length <= 0){
this.$message.warning('每次最多选择100条单条随访进行预约!'); this.$message.warning('请选择要发送预约的居民!');
return false; return;
} else { }else{
this.$message.warning('请选择要发送预约的居民!'); this.selectList = this.selectionData;
return false; // 发送预约校验
} this.initCheck();
}
}, },
sendReservationRow(row){ sendReservationRow(row){
let newList = []; let newList = [];
...@@ -345,6 +352,7 @@ ...@@ -345,6 +352,7 @@
...this.setSearchData(), ...this.setSearchData(),
status: this.status, status: this.status,
}) })
this.$refs.multipleReservation.clearSelection();
}, },
closeTipsDialog(val){ closeTipsDialog(val){
this.isNoEnoughShow = val; this.isNoEnoughShow = val;
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册