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.

312 lines
11KB

  1. /**
  2. * 从OA调用传来的指令,打开本地新建文件
  3. * @param {*} fileUrl 文件url路径
  4. */
  5. function NewFile(params) {
  6. //获取WPP Application 对象
  7. var wppApp = wps.WppApplication();
  8. var doc = wppApp.Presentations.Add(); //新增OA端文档
  9. wps.PluginStorage.setItem("IsInCurrOADocOpen", false);
  10. //检查系统临时文件目录是否能访问
  11. if (wps.Env && wps.Env.GetTempPath) {
  12. if (params.newFileName) {
  13. //按OA传入的文件名称保存
  14. doc.SaveAs($FileName = wps.Env.GetTempPath() + "/" + params.newFileName);
  15. } else {
  16. //OA传入空文件名称,则保存成系统时间文件
  17. doc.SaveAs($FileName = wps.Env.GetTempPath() + "/OA_" + currentTime());
  18. }
  19. } else {
  20. alert("文档保存临时目录出错!不能保存新建文档!请联系系统开发商。");
  21. }
  22. var l_NofityURL = GetParamsValue(params, "notifyUrl");
  23. if (l_NofityURL) {
  24. NotifyToServer(l_NofityURL.replace("{?}", "1"));
  25. }
  26. //Office文件打开后,设置该文件属性:从服务端来的OA文件
  27. pSetOADocumentFlag(doc, params);
  28. //设置当前文档为 本地磁盘落地模式
  29. DoSetOADocLandMode(doc, EnumDocLandMode.DLM_LocalDoc);
  30. //强制执行一次Activate事件
  31. OnWindowActivate();
  32. return doc; //返回新创建的Document对象
  33. }
  34. /**
  35. * 打开服务器上的文件
  36. * @param {*} fileUrl 文件url路径
  37. */
  38. function OpenFile(params) {
  39. var l_strFileUrl = params.fileName; //来自OA网页端的OA文件下载路径
  40. var doc;
  41. var l_IsOnlineDoc = false; //默认打开的是不落地文档
  42. if (l_strFileUrl) {
  43. //下载文档之前,判断是否已下载该文件
  44. if (pCheckIsExistOpenOADoc(l_strFileUrl) == true) {
  45. //如果找到相同OA地址文档,则给予提示
  46. wps.WppApplication().Activate(); //把WPS对象置前
  47. //根据OA助手对是否允许再次打开相同文件的判断处理
  48. var l_AllowOADocReOpen = false;
  49. l_AllowOADocReOpen = wps.PluginStorage.getItem("AllowOADocReOpen");
  50. if (l_AllowOADocReOpen == false) {
  51. alert("已打开相同的OA文件,请关闭之前的文件,再次打开。");
  52. wps.WppApplication().Activate();
  53. return null;
  54. } else {
  55. //处理重复打开相同OA 文件的方法
  56. var nDocCount = wps.WppApplication().Presentations.Count;
  57. pReOpenOADoc(l_strFileUrl);
  58. //重复打开的文档采用不落地的方式打开
  59. // 不落地方式打开文档判断落地比较多,V1版本先暂时关闭
  60. l_IsOnlineDoc = true;
  61. var nDocCount_New = wps.WppApplication().Presentations.Count;
  62. if (nDocCount_New > nDocCount) {
  63. doc = wps.WppApplication().ActivePresentation;
  64. }
  65. }
  66. } else {
  67. //如果当前没有打开文档,则另存为本地文件,再打开
  68. if (l_strFileUrl.startWith("http")) { // 网络文档
  69. DownloadFile(l_strFileUrl, function (path) {
  70. if (path == "") {
  71. alert("从服务端下载路径:" + l_strFileUrl + "\n" + "获取文件下载失败!");
  72. return null;
  73. }
  74. doc = pDoOpenOADocProcess(params, path);
  75. pOpenFile(doc, params, l_IsOnlineDoc);
  76. });
  77. return null;
  78. } else { //本地文档
  79. doc = pDoOpenOADocProcess(params, l_strFileUrl);
  80. if (doc)
  81. doc.SaveAs($FileName = wps.Env.GetTempPath() + "/" + doc.Name);
  82. }
  83. }
  84. } else {
  85. //fileURL 如果为空,则按新建OA本地文件处理
  86. NewFile(params);
  87. }
  88. //如果打开pdf等其他非Office文档,则doc对象为空
  89. if (!doc) {
  90. return null;
  91. }
  92. pOpenFile(doc, params, l_IsOnlineDoc);
  93. }
  94. function pOpenFile(doc, params, isOnlineDoc){
  95. var l_IsOnlineDoc = isOnlineDoc
  96. //Office文件打开后,设置该文件属性:从服务端来的OA文件
  97. pSetOADocumentFlag(doc, params);
  98. //设置当前文档为 本地磁盘落地模式
  99. if (l_IsOnlineDoc == true) {
  100. DoSetOADocLandMode(doc, EnumDocLandMode.DLM_OnlineDoc);
  101. } else {
  102. DoSetOADocLandMode(doc, EnumDocLandMode.DLM_LocalDoc);
  103. }
  104. l_NofityURL = GetParamsValue(params, "notifyUrl");
  105. if (l_NofityURL) {
  106. l_NofityURL = l_NofityURL.replace("{?}", "1"); //约定:参数为1则代码打开状态
  107. NotifyToServer(l_NofityURL);
  108. }
  109. //重新设置工具条按钮的显示状态
  110. pDoResetRibbonGroups();
  111. // 触发切换窗口事件
  112. OnWindowActivate();
  113. // 把WPS对象置前
  114. wps.WppApplication().Activate();
  115. return doc;
  116. }
  117. /**
  118. * 不落地打开服务端的文档
  119. * @param {*} fileUrl 文件url路径
  120. */
  121. function OpenOnLineFile(OAParams) {
  122. //OA参数如果为空的话退出
  123. if (!OAParams) return;
  124. //获取在线文档URL
  125. var l_OAFileUrl = OAParams.fileName;
  126. var l_doc;
  127. if (l_OAFileUrl) {
  128. //下载文档不落地
  129. wps.WppApplication().Presentations.OpenFromUrl(l_OAFileUrl, "OnOpenOnLineDocSuccess", "OnOpenOnLineDocDownFail");
  130. //设置文档的权限,模拟保护模式打开
  131. setDocumentRights(ksoRightsInfo.ksoNoneRight)
  132. l_doc = wps.WppApplication().ActivePresentation;
  133. }
  134. //执行文档打开后的方法
  135. pOpenFile(l_doc, OAParams, true);
  136. return l_doc;
  137. // //Office文件打开后,设置该文件属性:从服务端来的OA文件
  138. // pSetOADocumentFlag(l_doc, OAParams);
  139. // //设置当前文档为 不落地打开模式
  140. // DoSetOADocLandMode(l_doc, EnumDocLandMode.DLM_OnlineDoc);
  141. // // 强制执行一次Activate事件
  142. // OnWindowActivate();
  143. // return l_doc;
  144. }
  145. /**
  146. * 打开在线文档成功后触发事件
  147. * @param {*} resp
  148. */
  149. function OnOpenOnLineDocSuccess(resp) {
  150. }
  151. /**
  152. * 作用:打开文档处理的各种过程,包含:打开带密码的文档,保护方式打开文档,修订方式打开文档等种种情况
  153. * params Object OA Web端传来的请求JSON字符串,具体参数说明看下面数据
  154. * TempLocalFile : 字符串 先把文档从OA系统下载并保存在Temp临时目录,这个参数指已经下载下来的本地文档地址
  155. * ----------------------以下是OA参数的一些具体规范名称
  156. * docId String 文档ID
  157. * uploadPath String 保存文档接口
  158. * fileName String 获取服务器文档接口(不传即为新建空文档)
  159. * buttonGroups string 自定义按钮组 (可不传,不传显示所有按钮)
  160. */
  161. function pDoOpenOADocProcess(params, TempLocalFile) {
  162. for (var key = "" in params) {
  163. switch (key.toUpperCase()) //
  164. {
  165. case "buttonGroups".toUpperCase(): //按钮组合
  166. break;
  167. }
  168. }
  169. //可设置ReadOnly?: Kso.KsoMsoTriState属性设置:-1是只读,其他值都是非只读
  170. var l_Doc = wps.WppApplication().Presentations.Open(TempLocalFile);
  171. return l_Doc;
  172. }
  173. /**
  174. * 打开在线不落地文档出现失败时,给予错误提示
  175. */
  176. function OnOpenOnLineDocDownFail() {
  177. alert("打开在线不落地文档失败!请尝试重新打开。");
  178. return;
  179. }
  180. /**
  181. * 功能说明:判断是否已存在来自OA的已打开的文档
  182. * @param {字符串} FileURL
  183. */
  184. function pCheckIsExistOpenOADoc(FileURL) {
  185. var l_DocCount = wps.WppApplication().Presentations.Count;
  186. if (l_DocCount <= 0) return false;
  187. //轮询检查当前已打开的文档中,是否存在OA相同的文件
  188. if (l_DocCount >= 1) {
  189. for (var l_index = 1; l_index <= l_DocCount; l_index++) {
  190. var l_objDoc = wps.WppApplication().Presentations.Item(l_index);
  191. var l_strParam = wps.PluginStorage.getItem(l_objDoc.FullName);
  192. if (l_strParam == null)
  193. continue;
  194. var l_objParam = JSON.parse(l_strParam)
  195. if (l_objParam.fileName == FileURL) {
  196. return true;
  197. }
  198. }
  199. return false;
  200. }
  201. }
  202. /**
  203. * 参数:
  204. * doc : 当前OA文档的Document对象
  205. * DocLandMode : 落地模式设置
  206. */
  207. function DoSetOADocLandMode(doc, DocLandMode) {
  208. if (!doc) return;
  209. var l_Param = wps.PluginStorage.getItem(doc.FullName);
  210. var l_objParam = JSON.parse(l_Param);
  211. //增加属性,或设置
  212. l_objParam.OADocLandMode = DocLandMode; //设置OA文档的落地标志
  213. var l_p = JSON.stringify(l_objParam);
  214. //将OA文档落地模式标志存入系统变量对象保存
  215. wps.PluginStorage.setItem(doc.FullName, l_p);
  216. }
  217. //Office文件打开后,设置该文件属性:从服务端来的OA文件
  218. function pSetOADocumentFlag(doc, params) {
  219. if (!doc) {
  220. return;
  221. }
  222. var l_Param = params;
  223. l_Param.isOA = EnumOAFlag.DocFromOA; //设置OA打开文档的标志
  224. l_Param.SourcePath = doc.FullName; //保存OA的原始文件路径,用于保存时分析,是否进行了另存为操作
  225. if (doc) {
  226. var l_p = JSON.stringify(l_Param);
  227. //将OA文档标志存入系统变量对象保存
  228. wps.PluginStorage.setItem(doc.FullName, l_p);
  229. }
  230. }
  231. /**
  232. * 作用:设置Ribbon工具条的按钮显示状态
  233. * @param {*} paramsGroups
  234. */
  235. function pDoResetRibbonGroups(paramsGroups) {
  236. }
  237. /**
  238. * 按照定时器的时间,自动执行所有文档的自动保存事件
  239. */
  240. function OnDocSaveByAutoTimer() {
  241. var l_Doc;
  242. var l_Count = 0
  243. var l_docCounts = wps.WppApplication().Presentations.Count;
  244. for (l_Count = 0; l_Count < l_docCounts; l_Count++) {
  245. l_Doc = wps.WppApplication().Presentations.Item(l_Count);
  246. if (l_Doc) {
  247. if (pCheckIfOADoc(l_Doc) == true) { // 是否为OA文件
  248. //执行自动上传到OA服务器端的操作
  249. pAutoUploadToServer(l_Doc);
  250. //保存该文档对应的访问过程记录信息
  251. }
  252. }
  253. }
  254. }
  255. /**
  256. * 实现一个定时器
  257. */
  258. function OpenTimerRun(funcCallBack) {
  259. var l_mCount = 0; //设置一个计时器,按每分钟执行一次; 10分钟后重复执行
  260. var l_timeID = 0; //用于保存计时器ID值
  261. // 对间隔时间做处理
  262. var l_AutoSaveToServerTime = wps.PluginStorage.getItem("AutoSaveToServerTime");
  263. if (l_AutoSaveToServerTime == 0) { // 设置为0则不启动定时器
  264. l_timeID = wps.PluginStorage.getItem("TempTimerID");
  265. clearInterval(l_timeID);
  266. return;
  267. } else if (l_AutoSaveToServerTime < 3) {
  268. l_AutoSaveToServerTime = 3;
  269. }
  270. l_timeID = setInterval(function () {
  271. l_mCount = l_mCount + 1;
  272. if (l_mCount > l_AutoSaveToServerTime) { //l_AutoSaveToServerTime 值由系统配置时设定,见pInitParameters()函数
  273. l_mCount = 0;
  274. funcCallBack(); //每隔l_AutoSaveToServerTime 分钟(例如10分钟)执行一次回调函数
  275. }
  276. }, 60000); //60000 每隔1分钟,执行一次操作(1000*60)
  277. wps.PluginStorage.setItem("TempTimerID", l_timeID); //保存计时器ID值
  278. }