Word.js 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859
  1. //查看指定文件,,判断是否保存或者覆盖,包括创建邀请协作人员,创建编辑历史,创建生成链接.创建热门模板。加载当前word文档的内容。创建光标,监控键盘输入等。这里是iframe中的word起始点。
  2. //监控输入输出,
  3. //添加成员,共同编辑。
  4. Namespace.register("U.MD.O.W");
  5. document.oncontextmenu = U.UF.EV.stopDefault; //禁止右键菜单
  6. //由于当前文档的js是加载在ifame里面的,获取不到外部的文档(www.1473.cn)信息。所以通过传递参数设置全局变量的形式保存当前文档信息。
  7. //id是word文档id,PID是文档归属的目录id,fileinfo是文档的实体信息fileinfo,OL初始化回调函数,userid是当前文档创建者的id。 historyid就是最新历史记录的id
  8. U.MD.O.W = {
  9. "fileinfo": null, //文档的信息
  10. "userinfo": null, //文档用户的信息
  11. "historyid": US.EMPTYGUID, //历史记录更新的id
  12. "permission": { //权限设置
  13. "edit": true,
  14. "web": true
  15. },
  16. "init": false
  17. };
  18. US = parent.US;
  19. //#region 初始化区域
  20. //------------------------------------------------------------------------------初始化Word----------------------------------------------------------------------------
  21. //查看指定文件,,判断是否保存或者覆盖,包括创建邀请协作人员,创建编辑历史,创建生成链接.创建热门模板。加载当前word文档的内容。创建光标,监控键盘输入等。这里是iframe中的word起始点。
  22. /**
  23. * word初始化的处理
  24. *
  25. * @param {object} 文档信息
  26. * @param {object} 登录用户信息
  27. * @return {object} 返回当前窗体
  28. */
  29. // U.MD.O.W.load = async function (fileid, userinfo) {
  30. U.MD.O.W.load = async function (cid, stage, task, tool) {
  31. //U.MD.O.W.openRoomConfirm();
  32. // var fileinfo = U.MD.O.W.getfile(),
  33. var fileinfo, userinfo;
  34. userinfo = await U.MD.O.W.getuser();
  35. if (cid && (stage || stage == 0) && (task || task == 0) && (tool || tool == 0)) {
  36. fileinfo = await U.MD.O.W.getWork(cid, stage, task, tool, userinfo.userid);
  37. } else {
  38. fileinfo = U.MD.O.W.getfile()
  39. }
  40. U.MD.O.W.variable(fileinfo, userinfo); //初始化全局变量
  41. U.MD.O.W.setPermission(); //获取权限
  42. U.MD.O.W.setEvent(); //设置事件
  43. U.MD.O.W.E.createSelection(); //创建下拉框
  44. U.MD.O.W.E.toolsbind(); //初始化工具栏
  45. U.MD.O.W.loadContent(fileinfo); //加载内容
  46. //加载功能
  47. U.MD.O.W.Panel.loadlink(fileinfo); //加载链接窗体
  48. //U.MD.O.W.Panel.loadHotTemplates(); //加载热门模板
  49. //U.MD.O.W.Panel.loadOfficeHistory(fileinfo); //加载历史记录
  50. // U.MD.O.W.Panel.loadPlayUser(fileinfo); //加载协助人员窗体
  51. // //如果是协作文档,加载协作窗体
  52. // if (U.MD.O.W.permission.web) {
  53. // U.MD.O.W.Panel.loadPlayUser(fileinfo); //加载协助人员窗体
  54. // }
  55. // //如果不是协同文档,那么协同文档的窗体不显示,那么热门和链接窗体向上移
  56. // else {
  57. // $("#LoadOfficeHistory")[0].style.top = "140px";
  58. // $("#LoadHotTemplates")[0].style.top = "434px";
  59. // }
  60. }
  61. /**
  62. * 根据cookie获取用户
  63. *
  64. */
  65. U.MD.O.W.getuser = async function () {
  66. return new Promise((resolve, reject) => {
  67. U.A.Request(US.Config.server + "getcookieuserid", [], function (res) {
  68. if (res.value && res.value[0] && res.value[0][0]) {
  69. var _user = res.value[0][0];
  70. U.A.Request(US.Config.edu + "admin/userinfo/userinfoById/" + _user.userid, [], function (res) {
  71. if (res.value && res.value[0] && res.value[0][0]) {
  72. US.userInfo = res.value[0][0];
  73. U.A.Request(US.Config.pbl + "selectUser?userid=" + _user.userid, [], function (res) { //US.userInfo.userid
  74. if (res.value == null || res.value[0].length == 0) {
  75. US.userInfo.userid = _user.userid;
  76. resolve(US.userInfo); //记录用户数据
  77. } else {
  78. US.userInfo = res.value[0][0];
  79. US.userInfo.userid = _user.userid;
  80. resolve(res.value[0][0]); //记录用户数据
  81. }
  82. }, [], { "type": "GET", "withCredentials": true });
  83. }
  84. }, [], { "type": "GET", "withCredentials": true });
  85. }
  86. }, [], { "type": "GET", "withCredentials": true });
  87. });
  88. }
  89. U.MD.O.W.getMyfile = function () {
  90. return {
  91. UserDirectoryExtendType: "uw", //默认导航模式
  92. UsOffice: US.data,
  93. UserDirectoryID: Guid.newGuid(),
  94. newfile: US.roomid ? false : true,
  95. };
  96. }
  97. /**
  98. * 根据文件id获取文件
  99. *
  100. */
  101. U.MD.O.W.getfile = function (fileid) {
  102. return {
  103. UserDirectoryExtendType: "uw", //默认导航模式
  104. UsOffice: '',
  105. //UsOffice: '<div id="e4c133031-1982-c72b-525a-32a2ffb5bd4c" style="text-align: center;" name="U_MD_O_W_Font_Heading1"><span style="font-family: 微软雅黑; font-size: 48px; font-weight: bold;">什么是互联办公?</span></div><div id="e3412c1ae-730c-f87e-494c-c5df81a459e0" style="line-height: 2;"><span style="font-family: 微软雅黑; font-size: 16px;">&nbsp; 为了提高办公效率,解决现有word不能多人协同办公的问题,解决在外地旅游、出差不能办公的问题,我们提出了互联办公的概念。</span></div><div id="ecf866d78-6644-f14f-74f9-c31eaa0097a0" style="line-height: 2;"><span style="font-family: 微软雅黑; font-size: 16px;">&nbsp; 互联办公云平台是一款可以多端操作、多人协同、以网页形式编辑、以网站形式展示的互联网办公平台。互联办公云平台可以在ipad、手机、电脑以及其他支持浏览器的终端设备上进行操作;可以多人共同编辑同一份文档,实现文档的自动整合以及实时更新;可以在主流浏览器上进行文档的编辑修改,也可以输入好网站内容,一键发布完成专业化的企业网站。</span></div><div id="e8901ef2d-0b82-138f-91b0-e5697edfd6ca" style="line-height: 2;"><span style="font-family: 微软雅黑; font-size: 16px;">&nbsp; 互联办公云平台前端采用html+css技术实现, 后端使用java,Net,Nodejs予以实现,web服务器采用分布式集群部署,支持多人同时在线。</span><br></div><div id="e9c0df904-ebab-1392-7364-4ccab9862a9c" style="line-height: 2;"><br></div><div id="ebdb59933-5920-b5ae-1568-27fc769aeb3b" style="font-family: 微软雅黑; font-weight: bold; font-size: 16pt;" name="U_MD_O_W_Font_Heading2"><span style=""></span><span>1.实现随时随地办公</span></div><div id="ebd1bf28a-4f62-4ec1-346a-bb388c2191cd" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;">当需要紧急修改文件时,即使你在外地,在旅游,在出差,拿出手机即可修改文件,修改好的文件会即时呈现在领导面前,解决了用户出门在外不能同步办公的难题。</span></div><div id="e9a9993df-f28c-461b-0880-2848f1c2ccdc" style="line-height: 2;"><br></div><div id="e117f341a-f3c4-3d44-9145-57b86e09765c" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;"></span></div><div id="eb878bcdc-91a8-cd5c-d7bd-0e506fc83d0b" style="font-family: 微软雅黑; font-weight: bold; font-size: 16pt; line-height: 2;" name="U_MD_O_W_Font_Heading2"><span>2.解决了现有word不能多人协同办公的问题</span></div><div id="ec9514631-09c8-8329-a9de-106f7d88594f" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;">互联办公云平台把Word互联网化,允许多人编辑同一份文件,效果即时呈现,适合收集用户资料场景,提高办公效率。</span></div><div id="ecb60e99a-6e75-0c84-8b41-f5aa6b130d05" style="line-height: 2;"><br></div><div id="e99e0c9dd-506c-3d63-07cd-ff4a46f232b5" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;"></span></div><div id="e7f202d5b-8e90-a816-1ce8-5c12fde78637" style="font-family: 微软雅黑; font-weight: bold; font-size: 16pt; line-height: 2;" name="U_MD_O_W_Font_Heading2"><span>3.提高办公效率</span></div><div id="e2fdfea7a-38fb-b8bb-7ee5-a96644677f14" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;">解决了人们需分工合作以及整合文档需耗费大量时间的难题,当你需要收集公司各成员的个人信心档案时,只需要一个链接邀请大家编辑,成百上千个人就会在一份文档里面填写资料,以此解决用户需分工合作,整合文档工作量过大的问题。</span></div><div id="ea863ad74-d055-e53b-c23d-d1c76cbc5ee4" style="line-height: 2;"><br></div><div id="edb122ca1-ec53-5040-28f7-b0e2790869ee" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;"></span></div><div id="e332557aa-d8d2-45c9-d2e5-147fb7d8bf2c" style="font-family: 微软雅黑; font-weight: bold; font-size: 16pt; line-height: 2;" name="U_MD_O_W_Font_Heading2"><span>4.Word直接生成企业网站</span></div><div id="e22923078-2bcf-06a2-566f-ab1ed876afa5" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;">互联办公云平台为企业办公人员提供导航模式,用户无需了解前后台代码,以所见即所得的方式,编辑网站内容,一键发布即可生成专业化的企业网站,为企业解决需找专业代码人员耗费大量时间及耗费大量资金的问题。</span></div><div id="e08ee9567-3e92-999b-ba7e-815db2e29477" style="line-height: 2;"><br></div><div id="e50a05822-32af-439f-85bd-186f5358a6ba" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;"></span></div><div id="e9169080d-5ce2-c385-519d-952aea83d3f2" style="font-family: 微软雅黑; font-weight: bold; font-size: 16pt; line-height: 2;" name="U_MD_O_W_Font_Heading2"><span>5.解决用户文件丢失的问题</span></div><div id="e4a9be289-9b20-9131-4986-e530367a1d04" style="line-height: 2;"><span style="font-size: 18px; font-family: 微软雅黑;">互联办公云平台为用户提供所有文件支持云端存储,可上传任何格式的文件的功能用户不需要安装应用,只需要在网页上输入网址即可找到自己的文件。云端网盘采用树目录分类,方便用户查找文件,以此解决文件容易丢失的问题。</span><span style="font-size: 18px;"></span><span style=""></span><br></div>',
  106. UserDirectoryID: Guid.newGuid(),
  107. newfile: fileid ? false : true
  108. };
  109. }
  110. /**
  111. * 初始化全局变量
  112. * @param {object} 文档信息
  113. * @param {object} 登录用户信息
  114. *
  115. */
  116. U.MD.O.W.variable = function (fileinfo, userinfo) {
  117. //如果已经有全局变量 说明该文档已经是加载过了,不需要重复设置
  118. if (!U.MD.O.W.fileinfo) {
  119. U.MD.O.W.fileinfo = fileinfo //文档信息
  120. }
  121. //设置用户信息,为什么上面的不需要重复设置下面的需要呢,因为用户可能会注销
  122. U.MD.O.W.userInfo = userinfo; //用户信息
  123. }
  124. /**
  125. * 编辑器权限函数
  126. * @return 返回用户权限json
  127. */
  128. U.MD.O.W.setPermission = function () {
  129. U.MD.O.W.permission.web = true; //互联办公的权限
  130. U.MD.O.W.permission.edit = true; //就给其编辑权限
  131. // var _iseditor, _isgroup; //是否可编辑 //群用户
  132. // //权限主要包含了是否可编辑,是否互联办公文档查看
  133. // //判断文件是否是用户的群文档 US.friend.group这个变量需要独立
  134. // if (U.MD.O.W.fileinfo.GroupID && US.friend.group) {
  135. // _isgroup = U.Json.select(US.friend.group, { "GroupManageID": U.MD.O.W.fileinfo.GroupID });
  136. // if (_isgroup) {
  137. // U.MD.O.W.permission.web = true; //互联办公的权限
  138. // U.MD.O.W.permission.edit = true; //就给其编辑权限
  139. // }
  140. // }
  141. // //如果是共享文档,那么谁都可以编辑,如果是自己的文档那么也可以编辑
  142. // else if (((U.MD.O.W.fileinfo.GroupID && U.MD.O.W.fileinfo.GroupID == U.MD.O.W.userInfo.userid) || U.MD.O.W.fileinfo.UserId == US.userInfo.userid)) {//判断是否是有编辑权限
  143. // U.MD.O.W.permission.edit = true; //就给其编辑权限
  144. // if (U.MD.O.W.fileinfo.UserId == US.userInfo.userid) {
  145. // U.MD.O.W.permission.web = true;//互联办公的权限
  146. // }
  147. // }
  148. }
  149. /**
  150. * 设置事件
  151. *
  152. */
  153. U.MD.O.W.setEvent = function () {
  154. //un文件设置事件
  155. if (U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un') {
  156. //设置保存事件
  157. $('#U_MD_O_H_save')[0].onclick = function () {
  158. U.MD.O.W.T.N.saveNav(function () {
  159. U.MD.O.W.T.N.savePage(null, true);
  160. });
  161. }
  162. $('body').addClass('U_MD_O_W_Nav');
  163. }
  164. //uw文件设置事件
  165. else {
  166. //设置保存事件
  167. $('#U_MD_O_H_save')[0].onclick = function () {
  168. U.MD.O.W.save()
  169. }
  170. $('body').removeClass('U_MD_O_W_Nav');
  171. }
  172. //设置新建事件
  173. $('#U_MD_O_H_new')[0].onclick = function () {
  174. U.MD.O.W.newdocument();
  175. }
  176. //下载处理
  177. $("#U_MD_O_H_Area_Down")[0].onclick = function () {
  178. top.U.MD.C.D.downloadFileOrDir([U.MD.O.W.fileinfo], "true"); //下载文档
  179. }
  180. //添加Ctrl+S快捷保存事件
  181. $('body')[0].onkeydown = function (e) {
  182. var currKey = 0;
  183. e = e || event || window.event;
  184. currKey = e.keyCode;
  185. if (currKey == 83 && (e.ctrlKey || e.metaKey)) {
  186. $('#U_MD_O_H_save')[0].onclick();
  187. U.UF.EV.stopDefault();
  188. U.UF.EV.stopBubble();
  189. }
  190. };
  191. }
  192. /**
  193. * 加载Word编辑区域的内容
  194. * @param {string} 文档信息
  195. */
  196. U.MD.O.W.loadContent = function (fileinfo) {
  197. var _defaultnav,
  198. _permission = U.MD.O.W.permission, //获取权限
  199. _fileid = fileinfo.UserDirectoryID; //文档id
  200. //新建文件的处理
  201. if (fileinfo.newfile) {
  202. //un新建文件的处理
  203. if (U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un') {
  204. //默认导航的处理
  205. try {
  206. _defaultnav = JSON.parse(U.MD.O.W.fileinfo.UsOffice);
  207. } catch (e) {
  208. _defaultnav = { logo: "", nav: [{ pageId: Guid.newGuid(), name: "初始页面" }] };
  209. }
  210. //创建默认导航文档
  211. U.MD.O.W.T.N.form(_defaultnav);
  212. }
  213. //uw文件新建处理
  214. else {
  215. //初始化编辑器
  216. U.MD.O.W.E.initEditor();
  217. }
  218. //清楚文件新建的属性,说明文件不是新建
  219. delete fileinfo.newfile;
  220. }
  221. //互联办公文档获取数据
  222. else if (_permission.web) {
  223. parent.U.A.Request(US.SCOKET, [U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un' ? 'getNav' : "getWord", _fileid, US.pageId, U.MD.O.W.userInfo.userid], U.MD.O.W.asynLoad, [$("#U_MD_O_H_wordEditor")[0], fileinfo, _permission.web]); //获取office内容
  224. }
  225. //普通文档在数据库里面获取数据
  226. else {
  227. parent.U.A.Request(US.DISK, ["GetFileContent", _fileid], U.MD.O.W.asynLoad, [$("#U_MD_O_H_wordEditor")[0], fileinfo, _permission.web]);
  228. }
  229. }
  230. /**
  231. * 异步获取Word编辑区域的数据
  232. *
  233. */
  234. U.MD.O.W.asynLoad = function (r) { //object 值
  235. var _permission,
  236. _fileinfo = U.MD.O.W.fileinfo,
  237. _context = r.context, //获取array值
  238. _fileinfo = _context[1], //获取文件信息
  239. _synergy = _context[2]; //互联权限
  240. //获取后台返回的值,第一个是直接从数据库获取的,所以必须要从UsOffice获取值
  241. if (r.value && r.value.UsOffice !== undefined) {
  242. r = r.value.UsOffice;
  243. } else {
  244. r = r.value;
  245. }
  246. //un文件 导航文件处理
  247. if (U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un') {
  248. //因为导航文件默认是json格式的,如果这里从后台获取的值不是json那么进行转化
  249. if (typeof r != 'object') {
  250. try {
  251. r = JSON.parse(r);
  252. } catch (e) {
  253. r = { logo: "", nav: [{ pageId: Guid.newGuid(), name: "初始页面" }] };;
  254. }
  255. }
  256. //加载导航和内容
  257. U.MD.O.W.T.N.form(r);
  258. }
  259. //word文件处理
  260. else {
  261. //如果数据库里面有内容或者不是服务器文件,直接加载内容
  262. if (r || !_fileinfo.UserFilesServerName) {
  263. _fileinfo.UsOffice = (r || "").unEscapeQuotes(); //word内容
  264. //加载编辑器和内容
  265. U.MD.O.W.E.initEditor(_synergy); //初始化编辑器
  266. }
  267. //如果是office文件第一次初始化的处理
  268. else {
  269. //微软的office上传打开的方式
  270. U.A.Request("http://office.1473.cn/Officetohtml.ashx", ["Open", _fileinfo.UserDirectoryExtendType, _fileinfo.UserFilesServerName], function (r) {
  271. if (r.value && r.value.value != undefined) {
  272. r = r.value;
  273. _fileinfo.UsOffice = r.value.getBodyHtml().replace(/src=[\'\"]?([^\'\"]*)[\'\"]?/ig, function (str1, str2) {
  274. return "src=\"http://office.1473.cn/usoffice/" + str2 + "\"";
  275. });
  276. }
  277. U.MD.O.W.E.initEditor(_synergy); //初始化编辑器
  278. }, [""]);
  279. }
  280. }
  281. }
  282. //#endregion
  283. //#region 保存区域
  284. U.MD.O.W.updateEditorLine = function (wordInfo) {
  285. $("#U_MD_O_H_wordEditor")[0].innerHTML = wordInfo.data;
  286. }
  287. /**
  288. * 判断当前文件是否保存
  289. *
  290. * @param {function} 保存回调函数
  291. */
  292. U.MD.O.W.isSave = function () {
  293. var _fileinfo = U.MD.O.W.fileinfo, //word文件
  294. _fileid = _fileinfo.UserDirectoryID; //文件id
  295. return ((_fileid && _fileinfo.UserId && _fileinfo.UserallDirectoryName) && U.MD.O.W.permission.edit); //判断文档是否是已经保存到数据库的文档(判断的依据在于这个文件除了有文件id还有文件名和创建者id)
  296. }
  297. U.MD.O.W.updateSocket = function (wordInfo) {
  298. U.A.Request(US.SCOKET, ["send", JSON.stringify(wordInfo)], function (r) {
  299. console.log(r);
  300. });
  301. }
  302. U.MD.O.W.updateFileData = function (wordInfo) {
  303. U.A.Request("http://localhost:7003/api/pbl/" + "updateFileData", [wordInfo.messageInfo.data, wordInfo.receiveId], function (res) { //US.userInfo.userid
  304. U.Alert("保存成功");
  305. setTimeout(() => {
  306. U.MD.O.W.wordDirectory();
  307. }, 100)
  308. console.log(res);
  309. }, [], { "type": "GET", "withCredentials": true });
  310. }
  311. U.MD.O.W.wordInfo = function (type, content, navid, userid, roomid) {
  312. var _data = {
  313. "us.word": [{
  314. sendId: userid, //发送人id
  315. receiveId: roomid, //文件id
  316. type: navid, //消息类型
  317. messageInfo: {
  318. type: type, //类型
  319. data: content, //内容
  320. docId: roomid, //文档id
  321. // pageId: US.pageId, //当前页面id
  322. },
  323. },],
  324. };
  325. return _data;
  326. }
  327. /**
  328. * 保存Word
  329. *
  330. * @param {function} 保存回调函数
  331. */
  332. U.MD.O.W.save = function () {
  333. // var _islogin = top.U.MD.U.L.isLogin(function (userinfo) { U.MD.O.W.userInfo = userinfo; });
  334. // //判断用户是否登录,只有登录用户才能保存信息
  335. // var _isftp,
  336. // _isgroupuser,
  337. // _r, //返回值
  338. // _uid = U.MD.O.W.userInfo.userid,
  339. // _el = $("#U_MD_O_H_wordEditor")[0], //word编辑区域
  340. // _fileinfo = U.MD.O.W.fileinfo, //文件信息
  341. // _fileid = _fileinfo.UserDirectoryID, //文件ID
  342. // _name = top.$('#UD_Word' + _fileid + ' .U_MD_O_H_head_navigation_Title')[0].value, //文件名
  343. // _html = _el.innerHTML.escapeQuotes(); //内容
  344. // if (top.window.location.href.split("/")[2] != "www.1473.cn") {
  345. // U.MD.O.W.saveFileOther();
  346. // } else {
  347. // //判断文档是否是已经保存到数据库的文档
  348. // // U.A.Request(US.CD, [US.DB, "UseStudio_Disk", _fileid, "FB1CB716-E42E-4DEA-9A66-F14F0771826F"], function (r) { _r = r.value });
  349. // //if (_fileid && _fileinfo.UserId && _fileinfo.UserallDirectoryName && U.MD.O.W.permission.edit) {
  350. // if (_fileid && _fileinfo.UserId && _fileinfo.UserallDirectoryName && U.MD.O.W.permission.edit) { //如果是已经保存到数据库的文档,那么直接保存内容
  351. // U.MD.O.W.Panel.InsertOfficeHistory(_fileinfo, _html, _name, _el); //插入历史记录
  352. //保存到数据库
  353. //保存到数据库
  354. // top.U.A.Request(US.DISK, ["SaveFileContent", US.userInfo.userid, _fileid, _html, _name, "uw"], function (r) {
  355. // U.MD.O.W.fileinfo.UsOffice = r.context[1].innerHTML;
  356. let wordInfo = U.MD.O.W.wordInfo(
  357. "update",
  358. $("#U_MD_O_H_wordEditor")[0].innerHTML.escapeQuotes(),
  359. "us.word",
  360. top.US.userInfo.userid,
  361. top.US.wordRoomInfo.id,
  362. );
  363. U.MD.O.W.updateSocket(wordInfo);
  364. U.MD.O.W.updateFileData(wordInfo['us.word'][0]);
  365. // }, (['', _el])); //保存到数据库
  366. // }
  367. // //如果文件没有保存,那么直接新建文件
  368. // else {
  369. // //调用word新建文档的处理
  370. // top.U.MD.DK.VW.chosenSaveFile('uw', _fileid, _name, function (fileinfo) {
  371. // U.MD.O.W.fileinfo = fileinfo; //文档信息
  372. // top.$('#UD_Word' + _fileid + ' .U_MD_O_H_head_navigation_Title')[0].value = fileinfo.UserDirectoryName; //文件名设置
  373. // U.MD.O.W.setPermission(); //新建的文件设置权限,根据新建的位置
  374. // //如果是互联办公文档的处理(第一次新建的文件需要从保存到redis全局变量中,第二次之后都是直接从redis初始化的)
  375. // if (U.MD.O.W.permission.web) {
  376. // top.U.A.Request(US.SCOKET, ["newWordSave", _fileid, _html, fileinfo.UserDirectoryName, US.userInfo.userid, US.pageId], function (r) {
  377. // U.MD.O.W.Panel.loadPlayUser(fileinfo); //加载协助人员窗体
  378. // U.Alert("保存成功");
  379. // U.MD.O.W.fileinfo.UsOffice = _el.innerHTML;
  380. // //设置互联办公编辑回调的事件,这样设置不合理
  381. // $('#U_MD_O_H_wordEditor')[0].editor.operaNotice = U.MD.O.W.E.operationNotice;
  382. // });
  383. // }
  384. // //如果是普通文档的处理
  385. // else {
  386. // //保存到数据库
  387. // top.U.A.Request(US.DISK, ["SaveFileContent", US.userInfo.userid, _fileid, _html, fileinfo.UserDirectoryName, "uw"], function (r) {
  388. // U.Alert("保存成功");
  389. // U.MD.O.W.fileinfo.UsOffice = r.context[1].innerHTML;
  390. // }, (['', _el])); //保存到数据库
  391. // }
  392. // });
  393. // }
  394. // }
  395. }
  396. /**
  397. * 修改文件名处理
  398. *
  399. * @param {function} 保存回调函数
  400. */
  401. U.MD.O.W.updateName = function () {
  402. var _islogin = top.U.MD.U.L.isLogin(function (userinfo) { U.MD.O.W.userInfo = userinfo; }); //判断是否登录
  403. if (!_islogin) {
  404. var _fileinfo = U.MD.O.W.fileinfo, //文件信息
  405. _userinfo = U.MD.O.W.userInfo,
  406. _type = U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un' ? 'nav' : 'word',
  407. _fileid = _fileinfo.UserDirectoryID, //文件ID
  408. _name = top.$('#UD_Word' + _fileid + ' .U_MD_O_H_head_navigation_Title')[0].value;
  409. //文件名必须本人才能修改
  410. if (_userinfo.UserId == _fileinfo.UserId) {
  411. //判断文档是否是已经保存到数据库的文档(判断的依据在于这个文件除了有文件id还有文件名和创建者id)
  412. if ((_fileid && _fileinfo.UserId && _fileinfo.UserallDirectoryName) && U.MD.O.W.permission.edit) { //如果是已经保存到数据库的文档,那么直接保存内容
  413. //如果是互联办公文档的操作
  414. if (U.MD.O.W.permission.web) {
  415. top.U.A.Request(US.SCOKET, ["updateName", _type, _fileid, _name, US.userInfo.userid, US.pageId], function (r) {
  416. if (r.value == "updateNameSuccess") {
  417. _fileinfo.UserallDirectoryName = _name; //文件全写的名字
  418. _fileinfo.UserDirectoryName = _name.addEllipsis(20); //文件的缩略名
  419. }
  420. });
  421. }
  422. //普通文档修改信息
  423. else {
  424. top.U.A.Request(US.DISK, ["UpdateFileInfo", _fileid, _name], function (r) {
  425. if (r.value) {
  426. _fileinfo.UserallDirectoryName = _name; //文件全写的名字
  427. _fileinfo.UserDirectoryName = _name.addEllipsis(20); //文件的缩略名
  428. }
  429. });
  430. }
  431. }
  432. }
  433. //其他用户不允许修改文件名
  434. else {
  435. top.$('#UD_Word' + _fileid + ' .U_MD_O_H_head_navigation_Title')[0].value = _fileinfo.UserallDirectoryName;
  436. U.alert('非本人操作,修改失败!');
  437. }
  438. }
  439. }
  440. //#endregion
  441. //#region 新建文档
  442. /**
  443. * 新建文档的处理
  444. *
  445. */
  446. U.MD.O.W.newdocument = function () {
  447. var _divel = $$("div", { "className": "U_MD_O_newBtn" });
  448. $$("button", {
  449. "className": "U_MD_O_newDoc",
  450. "innerHTML": "普通word",
  451. "onclick": function () {
  452. parent.U.MD.O.W.openApplication("word", { "userid": US.userInfo.userid, "directoryid": US.FTPFOLDERID }); //打开文档处理
  453. $('#U_MD_O_Set')[0].style.display = "none";
  454. }
  455. }, _divel);
  456. $$("button", {
  457. "className": "U_MD_O_newNav",
  458. "innerHTML": "导航模板",
  459. "onclick": function () {
  460. parent.U.MD.O.W.openApplication("word", { UserDirectoryExtendType: "un" }); //新建导航文档
  461. $('#U_MD_O_Set')[0].style.display = "none";
  462. }
  463. }, _divel);
  464. new U.UF.UI.form("新建", _divel, { "id": "U_MD_O_Set", "style": { "width": "300px", "height": "150px" } }, { isenlarge: false, isstretching: false }).form;
  465. }
  466. //#endregion
  467. //#region 文档转化
  468. /**
  469. * 导航文件转化成普通文件
  470. */
  471. U.MD.O.W.newDocSwitch = function () {
  472. var _fileinfo = U.MD.O.W.fileinfo,
  473. _fileid = _fileinfo.UserDirectoryID;
  474. if (_fileinfo.UserDirectoryExtendType == "un") {
  475. $("#U_MD_O_H_Nav")[0].style.display = "none";
  476. $("#U_MD_O_W_N").Parent({ usform: "true" }).style.display = "none";
  477. }
  478. //获取文件内容异步
  479. U.A.Request(US.CD, ([US.DB, "UseStudio_Disk", "GetFileContent", "d17a2910-11ba-df39-cd8a-5cac851c2148"]), function (r) {
  480. _fileinfo.UserDirectoryExtendType = 'uw'; //设置格式为uw
  481. _fileinfo.UsOffice = r.value[0].UsOffice.unEscapeQuotes(); //获取值
  482. _fileinfo.newfile = true; //设置为新建文件
  483. U.MD.O.W.load(_fileinfo, U.MD.O.W.userInfo); //初始化
  484. });
  485. }
  486. /** * 普通文件转化成导航文件
  487. */
  488. U.MD.O.W.newNavSwitch = function () {
  489. var _fileinfo = U.MD.O.W.fileinfo,
  490. _fileid = _fileinfo.UserDirectoryID;
  491. //获取文件内容异步,此为获取默认的宣传文档
  492. U.A.Request(US.CD, ([US.DB, "UseStudio_Disk", "GetFileContent", "6a8a235a-41c4-c3d2-8dd5-b6ee851e1967"]), function (r) {
  493. _fileinfo.UserDirectoryExtendType = 'un'; //设置格式为un
  494. _fileinfo.UsOffice = r.value[0].UsOffice.unEscapeQuotes(); //获取值
  495. _fileinfo.newfile = true; //设置为新建文件
  496. U.MD.O.W.load(_fileinfo, U.MD.O.W.userInfo); //初始化
  497. });
  498. }
  499. window.addEventListener('message', function (e) { // 监听 message 事件
  500. // alert(e.data.type);
  501. if (e.data.num && e.data.num != "0") { //项目管理传入
  502. U.MD.O.W.goRoom(e.data.num);
  503. } else if (e.data.num && e.data.num == "0") {
  504. U.MD.O.W.checkNum(e.data.num);
  505. }
  506. });
  507. U.MD.O.W.isRoom = function () {
  508. U.A.Request(US.Config.pbl + "selectRoomByFile?uid=" + US.userInfo.userid, [], function (res) {
  509. if (res.value == null || res.value[0].length == 0) {
  510. U.MD.O.W.openRoomConfirm();
  511. } else {
  512. US.numNum = res.value[0][0].num;
  513. U.MD.O.W.getWork(res.value[0][0].id);
  514. U.MD.O.W.isOpenRoomConfirm();
  515. }
  516. }, [], { "type": "GET", "withCredentials": true });
  517. }
  518. U.MD.O.W.MathRand = function () {
  519. var Num = "";
  520. for (var i = 0; i < 6; i++) {
  521. Num += Math.floor(Math.random() * 10);
  522. }
  523. return Num;
  524. }
  525. U.MD.O.W.checkNum = function () {
  526. var numNum = U.MD.O.W.MathRand();
  527. U.A.Request(US.Config.pbl + "checkRoomNumByFile?num=" + numNum, [], function (res) {
  528. if (res.value == null || res.value[0].length == 0) {
  529. U.MD.O.W.addRoom(numNum);
  530. } else {
  531. U.MD.O.W.checkNum();
  532. }
  533. }, [], { "type": "GET", "withCredentials": true });
  534. }
  535. U.MD.O.W.addRoom = function (numNum) {
  536. U.MD.O.W.fileinfo.UsOffice = "";
  537. U.MD.O.W.E.initEditor(true); //初始化编辑器
  538. var data = $("#U_MD_O_H_wordEditor")[0].innerHTML.escapeQuotes();
  539. U.A.Request(US.Config.pbl + "insertRoomByFile", [US.userInfo.userid, numNum, data], function (res) {
  540. if (res.value == 1) {
  541. U.alert("创建成功");
  542. if ($("#add_room")[0]) {
  543. $("#add_room")[0].close(); //关闭登陆
  544. }
  545. U.MD.O.W.isRoom();
  546. } else {
  547. U.alert("创建失败");
  548. }
  549. }, [], { "type": "GET", "withCredentials": true });
  550. }
  551. U.MD.O.W.goRoom = function (number) {
  552. U.A.Request(US.Config.pbl + "selectRoomByFile?uid=" + number, [], function (res) {
  553. if (res.value[0].length > 0) {
  554. U.alert("加入成功");
  555. if ($("#add_room")[0]) {
  556. $("#add_room")[0].close();
  557. }
  558. U.MD.O.W.getWork(res.value[0][0].id);
  559. } else {
  560. U.alert("此房间不存在或已被解散");
  561. }
  562. }, [], { "type": "GET", "withCredentials": true });
  563. }
  564. U.MD.O.W.copyText = function (target) {
  565. var div = $(".form_delete-main-room")[0].innerText;
  566. var clipboard = new ClipboardJS('.copy-message', {
  567. text: function () {
  568. return div;
  569. }
  570. });
  571. clipboard.on('success', function (e) {
  572. console.log(e);
  573. e.clearSelection();
  574. U.alert("复制成功");
  575. });
  576. clipboard.on('error', function (e) {
  577. console.log(e);
  578. U.alert("复制失败");
  579. });
  580. }
  581. U.MD.O.W.getWork = async function (cid, s, task, t, uid) {
  582. return new Promise((resolve, reject) => {
  583. U.A.Request(US.Config.pbl + "selectWord?uid=" + uid + "&cid=" + cid + "&s=" + s + "&task=" + task + "&t=" + t, [], function (res) {
  584. if (res.value[0].length > 0) {
  585. US.wordRoomInfo = res.value[0][0];
  586. // U.A.Request(US.SCOKET, ["getWord", rid, US.pageId, US.userInfo.userid], function(r) {
  587. // U.MD.O.W.fileinfo.UsOffice = US.wordRoomInfo.text;
  588. // U.MD.O.W.fileinfo.UserDirectoryID = rid;
  589. // });
  590. // return res.value[0][0].text
  591. let a = {
  592. UserDirectoryExtendType: "uw", //默认导航模式
  593. UsOffice: res.value[0][0].text,
  594. UserDirectoryID: Guid.newGuid(),
  595. newfile: true
  596. }
  597. resolve(a);
  598. // setTimeout(() => {
  599. // U.MD.O.W.wordDirectory();
  600. // }, 100)
  601. }
  602. }, [], { "type": "GET", "withCredentials": true });
  603. });
  604. }
  605. /**
  606. * 创建目录的窗体
  607. *
  608. * @param fileinfo {object} 文件信息
  609. */
  610. U.MD.O.W.wordDirectory = function (fileinfo) {
  611. var _coopwindow, _frienddiv, _example, _shareLink, _cBox;
  612. //如果不存在团队成员窗口,则创建一个团队成员窗口。
  613. if (!$("#U_MD_O_H_body_left_book")[0]) {
  614. //创建邀请协助人员窗口
  615. _coopwindow = $("#U_MD_O_H_body_left")[0];
  616. _cBox = $$("div");
  617. // _shareLink = $$("div", {
  618. // className: 'U_MD_O_H_body_left_invite_linkTxt', "onclick": function () {
  619. // U.MD.O.W.Panel.isSynergy(U.MD.O.W.Panel.shareLink);
  620. // }, "innerText": "第三方链接邀请"
  621. // }, _cBox);
  622. _frienddiv = $$("div", { "className": "U_MD_O_H_body_left_book", "id": "U_MD_O_H_body_left_book" }, _cBox); //目录内容
  623. _example = $$("div", {
  624. "className": "U_MD_O_H_body_left_book_a",
  625. }, _frienddiv); //默认邀请按钮
  626. var span = $("div[name=U_MD_O_W_Font_Heading1]");
  627. if (span.length > 0) {
  628. for (var i = 0; i < span.length; i++) {
  629. var a = $$("div", { "className": "isMulu" }, _example)
  630. a.innerHTML = span[i].children[0].innerHTML;
  631. }
  632. } else {
  633. var b = $$("div", { "className": "noMulu" }, _example)
  634. b.innerHTML = "暂无目录"
  635. }
  636. // $$("div", { "innerHTML": "一、项目概述" }, _example);
  637. // $$("div", { "innerHTML": "二、业务流程" }, _example);
  638. // $$("div", { "innerHTML": "三、系统角色" }, _example);
  639. // $$("div", { "innerHTML": "四、产品功能场景描述" }, _example);
  640. // $$("div", { "innerHTML": "五、功能模块" }, _example);
  641. // $$("div", { "className": "U_MD_O_H_body_left_book_a_img" }, _example);
  642. // $$("div", { "className": "U_MD_O_H_body_left_book_a_div", "innerHTML": "邀请" }, _example);
  643. new U.UF.UI.form("目录", _cBox, { id: "wordDirectory", style: { border: "none", position: "absolute", width: "300px", "min-width": "200px", height: "250px", top: "50px", left: "auto", "box-shadow": "none" } }, { isenlarge: false, isnarrow: false }, { style: { height: "40px", "border-bottom": "1px solid #d6def0", color: "#000", background: "#f1f1f1" } }, null, null, _coopwindow);
  644. }
  645. }
  646. U.MD.O.W.addPerson = function () {
  647. var BOX = $$("div", {});
  648. var form_main = $$('div', { "className": "form-main" }, BOX);
  649. var form_content = $$('div', { "className": "form-content" }, form_main);
  650. var form_delete_main = $$('div', { "className": "form_delete-main-room" }, form_content);
  651. var form_delete_main_body = $$('div', { "className": "form_delete-main-body" }, form_delete_main);
  652. var searchPerson = $$('div', { "className": "searchPerson" }, form_delete_main_body);
  653. $$("input", { "className": "inputSearch", "type": "text", "placeholder": "搜索成员" }, searchPerson);
  654. $$("div", { "className": "searchImg", }, searchPerson);
  655. var a = [];
  656. var r = [{ "userid": "1", "title": "李华" }, { "userid": "2", "title": "李雷" }, { "userid": "3", "title": "莉莉" }, { "userid": "4", "title": "李磊" }, { "userid": "5", "title": "李莉" }]
  657. var checkboxPerson = $$('div', { "className": "checkboxPerson" }, form_delete_main_body);
  658. for (let i = 0; i < r.length; i++) {
  659. var person = $$("div", { "className": "person", }, checkboxPerson);
  660. let abc = $$('input', { "type": "checkbox", "id": r[i].userid }, person);
  661. $$('div', { "className": "personAvatar", }, person);
  662. $$('span', { "className": "thirdSpan", "innerHTML": r[i].title }, person);
  663. if (a.indexOf(r[i].userid) != -1) {
  664. abc.checked = true
  665. }
  666. person.onclick = function (e) {
  667. var el = e.currentTarget
  668. el.getElementsByTagName("input")[0].click();
  669. }
  670. abc.onclick = function (e) {
  671. e.stopPropagation();
  672. if (a.indexOf(e.target.id) !== -1) {
  673. a.splice(a.indexOf(e.target.id), 1);
  674. } else {
  675. a.push(e.target.id);
  676. }
  677. }
  678. }
  679. var btnBox = $$('div', { "className": "copy-btn" }, form_main);
  680. var confirm = $$('button', { "className": "copy-message", "innerHTML": `${"移出成员"}` }, btnBox);
  681. new U.UF.UI.form(`${"管理成员"}`, BOX, {
  682. id: 'invite_members',
  683. style: {
  684. "background": "#fffefe",
  685. "width": "350px",
  686. "height": "500px",
  687. "z-index": "99",
  688. }
  689. }, {
  690. isenlarge: false,
  691. isnarrow: false
  692. }, {
  693. style: {
  694. "height": "40px",
  695. "text-align": "center",
  696. "line-height": "40px",
  697. "text-indent": "25px",
  698. "background-repeat": "no-repeat",
  699. "font-size": "14px",
  700. "background-color": "#494949",
  701. "display": "flex",
  702. }
  703. });
  704. // confirm.onclick = function () {
  705. // U.MD.O.W.copyText();
  706. // }
  707. }
  708. U.MD.O.W.isOpenRoomConfirm = function () {
  709. var BOX = $$("div", {});
  710. var form_main = $$('div', { "className": "form-main" }, BOX);
  711. var form_content = $$('div', { "className": "form-content" }, form_main);
  712. var form_delete_main = $$('div', { "className": "form_delete-main-room" }, form_content);
  713. var form_delete_main_body = $$('div', { "className": "form_delete-main-body" }, form_delete_main);
  714. $$("div", { "className": "remark", "innerHTML": US.userInfo.username + "邀请您参与协同文档", }, form_delete_main_body)
  715. $$("div", {
  716. "class": "clickNav",
  717. "innerHTML": "点击链接加入房间",
  718. }, form_delete_main_body)
  719. $$("div", { "class": "link", "innerHTML": "http://cocorobo.wg.com/dm/EOGyBbFiCwam", }, form_delete_main_body)
  720. var room_number = $$('div', { "className": "room_number" }, form_delete_main_body);
  721. $$("div", { "class": "link", "innerHTML": "房间号:", }, room_number)
  722. $$("div", { "class": "roomNumber", "innerHTML": US.numNum, }, room_number)
  723. $$("div", { "className": "link", "innerHTML": "复制房间号信息,打开协同文档输入即可加入。", }, form_delete_main_body)
  724. // $$("input", { "className": "text", "type": "text" }, form_delete_main_body);
  725. var btnBox = $$('div', { "className": "copy-btn" }, form_main);
  726. var confirm = $$('button', { "className": "copy-message", "innerHTML": `${"一键复制信息"}` }, btnBox);
  727. new U.UF.UI.form(`${"邀请成员"}`, BOX, {
  728. id: 'invite_members',
  729. style: {
  730. "background": "#fffefe",
  731. "width": "350px",
  732. "height": "500px",
  733. "z-index": "99",
  734. }
  735. }, {
  736. isenlarge: false,
  737. isnarrow: false
  738. }, {
  739. style: {
  740. "height": "40px",
  741. "text-align": "center",
  742. "line-height": "40px",
  743. "text-indent": "25px",
  744. "background-repeat": "no-repeat",
  745. "font-size": "14px",
  746. "background-color": "#494949",
  747. "display": "flex",
  748. }
  749. });
  750. confirm.onclick = function () {
  751. U.MD.O.W.copyText();
  752. }
  753. }
  754. U.MD.O.W.openRoomConfirm = function () {
  755. var BOX = $$("div", {});
  756. var form_main = $$('div', { "className": "form-main" }, BOX);
  757. var form_content = $$('div', { "className": "form-content" }, form_main);
  758. var form_delete_main = $$('div', { "className": "form_delete-main" }, form_content);
  759. $$("input", { "className": "form_delete-main_box", "placeholder": `${"请输入要加入的房间号"}` }, form_delete_main);
  760. $$("div", { "className": "remark", "innerHTML": "备注:输入房间号点击加入房间或点击创建房间直接创建房间", }, form_delete_main)
  761. var btnBox = $$('div', { "className": "form-btn" }, form_delete_main);
  762. var cencal = $$('button', { "className": "form-cencal", "innerHTML": `${"加入房间"}` }, btnBox);
  763. var confirm = $$('button', { "className": "form-confirm", "innerHTML": `${"创建房间"}` }, btnBox);
  764. new U.UF.UI.form(`${"创建/加入房间"}`, BOX, {
  765. id: 'add_room',
  766. style: {
  767. "background": "#fffefe",
  768. "width": "400px",
  769. "height": "281px",
  770. "z-index": "99 !important",
  771. }
  772. }, {
  773. isenlarge: false,
  774. isnarrow: false
  775. }, {
  776. style: {
  777. "height": "40px",
  778. "text-align": "center",
  779. "line-height": "40px",
  780. "text-indent": "25px",
  781. "background-repeat": "no-repeat",
  782. "font-size": "16px",
  783. "background-color": "#32455B",
  784. "display": "flex",
  785. }
  786. });
  787. confirm.onclick = function () {
  788. U.MD.O.W.checkNum();
  789. }
  790. cencal.onclick = function () {
  791. U.MD.O.W.goRoom($(".form_delete-main_box")[0].value);
  792. }
  793. }
  794. U.MD.O.W.getContent = function (cid, s, task, t, uid, type, iframe) {
  795. U.A.Request(US.Config.pbl + "selectWord2?uid=" + uid + "&cid=" + cid + "&s=" + s + "&task=" + task + "&t=" + t + "&type=" + type, [], function (res) {
  796. if (res.value[0].length > 0) {
  797. // resolve(res.value[0][0].text);
  798. iframe.contentWindow.editor.minder.importData('json', res.value[0][0].text).then(function (data) {
  799. $(fileInput).val('');
  800. });
  801. }
  802. });
  803. }
  804. //#endregion