You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
128 lines
3.6 KiB
128 lines
3.6 KiB
<template> |
|
<div> |
|
<a-button type="primary" icon="download" @click="downWord">下载</a-button> |
|
<a-button type="primary" style="left: 10px" @click="previewWord">预览并打印</a-button> |
|
|
|
<div style="width: 100%;height: 100%;"> |
|
<pdf v-show="false" ref="pdfWord" :src="pdfSrc" class="pdf" style=""></pdf> |
|
</div> |
|
</div> |
|
|
|
</template> |
|
|
|
<script> |
|
const VALIDATE_NO_PASSED = Symbol() |
|
import pick from 'lodash.pick' |
|
import { mixinDevice } from '@/utils/mixin' |
|
import { JeecgListMixin } from '@/mixins/JeecgListMixin' |
|
import { getAction, downFile } from '@/api/manage' |
|
import pdf from 'vue-pdf-signature' |
|
import CMapReaderFactory from 'vue-pdf-signature/src/CMapReaderFactory' |
|
|
|
export default { |
|
name: 'ProcessMaterialsPlanStatement', |
|
mixins: [JeecgListMixin, mixinDevice], |
|
components: { pdf, CMapReaderFactory }, |
|
props: { |
|
materWared: { |
|
type: String |
|
}, |
|
/**/ |
|
procInstId: { |
|
type: String, |
|
default: '', |
|
required: false |
|
}, |
|
pictureId: { |
|
type: String, |
|
default: '', |
|
required: false |
|
}, |
|
lcModa: { |
|
type: Object, |
|
required: false |
|
} |
|
}, |
|
|
|
data() { |
|
return { |
|
showSessionId: '', |
|
srcHtml: '', |
|
modalLsVisible: false, |
|
pdfWord: '', |
|
pdfSrc: '', |
|
url: { |
|
list: '/hy/processUdgetPlan/getPlanTable', |
|
queryPlandDownWord: '/word/queryPlandTableDownWord', |
|
queryPlanPrevie: '/word/queryPlanTablePrevie' |
|
}, |
|
Wslist: null |
|
} |
|
}, |
|
mounted() { |
|
this.showSessionId = window.location.search |
|
}, |
|
created() { |
|
downFile(this.url.queryPlanPrevie, { id: this.queryParam.id }).then((data) => { |
|
console.log(data) |
|
const blob = new Blob([data], { type: 'application/pdf' }) |
|
this.pdfWord = window.URL.createObjectURL(blob) |
|
|
|
}) |
|
// this.loadData(); |
|
}, |
|
activated() { |
|
|
|
}, |
|
beforeMount() { |
|
|
|
}, |
|
computed: { |
|
importExcelUrl: function() { |
|
return `${window._CONFIG['domianURL']}/${this.url.queryPlanApply}` |
|
} |
|
}, |
|
methods: { |
|
// 下载 |
|
downWord() { |
|
downFile(this.url.queryPlandDownWord, { id: this.queryParam.id }).then((data) => { |
|
if (!data) { |
|
this.$message.warning("文件下载失败") |
|
return |
|
} |
|
const blob = new Blob([data]) // 把得到的结果用流对象转一下 |
|
var a = document.createElement('a') //创建一个<a></a>标签 |
|
a.href = URL.createObjectURL(blob) // 将流文件写入a标签的href属性值 |
|
a.download = '采购申请表.docx' //设置文件名 |
|
a.style.display = 'none' // 障眼法藏起来a标签 |
|
document.body.appendChild(a) // 将a标签追加到文档对象中 |
|
a.click() // 模拟点击了a标签,会触发a标签的href的读取,浏览器就会自动下载了 |
|
a.remove() |
|
}) |
|
|
|
}, |
|
previewWord() { |
|
downFile(this.url.queryPlanPrevie, { id: this.queryParam.id }).then((data) => { |
|
if (!data) { |
|
this.$message.warning("文件预览失败") |
|
return |
|
} |
|
console.log(data) |
|
const blob = new Blob([data], { type: 'application/pdf' }) |
|
this.pdfSrc = window.URL.createObjectURL(blob) |
|
console.log(this.pdfSrc) |
|
window.open(this.pdfSrc)//新窗口打开,借用浏览器去打印 |
|
}) |
|
}, |
|
loadData() { |
|
this.queryParam.id = this.materWared |
|
}, |
|
|
|
|
|
} |
|
} |
|
</script> |
|
|
|
<style lang="less" scoped> |
|
|
|
</style> |