wps加载项在vue2项目中的应用
应用代码:
wps.js
/**
* WPS OA助手-WPS启动方法入口
*/
var pluginsMode = location.search.split("=")[1]; //截取url中的参数值
var pluginType = WpsInvoke.ClientType.wps; //加载项类型wps,et,wpp
var pluginName = "WpsOAAssist"; //加载项名称
var wpsClient = new WpsClient(pluginType); //初始化一个多进程对象,多进程时才需要
var clientStr = pluginName + pluginType + "ClientId";
//单进程封装开始
/**
* 此方法是根据wps_sdk.js做的调用方法封装
* 可参照此定义
* @param {*} funcs 这是在WPS加载项内部定义的方法,采用JSON格式(先方法名,再参数)
* @param {*} front 控制着通过页面执行WPS加载项方法,WPS的界面是否在执行时在前台显示
* @param {*} jsPluginsXml 指定一个新的WPS加载项配置文件的地址,动态传递jsplugins.xml模式,例如:http://127.0.0.1:3888/jsplugins.xml
* @param {*} isSilent 隐藏打开WPS,如果需要隐藏,那么需要传递front参数为false
*/
export function _Wps(funcs, front, jsPluginsXml, isSilent) {
var info = {};
info.funcs = funcs;
if (isSilent) {
//隐藏启动时,front必须为false
front = false;
}
/**
* 下面函数为调起WPS,并且执行加载项WpsOAAssist中的函数dispatcher,该函数的参数为业务系统传递过去的info
*/
if (pluginsMode != 2) {
//单进程
singleInvoke(info, front, jsPluginsXml, isSilent);
} else {
//多进程
multInvoke(info, front, jsPluginsXml, isSilent);
}
}
//单进程
function singleInvoke(info, front, jsPluginsXml, isSilent) {
WpsInvoke.InvokeAsHttp(
pluginType, // 组件类型
pluginName, // 插件名,与wps客户端加载的加载的插件名对应
"dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
info, // 传递给插件的数据
function (result) {
console.log(result, 44545)
// 调用回调,status为0为成功,其他是错误
if (result.status) {
if (result.status == 100) {
WpsInvoke.AuthHttpesCert(
'请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。'
);
return;
}
alert(result.message);
} else {
console.log(result.response);
showresult(result.response);
}
},
front,
jsPluginsXml,
isSilent
);
/**
* 接受WPS加载项发送的消息
* 接收消息:WpsInvoke.RegWebNotify(type,name,callback)
* WPS客户端返回消息: wps.OAAssist.WebNotify(message)
* @param {*} type 加载项对应的插件类型
* @param {*} name 加载项对应的名字
* @param {func} callback 接收到WPS客户端的消息后的回调函数,参数为接受到的数据
*/
WpsInvoke.RegWebNotify(pluginType, pluginName, handleOaMessage);
}
//多进程
function multInvoke(info, front, jsPluginsXml, isSilent) {
wpsClient.jsPluginsXml = jsPluginsXml
? jsPluginsXml
: "http://192.168../cdn/wps-oa/jsplugins.xml"; //这里改成自己起的服务地址
if (localStorage.getItem(clientStr)) {
wpsClient.clientId = localStorage.getItem(clientStr);
}
if (isSilent) {
wpsClient.StartWpsInSilentMode(pluginName, function () {
//隐藏启动后的回调函数
mult(info, front);
});
} else {
mult(info, front);
}
wpsClient.onMessage = handleOaMessage;
}
//多进程二次封装
function mult(info, front) {
wpsClient.InvokeAsHttp(
pluginName, // 插件名,与wps客户端加载的加载的插件名对应
"dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
info, // 传递给插件的数据
function (result) {
// 调用回调,status为0为成功,其他是错误
if (wpsClient.clientId) {
localStorage.setItem(clientStr, wpsClient.clientId);
}
if (result.status !== 0) {
console.log(result);
if (result.message == '{"data": "Failed to send message to WPS."}') {
wpsClient.IsClientRunning(function (status) {
console.log(status);
if (status.response == "Client is running.")
alert(
"任务发送失败,WPS 正在执行其他任务,请前往WPS完成当前任务"
);
else {
wpsClient.clientId = "";
wpsClient.notifyRegsitered = false;
localStorage.setItem(clientStr, "");
mult(info);
}
});
return;
} else if (result.status == 100) {
// WpsInvoke.AuthHttpesCert('请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。')
return;
}
alert(result.message);
} else {
console.log(result.response);
}
},
front
);
}
function handleOaMessage(data) {
console.log(data);
}
function handleOaFunc1(message) {
alert("我是函数handleOaFunc1,我接收到的参数是:" + message);
}
function handleOaFunc2(message) {
alert("我是函数handleOaFunc2,我接收到的参数是:" + message);
var span = window.parent.document.getElementById("webnotifyspan");
span.innerHTML = message;
}
/**
* 处理WPS加载项的方法返回值
*
* @param {*} resultData
*/
function showresult(resultData) {
let json = eval("(" + resultData + ")");
switch (json.message) {
case "GetDocStatus": {
let docstatus = json.docstatus;
if (typeof docstatus != "undefined") {
let str =
"文档保存状态:" +
docstatus.saved +
"\n文档字数:" +
docstatus.words +
"\n文档页数:" +
docstatus.pages;
alert(str);
}
}
}
}
wpsFun.js
/**
* WPS OA助手公用方法
*
*/
import { wps_sdk } from "@/util/wpsjsrpcsdk.js";
import { _Wps } from "@/util/wps.js";
import { _Et } from "@/util/et.js";
// 打开文档
export function openDoc(data) {
// 保存文档上传路径
let baseUrl = "";
let port = "/path";
data.uploadPath = baseUrl + port + "? "filepath=" + data.filePath + "&originalName=" + data.originalName;
if (data.onLoadType == "wps") {
_Wps([
{
OpenDoc: {
docId: data.docId || "", // 文档ID
uploadPath: data.uploadPath, // 保存文档上传路径
fileName: data.fileName, // 文件路径
uploadFieldName: data.uploadFieldName || "", // 文件上传名称
userName: store.state.user.userInfo.nick_name || ""
}
}
]); // OpenDoc方法对应于OA助手dispatcher支持的方法名
} else if (data.onLoadType == "et") {
_Et([
{
OpenDoc: {
docId: data.docId || "", // 文档ID
uploadPath: data.uploadPath, // 保存文档上传路径
fileName: data.fileName, // 文件路径
uploadFieldName: data.uploadFieldName || "", // 文件上传名称
userName: store.state.user.userInfo.nick_name || ""
},
}
]); // OpenDoc方法对应于OA助手dispatcher支持的方法名
}
}
/**
* WPS OA助手启动封装方法
*/
(function(global, factory) {
"use strict";
if (typeof module === "object" && typeof module.exports === "object") {
module.exports = factory(global, true);
} else {
factory(global);
}
})(typeof window !== "undefined" ? window : this, function(window, noGlobal) {
"use strict";
var bFinished = true;
/**
* 兼容IE低版本的创建httpobj对象的方法
* @returns httpobj,可用于进行数据传输的http的对象
*/
function getHttpObj() {
var httpobj = null;
if (IEVersion() < 10) {
try {
httpobj = new XDomainRequest();
} catch (e1) {
httpobj = new createXHR();
}
} else {
httpobj = new createXHR();
}
return httpobj;
}
//兼容IE低版本的创建xmlhttprequest对象的方法
/**
* 兼容IE低版本的创建xmlhttprequest对象的方法
* @returns xmlhttprequest对象,兼容低版本IE
*/
function createXHR() {
if (typeof XMLHttpRequest != "undefined") {
//兼容高版本浏览器
return new XMLHttpRequest();
} else if (typeof ActiveXObject != "undefined") {
//IE6 采用 ActiveXObject, 兼容IE6
var versions = [
//由于MSXML库有3个版本,因此都要考虑
"MSXML2.XMLHttp.6.0",
"MSXML2.XMLHttp.3.0",
"MSXML2.XMLHttp"
];
for (var i = 0; i < versions.length; i++) {
try {
return new ActiveXObject(versions[i]);
} catch (e) {
//跳过
}
}
} else {
throw new Error("您的浏览器不支持XHR对象");
}
}
/**
* 通过该接口给服务器发请求
* @param {*} options 参数对象,具体包含的参数如下:
* @param {*} url 网页路径,传输地址
* @param {*} type 传输类型,POST / GET / PUT
* @param {*} sendData 传输的数据
* @param {*} callback 回调函数
* @param {*} tryCount 请求失败后的尝试次数
* @param {*} bPop 是否弹出浏览器提示对话框
* @param {*} timeout 请求等待响应的时间,超过时间请求实效
* @param {*} concurrent 请求是否同步发送
* @param {*} client wpsclient对象
* @returns NULL
*/
function startWps(options) {
console.log("startWps",options);
if (!bFinished && !options.concurrent) {
if (options.callback)
options.callback({
status: 1,
message: "上一次请求没有完成"
});
return;
}
bFinished = false;
function startWpsInnder(tryCount) {
console.log("startWpsInnder",tryCount);
if (tryCount <= 0) {
if (bFinished) return;
bFinished = true;
if (options.callback)
options.callback({
status: 2,
message: "请允许浏览器打开WPS Office"
});
return;
}
var xmlReq = getHttpObj();
//WPS客户端提供的接收参数的本地服务,HTTP服务端口为58890,HTTPS服务端口为58891
//这俩配置,取一即可,不可同时启用
xmlReq.open("POST", options.url);
xmlReq.onload = function(res) {
bFinished = true;
if (initCloudsvr == true) {
initCloudsvr = false;
}
if (options.callback) {
if (
res.target.response == '{"data": "Failed to send message to WPS."}'
) {
options.callback({
status: 1,
message:
IEVersion() < 10 ? xmlReq.responseText : res.target.response
});
} else {
options.callback({
status: 0,
response:
IEVersion() < 10 ? xmlReq.responseText : res.target.response
});
}
}
};
xmlReq.ontimeout = xmlReq.onerror = function(res) {
xmlReq.bTimeout = true;
if (
tryCount == options.tryCount &&
options.bPop &&
initCloudsvr == false
) {
//打开wps并传参
InitWpsCloudSvr();
}
setTimeout(function() {
startWpsInnder(tryCount - 1);
}, 1000);
};
if (IEVersion() < 10) {
xmlReq.onreadystatechange = function() {
if (xmlReq.readyState != 4) return;
if (xmlReq.bTimeout) {
return;
}
if (xmlReq.status === 200) xmlReq.onload();
else xmlReq.onerror();
};
}
xmlReq.timeout = options.timeout;
xmlReq.send(options.sendData);
}
startWpsInnder(options.tryCount);
return;
}
var fromCharCode = String.fromCharCode;
// encoder stuff
var cb_utob = function(c) {
if (c.length < 2) {
var cc = c.charCodeAt(0);
return cc < 0x80
? c
: cc < 0x800
? fromCharCode(0xc0 | (cc >>> 6)) + fromCharCode(0x80 | (cc & 0x3f))
: fromCharCode(0xe0 | ((cc >>> 12) & 0x0f)) +
fromCharCode(0x80 | ((cc >>> 6) & 0x3f)) +
fromCharCode(0x80 | (cc & 0x3f));
} else {
var cc =
0x10000 +
(c.charCodeAt(0) - 0xd800) * 0x400 +
(c.charCodeAt(1) - 0xdc00);
return (
fromCharCode(0xf0 | ((cc >>> 18) & 0x07)) +
fromCharCode(0x80 | ((cc >>> 12) & 0x3f)) +
fromCharCode(0x80 | ((cc >>> 6) & 0x3f)) +
fromCharCode(0x80 | (cc & 0x3f))
);
}
};
var re_utob = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g;
var utob = function(u) {
return u.replace(re_utob, cb_utob);
};
var _encode = function(u) {
var isUint8Array =
Object.prototype.toString.call(u) === "[object Uint8Array]";
if (isUint8Array) return u.toString("base64");
else return btoa(utob(String(u)));
};
if (typeof window.btoa !== "function") window.btoa = func_btoa;
function func_btoa(input) {
var str = String(input);
var chars =
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
for (
// initialize result and counter
var block, charCode, idx = 0, map = chars, output = "";
// if the next str index does not exist:
// change the mapping table to "="
// check if d has no fractional digits
str.charAt(idx | 0) || ((map = "="), idx % 1);
// "8 - idx % 1 * 8" generates the sequence 2, 4, 6, 8
output += map.charAt(63 & (block >> (8 - (idx % 1) * 8)))
) {
charCode = str.charCodeAt((idx += 3 / 4));
if (charCode > 0xff) {
throw new InvalidCharacterError(
"'btoa' failed: The string to be encoded contains characters outside of the Latin1 range."
);
}
block = (block << 8) | charCode;
}
return output;
}
/**
* 将字符串进行Base64编码
* @param {*} u 需要编码的数据
* @param {*} urisafe 返回值,编码后的数据
* @returns urisafe
*/
var encode = function(u, urisafe) {
return !urisafe
? _encode(u)
: _encode(String(u))
.replace(/[+\/]/g, function(m0) {
return m0 == "+" ? "-" : "_";
})
.replace(/=/g, "");
};
/**
* 获取IE浏览器版本
* @returns IE浏览器版本
*/
function IEVersion() {
var userAgent = navigator.userAgent; //取得浏览器的userAgent字符串
var isIE =
userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1; //判断是否IE<11浏览器
var isEdge = userAgent.indexOf("Edge") > -1 && !isIE; //判断是否IE的Edge浏览器
var isIE11 =
userAgent.indexOf("Trident") > -1 && userAgent.indexOf("rv:11.0") > -1;
if (isIE) {
var reIE = new RegExp("MSIE (\\d+\\.\\d+);");
reIE.test(userAgent);
var fIEVersion = parseFloat(RegExp["$1"]);
if (fIEVersion == 7) {
return 7;
} else if (fIEVersion == 8) {
return 8;
} else if (fIEVersion == 9) {
return 9;
} else if (fIEVersion == 10) {
return 10;
} else {
return 6; //IE版本<=7
}
} else if (isEdge) {
return 20; //edge
} else if (isIE11) {
return 11; //IE11
} else {
return 30; //不是ie浏览器
}
}
/**
* 启动wps客户端,加载项执行操作,无返回值
* @param {*} options 参数对象,详情见下:
* @param {*} clientType 加载项类型, wps / wpp / et
* @param {*} name 加载项名称
* @param {*} func 客户端加载项要执行的方法
* @param {*} param 客户端家乡执行方法的参数
* @param {*} urlBase 网页路径前缀
* @param {*} callback 回调函数
* @param {*} tryCount 请求失败后的尝试次数
* @param {*} bPop 是否弹出浏览器提示对话框
* @param {*} wpsclient wpsclient对象
*/
function WpsStart(options) {
console.log("WpsStart", options);
var startInfo = {
name: options.name,
function: options.func,
info: options.param.param,
jsPluginsXml: options.param.jsPluginsXml
};
var strData = JSON.stringify(startInfo);
if (IEVersion() < 10) {
try {
eval("strData = '" + JSON.stringify(startInfo) + "';");
} catch (err) {}
}
var baseData = encode(strData);
var url = options.urlBase + "/" + options.clientType + "/runParams";
var data = "ksowebstartup" + options.clientType + "://" + baseData;
startWps({
url: url,
sendData: data,
callback: options.callback,
tryCount: options.tryCount,
bPop: options.bPop,
timeout: 5000,
concurrent: false,
client: options.wpsclient
});
}
/**
* 服务端版本为空时,通过该接口启动wps
* @param {*} options 参数对象,详情见下:
* @param {*} clientType 加载项类型, wps / wpp / et
* @param {*} name 加载项名称
* @param {*} func 客户端加载项要执行的方法
* @param {*} param 客户端家乡执行方法的参数
* @param {*} urlBase 网页路径前缀
* @param {*} callback 回调函数
* @param {*} wpsclient wpsclient对象
* @param {*} concurrent 请求是否同步发送
*/
function WpsStartWrap(options) {
console.log("WpsStartWrap");
WpsStart({
clientType: options.clientType,
name: options.name,
func: options.func,
param: options.param,
urlBase: options.urlBase,
callback: options.callback,
tryCount: 4,
bPop: true,
wpsclient: options.wpsclient
});
}
/**
* 支持浏览器触发,WPS有返回值的启动
*
* @param {*} clientType 组件类型
* @param {*} name WPS加载项名称
* @param {*} func WPS加载项入口方法
* @param {*} param 参数:包括WPS加载项内部定义的方法,参数等
* @param {*} callback 回调函数
* @param {*} tryCount 重试次数
* @param {*} bPop 是否弹出浏览器提示对话框
*/
var exId = 0;
function WpsStartWrapExInner(options) {
console.log("WpsStartWrapExInner", options);
var infocontent = options.param.param;
if (!options.wpsclient || options.wpsclient.single) {
infocontent = JSON.stringify(options.param.param);
var rspUrl = options.urlBase + "/transferEcho/runParams";
var time = new Date();
var cmdId = "js" + time.getTime() + "_" + exId;
var funcEx = "var res = " + options.func;
var cbCode =
"var xhr = new XMLHttpRequest();xhr.open('POST', '" +
rspUrl +
"');xhr.send(JSON.stringify({id: '" +
cmdId +
"', response: res}));"; //res 为func执行返回值
var infoEx = infocontent + ");" + cbCode + "void(0";
options.func = funcEx;
infocontent = infoEx;
}
var startInfo = {
name: options.name,
function: options.func,
info: infocontent,
showToFront: options.param.showToFront,
jsPluginsXml: options.param.jsPluginsXml
};
var strData = JSON.stringify(startInfo);
if (IEVersion() < 10) {
try {
eval("strData = '" + JSON.stringify(startInfo) + "';");
} catch (err) {}
}
var baseData = encode(strData);
var wrapper;
if (!options.wpsclient || options.wpsclient.single) {
var url = options.urlBase + "/transfer/runParams";
var data = "ksowebstartup" + options.clientType + "://" + baseData;
wrapper = {
id: cmdId,
app: options.clientType,
data: data,
serverId: serverId,
mode: options.silentMode ? "true" : "false"
};
} else {
var url = options.urlBase + "/transferEx/runParams";
wrapper = {
id: options.wpsclient.clientId,
app: options.clientType,
data: baseData,
mode: options.wpsclient.silentMode ? "true" : "false",
serverId: serverId
};
}
wrapper = JSON.stringify(wrapper);
startWps({
url: url,
sendData: wrapper,
callback: options.callback,
tryCount: options.tryCount,
bPop: options.bPop,
timeout: 0,
concurrent: options.concurrent,
client: options.wpsclient
});
}
var serverVersion = "wait";
var cloudSvrStart = true;
var initCloudsvr = false;
/**
* 获取服务端版本号的接口
* @param {*} options 参数对象,详情见下:
* @param {*} clientType 加载项类型, wps / wpp / et
* @param {*} name 加载项名称
* @param {*} func 客户端加载项要执行的方法
* @param {*} param 客户端家乡执行方法的参数
* @param {*} urlBase 网页路径前缀
* @param {*} callback 回调函数
* @param {*} wpsclient wpsclient对象
* @param {*} concurrent 请求是否同步发送
*/
function WpsStartWrapVersionInner(options) {
console.log("WpsStartWrapVersionInner",options);
if (serverVersion == "wait") {
if (cloudSvrStart == false) {
InitWpsCloudSvr();
initCloudsvr = true;
}
startWps({
url: options.urlBase + "/version",
sendData: JSON.stringify({ serverId: serverId }),
callback: function(res) {
if (res.status !== 0) {
options.callback(res);
return;
}
serverVersion = res.response;
cloudSvrStart = true;
options.tryCount = 1;
options.bPop = false;
if (serverVersion === "") {
WpsStart(options);
} else if (serverVersion < "1.0.1" && options.wpsclient) {
options.wpsclient.single = true;
WpsStartWrapExInner(options);
} else {
WpsStartWrapExInner(options);
}
},
tryCount: 4,
bPop: true,
timeout: 5000,
concurrent: options.concurrent
});
} else {
options.tryCount = 4;
options.bPop = true;
if (serverVersion === "") {
WpsStartWrap(options);
} else if (serverVersion < "1.0.1" && options.wpsclient) {
options.wpsclient.single = true;
WpsStartWrapExInner(options);
} else {
WpsStartWrapExInner(options);
}
}
}
var HeartBeatCode =
"function getHttpObj() {\n" +
" var httpobj = null;\n" +
" if (IEVersion() < 10) {\n" +
" try {\n" +
" httpobj = new XDomainRequest();\n" +
" } catch (e1) {\n" +
" httpobj = new createXHR();\n" +
" }\n" +
" } else {\n" +
" httpobj = new createXHR();\n" +
" }\n" +
" return httpobj;\n" +
" }\n" +
" \n" +
" function createXHR() {\n" +
" if (typeof XMLHttpRequest != 'undefined') {\n" +
" return new XMLHttpRequest();\n" +
" } else if (typeof ActiveXObject != 'undefined') {\n" +
" var versions = [\n" +
" 'MSXML2.XMLHttp.6.0',\n" +
" 'MSXML2.XMLHttp.3.0',\n" +
" 'MSXML2.XMLHttp'\n" +
" ];\n" +
" \n" +
" for (var i = 0; i < versions.length; i++) {\n" +
" try {\n" +
" return new ActiveXObject(versions[i]);\n" +
" } catch (e) {\n" +
" \n" +
" }\n" +
" }\n" +
" } else {\n" +
" throw new Error('您的浏览器不支持XHR对象');\n" +
" }\n" +
" }\n" +
" \n" +
" function IEVersion() {\n" +
" var userAgent = navigator.userAgent; \n" +
" var isIE = userAgent.indexOf('compatible') > -1 && userAgent.indexOf('MSIE') > -1;\n" +
" var isEdge = userAgent.indexOf('Edge') > -1 && !isIE; \n" +
" var isIE11 = userAgent.indexOf('Trident') > -1 && userAgent.indexOf('rv:11.0') > -1;\n" +
" if (isIE) {\n" +
" var reIE = new RegExp('MSIE (\\d+\\.\\d+);');\n" +
" reIE.test(userAgent);\n" +
" var fIEVersion = parseFloat(RegExp['$1']);\n" +
" if (fIEVersion == 7) {\n" +
" return 7;\n" +
" } else if (fIEVersion == 8) {\n" +
" return 8;\n" +
" } else if (fIEVersion == 9) {\n" +
" return 9;\n" +
" } else if (fIEVersion == 10) {\n" +
" return 10;\n" +
" } else {\n" +
" return 6; \n" +
" }\n" +
" } else if (isEdge) {\n" +
" return 20; \n" +
" } else if (isIE11) {\n" +
" return 11; \n" +
" } else {\n" +
" return 30; \n" +
" }\n" +
" }\n" +
" var heartBeatStart = false;\n" +
" function checkLastRegTime() {\n" +
" var now = new Date().valueOf();\n" +
" var TimeGap = now - LastRegTime;\n" +
" if (TimeGap > 5000 && !heartBeatStart) {\n" +
" HeartBeat();\n" +
" heartBeatStart = true;\n" +
" }\n" +
" }\n" +
" \n" +
" function HeartBeat() {\n" +
" var heartBeatItem = function () {\n" +
" var xhr = getHttpObj();\n" +
" xhr.onload = function (e) {\n" +
" self.setTimeout(heartBeatItem, 5000);\n" +
" }\n" +
" xhr.onerror = function (e) {\n" +
" self.setTimeout(heartBeatItem, 5000);\n" +
" }\n" +
" xhr.ontimeout = function (e) {\n" +
" self.setTimeout(heartBeatItem, 5000);\n" +
" }\n" +
" xhr.open('POST', 'http://127.0.0.1:58890/askwebnotify', true);\n" +
" xhr.timeout = 2000;\n" +
" xhr.send(JSON.stringify(paramStr));\n" +
" }\n" +
" heartBeatItem();\n" +
" }\n" +
" \n" +
" var paramStr;\n" +
" var startCheck = false;\n" +
" self.addEventListener('message', function (event) {\n" +
" var data = event.data;\n" +
" paramStr = data.param\n" +
" paramStr.heartBeat = true\n" +
" LastRegTime = data.LastRegTime;\n" +
" if (!startCheck) {\n" +
" startCheck = true;\n" +
" self.setInterval(checkLastRegTime, 5000)\n" +
" }\n" +
" }, false);\n";
/**
* 生成guid的接口
* @returns guid
*/
function guid() {
return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function(c) {
var r = (Math.random() * 16) | 0,
v = c == "x" ? r : (r & 0x3) | 0x8;
return v.toString(16);
});
}
/**
* 开启多用户的接口
*/
var serverId = undefined;
function EnableMultiUser() {
serverId = getServerId();
}
/**
* 自定义协议启动服务端
* 默认不带参数serverId,linux未升级之前不要使用多用户
*/
function InitWpsCloudSvr() {
if (serverId == undefined)
window.location.href = "ksoWPSCloudSvr://start=RelayHttpServer";
//是否启动wps弹框
else
window.location.href =
"ksoWPSCloudSvr://start=RelayHttpServer" + "&serverId=" + serverId; //是否启动wps弹框
}
/**
* 获取serverId的接口
* @returns serverId
*/
function getServerId() {
if (window.localStorage) {
if (localStorage.getItem("serverId")) {
//
} else {
localStorage.setItem("serverId", guid());
}
return localStorage.getItem("serverId");
} else {
return guid();
}
}
/**
* 将字符串转成二进制,这里用来将字符串化后的js代码转成二进制文件
* @param {*} code
* @returns js文件对象的url
*/
function codeToBlob(code) {
var blob = new Blob([code], { type: "text/javascript" }); // 生成js文件对象
var objectURL = window.URL.createObjectURL(blob); // 生成js文件的url
return objectURL;
}
var RegWebNotifyMap = { wps: {}, wpp: {}, et: {} };
var bWebNotifyUseTimeout = true;
function WebNotifyUseTimeout(value) {
bWebNotifyUseTimeout = value ? true : false;
}
var g_businessId = Number(
Math.random()
.toString()
.substr(3, 5) + Date.parse(new Date())
).toString(36);
var HeartBeatWorker;
if (window.Worker) {
try {
HeartBeatWorker = new Worker(codeToBlob(HeartBeatCode));
} catch (error) {
//
}
}
var g_LastRegTime;
/**
* 注册一个前端页面接收WPS传来消息的方法
* @param {*} clientType wps | et | wpp
* @param {*} name WPS加载项的名称
* @param {*} callback 回调函数
* @param {*} wpsclient wpsclient对象
*/
function RegWebNotify(clientType, name, callback, wpsclient) {
if (clientType != "wps" && clientType != "wpp" && clientType != "et")
return;
var paramStr = {};
if (wpsclient) {
if (wpsclient.notifyRegsitered == true) {
return;
}
wpsclient.notifyRegsitered = true;
paramStr = {
clientId: wpsclient.clientId,
name: name,
type: clientType,
serverId: serverId
};
if (HeartBeatWorker) paramStr.businessId = g_businessId;
} else {
if (typeof callback != "function") return;
if (RegWebNotifyMap[clientType][name]) {
RegWebNotifyMap[clientType][name] = callback;
return;
}
var RegWebNotifyID = new Date().valueOf() + "";
paramStr = {
id: RegWebNotifyID,
name: name,
type: clientType,
serverId: serverId
};
if (HeartBeatWorker) paramStr.businessId = g_businessId;
RegWebNotifyMap[clientType][name] = callback;
}
var askItem = function() {
var xhr = getHttpObj();
xhr.onload = function(e) {
if (xhr.responseText == "WPSInnerMessage_quit") {
return;
}
try {
var resText = JSON.parse(xhr.responseText);
if (typeof resText == "object") {
paramStr.messageId = resText.msgId;
}
if (wpsclient) {
if (typeof resText.data == "object")
// 如果发的数据是字符串化后的json对象,这里的resText.data就是一个json对象,可以输出自己想要的json数据
wpsclient.OnRegWebNotify(resText.data.data);
else wpsclient.OnRegWebNotify(resText.data);
} else {
var func = RegWebNotifyMap[clientType][name];
if (typeof resText.data == "object")
// 如果发的数据是字符串化后的json对象,这里的resText.data就是一个json对象,可以输出自己想要的json数据
func(resText.data.data);
else func(resText.data);
}
} catch (e) {
// 这里做一个容错,即使json解析失败,也要把msgId提取出来,发回给服务端,避免消息清不掉一直重复发送
// 同时把data也取出来,但是格式无法保证
var str = xhr.responseText;
var idx1 = str.indexOf(":");
var idx2 = str.indexOf(",");
paramStr.messageId = parseInt(str.substring(idx1 + 1, idx2));
var idx3 = str.indexOf('"data"');
var idx4 = str.indexOf("}");
var data = str.substring(idx3, idx4);
if (wpsclient) {
if (data) wpsclient.OnRegWebNotify(data);
else wpsclient.OnRegWebNotify(xhr.responseText);
} else {
var func = RegWebNotifyMap[clientType][name];
if (data) func(data);
else func(xhr.responseText);
}
}
window.setTimeout(askItem, 300);
};
xhr.onerror = function(e) {
if (bWebNotifyUseTimeout) window.setTimeout(askItem, 1000);
else window.setTimeout(askItem, 10000);
};
xhr.ontimeout = function(e) {
if (bWebNotifyUseTimeout) window.setTimeout(askItem, 300);
else window.setTimeout(askItem, 10000);
};
if (IEVersion() < 10) {
xhr.onreadystatechange = function() {
if (xhr.readyState != 4) return;
if (xhr.bTimeout) {
return;
}
if (xhr.status === 200) xhr.onload();
else xhr.onerror();
};
}
xhr.open("POST", GetUrlBase() + "/askwebnotify", true);
if (bWebNotifyUseTimeout) xhr.timeout = 2000;
if (HeartBeatWorker) {
g_LastRegTime = new Date().valueOf();
var param = {
param: {
name: name,
type: clientType,
businessId: g_businessId,
serverId: serverId
},
LastRegTime: g_LastRegTime
};
HeartBeatWorker.postMessage(param);
}
xhr.send(JSON.stringify(paramStr));
};
window.setTimeout(askItem, 2000);
}
/**
* 获取网页路径前缀
* @returns url前缀
*/
function GetUrlBase() {
if (location.protocol == "https:") return "https://127.0.0.1:58891";
return "http://127.0.0.1:58890";
}
/**
* 获取服务端版本号的接口,这里主要是初始化一些参数
* @param {*} clientType 加载项类型, wps / wpp / et
* @param {*} name 加载项名称
* @param {*} func 客户端加载项要执行的方法
* @param {*} param 客户端家乡执行方法的参数
* @param {*} callback 回调函数
* @param {*} showToFront 设置客户端是否显示到前面
* @param {*} jsPluginsXml 设置加载项路径
* @param {*} silentMode 静默启动WPS
*/
function WpsStartWrapVersion(
clientType,
name,
func,
param,
callback,
showToFront,
jsPluginsXml,
silentMode
) {
var paramEx = {
jsPluginsXml: jsPluginsXml ? jsPluginsXml : "",
showToFront: typeof showToFront == "boolean" ? showToFront : true,
param: typeof param == "object" ? param : JSON.parse(param)
};
var options = {
clientType: clientType,
name: name,
func: func,
param: paramEx,
urlBase: GetUrlBase(),
callback: callback,
wpsclient: undefined,
concurrent: true,
silentMode: silentMode
};
WpsStartWrapVersionInner(options);
}
//从外部浏览器远程调用 WPS 加载项中的方法
var WpsInvoke = {
InvokeAsHttp: WpsStartWrapVersion,
InvokeAsHttps: WpsStartWrapVersion,
RegWebNotify: RegWebNotify,
ClientType: {
wps: "wps",
et: "et",
wpp: "wpp"
},
CreateXHR: getHttpObj,
IsClientRunning: IsClientRunning
};
window.wpsclients = [];
/**
* @constructor WpsClient wps客户端
* @param {string} clientType 必传参数,加载项类型,有效值为"wps","wpp","et";分别表示文字,演示,电子表格
*/
function WpsClient(clientType) {
/**
* 设置RegWebNotify的回调函数,加载项给业务端发消息通过该函数
* @memberof WpsClient
* @member onMessage
*/
this.onMessage;
/**
* 设置加载项路径
* @memberof WpsClient
* @member jsPluginsXml
*/
this.jsPluginsXml;
/**
* 内部成员,外部无需调用
*/
this.notifyRegsitered = false;
this.clientId = "";
this.concurrent = false;
this.clientType = clientType;
this.firstRequest = true;
/**
* 内部函数,外部无需调用
* @param {*} options
*/
this.initWpsClient = function(options) {
options.clientType = this.clientType;
options.wpsclient = this;
options.concurrent = this.firstRequest ? true : this.concurrent;
this.firstRequest = false;
WpsStartWrapVersionInner(options);
};
/**
* 以http启动
* @param {string} name 加载项名称
* @param {string} func 要调用的加载项中的函数行
* @param {string} param 在加载项中执行函数func要传递的数据
* @param {function({int, string})} callback 回调函数,status = 0 表示成功,失败请查看message信息
* @param {bool} showToFront 设置wps是否显示到前面来
* @return {string} "Failed to send message to WPS." 发送消息失败,客户端已关闭;
* "WPS Addon is not response." 加载项阻塞,函数执行失败
*/
this.InvokeAsHttp = function(name, func, param, callback, showToFront) {
function clientCallback(res) {
//this不是WpsClient
if (res.status !== 0 || serverVersion < "1.0.1") {
if (callback) callback(res);
RegWebNotify(clientType, name, this.client.onMessage);
return;
}
var resObject = JSON.parse(res.response);
if (this.client.clientId == "") {
this.client.clientId = resObject.clientId;
}
this.client.concurrent = true;
if (typeof resObject.data == "object")
res.response = JSON.stringify(resObject.data);
else res.response = resObject.data;
if (IEVersion() < 10) eval(" res.response = '" + res.response + "';");
if (callback) callback(res);
this.client.RegWebNotify(name);
}
var paramEx = {
jsPluginsXml: this.jsPluginsXml ? this.jsPluginsXml : "",
showToFront: typeof showToFront == "boolean" ? showToFront : true,
param: typeof param == "object" ? param : JSON.parse(param)
};
this.initWpsClient({
name: name,
func: func,
param: paramEx,
urlBase: GetUrlBase(),
callback: clientCallback
});
};
/**
* 以https启动
* @param {string} name 加载项名称
* @param {string} func 要调用的加载项中的函数行
* @param {string} param 在加载项中执行函数func要传递的数据
* @param {function({int, string})} callback 回调函数,status = 0 表示成功,失败请查看message信息
* @param {bool} showToFront 设置wps是否显示到前面来
*/
this.InvokeAsHttps = function(name, func, param, callback, showToFront) {
var paramEx = {
jsPluginsXml: this.jsPluginsXml ? this.jsPluginsXml : "",
showToFront: typeof showToFront == "boolean" ? showToFront : true,
param: typeof param == "object" ? param : JSON.parse(param)
};
this.initWpsClient({
name: name,
func: func,
param: paramEx,
urlBase: GetUrlBase(),
callback: callback
});
};
/**
* 内部函数,外部无需调用
* @param {*} name
*/
this.RegWebNotify = function(name) {
RegWebNotify(this.clientType, name, null, this);
};
/**
* 消息注册函数的回调函数
* @param {*} message 客户端发来的消息
*/
this.OnRegWebNotify = function(message) {
if (this.onMessage) this.onMessage(message);
};
/**
* 以静默模式启动客户端
* @param {string} name 必传参数,加载项名称
* @param {function({int, string})} [callback] 回调函数,status = 0 表示成功,失败请查看message信息
*/
this.StartWpsInSilentMode = function(name, callback) {
function initCallback(res) {
//this不是WpsClient
if (res.status !== 0 || serverVersion < "1.0.1") {
if (callback) callback(res);
RegWebNotify(clientType, name, this.client.onMessage);
return;
}
if (this.client.clientId == "") {
this.client.clientId = JSON.parse(res.response).clientId;
window.wpsclients[window.wpsclients.length] = {
name: name,
client: this.client
};
}
res.response = JSON.stringify(JSON.parse(res.response).data);
this.client.concurrent = true;
if (callback) {
callback(res);
}
this.client.RegWebNotify(name);
}
var paramEx = {
jsPluginsXml: this.jsPluginsXml,
showToFront: false,
param: { status: "InitInSilentMode" }
};
this.silentMode = true;
this.initWpsClient({
name: name,
func: "",
param: paramEx,
urlBase: GetUrlBase(),
callback: initCallback
});
};
/**
* 显示客户端到最前面
* @param {string} name 必传参数,加载项名称
* @param {function({int, string})} [callback] 回调函数
*/
this.ShowToFront = function(name, callback) {
if (serverVersion < "1.0.1") {
if (callback) {
callback({
status: 4,
message: "当前客户端不支持,请升级客户端"
});
return;
}
return;
}
if (this.clientId == "") {
if (callback)
callback({
status: 3,
message: "没有静默启动客户端"
});
return;
}
var paramEx = {
jsPluginsXml: "",
showToFront: true,
param: { status: "ShowToFront" }
};
this.initWpsClient({
name: name,
func: "",
param: paramEx,
urlBase: GetUrlBase(),
callback: callback
});
};
/**
* 关闭未显示出来的静默启动客户端
* @param {string} name 必传参数,加载项名称
* @param {function({int, string})} [callback] 回调函数
*/
this.CloseSilentClient = function(name, callback) {
if (serverVersion < "1.0.1") {
if (callback) {
callback({
status: 4,
message: "当前客户端不支持,请升级客户端"
});
return;
}
return;
}
if (this.clientId == "") {
if (callback)
callback({
status: 3,
message: "没有静默启动客户端"
});
return;
}
var paramEx = {
jsPluginsXml: "",
showToFront: false,
param: undefined
};
var func;
if (this.clientType == "wps") func = "wps.WpsApplication().Quit";
else if (this.clientType == "et") func = "wps.EtApplication().Quit";
else if (this.clientType == "wpp") func = "wps.WppApplication().Quit";
function closeSilentClient(res) {
if (res.status == 0) this.client.clientId = "";
if (callback) callback(res);
return;
}
this.initWpsClient({
name: name,
func: func,
param: paramEx,
urlBase: GetUrlBase(),
callback: closeSilentClient
});
};
/**
* 当前客户端是否在运行,使用WpsClient.IsClientRunning()进行调用
* @param {function({int, string})} [callback] 回调函数,"Client is running." 客户端正在运行
* "Client is not running." 客户端没有运行
*/
this.IsClientRunning = function(callback) {
if (serverVersion < "1.0.1") {
if (callback) {
callback({
status: 4,
message: "当前客户端不支持,请升级客户端"
});
return;
}
return;
}
IsClientRunning(this.clientType, callback, this);
};
}
/**
* 初始化sdk,用来减少在服务进程启动时自定义协议弹框出现的次数
*/
function InitSdk() {
var url = GetUrlBase() + "/version";
startWps({
url: url,
callback: function(res) {
if (res.status !== 0) {
cloudSvrStart = false;
return;
}
if (serverVersion == "wait") {
InitMultiUser();
}
},
tryCount: 1,
bPop: false,
timeout: 1000
});
}
InitSdk();
/**
* 初始化多用户模式
*/
function InitMultiUser() {
var url = GetUrlBase() + "/version";
startWps({
url: url,
sendData: JSON.stringify({ serverId: serverId }),
callback: function(res) {
if (res.status !== 0) {
cloudSvrStart = false;
return;
}
if (serverVersion == "wait") {
serverVersion = res.response;
cloudSvrStart = true;
}
},
tryCount: 1,
bPop: false,
timeout: 1000
});
}
if (typeof noGlobal === "undefined") {
window.WpsInvoke = WpsInvoke;
window.WpsClient = WpsClient;
window.WebNotifyUseTimeout = WebNotifyUseTimeout;
window.EnableMultiUser = EnableMultiUser;
}
/**
* 当前客户端是否在运行,使用WpsInvoke.IsClientRunning()进行调用
* @param {string} clientType 加载项类型
* @param {function} [callback] 回调函数,"Client is running." 客户端正在运行
* "Client is not running." 客户端没有运行
*/
function IsClientRunning(clientType, callback, wpsclient) {
var url = GetUrlBase() + "/isRunning";
var wrapper = {
id: wpsclient == undefined ? undefined : wpsclient.clientId,
app: clientType,
serverId: serverId
};
wrapper = JSON.stringify(wrapper);
startWps({
url: url,
sendData: wrapper,
callback: callback,
tryCount: 1,
bPop: false,
timeout: 2000,
concurrent: true,
client: wpsclient
});
}
/**
* 获取publish.xml的内容
* @param {*} callBack 回调函数
*/
function WpsAddonGetAllConfig(callBack) {
var baseData = JSON.stringify({ serverId: serverId });
startWps({
url: GetUrlBase() + "/publishlist",
type: "POST",
sendData: baseData,
callback: callBack,
tryCount: 3,
bPop: true,
timeout: 5000,
concurrent: true
});
}
/**
* 检查ribbon.xml文件是否有效
* @param {*} element 参数对象
* @param {*} callBack 回调函数
*/
function WpsAddonVerifyStatus(element, callBack) {
var xmlReq = getHttpObj();
var offline = element.online === "false";
var url = offline ? element.url : element.url + "ribbon.xml";
xmlReq.open("POST", GetUrlBase() + "/redirect/runParams");
xmlReq.onload = function(res) {
if (offline && !res.target.response.startsWith("7z")) {
callBack({ status: 1, msg: "不是有效的7z格式" + url });
} else if (!offline && !res.target.response.startsWith("<customUI")) {
callBack({ status: 1, msg: "不是有效的ribbon.xml, " + url });
} else {
callBack({ status: 0, msg: "OK" });
}
};
xmlReq.onerror = function(res) {
xmlReq.bTimeout = true;
callBack({
status: 2,
msg: "网页路径不可访问,如果是跨域问题,不影响使用" + url
});
};
xmlReq.ontimeout = function(res) {
xmlReq.bTimeout = true;
callBack({ status: 3, msg: "访问超时" + url });
};
if (IEVersion() < 10) {
xmlReq.onreadystatechange = function() {
if (xmlReq.readyState != 4) return;
if (xmlReq.bTimeout) {
return;
}
if (xmlReq.status === 200) xmlReq.onload();
else xmlReq.onerror();
};
}
xmlReq.timeout = 5000;
var data = {
method: "get",
url: url,
data: ""
};
var sendData = FormatSendData(data);
xmlReq.send(sendData);
}
/**
* 部署加载项,包括启动enable / disable禁用 / disableall禁用所有
* @param {*} element 参数对象
* @param {*} cmd 具体操作,enable / disable / disableall
* @param {*} callBack 回调函数
*/
function WpsAddonHandleEx(element, cmd, callBack) {
console.log("WpsAddonHandleEx", element, cmd, callBack)
var data = FormatData(element, cmd);
startWps({
url: GetUrlBase() + "/deployaddons/runParams",
type: "POST",
sendData: data,
callback: callBack,
tryCount: 3,
bPop: true,
timeout: 5000,
concurrent: true
});
}
/**
* 启用加载项
* @param {*} element 参数对象
* @param {*} callBack 回调函数
*/
function WpsAddonEnable(element, callBack) {
WpsAddonHandleEx(element, "enable", callBack);
}
/**
* 禁用加载项
* @param {*} element 参数对象
* @param {*} callBack 回调函数
*/
function WpsAddonDisable(element, callBack) {
WpsAddonHandleEx(element, "disable", callBack);
}
wpsjsrpcsdk.js
/**
* 生成json格式的数据
* @param {*} element 参数对象
* @param {*} cmd 具体操作,enable / disable / disableall
* @returns base64编码后的数据
*/
function FormatData(element, cmd) {
var data = {
cmd: cmd, //"enable", 启用, "disable", 禁用, "disableall", 禁用所有
name: element.name,
url: element.url,
addonType: element.addonType,
online: element.online,
version: element.version
};
return FormatSendData(data);
}
/**
* 将json格式的数据字符串化,并进行base64编码
* @param {*} data 数据
* @returns base64编码后的数据
*/
function FormatSendData(data) {
var strData = JSON.stringify(data);
if (IEVersion() < 10) eval("strData = '" + JSON.stringify(strData) + "';");
if (serverVersion == "1.0.2") {
var base64Data = encode(strData);
return JSON.stringify({
serverId: serverId,
data: base64Data
});
} else {
return encode(strData);
}
}
//管理 WPS 加载项
var WpsAddonMgr = {
getAllConfig: WpsAddonGetAllConfig,
verifyStatus: WpsAddonVerifyStatus,
enable: WpsAddonEnable,
disable: WpsAddonDisable
};
if (typeof noGlobal === "undefined") {
window.WpsAddonMgr = WpsAddonMgr;
}
return { WpsInvoke: WpsInvoke, WpsAddonMgr: WpsAddonMgr, version: "1.0.21" };
});
et.js
var pluginsMode = location.search.split("=")[1];//截取url中的参数值
var pluginType = WpsInvoke.ClientType.et//加载项类型wps,et,wpp
var pluginName = "EtOAAssist";//加载项名称
var wpsClient = new WpsClient(pluginType);//初始化一个多进程对象,多进程时才需要
var clientStr = pluginName + pluginType + "ClientId"
//单进程封装开始
/**
* 此方法是根据wps_sdk.js做的调用方法封装
* 可参照此定义
* @param {*} funcs 这是在WPS加载项内部定义的方法,采用JSON格式(先方法名,再参数)
* @param {*} front 控制着通过页面执行WPS加载项方法,WPS的界面是否在执行时在前台显示
* @param {*} jsPluginsXml 指定一个新的WPS加载项配置文件的地址,动态传递jsplugins.xml模式,例如:http://127.0.0.1:3888/jsplugins.xml
* @param {*} isSilent 隐藏打开WPS,如果需要隐藏,那么需要传递front参数为false
*/
export function _Et(funcs, front, jsPluginsXml, isSilent) {
var info = {};
info.funcs = funcs;
if (isSilent) {//隐藏启动时,front必须为false
front = false;
}
/**
* 下面函数为调起WPS,并且执行加载项WpsOAAssist中的函数dispatcher,该函数的参数为业务系统传递过去的info
*/
if (pluginsMode != 2) {//单进程
singleInvoke(info, front, jsPluginsXml, isSilent)
} else {//多进程
multInvoke(info, front, jsPluginsXml, isSilent)
}
}
//单进程
function singleInvoke(info, front, jsPluginsXml, isSilent) {
WpsInvoke.InvokeAsHttp(pluginType, // 组件类型
pluginName, // 插件名,与wps客户端加载的加载的插件名对应
"dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
info, // 传递给插件的数据
function (result) { // 调用回调,status为0为成功,其他是错误
if (result.status) {
if (result.status == 100) {
WpsInvoke.AuthHttpesCert('请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。')
return;
}
alert(result.message)
} else {
console.log(result.response)
}
},
front,
jsPluginsXml,
isSilent)
/**
* 接受WPS加载项发送的消息
* 接收消息:WpsInvoke.RegWebNotify(type,name,callback)
* WPS客户端返回消息: wps.OAAssist.WebNotify(message)
* @param {*} type 加载项对应的插件类型
* @param {*} name 加载项对应的名字
* @param {func} callback 接收到WPS客户端的消息后的回调函数,参数为接受到的数据
*/
WpsInvoke.RegWebNotify(pluginType, pluginName, handleOaMessage)
}
//多进程
function multInvoke(info, front, jsPluginsXml, isSilent) {
wpsClient.jsPluginsXml = jsPluginsXml ? jsPluginsXml : "http://192.168.21.5:9998/wps/jsplugins.xml"; //这里改成自己起的服务地址
if (localStorage.getItem(clientStr)) {
wpsClient.clientId = localStorage.getItem(clientStr)
}
if (isSilent) {
wpsClient.StartWpsInSilentMode(pluginName, function () {//隐藏启动后的回调函数
mult(info, front)
})
} else {
mult(info, front)
}
wpsClient.onMessage = handleOaMessage
}
//多进程二次封装
function mult(info, front) {
wpsClient.InvokeAsHttp(
pluginName, // 插件名,与wps客户端加载的加载的插件名对应
"dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
info, // 传递给插件的数据
function (result) { // 调用回调,status为0为成功,其他是错误
if (wpsClient.clientId) {
localStorage.setItem(clientStr, wpsClient.clientId)
}
if (result.status !== 0) {
console.log(result)
if (result.message == '{\"data\": \"Failed to send message to WPS.\"}') {
wpsClient.IsClientRunning(function (status) {
console.log(status)
if (status.response == "Client is running.")
alert("任务发送失败,WPS 正在执行其他任务,请前往WPS完成当前任务")
else {
wpsClient.clientId = "";
wpsClient.notifyRegsitered = false;
localStorage.setItem(clientStr, "")
mult(info)
}
})
return;
}
else if (result.status == 100) {
// WpsInvoke.AuthHttpesCert('请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。')
return;
}
alert(result.message)
} else {
console.log(result.response)
}
},
front)
}
function handleOaMessage(data) {
console.log(data)
}
function GetUploadPath() {
var url = document.location.host;
return document.location.protocol + "//" + url + "/Upload";
}
function GetDemoPath(fileName) {
var url = document.location.host;
return document.location.protocol + "//" + url + "/file/" + fileName;
}
function newDoc() {
_WpsInvoke([{
"OpenDoc": {
showButton: "btnSaveFile;btnSaveAsLocal"
}
}])
}
wps文件:我是放在public\cdn\wps-oa的,所以LoadPublishAddons方法里面的/cdn/wps-oa要随你放置的位置进行变动。
function LoadPublishAddons() {
var addonList = document.getElementById("addonList");
var origin = window.location.origin
var curList = [{"name":"WpsOAAssist","addonType":"wps","online":"true","multiUser":"false","url":origin + "/cdn/wps-oa/WpsOAAssist/"},{"name":"EtOAAssist","addonType":"et","online":"true","multiUser":"false","url":origin + "/cdn/wps-oa/EtOAAssist/"},{"name":"WppOAAssist","addonType":"wpp","online":"true","multiUser":"false","url":origin + "/cdn/wps-oa/WppOAAssist/"}];
curList.forEach(function (element) {
var param = JSON.stringify(element).replace("\"", "\'");
UpdateElement(element, 'enable')
});
}
标签:function,return,name,param,wps,callback,publish,vue2,var
From: https://www.cnblogs.com/xiaojianwei/p/18184951