wucl 9 месяцев назад
Родитель
Сommit
ac3baba8f6

+ 1 - 0
package.json

@@ -36,6 +36,7 @@
     "js-base64": "^2.6.2",
     "js-cookie": "^2.2.1",
     "js-md5": "^0.7.3",
+    "js-pageoffice": "6.3.1",
     "jspdf": "^2.0.0",
     "lodash": "^4.17.21",
     "lodash.merge": "^4.6.2",

+ 5 - 0
src/router/index.js

@@ -84,6 +84,11 @@ VueRouter.prototype.push = function push(location, onResolve, onReject) {
       path: '/print/code',
       component: () => import('@/views/print/printCode'),
     },
+    {
+      path: '/showDoc',
+      name: 'doc',
+      component: () => import('@/views/DocView')
+    }
   ];
 
 const files = require.context('./modules', false, /\.js$/);

+ 18 - 0
src/utils/request.js

@@ -4,6 +4,7 @@ import store from '@/store'
 import { getToken } from '@/utils/auth'
 import $router from '@/router'
 import { Loading } from 'element-ui'
+import { POBrowser } from "js-pageoffice";
 /*导入加载中*/
 let loadingInstance = null
 
@@ -27,6 +28,23 @@ service.interceptors.request.use(
       // ['X-Token'] is a custom headers key
       // please modify it according to the actual situation
       config.headers['token'] = getToken()
+
+      config.headers["Authorization"] = "Bearer " + getToken(); // 将token添加到请求头中
+      // PageOffice全局配置,必须在此拦截器中定义
+      //必须。设置后端代理,具体属性值以您实际开发为准,比如POBrowser.setProxyBaseAPI(process.env.VUE_APP_BASE_API);
+      POBrowser.setProxyBaseAPI("/api");
+      //必须。向PageOffice后端请求设置header,支持多次调用setHeader()设置更多的值,具体属性名称和属性值以您实际开发为准。
+      POBrowser.setHeader("Authorization", "Bearer " + getToken()); 
+      /**
+       * 前端存储token的方案
+       *方案1.使用Cookie
+       *如果您的令牌(token)存储在Cookie中,PageOffice会默认支持通过Cookie方式保存令牌,因此您无需编写任何额外的代码。
+       *方案2.使用Localstorage或者SessionStorage
+       *如果令牌(token)是保存在LocalStorage或SessionStorage中,您必须调用POBrowser.setStorage()方法。
+       */
+      //POBrowser.setStorage("Admin-Token",getToken());//支持多次调用setStorage()设置更多的值,具体属性名称和属性值以您实际开发为准。
+ 
+
     }
     // console.log('$route', window.app.$route.meta)
     if (window.app.$route.meta) {

+ 62 - 0
src/views/DocView.vue

@@ -0,0 +1,62 @@
+<template>
+    <div class="doc">
+      演示: 文档<br /><br />
+      <!-- 此div用来加载PageOffice客户端控件,其中div的高宽及位置就决定了控件的大小及位置 -->
+      <div style="width:auto; height:900px;" v-html="poHtmlCode"></div>
+    </div>
+  </template>
+ 
+  <script>
+  import request from '@/utils/request'
+  export default {
+    name: 'DocView',
+    data() {
+      return {
+        poHtmlCode: '',
+        open_params: '',
+      }
+    },
+    created: function () {
+      //使用pageofficectrl.WindowParams获取获取父页面(此项目中为:HomeView.vue)中POBrowser.openWindow()方法的第三个参数的值,获取到的值为string类型
+      this.open_params = JSON.parse(pageofficectrl.WindowParams);
+      // 请求后端打开文件
+      this.openFile().then(response => {
+        this.poHtmlCode = response;
+      }
+      );
+ 
+    },
+    methods: {
+      OnPageOfficeCtrlInit() {
+        //PageOffice的初始化事件回调函数,您可以在这里添加自定义按钮
+        pageofficectrl.AddCustomToolButton("保存", "Save", 1);//其中"Save"对应methods中的Save()函数,并且需要在mounted中挂载。
+      },
+      Save() {
+        //使用SaveFilePage属性设置后端保存方法的Controller路由地址,这个地址必须从"/"开始,并且也可以向此路由地址传递json字符串参数,示例如下:
+        let saveFileUrl = "/doc/saveFile";
+        let paramValue = new URLSearchParams(this.open_params);//为了简单起见,这里直接使用打开时的参数。
+        pageofficectrl.SaveFilePage = `${saveFileUrl}?${paramValue.toString()}`;
+        //在这里写您保存前的代码
+        pageofficectrl.WebSave();
+        //在这里写您保存后的代码,比如判断保存结果pageofficectrl.CustomSaveResult
+        //alert(pageofficectrl.CustomSaveResult);
+      },
+      AfterDocumentOpened() {
+        //在这里写您文档打开后自动触发的代码
+      },
+      openFile() {
+        //发起GET请求到后端Controller的/doc/openFile路由
+        return request({
+          url: '/doc/openFile',
+          method: 'get',
+          params: this.open_params
+        })
+      }
+    },
+    mounted: function () {
+      //将当前页面methods中定义的函数挂载到PageOffice控件,例如控件触发的事件、自定义按钮触发的函数。
+      window.POPageMounted = this;//此行必须
+    }
+  }
+  </script>
+ 

+ 13 - 1
src/views/personal/todoDetail.vue

@@ -858,6 +858,7 @@
                   :disabled="!statementProd.isOnline">加盖公章</el-button>
                 <el-button type="text" class="button" @click="genProductionFile(1)" >系统生成</el-button>
               </div>
+              <a href="#" @click.prevent="open_pageoffice()">打开文件</a>
             </div>
             <el-upload style="position: relative; top: -10px; padding: 10px;"
               :action="'/api/personalProduction/upload/' + target.id + '/1'" :file-list="statementProd.files" :limit="1"
@@ -1109,6 +1110,7 @@ import BackgroundInfo from '@/components/personalForms/backgroundInfo'
 import SellingAbilityInfo from '@/components/personalForms/sellingAbilityInfo'
 import existPNG from '@/assets/images/exist.png'
 import emptyPNG from '@/assets/images/empty.png'
+import { POBrowser } from 'js-pageoffice'
 
 export default {
   name: 'personalTodoDetail',
@@ -2742,7 +2744,17 @@ export default {
     cleanFlag(){
       this.decideProduction = false;
       this.checkStateFlag = false;
-    }
+    },
+    open_pageoffice() {
+       let paramJson={};
+       paramJson.file_id=1;
+       paramJson.file_name="/dfs/2024/09/29/2024090029结果报告.docx";
+       let paramString=JSON.stringify(paramJson);
+       //openWindow()第三个参数用来向弹出的PageOffice浏览器(POBrowser)窗口传递参数(参数长度不限),支持json格式字符串。
+       //此处为了方便演示,我们传递了file_id和file_name两个参数,具体以您实际开发为准。
+      POBrowser.openWindow('/showDoc', 'width=1150px;height=900px;',paramString);
+
+     },
   }
 }
 </script>

+ 2 - 1
src/views/personal/todoList.vue

@@ -582,7 +582,8 @@ export default {
         pickedCommits.push(commit);
       }
       this.workNodeCommits = pickedCommits;
-    }
+    },
+
   },
 
 }

+ 9 - 1
vue.config.js

@@ -58,7 +58,15 @@ module.exports = {
         target: 'http://127.0.0.1:80',
         changeOrigin: true,
         pathRewrite: {}
-      }
+      },
+      // '/pageoffice-api': { // "/dev-api"对应后端项目"http://192.168.1.100:8081"地址 
+      //   target: 'http://127.0.0.1:8088', 
+      //   ws: true,
+      //   changeOrigin: true, 
+      //   pathRewrite: {
+      //   '^/pageoffice-api': ''   
+      //   }
+      // },
     },
     // before: require('./mock/mock-server.js')
   },