This commit is contained in:
2024-06-27 09:02:48 +08:00
parent 013dcf564c
commit 4328c6c66e
9 changed files with 1158 additions and 149 deletions

View File

@ -24,4 +24,29 @@ export function audit(data) {
method: 'post',
data
})
}
}
//路径信息
export function getRouteAuditinfo(signRecordId) {
return request({
url: `/manage/signroute/getRouteAuditInfo/${signRecordId}`,
method: 'get',
})
}
//路径任务
export function getRouteNodeInfo(signRecordId) {
return request({
url: `/manage/signroute/getRouteNodeInfo/${signRecordId}`,
method: 'get',
})
}
//路径审核
export function updateRouteCheckStatus(data) {
return request({
url: `/manage/signRecord/updateRouteCheckStatus`,
method: 'post',
data
})
}

View File

@ -2,17 +2,26 @@ import request from '@/utils/request'
//新增
export function insertScriptEdgeNode(data) {
return request({
url: '/manage/script/updateScriptEdgeNode',
method: 'post',
data: data
})
return request({
url: '/manage/script/updateScriptEdgeNode',
method: 'post',
data: data
})
}
// 话术列表
export function selectScriptEdgeNode(id) {
return request({
url: `/manage/script/selectScriptEdgeNode?id=${id}`,
method: 'get'
})
}
return request({
url: `/manage/script/selectScriptEdgeNode?id=${id}`,
method: 'get'
})
}
//路径任务话术预览
export function getFlowScheme(id) {
return request({
url: `/manage/signroute/getFlowScheme/${id}`,
method: 'get'
})
}

View File

