var PersonEditPanel = { template: '
\
\ 指导模板\
\ 保存\
\
\ 删除\
\
\
\
\ 模板名称:\
\
\ \
{{count}}/{{words}}
\
\
\
\
插入图片({{imgs.length}}/9)
\
\
\ \
\
\ \
\
\
\ \ 预览\ \ \ 保存\ \ \ 发送\ \
\
', beforeRouteEnter: function (to, from, next) { next(function (vm) { var query = vm.$route.query vm.modelCode = query.modelCode console.log(storage.patient, query.patient, 'xxxxxxxxxxxxxxxxxxx') if (!storage.patient && !query.patient) { vm.sendMode = false } else { storage.patient = storage.patient || query.patient storage.planId = storage.planId || query.planId vm.sendMode = true } if (vm.modelCode && from.path != '/preview-panel') { vm.editable = true vm.listDetail() } }) }, props: [], data: function () { return { words: 1000, count: 0, content: '', modelName: '', imgs: [], modelCode: '', editable: true, sendMode: false, // 根据url中是否携带patient来判断是否是"发送"模式 isloading:false, } }, mounted: function () { var vm = this EventBus.$emit('active-nav-tab', 0) }, methods: { countWord: function () { if (this.content.length <= this.words) { this.count = this.content.length } else { this.content = this.content.slice(0, this.words) } }, listDetail: function () { var vm = this guidanceAPI .listDetail({ modelCode: vm.modelCode }) .then(function (res) { var data = res.data if (data) { vm.content = data.content vm.modelName = data.modelName vm.imgs = _.map(data.imagesUrls, function (s) { return httpRequest.getImgUrl(s) }) } }) }, imgUploaded: function (url) { var vm = this vm.imgs.push(httpRequest.getImgUrl(url)) }, removeImg: function (url, idx) { var vm = this vm.imgs.splice(idx, 1) }, save: function () { var vm = this if (!vm.modelCode) { toastr && toastr.error('请选择模板') return } if (!vm.modelName) { toastr && toastr.error('模板名称不能为空') return } if (!vm.content) { toastr && toastr.error('模板内容不能为空') return } guidanceAPI .modifyTemplate({ content: vm.content, modelName: vm.modelName, imagesUrl: vm.imgs.join(','), code: vm.modelCode }) .then(function (res) { if (res.status == 200) { toastr && toastr.success('保存成功') EventBus.$emit('refresh-person-panel') } }) .catch(function (e) { console.error(e) }) }, deleteTemplate: function () { var vm = this var d = dialog({ width: 350, title: '删除模板', content: '删除后无法恢复,是否确认删除?', okValue: '确定', ok: function () { guidanceAPI .deleteTemplate({ code: vm.modelCode }) .then(function (res) { toastr && toastr.success('删除成功') vm.editable = false EventBus.$emit('refresh-person-panel') }) .catch(function (e) { console.error(e) }) }, cancelValue: '取消', cancel: function () {} }) d.showModal() }, sendTemplate: function () { var vm = this if (!vm.modelName) { toastr && toastr.error('模板名称不能为空') return } if (!vm.content) { toastr && toastr.error('模板内容不能为空') return } var d = dialog({ width: 350, content: '发出后无法变更,是否确认发送给居民?', okValue: '继续发送', ok: function () { vm.isloading = true guidanceAPI .sendTemplate({ patient: storage.patient, content: vm.content, modelCode: vm.modelCode, images: vm.imgs.join(',') }) .then(function (res) { vm.isloading = false toastr && toastr.success('发送成功') var obj = { rehabilitationDetailId: storage.planId, patientCode: storage.patient, // patientName: patientName, doctorCode: storage.docInfo.code, doctorName: storage.docInfo.name, relationRecordType: 2, //健康指导 relationRecordCode: res.data.id } guidanceAPI .saveRehabilitationOperateRecord({ dataJson: JSON.stringify(obj) }) .then(function (res) { if (res.status == 200) { var index = parent.layer && parent.layer.getFrameIndex(window.name) //先得到当前iframe层的索引 parent.layer && parent.layer.close(index) } else { // toastr && toastr.success(res.msg) } }) }) .catch(function (e) { console.error(e) }) }, cancelValue: '取消', cancel: function () {} }) d.showModal() }, preview: function () { var vm = this var query = { modelCode: vm.modelCode, patient: storage.patient || '', timestemp: $.now() } this.$router.push({ path: '/preview-panel', query: query }) } }, watch: { '$route': function (to, from) { var vm = this var query = vm.$route.query if (query && query.modelCode && from.path == '/person-edit-panel' && to.path == '/person-edit-panel') { vm.modelCode = query.modelCode vm.editable = true vm.listDetail() } if (storage.patient) { vm.sendMode = true } else { vm.sendMode = false } if (to.path == '/preview-panel') { EventBus.$emit('preview-template', { content: vm.content, modelName: vm.modelName, imgs: vm.imgs }) } }, 'content': function (v) { this.countWord() } } }