123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702 |
- <template>
- <view class="changeUser">
- <view class="head">
- <view class="tab" :class="{active: tab.value === dataInfo.tabActiveValue}" v-for="tab in dataInfo.tabs" :key="tab.id" @click="clickTab(tab.value)">
- {{tab.name}}<text v-if="tab.num !== ''">({{tab.num}})</text>
- </view>
- </view>
- <!-- <scroll-view scroll-y class="body"> -->
- <view class="body view-body">
- <!-- 转派 -->
- <template v-if="dataInfo.tabActiveValue === 'redeploy'">
- <view class="form_item">
- <view class="title select"><text class="required newicon newicon-bitian"></text>工作组:</view>
- <!-- <uni-data-select class="value" v-model="dataInfo.groupId" :localdata="dataInfo.groupList" :clear="false" placeholder="请选择工作组" @change="changeGroup" :class="{formRed: isSubmit && !dataInfo.groupId}"></uni-data-select> -->
- <uni-data-picker class="value" placeholder="请选择工作组"
- :localdata="dataInfo.groupList" v-model="dataInfo.groupId"
- :clear-icon="false" @change="changeGroup" :class="{formRed: isSubmit && !dataInfo.groupId}">
- </uni-data-picker>
- </view>
- <view class="form_item">
- <view class="title radio"><text class="required newicon newicon-bitian"></text>是否转派到人:</view>
- <uni-data-checkbox class="value" v-model="dataInfo.isAssignUser" :localdata="dataInfo.isAssignUserList" @change="changeIsAssignUser" />
- </view>
- <view class="form_item" v-if="dataInfo.isAssignUser === 1">
- <view class="title select"><text class="required newicon newicon-bitian"></text>转派对象:</view>
- <!-- <uni-data-select class="value" v-model="dataInfo.userId" :localdata="dataInfo.userList" :clear="false" placeholder="请选择转派对象" :class="{formRed: isSubmit && dataInfo.groupId && dataInfo.isAssignUser == 1 && !dataInfo.userId}"></uni-data-select> -->
- <uni-data-picker class="value" placeholder="请选择转派对象"
- :localdata="dataInfo.userList" v-model="dataInfo.userId"
- :clear-icon="false" :class="{formRed: isSubmit && dataInfo.groupId && dataInfo.isAssignUser == 1 && !dataInfo.userId}">
- </uni-data-picker>
- </view>
- </template>
-
- <!-- 指派 -->
- <template v-if="dataInfo.tabActiveValue === 'assign'">
- <view class="form_item">
- <view class="title select"><text class="required newicon newicon-bitian"></text>院区:</view>
- <!-- <uni-data-select class="value" v-model="dataInfo.branchId" :localdata="dataInfo.branchList" :clear="false" placeholder="请选择院区" @change="changeBranch" :class="{formRed: isSubmit && !dataInfo.branchId}"></uni-data-select> -->
- <uni-data-picker class="value" placeholder="请选择院区"
- :localdata="dataInfo.branchList" v-model="dataInfo.branchId"
- :clear-icon="false" @change="changeBranch" :class="{formRed: isSubmit && !dataInfo.branchId}">
- </uni-data-picker>
- </view>
- <view class="form_item">
- <view class="title select"><text class="required newicon newicon-bitian"></text>责任科室:</view>
- <!-- <uni-data-select class="value" v-model="dataInfo.dutyId" :localdata="dataInfo.dutyList" :clear="false" placeholder="请选择责任科室" @change="changeDuty" :class="{formRed: isSubmit && !dataInfo.dutyId}"></uni-data-select> -->
- <uni-data-picker class="value" placeholder="请选择责任科室"
- :localdata="dataInfo.dutyList" v-model="dataInfo.dutyId"
- :clear-icon="false" @change="changeDuty" :class="{formRed: isSubmit && !dataInfo.dutyId}">
- </uni-data-picker>
- </view>
- <view class="form_item">
- <view class="title select"><text class="required newicon newicon-bitian"></text>工作组:</view>
- <!-- <uni-data-select class="value" v-model="dataInfo.groupId" :localdata="dataInfo.groupList" :clear="false" placeholder="请选择工作组" @change="changeGroup" :class="{formRed: isSubmit && !dataInfo.groupId}"></uni-data-select> -->
- <uni-data-picker class="value" placeholder="请选择工作组"
- v-model="dataInfo.groupId" :localdata="dataInfo.groupList"
- :clear-icon="false" @change="changeGroup" :class="{formRed: isSubmit && !dataInfo.groupId}">
- </uni-data-picker>
- </view>
- <view class="form_item">
- <view class="title radio"><text class="required newicon newicon-bitian"></text>是否指派到人:</view>
- <uni-data-checkbox class="value" v-model="dataInfo.isAssignUser" :localdata="dataInfo.isAssignUserList" @change="changeIsAssignUser" />
- </view>
- <view class="form_item" v-if="dataInfo.isAssignUser === 1">
- <view class="title select"><text class="required newicon newicon-bitian"></text>指派对象:</view>
- <!-- <uni-data-select class="value" v-model="dataInfo.userId" :localdata="dataInfo.userList" :clear="false" placeholder="请选择指派对象" :class="{formRed: isSubmit && dataInfo.groupId && dataInfo.isAssignUser == 1 && !dataInfo.userId}"></uni-data-select> -->
- <uni-data-picker class="value" placeholder="请选择指派对象"
- v-model="dataInfo.userId" :localdata="dataInfo.userList"
- :clear-icon="false" :class="{formRed: isSubmit && dataInfo.groupId && dataInfo.isAssignUser == 1 && !dataInfo.userId}">
- </uni-data-picker>
- </view>
- </template>
-
- <!-- 退回 -->
- <template v-if="dataInfo.tabActiveValue === 'reassign'">
- <view class="form_item column">
- <view class="title"><text class="required newicon newicon-bitian"></text>退回原因:</view>
- <uni-easyinput class="value" type="textarea" v-model="dataInfo.reassignRemark" placeholder="请输入退回原因" :class="{formRed: isSubmit && !dataInfo.reassignRemark.trim()}" />
- <view class="tips">注:退回后,由调度台重新指派。</view>
- </view>
- </template>
- </view>
- <!-- </scroll-view> -->
- <view class="foot_common_btns">
- <button @click="goBack" type="default" class="cancelButton btn">返回</button>
- <button @click="submit" type="default" class="primaryButton btn">提交</button>
- </view>
- </view>
- </template>
- <script setup>
- import { ref, reactive } from 'vue'
- import { onLoad } from '@dcloudio/uni-app'
- import { api_group, api_department, api_incidentDetail, api_user, api_incidentTask, api_branch, api_dutyDepartment } from "@/http/api.js"
- import { defaultColor } from '@/static/js/theme.js'
- import { useSetTitle } from '@/share/useSetTitle.js'
- import { useMakePhoneCall } from '@/share/useMakePhoneCall.js'
- import { useGoBack } from '@/share/useGoBack.js'
- import { useLoginUserStore } from '@/stores/loginUser'
-
- useSetTitle();
- const loginUserStore = useLoginUserStore();
- const { makePhoneCall } = useMakePhoneCall();
- const { goBack } = useGoBack();
-
- // 主题颜色
- const primaryColor = ref(defaultColor)
-
- // 数据
- const dataInfo = reactive({
- tabs: [
- // {id: 1, name: '转派', value: 'redeploy', num: ''},
- // {id: 2, name: '指派', value: 'assign', num: ''},
- // {id: 3, name: '升级', value: 'upgrade', num: ''},
- // {id: 4, name: '退回', value: 'reassign', num: ''},
- ],
- tabActiveValue: 0,//当前选择的tab
- incidentId: undefined,//事件ID
- incidentData: {},//事件对象
- groupList: [], //工作组列表
- groupId: undefined, //工作组ID
- userList: [], //用户列表
- userId: undefined, //用户ID
- branchList: [], //院区列表
- branchId: undefined, //院区ID
- dutyList: [], //责任科室列表
- dutyId: undefined, //责任科室ID
- isAssignUser: 1, //工作组是否转派到人
- isAssignUserList: [
- { text: '是', value: 1 },
- { text: '否', value: 0 },
- ], //工作组是否转派到人选项
- reassignRemark: '',//退回原因
- })
-
- // 是否提交
- const isSubmit = ref(false)
-
- // 重置
- function reset(){
- dataInfo.branchId = undefined;
- dataInfo.branchList = [];
-
- dataInfo.dutyId = undefined;
- dataInfo.dutyList = [];
-
- dataInfo.groupId = undefined;
- dataInfo.groupList = [];
-
- dataInfo.userId = undefined;
- dataInfo.userList = [];
-
- dataInfo.isAssignUser = 1;
-
- dataInfo.reassignRemark = '';
- }
-
- // 初始化表单
- function initForm(){
- if(dataInfo.tabActiveValue === 'redeploy'){
- getGroups();
- }else if(dataInfo.tabActiveValue === 'assign'){
- getBranchs();
- }
- }
-
- // 点击tab
- function clickTab(tabValue){
- if(dataInfo.tabActiveValue == tabValue){
- return;
- }
- dataInfo.tabActiveValue = tabValue;
- isSubmit.value = false;
- reset();
- initForm()
- }
-
- // 获取事件详情
- function getIncidentDetail(){
- uni.showLoading({
- title: "加载中",
- mask: true,
- });
- api_incidentDetail(dataInfo.incidentId).then(res => {
- uni.hideLoading();
- if(res.status == 200){
- dataInfo.incidentData = res.data || {};
- let transferFlag = false;//转派权限
- let assignFlag = false;//指派权限
- for (let i = 0; i < loginUserStore.loginUser.menu.length; i++) {
- if (loginUserStore.loginUser.menu[i].link == "assign") {
- assignFlag = true
- }
- if (loginUserStore.loginUser.menu[i].link == "receive") {
- transferFlag = true
- }
- }
-
- // 转派
- if(dataInfo.incidentData.state.value == 'handler' && dataInfo.incidentData.handlingPersonnelUser && dataInfo.incidentData.handlingPersonnelUser.id == loginUserStore.loginUser.user.id && !assignFlag && transferFlag){
- dataInfo.tabs.splice(0, 0, {id: 1, name: '转派', value: 'redeploy', num: ''});
- }
-
- // 指派
- if((dataInfo.incidentData.state.value == 'pending' || dataInfo.incidentData.state.value == 'handler' || dataInfo.incidentData.state.value == 'reassign') && assignFlag){
- let index = dataInfo.tabs.findIndex(v => v.value === 'reassign');
- if(index < 0){
- dataInfo.tabs = [{id: 1, name: '指派', value: 'assign', num: ''}];
- }else{
- dataInfo.tabs.splice(index, 0, {id: 1, name: '指派', value: 'assign', num: ''});
- }
- }
-
- // 退回
- if(dataInfo.incidentData.state.value == 'pending' || dataInfo.incidentData.state.value == 'handler'){
- if(dataInfo.tabs.length){
- dataInfo.tabs.splice(dataInfo.tabs.length, 0, {id: 4, name: '退回', value: 'reassign', num: ''});
- }else{
- dataInfo.tabs = [{id: 4, name: '退回', value: 'reassign', num: ''}];
- }
- }
-
- dataInfo.tabActiveValue = dataInfo.tabs[0].value;
-
- initForm()
- }else{
- uni.showToast({
- icon: 'none',
- title: res.msg || '请求数据失败!'
- });
- }
- })
- }
-
- // 获取院区列表
- function getBranchs(){
- let arr = loginUserStore.loginUser.hospital.filter(i=>i.parent==undefined)
- dataInfo.branchList = arr.map(v => ({
- text: v.hosName,
- value: v.id,
- }));
- // uni.showLoading({
- // title: "加载中",
- // mask: true,
- // });
- // let postData = {
- // "idx": 0,
- // "sum": 9999,
- // hospital:{
- // selectType:"level1",
- // }
-
- // // parent:{id:loginUserStore.loginUser.user.currentHospital.id}
- // };
-
- // api_branch(postData).then(res => {
- // uni.hideLoading();
- // if(res.status == 200){
- // res.list = res.list || [];
- // dataInfo.branchList = res.list.map(v => ({
- // text: v.hosName,
- // value: v.id,
- // }));
-
- // if(loginUserStore.loginUser.user.duty){
- // // 当前的所属责任科室
- // dataInfo.branchId = loginUserStore.loginUser.user.duty.branch;
- // changeBranch();
-
- // dataInfo.dutyId = loginUserStore.loginUser.user.duty.id;
- // changeDuty();
- // }else if(loginUserStore.loginUser.user.branch){
- // // 当前的所属院区
- // dataInfo.branchId = loginUserStore.loginUser.user.branch.id;
- // changeBranch();
- // }
- // }else{
- // uni.showToast({
- // icon: 'none',
- // title: res.msg || '请求数据失败!'
- // });
- // }
- // })
- }
-
- // 获取责任科室列表
- function getDutys(){
- uni.showLoading({
- title: "加载中",
- mask: true,
- });
- let postData = {
- "idx": 0,
- "sum": 9999,
- hospital: {
- parent:{
- id:dataInfo.branchId
- },
- type:{value:6}
- }
- };
- api_branch(postData).then(res => {
- uni.hideLoading();
- if(res.status == 200){
- res.list = res.list || [];
- dataInfo.dutyList = res.list.map(v => ({
- text: v.hosName,
- value: v.id,
- }));
- }else{
- uni.showToast({
- icon: 'none',
- title: res.msg || '请求数据失败!'
- });
- }
- })
- }
-
- // 获取工作组列表
- function getGroups(){
- uni.showLoading({
- title: "加载中",
- mask: true,
- });
-
- let duty = undefined;
- if(dataInfo.tabActiveValue === 'redeploy'){
- duty = dataInfo.incidentData.duty.id;
- }else if(dataInfo.tabActiveValue === 'assign'){
- duty = dataInfo.dutyId;
- }
-
- let postData = {
- "idx": 0,
- "sum": 9999,
- "group2": {
- "hospitals": duty
- }
- };
- api_group(postData).then(res => {
- uni.hideLoading();
- if(res.status == 200){
- res.list = res.list || [];
- let arr = res.list.filter(i=>i.type==3)
- dataInfo.groupList = arr.map(v => ({
- text: v.groupName,
- value: v.id,
- }));
- }else{
- uni.showToast({
- icon: 'none',
- title: res.msg || '请求数据失败!'
- });
- }
- })
- }
-
- // 获取用户列表
- function getUsers(){
- uni.showLoading({
- title: "加载中",
- mask: true,
- });
- let postData = {
- "idx": 0,
- "sum": 9999,
- "user": {
- "groupdata":{
- "id": dataInfo.groupId,
- },
- roleCodes: 'first-line support,second-line support'
- // "roledata": {
- // "rolecode": "first-line support"
- // },
- // "roledata2": {
- // "rolecode": "second-line support"
- // },
- // "selectType": "1",
- // "selectDetails": 1,
- // "simple": true,
- // "engineer": 1
- }
- };
- api_user(postData).then(res => {
- uni.hideLoading();
- if(res.status == 200){
- res.list = res.list || [];
- dataInfo.userList = res.list.map(v => ({
- text: v.name,
- value: v.id,
- }));
- }else{
- uni.showToast({
- icon: 'none',
- title: res.msg || '请求数据失败!'
- });
- }
- })
- }
-
- // 选择院区
- function changeBranch(){
- dataInfo.dutyId = undefined;
- dataInfo.dutyList = [];
-
- dataInfo.groupId = undefined;
- dataInfo.groupList = [];
-
- dataInfo.userId = undefined;
- dataInfo.userList = [];
- getDutys();
- }
-
- // 选择责任科室
- function changeDuty(){
- dataInfo.groupId = undefined;
- dataInfo.groupList = [];
-
- dataInfo.userId = undefined;
- dataInfo.userList = [];
- getGroups();
- }
-
- // 选择工作组
- function changeGroup(){
- dataInfo.userId = undefined;
- dataInfo.userList = [];
- getUsers();
- }
-
- // 选择是否转派到人
- function changeIsAssignUser(){
- dataInfo.userId = undefined;
- }
-
- // 提交
- function submit(){
- isSubmit.value = true;
-
- if(dataInfo.tabActiveValue === 'redeploy'){
- submitRedeploy();
- }else if(dataInfo.tabActiveValue === 'assign'){
- submitAssign();
- }else if(dataInfo.tabActiveValue === 'reassign'){
- submitReassign();
- }
- }
-
- // 转派提交
- function submitRedeploy(){
- if(!dataInfo.groupId){
- uni.showToast({
- icon: 'none',
- title: '请选择工作组'
- });
- return;
- }
-
- if(dataInfo.isAssignUser == 1 && !dataInfo.userId){
- uni.showToast({
- icon: 'none',
- title: '请选择指派对象'
- });
- return;
- }
-
- uni.showLoading({
- title: "加载中",
- mask: true,
- });
-
- let postData = {
- incident: dataInfo.incidentData,
- }
-
- if(dataInfo.userId){
- // 派人
- postData.incident.assignee = dataInfo.userId;
- } else {
- // 派组
- postData.incident.candidateGroups = dataInfo.groupId;
- }
-
- api_incidentTask(dataInfo.tabActiveValue, postData).then(res => {
- uni.hideLoading();
- if(res.state == 200){
- uni.showToast({
- icon: 'none',
- title: '转派成功',
- mask: true,
- });
- setTimeout(() => {
- uni.reLaunch({
- url: '/pages/incidentList/incidentList',
- })
- }, 1500)
- }else{
- uni.showToast({
- icon: 'none',
- title: res.msg || '请求数据失败!'
- });
- }
- })
- }
-
- // 指派提交
- function submitAssign(){
- if(!dataInfo.branchId){
- uni.showToast({
- icon: 'none',
- title: '请选择院区'
- });
- return;
- }
-
- if(!dataInfo.dutyId){
- uni.showToast({
- icon: 'none',
- title: '请选择责任科室'
- });
- return;
- }
-
- if(!dataInfo.groupId){
- uni.showToast({
- icon: 'none',
- title: '请选择工作组'
- });
- return;
- }
-
- if(dataInfo.isAssignUser == 1 && !dataInfo.userId){
- uni.showToast({
- icon: 'none',
- title: '请选择指派对象'
- });
- return;
- }
-
- uni.showLoading({
- title: "加载中",
- mask: true,
- });
-
- let postData = {
- incident: dataInfo.incidentData,
- }
-
- if(dataInfo.userId){
- // 派人
- postData.incident.assignee = dataInfo.userId;
- } else {
- // 派组
- postData.incident.candidateGroups = dataInfo.groupId;
- }
-
- postData.incident.duty = { id: dataInfo.dutyId };
- postData.incident.hosId = dataInfo.branchId
- api_incidentTask(dataInfo.tabActiveValue, postData).then(res => {
- uni.hideLoading();
- if(res.state == 200){
- uni.showToast({
- icon: 'none',
- title: '指派成功',
- mask: true,
- });
- setTimeout(() => {
- uni.reLaunch({
- url: '/pages/incidentList/incidentList',
- })
- }, 1500)
- }else{
- uni.showToast({
- icon: 'none',
- title: res.msg || '请求数据失败!'
- });
- }
- })
- }
-
- // 退回提交
- function submitReassign(){
- if(!dataInfo.reassignRemark.trim()){
- uni.showToast({
- icon: 'none',
- title: '请填写退回原因'
- });
- return;
- }
-
- uni.showLoading({
- title: "加载中",
- mask: true,
- });
-
- let postData = {
- incident: dataInfo.incidentData,
- }
-
- postData.incident.reassignRemark = dataInfo.reassignRemark;
-
- api_incidentTask(dataInfo.tabActiveValue, postData).then(res => {
- uni.hideLoading();
- if(res.state == 200){
- uni.showToast({
- icon: 'none',
- title: '退回成功',
- mask: true,
- });
- setTimeout(() => {
- uni.reLaunch({
- url: '/pages/incidentList/incidentList',
- })
- }, 1500)
- }else{
- uni.showToast({
- icon: 'none',
- title: res.msg || '请求数据失败!'
- });
- }
- })
- }
-
- onLoad((option) => {
- dataInfo.incidentId = option.incidentId;
- getIncidentDetail();
- })
- </script>
- <style lang="scss" scoped>
- .changeUser{
- height: 100%;
- display: flex;
- flex-direction: column;
- justify-content: space-between;
- .head{
- height: 88rpx;
- display: flex;
- position: fixed;
- z-index: 99;
- width: 100%;
- background-color: #fff;
- font-size: 30rpx;
- .tab{
- flex: 1;
- display: flex;
- justify-content: center;
- align-items: center;
- border-bottom: 4rpx solid transparent;
- &.active{
- color: $uni-primary;
- border-color: $uni-primary;
- }
- }
- }
- .body{
- margin-top: 88rpx;
- padding: 0 24rpx;
- box-sizing: border-box;
- flex: 1;
- min-height: 0;
- .form_item{
- display: flex;
- align-items: center;
- padding-top: 24rpx;
- min-height: 86rpx;
- &.column{
- height: auto;
- flex-direction: column;
- align-items: flex-start;
- .title{
- margin-right: 0;
- }
- .value{
- margin-top: 10rpx;
- padding-left: 20rpx;
- box-sizing: border-box;
- }
- .tips{
- padding: 24rpx;
- text-align: center;
- font-size: 22rpx;
- color: #909399;
- width: 100%;
- box-sizing: border-box;
- }
- }
- .title{
- font-size: 26rpx;
- display: flex;
- align-items: center;
- margin-right: 12rpx;
- &.select{
- width: calc(5em + 20rpx);
- }
- }
- }
- }
- }
- </style>
|