@ -100,7 +100,7 @@
</div>
</div>
<div class="card" v-else>
<PathReview></PathReview>
<PathReview ref="PathReview"></PathReview>
</div>
</div>
</template>
@ -109,7 +109,8 @@
import {
getRouteNodeList,
getByPatientId,
audit
audit,
updateRouteCheckStatus
} from '@/api/manage/Auditing.js'
import { getAge } from "@/utils/age";
import portrait from '../components/portrait.vue'
@ -126,7 +127,7 @@ export default {
baseUrl: process.env.VUE_APP_BASE_API,
activeNames: ['-1', '-2', '-3'],
list: {},
nodelist: [],
// nodelist: [],
lookitem: {},
};
},
@ -142,10 +143,10 @@ export default {
},
//
ignore() {
let manageRouteNodeIds = []
this.nodelist.map(e => {
manageRouteNodeIds = [...manageRouteNodeIds, ...e.nodeList.map(el => el.id)]
})
// let manageRouteNodeIds = []
// this.nodelist.map(e => {
// manageRouteNodeIds = [...manageRouteNodeIds, ...e.nodeList.map(el => el.id)]
// })
this.$prompt('请输入忽略备注信息?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
@ -154,7 +155,7 @@ export default {
routeCheckPerson: JSON.parse(localStorage.getItem('user')).nickName,
routeCheckRemark: value,
routeCheckStatus: 'DISAGREE',
manageRouteNodeIds: manageRouteNodeIds
// manageRouteNodeIds: manageRouteNodeIds
}
audit(obj).then(res => {
this.$notify({
@ -176,36 +177,46 @@ export default {
//
auditing() {
let manageRouteNodeIds = []
this.nodelist.map(e => {
manageRouteNodeIds = [...manageRouteNodeIds, ...e.nodeList.map(el => el.id)]
})
// this.nodelist.map(e => {
// manageRouteNodeIds = [...manageRouteNodeIds, ...e.nodeList.map(el => el.id)]
// })
this.$prompt('请输入审核备注信息?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
}).then(({ value }) => {
let obj = {
routeCheckPerson: JSON.parse(localStorage.getItem('user')).nickName,
routeCheckRemark: value,
routeCheckStatus: 'AGREE',
manageRouteNodeIds: manageRouteNodeIds
if (this.activeNametab == 'route') {
let obj = {
routeCheckRemark: value,
routeCheckStatus: 'AGREE',
signPatientRecordId: this.$route.query.signRecordId
}
updateRouteCheckStatus(obj).then(res => {
this.$notify({
type: 'success',
title: '提示',
message: '路径审核通过',
duration: 3000
});
setTimeout(() => {
this.$refs.PathReview.info();
}, 1500);
})
} else {
let obj = {
routeCheckPerson: JSON.parse(localStorage.getItem('user')).nickName,
routeCheckRemark: value,
routeCheckStatus: 'AGREE',
// manageRouteNodeIds: manageRouteNodeIds
}
audit(obj).then(res => {
this.$notify({
type: 'success',
title: '提示',
message: '画像审核通过',
duration: 3000
});
})
}
console.log(obj)
// return
audit(obj).then(res => {
this.$notify({
type: 'success',
title: '提示',
message: '审核通过,即将返回上一页',
duration: 3000
});
setTimeout(() => {
this.$store.dispatch('tagsView/delView', this.$route).then(({ visitedViews }) => {
this.$router.push({
path: "/task/manualReview",
});
})
}, 3000);
})
})
},
info() {
@ -213,9 +224,9 @@ export default {
res.data.birthDate ? res.data.age = getAge(res.data.birthDate) : ''
this.list = res.data
})
getRouteNodeList({ patientId: this.$route.query.patientId, taskCreateType: 'MANUAL_CREATE', routeCheckStatus: "UNAUDITED" }).then(res => {
this.nodelist = res.data
})
// getRouteNodeList({ patientId: this.$route.query.patientId, taskCreateType: 'MANUAL_CREATE', routeCheckStatus: "UNAUDITED" }).then(res => {
// this.nodelist = res.data
// })
},
cancel() {
this.$store.dispatch('tagsView/delView', this.$route).then(({ visitedViews }) => {

View File

@ -88,7 +88,7 @@
<el-descriptions title="用药情况" style="margin: 30px 0 0;" />
<div class="texts">
<div class="text">
<el-popover placement="right" width="400" trigger="hover">
<el-popover placement="bottom" width="400" trigger="hover">
<el-descriptions title="用户信息" :column="2">
<el-descriptions-item label="用药频次">每日2次</el-descriptions-item>
<el-descriptions-item label="药品用法">1</el-descriptions-item>
@ -106,7 +106,7 @@
</el-popover>
</div>
<div class="text">
<el-popover placement="right" width="400" trigger="hover">
<el-popover placement="bottom" width="400" trigger="hover">
<el-descriptions title="用户信息" :column="2">
<el-descriptions-item label="用药频次">每日2次</el-descriptions-item>
<el-descriptions-item label="药品用法">1</el-descriptions-item>
@ -160,12 +160,12 @@
</div>
<div v-if="tab == 1">
<div class="nodetitle">
<div>主路径:</div>
<div>病种:</div>
<div>主路径:{{ informationlist.routeName }}</div>
<div>病种:{{ informationlist.diseaseTypeName }}</div>
</div>
<el-collapse v-model="activeNames">
<el-collapse-item title="主路径" name="1">
<el-table :data="RouteList" style="width: 100%">
<el-table :data="informationlist.nodeList" style="width: 100%">
<el-table-column prop="" label="" width="160">
<template slot-scope="scope">
<div class="zlj" style="font-weight: bold;">
@ -189,7 +189,7 @@
</el-collapse>
<el-collapse v-model="activeNames">
<el-collapse-item title="子路径" name="2">
<div v-for="(item) in childRouteList" :key="item.id">
<div v-for="item in informationlist.childRouteList" :key="item.id">
<div class="zljtitle">
{{ item.routeName }}
</div>
@ -217,68 +217,158 @@
</el-collapse-item>
</el-collapse>
</div>
<div v-if="tab == 2" class="tabtwo">
<div v-for="item in routelist" :key="item.id" style="margin: 0 auto 30px;">
<div class="tabtexts">
<div class="tabtitle">
{{ item.taskTypeName }}-{{ item.taskPartitionDictName }}
</div>
<div class="tabtext" style="height: 50px;line-height: 30px;">
<div class="lefttext">
开始节点:
</div>
<div class="lefttext" style="width:38%">
{{ item.routeNodeNameCN }}
{{ item.routeNodeDay }}
</div>
<div class="lefttext">
执行时间:
</div>
<div class="lefttext" style="width:38%">
{{ item.executeTime }}
</div>
</div>
<div class="tabtext">
<div class="lefttext">
推送方式:
</div>
<div class="righttext">
<span v-if="item.messagePushSign == 1">
短信
</span>
<span v-if="item.officialPushSign == 1">
公众号
</span>
<span v-if="item.AppletPushSign == 1">
小程序
</span>
</div>
</div>
</div>
<div class="tabtexts">
<div class="tabtext" style="align-items: center;" v-if="item.messagePushSign == 1">
<div class="lefttext">
短信模板
</div>
<div class="righttextarea">
{{ item.messageNodeContent }}
</div>
</div>
<div class="tabtext" style="align-items: center;" v-if="item.officialPushSign == 1">
<div class="lefttext">
公众号模板
</div>
<div class="righttextarea">
{{ item.officialNodeContent }}
</div>
</div>
<div class="tabtext" style="align-items: center;" v-if="item.AppletPushSign == 1">
<div class="lefttext">
小程序模板
</div>
<div class="righttextarea">
{{ item.appletNodeContent }}
</div>
</div>
<div class="tabtext" style="align-items: center;" v-if="item.templateType == 'SCRIPT'">
<div class="lefttext">
话术
</div>
<div class="righttext">
<!-- <Scriptpreview></Scriptpreview> -->
<el-button type="primary" size="small" @click="scriptlook(item)">预览</el-button>
</div>
</div>
<div class="tabtext" v-else-if="item.templateType == 'PROPAGANDA'">
<div class="lefttext">
宣教
</div>
<div class="righttextarea">
<span v-html="item.templateDetail.propagandaContent">
</span>
<!-- <editor v-model="item.templateDetail" :min-height="192" style="width: 100%" /> -->
</div>
</div>
<div class="tabtext" v-else-if="item.templateType == 'QUESTIONNAIRE'">
<div class="lefttext">
问卷
</div>
<div class="righttextarea">
<questionopennew :lookitemnew="item.templateDetail"></questionopennew>
</div>
</div>
<div class="tabtext" v-else-if="item.templateType == 'TEXT_REMIND'">
<div class="lefttext">
文字提醒
</div>
<div class="righttextarea">
{{ item.textRemindContent }}
</div>
</div>
<div class="tabtext" v-else>
<div class="lefttext">
内容
</div>
<div class="righttextarea" v-html="item.nodeContent">
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<el-dialog title="话术预览" :visible.sync="lookshow" width="90%">
<Scriptpreview :phoneNodeContent="phoneNodeContent" v-if="lookshow"></Scriptpreview>
<span slot="footer" class="dialog-footer">
<el-button type="primary" @click="lookshow = false"> </el-button>
</span>
</el-dialog>
</div>
</template>
<script>
import {
getByPatientId,
getRouteAuditinfo,
getRouteNodeInfo
} from '@/api/manage/Auditing.js'
import { getAge } from "@/utils/age";
import questionopennew from './questionopennew.vue';
import Scriptpreview from './Scriptpreviewopen.vue'
export default {
name: "PathReview",
components: { questionopennew, Scriptpreview },
data() {
return {
baseUrl: process.env.VUE_APP_BASE_API,
list: {},
tab: 1,
activeNames: ['2'],
RouteList: [
{
"routeNodeName": "AFTER_DISCHARGE",
"routeNodeDay": 1,
executeTime: '2024-06-24',
"executionTime": "08:00",
"taskPartitionCodes": "HEALTH_ARCHIVE,TPC202405070001",
"taskPartitionDictNames": ["健康档案", "康复宣教"]
},
{
"routeNodeName": "AFTER_DISCHARGE",
"routeNodeDay": 2,
executeTime: '2024-06-25',
"executionTime": "08:00",
"taskPartitionCodes": "TPC202403290001",
"taskPartitionDictNames": ["随访"]
}
],
childRouteList: [
{
"id": 59,
"routeName": "诊断包含123123",
"diseaseTypeId": 63,
"diseaseTypeName": "眼部疾病",
"nodeList": [
{
"routeNodeName": "AFTER_DISCHARGE",
"routeNodeDay": 3,
"executionTime": "09:30",
"executeTime": "2024-06-27",
"taskPartitionCodes": "SPORT_GUIDE",
"taskPartitionDictNames": ["运动指导"]
},
{
"routeNodeName": "AFTER_DISCHARGE",
"routeNodeDay": 4,
"executionTime": "09:00",
"executeTime": "2024-06-28",
"taskPartitionCodes": "TPC202404220002",
"taskPartitionDictNames": ["换药"]
}
]
}
]
activeNames: ['1', '2'],
informationlist: {
routeName: "",
diseaseTypeName: '',
nodeList: [],
childRouteList: []
},
routelist: [],
phoneNodeContent: {
scriptInfoId: null,
flowScheme: null,
nodes: [],
edges: [],
},
lookshow: false,
};
},
created() {
@ -286,20 +376,90 @@ export default {
},
methods: {
info() {
const loading = this.$loading({
lock: true,
text: '加载中',
spinner: 'el-icon-loading',
background: 'rgba(255, 255, 255, 0.7)'
});
getByPatientId(this.$route.query.patientId).then(res => {
res.data.birthDate ? res.data.age = getAge(res.data.birthDate) : ''
this.list = res.data
})
getRouteAuditinfo(this.$route.query.signRecordId).then(res => {
res.data.nodeList?.forEach(e => {
e.taskPartitionDictNames = e.taskPartitionDictNames.split(',')
})
res.data.childRouteList?.forEach(e => {
e.nodeList.forEach(el => {
el.taskPartitionDictNames = el.taskPartitionDictNames.split(',')
})
})
this.informationlist = res.data
loading.close();
})
getRouteNodeInfo(this.$route.query.signRecordId).then(res => {
this.routelist = res.data
})
},
scriptlook(item) {
this.phoneNodeContent = item.phoneNodeContent
this.lookshow = true
// this.$router.push({
// path: "/Scriptpreviewopen",
// query: { id: item.phoneNodeContent }
// });
},
}
};
</script>
<style lang="scss" scoped>
.tabtexts {
.tabtitle {
font-size: 16px;
font-weight: bold;
padding-bottom: 10px;
}
.tabtext {
font-size: 14px;
font-weight: 400;
padding-bottom: 20px;
width: 100%;
display: flex;
.lefttext {
width: 12%;
}
.righttext {
width: 88%;
height: 100%;
}
.righttextarea {
min-height: 80px;
padding: 10px;
width: 90%;
height: 100%;
border: 1.5px solid #C7C7C7;
border-radius: 5px;
}
}
}
.tabtwo {
background-color: #fff;
margin-top: 20px;
padding: 15px;
}
.zljtitle {
font-size: 14px;
height: 38px;
line-height: 38px;
height: 50px;
line-height: 50px;
color: #92A2AB;
border-bottom: 1px solid #e6ebf5;
}
.zljcard {

View File

@ -0,0 +1,794 @@
<template>
<div id="vue-g6-editor">
<el-row>
<el-col :span="24">
<!-- <header>
<el-button type="primary" plain @click="handledel">返回</el-button>
</header> -->
</el-col>
</el-row>
<!-- 工具栏 -->
<el-row>
<el-col :span="24">
<div id="toolbar">
<!-- <font-awesome-icon icon="fa fa-history" />
<font-awesome-icon icon="heart" />
<font-awesome-icon icon="clock" />
<font-awesome-icon icon="clock" style="color: #476151" />
<i
class="el-icon-edit"
data-command="save"
title="保存"
@click="submitForm"
>保存</i
> -->
<!-- <font-awesome-icon icon="heart" /> -->
<!-- <FontAwesomeIcon icon="far fa-copy" /> -->
<font-awesome-icon data-command="save" class="command fa fa-floppy-o" icon="command far far fa-copy"
title="保存"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-reply-all" title="历史数据"
@click="readHistoryData"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" class="fa fa-hdd-o" icon="fas fa-file" title="上传数据"
@click="readUploadData"></font-awesome-icon>
<font-awesome-icon icon="fas fa-download" style="margin-left: 10px" title="另存为文件"
@click="saveAsFile">文件</font-awesome-icon>
<!-- <FontAwesomeIcon icon="fas fa-image" /> -->
<font-awesome-icon style="margin-left: 10px" icon="fas fa-image" title="另存为图片"
@click="openSaveAsImageDialog"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" data-command="undo" icon="fas fa-undo" class="command fa fa-undo"
title="撤销"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" data-command="redo" class="command fa fa-repeat"
icon="fas fa-repeat" title="重做"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" data-command="delete" class="command fa fa-trash-o"
icon="fas fa-trash-alt" title="删除"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" data-command="zoomOut" class="command fa fa-search-minus"
icon="fas fa-search-minus" title="缩小"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" data-command="zoomIn" icon="fas fa-search-plus"
class="command fa fa-search-plus" title="放大"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-eraser" data-command="clear"
class="command fa fa-eraser" title="清除画布"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-arrow-up" data-command="toFront"
class="command fa fa-arrow-up" title="提升层级"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-arrow-down" data-command="toBack"
class="command fa fa-arrow-down" title="下降层级"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-check-square" data-command="selectAll"
class="command fa fa-check-square-o" title="全选"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="far fa-copy" data-command="copy"
class="command fa fa-files-o" title="复制"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-clone" data-command="paste"
class="command fa fa-clipboard" title="粘贴"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-expand" data-command="autoZoom"
class="command fa fa-expand" title="实际大小"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-compress" data-command="resetZoom"
class="command fa fa-compress" title="适应页面"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-object-group" data-command="addGroup"
class="command fa fa-object-group" title="组合"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-object-ungroup" data-command="unGroup"
class="command fa fa-object-ungroup" title="取消组合"></font-awesome-icon>
<font-awesome-icon style="margin-left: 10px" icon="fas fa-crop" data-command="multiSelect"
class="command fa fa fa-crop" title="多选"></font-awesome-icon>
</div>
</el-col>
</el-row>
<!-- 元素面板 + 画布 + 属性栏 -->
<el-row>
<!-- 元素面板 -->
<el-col :span="2">
<!-- <div id="itempannel">
</div> -->
</el-col>
<!-- 画布 -->
<el-col :span="20">
<el-col :span="24">
<div id="page"></div>
</el-col>
</el-col>
<!-- 属性栏 -->
<el-col :span="4">
<section class="right-part">
<!-- 缩略图 -->
<div id="minimap">
<div class="title">缩略图</div>
</div>
</section>
</el-col>
</el-row>
<!-- 弹窗 -->
<article>
<!-- 下载图片 -->
<section class="save-as-image-dialog">
<el-dialog title="下载图片" :visible.sync="saveAsImageDialogVisible" width="360px">
<el-form label-width="100px" label-position="top">
<el-form-item label="选择图片格式">
<el-select v-model="saveAsImageFormat">
<el-option label="jpg" value="jpg">
<span style="float: left">jpg</span>
<span style="float: right; color: #8492a6; font-size: 13px">白色背景</span>
</el-option>
<el-option label="png" value="png">
<span style="float: left">png</span>
<span style="float: right; color: #8492a6; font-size: 13px">透明背景</span>
</el-option>
</el-select>
</el-form-item>
</el-form>
<span slot="footer">
<el-button @click="saveAsImageDialogVisible = false"> </el-button>
<el-button type="primary" @click="saveAsImage"> </el-button>
</span>
</el-dialog>
</section>
</article>
<!-- 右键菜单 -->
<section>
<div id="contextmenu">
<div data-status="node-selected" class="menu">
<el-button data-command="copy" class="command">复制</el-button>
<el-button data-command="paste" class="command">粘贴</el-button>
<el-button data-command="delete" class="command">删除</el-button>
</div>
<div data-status="edge-selected" class="menu">
<el-button data-command="delete" class="command">删除</el-button>
</div>
<div data-status="group-selected" class="menu">
<el-button data-command="copy" class="command">复制</el-button>
<el-button data-command="paste" class="command">粘贴</el-button>
<el-button data-command="unGroup" class="command">取消组合</el-button>
<el-button data-command="delete" class="command">删除</el-button>
</div>
<div data-status="canvas-selected" class="menu">
<el-button data-command="undo" class="command">撤销</el-button>
<el-button data-command="redo" class="command disable">重做</el-button>
</div>
<div data-status="multi-selected" class="menu">
<el-button data-command="copy" class="command">复制</el-button>
<el-button data-command="paste" class="command">粘贴</el-button>
<el-button data-command="addGroup" class="command">组合</el-button>
</div>
</div>
</section>
</div>
</template>
<script>
import G6Editor from "@antv/g6-editor";
import mixin from "@/views/system/mianview/mixin";
import { getFlowScheme } from "@/api/system/preview";
import { construct } from "netflix-conductor-json-tree/dist/index";
import Cookies from 'js-cookie'
export default {
name: "VueG6Editor",
props: ['phoneNodeContent'],
mixins: [mixin],
data() {
return {
form: {
scriptInfoId: null,
flowScheme: null,
nodes: [],
edges: [],
},
// form: {
// nodes: [{
// color
// :
// "#FA8C16",
// id
// :
// "655c5165",
// index
// :
// 0,
// label
// :
// "",
// nodetype
// :
// "startNode",
// shape
// :
// "flow-circle",
// size
// :
// "72*72",
// type
// :
// "node",
// x
// :
// 441.5124969482422,
// y
// :
// 60.79999542236328,
// }, {
// color
// :
// "#1890ff",
// id
// :
// "8660695d",
// index
// :
// 1,
// label
// :
// "",
// size
// :
// "100*50",
// type
// :
// "node",
// x
// :
// 242.5124969482422,
// y
// :
// 183.5999984741211,
// },
// {
// color
// :
// "#1890ff",
// id
// :
// "59c9ceed",
// index
// :
// 2,
// label
// :
// "",
// size
// :
// "100*50",
// type
// :
// "node",
// x
// :
// 606.5124969482422,
// y
// :
// 187.5999984741211,
// }, {
// color
// :
// "#722ED1",
// id
// :
// "16f4c8ba",
// index
// :
// 5,
// label
// :
// "##",
// shape
// :
// "flow-capsule",
// size
// :
// "200*48",
// type
// :
// "node",
// x
// :
// 433.5124969482422,
// y
// :
// 125.5999984741211,
// }, {
// color
// :
// "#722ED1",
// id
// :
// "e4839dcc",
// index
// :
// 6,
// label
// :
// "",
// shape
// :
// "flow-capsule",
// size
// :
// "80*48",
// type
// :
// "node",
// x
// :
// 233.5124969482422,
// y
// :
// 251.5999984741211,
// }, {
// color
// :
// "#1890ff",
// id
// :
// "392ca0b8",
// index
// :
// 7,
// label
// :
// "",
// size
// :
// "100*50",
// type
// :
// "node",
// x
// :
// 55.51249694824219,
// y
// :
// 299.5999984741211
// }, {
// color
// :
// "#1890ff",
// id
// :
// "6bcab22d",
// index
// :
// 8,
// label
// :
// "",
// size
// :
// "100*50",
// type
// :
// "node",
// x
// :
// 384.5124969482422,
// y
// :
// 307.5999984741211
// },
// {
// color
// :
// "#722ED1",
// id
// :
// "dc5de91f",
// index
// :
// 11,
// label
// :
// " ",
// shape
// :
// "flow-capsule",
// size
// :
// "200*48",
// type
// :
// "node",
// x
// :
// 55.51249694824219,
// y
// :
// 366.5
// }],
// edges: [{
// id: "b04d23c7",
// index
// :
// 3,
// label
// :
// "",
// shape
// :
// "flow-polyline-round",
// source
// :
// "655c5165",
// sourceAnchor
// :
// 1,
// target
// :
// "59c9ceed",
// targetAnchor
// :
// 0,
// }, {
// id
// :
// "7894068d",
// index
// :
// 4,
// label
// :
// "",
// shape
// :
// "flow-polyline-round",
// source
// :
// "655c5165",
// sourceAnchor
// :
// 3,
// target
// :
// "8660695d",
// targetAnchor
// :
// 0,
// }, {
// id
// :
// "6aa429cc",
// index
// :
// 9,
// label
// :
// "",
// shape
// :
// "flow-polyline-round",
// source
// :
// "8660695d",
// sourceAnchor
// :
// 3,
// target
// :
// "392ca0b8",
// targetAnchor
// :
// 0,
// },
// {
// id
// :
// "02bfc4d0",
// index
// :
// 10,
// label
// :
// "",
// shape
// :
// "flow-polyline-round",
// source
// :
// "8660695d",
// sourceAnchor
// :
// 1,
// target
// :
// "6bcab22d",
// targetAnchor
// :
// 0
// }
// ]
// },
//
nodeAttributeForm: {
label: "",
width: "",
height: ""
},
//
edgeAttributeForm: {
label: ""
},
//
canvasAttributeForm: {
grid: true,
cell: 20
},
// SVGURL
startNodeSVGUrl: require("@/views/system/mianview/start-node.svg"),
endNodeSVGUrl: require("@/views/system/mianview/end-node.svg"),
regularNodeSVGUrl: require("@/views/system/mianview/regular-node.svg"),
conditionNodeSVGUrl: require("@/views/system/mianview/condition-node.svg"),
nNodeSVGUrl: "https://gw.alipayobjects.com/zos/rmsportal/rQMUhHHSqwYsPwjXxcfP.svg",
modelNodeSVGUrl: "https://gw.alipayobjects.com/zos/rmsportal/rQMUhHHSqwYsPwjXxcfP.svg",
//
editor: null,
saveAsImageDialogVisible: false,
saveAsImageFormat: "jpg"
};
},
mounted() {
console.log()
this.initG6Editor();
this.getlist();
// this.editor.getCurrentPage().save()
this.editor.getCurrentPage().hideGrid();
this.editor.getCurrentPage().read(this.form);
},
methods: {
getlist() {
// console.log(this.$route.query)
// console.log(this.phoneNodeContent)
// getFlowScheme(this.$route.query.id).then(res => {
// this.form = JSON.parse(this.$route.query.id)
this.form = JSON.parse(this.phoneNodeContent)
this.editor.getCurrentPage().read(this.form);
// })
},
//
initG6Editor() {
const _this = this;
const editor = new G6Editor();
this.editor = editor;
G6Editor.track(false);
const Command = G6Editor.Command;
// save
Command.registerCommand("save", {
//
queue: false,
//
enable: (editor) => {
return true;
},
//
execute(editor) {
let needSaveData = editor.getCurrentPage().save();
console.log(needSaveData, 'needSaveData');
// JSON.parse(JSON.stringify(needSaveData))
const text = JSON.stringify(needSaveData)
console.log(JSON.parse(JSON.stringify(text)), 'text');
localStorage.setItem("flowData", JSON.stringify(needSaveData));
_this.save(needSaveData);
},
//
back(editor) {
console.log("反向命令");
console.log(editor);
},
// Ctrl + S
shortcutCodes: [
["metaKey", "s"],
["ctrlKey", "s"]
]
});
//
const flow = new G6Editor.Flow({
graph: {
container: "page"
},
align: {
line: {
// 线
stroke: "#FA8C16",
// 线
lineWidth: 1
},
//
item: true,
//
grid: true
},
grid: {
//
cell: 18
},
shortcut: {
//
save: true
}
});
window.flow = flow;
//
flow.getGraph().edge({
shape: "flow-polyline"
});
//
const itempannel = new G6Editor.Itempannel({
container: "itempannel"
});
//
const toolbar = new G6Editor.Toolbar({
container: "toolbar"
});
//
// const detailpannel = new G6Editor.Detailpannel({
// container: "detailpannel"
// });
//
let minimapWidth = getComputedStyle(document.querySelector(".right-part")).width;
minimapWidth = Number(minimapWidth.replace(/px$/, ""));
const minimap = new G6Editor.Minimap({
container: "minimap",
width: minimapWidth,
height: 200
});
//
const contextmenu = new G6Editor.Contextmenu({
container: "contextmenu"
});
// Editor
editor.add(flow);
editor.add(itempannel);
editor.add(toolbar);
// editor.add(detailpannel);
editor.add(minimap);
editor.add(contextmenu);
// window便
window.editor = editor;
//
const currentPage = editor.getCurrentPage();
currentPage.on("afterchange", (e) => {
if (e.action === "add") {
if (e.model.nodetype === "startNode" || e.model.nodetype === "endNode") {
let nodes = this.editor.getCurrentPage().getNodes();
for (const item of nodes) {
if (item.model.nodetype === e.model.nodetype && item.model.id !== e.model.id) {
this.editor.getCurrentPage().remove(e.item);
this.$message.warning("只能有一个开始节点或结束节点");
}
}
}
}
});
//
currentPage.on("afteritemselected", (ev) => {
console.log("打印所选对象属性", ev.item);
console.log("打印所选对象数据模型", ev.item.model);
const selectedItemDataModel = ev.item.model;
//
if (ev.item.isNode) {
this.nodeAttributeForm.label = selectedItemDataModel.label;
this.nodeAttributeForm.width = selectedItemDataModel.size.split("*")[0];
this.nodeAttributeForm.height = selectedItemDataModel.size.split("*")[1];
this.nodeAttributeForm.color = selectedItemDataModel.color;
}
//
if (ev.item.isEdge) {
ev.item.graph.edge({
shape: "flow-polyline-round"
});
this.edgeAttributeForm.label = selectedItemDataModel.label;
this.edgeAttributeForm.shape = selectedItemDataModel.shape;
}
});
//
currentPage.on("afterdelete", (ev) => { });
},
//
openSaveAsImageDialog() {
this.saveAsImageDialogVisible = true;
},
// /
toggleGridShowStatus(value) {
if (value) {
this.editor.getCurrentPage().showGrid();
} else {
this.editor.getCurrentPage().hideGrid();
}
},
//
saveAsImage() {
let newCanvas;
if (this.saveAsImageFormat === "jpg") {
let canvas = this.editor.getCurrentPage().saveImage();
newCanvas = document.createElement("canvas");
newCanvas.width = canvas.width;
newCanvas.height = canvas.height;
let newContext = newCanvas.getContext("2d");
newContext.fillStyle = "#fff";
newContext.fillRect(0, 0, newCanvas.width, newCanvas.height);
newContext.drawImage(canvas, 0, 0);
}
if (this.saveAsImageFormat === "png") {
newCanvas = this.editor.getCurrentPage().saveImage();
}
let imageDataURL = newCanvas.toDataURL();
let downloadLink = document.createElement("a");
downloadLink.download = "图片.jpg";
downloadLink.href = imageDataURL;
document.body.appendChild(downloadLink);
downloadLink.click();
document.body.removeChild(downloadLink);
this.saveAsImageDialogVisible = false;
},
//
submitForm() {
const _this = this;
let needSaveData = editor.getCurrentPage().save();
console.log(needSaveData, 'needSaveData');
localStorage.setItem("flowData", JSON.stringify(needSaveData));
_this.save(needSaveData);
_this.$message.success("数据已保存");
},
//
saveAsFile() {
let sub = this.editor.getCurrentPage().save()
console.log(sub, 'sub')
let jsonString = JSON.stringify(this.editor.getCurrentPage().save());
let blob = new Blob([jsonString]);
let blobURL = URL.createObjectURL(blob);
let downloadLink = document.createElement("a");
downloadLink.download = "数据.json";
downloadLink.href = blobURL;
document.body.appendChild(downloadLink);
downloadLink.click();
URL.revokeObjectURL(blobURL);
document.body.removeChild(downloadLink);
},
//
readHistoryData() {
let stringData = localStorage.getItem("flowData");
if (stringData === "" || stringData === "{}" || stringData === null) {
this.$message.warning("无历史数据");
return;
}
let jsonData = JSON.parse(stringData);
this.editor.getCurrentPage().read(jsonData);
},
//
readUploadData() {
let uploadButton = document.createElement("input");
uploadButton.setAttribute("type", "file");
uploadButton.setAttribute("accept", ".json");
uploadButton.addEventListener("change", (e) => {
console.dir(uploadButton);
let file = uploadButton.files[0];
let fileReader = new FileReader();
fileReader.onload = (event) => {
console.log(event);
let text = JSON.parse(event.target.result);
console.log(text);
this.editor.getCurrentPage().read(text);
};
fileReader.readAsText(file);
});
uploadButton.click();
},
//
save(source) {
let edges = source.edges;
let nodes = source.nodes;
console.log(construct);
let res = construct(source);
console.log(JSON.stringify(res, null, 2));
},
handledel() {
this.$store.dispatch("tagsView/delView", this.$route);
this.$router.go(-1)
},
}
};
</script>
<style lang="less">
@import url("@/views/system/mianview/index.less");
</style>

View File

@ -133,12 +133,12 @@ export default {
};
</script>
<style scoped lang="scss">
::v-deep .el-input.is-disabled .el-input__inner {
::v-deep .el-input .is-disabled .el-input__inner {
background: #fff !important;
color: #606266;
}
::v-deep .el-textarea.is-disabled .el-textarea__inner {
::v-deep .el-textarea .is-disabled .el-textarea__inner {
color: #606266;
background: #fff;
}

View File

@ -2,60 +2,59 @@
<div class="app-container">
<!-- 问卷模板 -->
<!-- <el-dialog title="问卷预览" :visible.sync="questionopen" width="30%"> -->
<div class="words" v-for="(item, index) in questiondata.questionSubjectList" :key="index">
{{ index + 1 }}.{{ item.questionName }}
<span v-if="item.questionType == 'MULTIPLE_CHOICE'">单选题</span>
<span v-if="item.questionType == 'MULTIPLE_CHOICE_QUESTIONS'">多选题</span>
<span v-if="item.questionType == 'SCORING_QUESTIONS'">打分题</span>
<span v-if="item.questionType == 'COMBINATION_RADIO_SUBJECT'">组合单选题</span>
<span v-if="item.questionType == 'COMBINATION_MULTIPLE_SUBJECT'">组合多选题</span>
<span v-if="item.questionType == 'COMBINATION_BLANKS_SUBJECT'">组合填空题</span>
<span v-if="item.questionType == 'FILL_IN_THE_BLANKS'">填空题</span>
<span v-if="item.questionType == 'COMBINATION_SCORING_SUBJECT'">组合打分题</span>
<span v-if="item.questionType == 'DATE_BLANKS_SUBJECT'">日期填空题</span>
<span v-if="item.questionType == 'TIME_BLANKS_SUBJECT'">时间填空题</span>
<el-radio-group v-if="item.questionType == 'MULTIPLE_CHOICE' ||
<div class="words" v-for="(item, index) in questiondata.questionSubjectList" :key="index">
{{ index + 1 }}.{{ item.questionName }}
<span v-if="item.questionType == 'MULTIPLE_CHOICE'">单选题</span>
<span v-if="item.questionType == 'MULTIPLE_CHOICE_QUESTIONS'">多选题</span>
<span v-if="item.questionType == 'SCORING_QUESTIONS'">打分题</span>
<span v-if="item.questionType == 'COMBINATION_RADIO_SUBJECT'">组合单选题</span>
<span v-if="item.questionType == 'COMBINATION_MULTIPLE_SUBJECT'">组合多选题</span>
<span v-if="item.questionType == 'COMBINATION_BLANKS_SUBJECT'">组合填空题</span>
<span v-if="item.questionType == 'FILL_IN_THE_BLANKS'">填空题</span>
<span v-if="item.questionType == 'COMBINATION_SCORING_SUBJECT'">组合打分题</span>
<span v-if="item.questionType == 'DATE_BLANKS_SUBJECT'">日期填空题</span>
<span v-if="item.questionType == 'TIME_BLANKS_SUBJECT'">时间填空题</span>
<el-radio-group v-if="item.questionType == 'MULTIPLE_CHOICE' ||
item.questionType == 'COMBINATION_RADIO_SUBJECT' ||
item.questionType == 'SCORING_QUESTIONS' ||
item.questionType == 'COMBINATION_SCORING_SUBJECT'
" v-model="questiondata[index]" class="custom-radio-group" disabled
@change="radioGroupChange($event, item)">
<el-radio class="custom" v-for="(aitem, aindex) in item.questionSubjectOptionList" :key="aindex"
:label="aitem.id" @change="radioChange($event, aitem, index)">{{ aitem.optionName }}</el-radio>
</el-radio-group>
<!-- 多选组合多选 -->
<el-checkbox-group disabled v-model="checkeddata" @change="radioGroupChange($event, item, 'checkbox')"
v-if="item.questionType == 'MULTIPLE_CHOICE_QUESTIONS' ||
@change="radioGroupChange($event, item)">
<el-radio class="custom" v-for="(aitem, aindex) in item.questionSubjectOptionList" :key="aindex"
:label="aitem.id" @change="radioChange($event, aitem, index)">{{ aitem.optionName }}</el-radio>
</el-radio-group>
<!-- 多选组合多选 -->
<el-checkbox-group disabled v-model="checkeddata" @change="radioGroupChange($event, item, 'checkbox')" v-if="item.questionType == 'MULTIPLE_CHOICE_QUESTIONS' ||
item.questionType == 'COMBINATION_MULTIPLE_SUBJECT'
">
<el-checkbox v-for="(aitem, aindex) in item.questionSubjectOptionList" :key="aindex"
:label="aitem.id" @change="radioChangecheck($event, aitem, index, aindex)">{{ aitem.optionName
}}</el-checkbox>
</el-checkbox-group>
<!-- 填空题组合填空 -->
<div v-if="item.questionType == 'FILL_IN_THE_BLANKS' ||
<el-checkbox v-for="(aitem, aindex) in item.questionSubjectOptionList" :key="aindex" :label="aitem.id"
@change="radioChangecheck($event, aitem, index, aindex)">{{ aitem.optionName
}}</el-checkbox>
</el-checkbox-group>
<!-- 填空题组合填空 -->
<div v-if="item.questionType == 'FILL_IN_THE_BLANKS' ||
item.questionType == 'COMBINATION_BLANKS_SUBJECT'
" class="tk">
<el-input v-model="item.fillBlanksAnswer" disabled placeholder="请输入答案" type="textarea" />
<!-- <el-input></el-input> -->
</div>
<!-- 日期填空题 -->
<div v-if="item.questionType == 'DATE_BLANKS_SUBJECT'" style="margin: 20px 0 10px 30px">
<el-date-picker disabled @change="timepicker($event, index)" clearable
v-model="item.fillBlanksAnswer" type="date" value-format="yyyy-MM-dd" placeholder="选择日期">
</el-date-picker>
</div>
<!-- 时间填空题 -->
<div style="margin: 20px 0 10px 30px" v-if="item.questionType == 'TIME_BLANKS_SUBJECT'">
<el-time-select disabled @change="timepickerselect($event, index)" clearable
v-model="item.fillBlanksAnswer" :picker-options="{
<el-input v-model="item.fillBlanksAnswer" disabled placeholder="请输入答案" type="textarea" />
<!-- <el-input></el-input> -->
</div>
<!-- 日期填空题 -->
<div v-if="item.questionType == 'DATE_BLANKS_SUBJECT'" style="margin: 20px 0 10px 30px">
<el-date-picker disabled @change="timepicker($event, index)" clearable v-model="item.fillBlanksAnswer"
type="date" value-format="yyyy-MM-dd" placeholder="选择日期">
</el-date-picker>
</div>
<!-- 时间填空题 -->
<div style="margin: 20px 0 10px 30px" v-if="item.questionType == 'TIME_BLANKS_SUBJECT'">
<el-time-select disabled @change="timepickerselect($event, index)" clearable
v-model="item.fillBlanksAnswer" :picker-options="{
start: '08:30',
step: '00:30',
end: '23:30',
}" placeholder="选择时间">
</el-time-select>
</div>
</el-time-select>
</div>
</div>
<!-- </el-dialog> -->
</div>
</template>
@ -80,7 +79,7 @@ export default {
},
watch: {
lookitemnew(newValue, oldValue) {
console.log(newValue,'newValue111')
console.log(newValue, 'newValue111')
if (newValue) {
this.questiondata = newValue;
}
@ -134,16 +133,26 @@ export default {
};
</script>
<style scoped lang="scss">
::v-deep .el-input.is-disabled .el-input__inner {
.app-container {
height: 100% !important;
}
::v-deep .el-input .is-disabled .el-input__inner {
background: #fff !important;
color: #606266;
}
::v-deep .el-textarea.is-disabled .el-textarea__inner {
::v-deep .el-textarea .is-disabled .el-textarea__inner {
color: #606266;
background: #fff;
}
::v-deep .el-radio__input.is-disabled+span.el-radio__label {
color: black;
background: #fff;
cursor: default;
}
.tk {
::v-deep .el-textarea__inner {
margin: 20px 0 10px 10px;

View File

@ -256,6 +256,7 @@ export default {
path: "/task/Auditing",
query: {
patientId: row.patientId,
signRecordId: row.id,
},
});
},

View File

@ -356,11 +356,9 @@ export default {
},
created() {
this.selectAgencyinfo();
this.getList();
},
mounted() {
this.getMaxTableHeight()
this.screenChange()
this.getList();
},
methods: {
updateCPage(index, size) {
@ -376,6 +374,8 @@ export default {
this.signRecordList = response.rows;
this.total = response.total;
this.loading = false;
this.getMaxTableHeight()
this.screenChange()
});
},
//