WordPanel.js 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846
  1. //此处放置iframe中的word中的功能面板,包括包括创建邀请协作人员,创建编辑历史,创建生成链接.创建热门模板。
  2. Namespace.register("U.MD.O.W.Panel");
  3. //协作统一命名为Collaborative,但牵涉的地方太多,暂时还是用Synergy
  4. //#region 本地转协同文档及新建保存为协同文档操作
  5. /**
  6. * 本地转协同文档及新建保存为协同文档操作,此函数逻辑不清,需要改写!
  7. *
  8. * @param fun {element} 回调函数
  9. */
  10. U.MD.O.W.Panel.isSynergy = function (fun) {
  11. //判断是登录
  12. if (!top.U.MD.U.L.isLogin()) {
  13. var _fileinfo = U.MD.O.W.fileinfo, //文件信息
  14. ////或者是什么意思?不严谨
  15. _filegroupid = _fileinfo.GroupID; //获取_filegroupid群id,判断是否是在自己的ftp下的文档
  16. //判断是否为互联办公文档,此处有问题。互联办公的权限有问题。
  17. if (U.MD.O.W.permission.web) {
  18. if (U.UF.C.isFunction(fun)) {//判断是否有点击事件的方法,如果有,运行它
  19. fun(_fileinfo);
  20. }
  21. return true;
  22. }
  23. else {
  24. var _filename = top.$('#UD_Word' + _fileinfo.UserDirectoryID + ' .U_MD_O_H_head_navigation_Title')[0]; //获取文件名
  25. //判断文档是否是保持文档,是否是可编辑文档
  26. if (U.MD.O.W.isSave() && U.MD.O.W.permission.edit) {
  27. //如果是保持的文档,那么直接提示是否转成系统文档
  28. new U.UF.UI.confirm("是否将此文档转成互联办公文档", function () {
  29. //保存到群里
  30. top.U.MD.DK.VW.saveSynergy(_fileinfo.UserDirectoryExtendType || "uw", _fileinfo, _filename.value, 'move', function (fileinfo) {
  31. U.MD.O.W.Panel.isSynergy.async(fileinfo, fun);
  32. });
  33. });
  34. }
  35. //新建保存为协同
  36. else {
  37. //否则是新建文档
  38. top.U.MD.DK.VW.saveSynergy(_fileinfo.UserDirectoryExtendType || "uw", _fileinfo, _filename.value, 'new', function (fileinfo) {
  39. U.MD.O.W.Panel.isSynergy.async(fileinfo, fun);
  40. });
  41. }
  42. }
  43. }
  44. return false;
  45. }
  46. /**
  47. * 本地转协同文档及新建保存为协同文档操作
  48. *
  49. * @param fileinfo {object} 文件信息
  50. * @param fun {element} 回调函数
  51. */
  52. U.MD.O.W.Panel.isSynergy.async = function (fileinfo, fun) {
  53. U.MD.O.W.fileinfo = fileinfo; //设置文件信息
  54. U.MD.O.W.Panel.disPlayUser(fileinfo); //获取协作人员
  55. var _eidtorel = $('#U_MD_O_H_wordEditor')[0]; //获取编辑器
  56. //导航文件转成互联
  57. if (fileinfo.UserDirectoryExtendType == 'un') {
  58. //保存文件到后台
  59. U.MD.O.W.T.N.saveAllPage(function () {
  60. U.MD.O.W.T.N.saveNav.asyn(true, fileinfo, _eidtorel);
  61. }, 0, true, _eidtorel.innerHTML);
  62. }
  63. else {
  64. //保存文件到后台
  65. U.A.Request(US.SCOKET, ["newWordSave", fileinfo.UserDirectoryID, _eidtorel.innerHTML.escapeQuotes(), fileinfo.UserDirectoryName, US.userInfo.userid, top.US.pageId], U.MD.O.W.Panel.isSynergy.saveAsync, [null, fileinfo, _eidtorel]);
  66. }
  67. if (U.UF.C.isFunction(fun)) {//判断是否有点击事件的方法,如果有,运行它
  68. fun(fileinfo);
  69. }
  70. }
  71. U.MD.O.W.Panel.isSynergy.saveAsync = function (r) {
  72. var _fileinfo = r.context[1];
  73. var _eidtorel = r.context[2];
  74. U.MD.O.W.permission.edit = true;
  75. U.MD.O.W.permission.web = true;
  76. top.$('#UD_Word' + _fileinfo.UserDirectoryID + ' .U_MD_O_H_head_navigation_Title')[0].value = _fileinfo.UserDirectoryName; //设置文件名
  77. U.Alert("保存成功"); //提示保存成功
  78. U.MD.O.W.fileinfo.UsOffice = _eidtorel.innerHTML; //设置内容
  79. _eidtorel.editor.operaNotice = U.MD.O.W.E.operationNotice; //设置协同监听回调
  80. }
  81. //#endregion
  82. //#region 团队成员
  83. /**
  84. * 创建团队成员的窗体
  85. *
  86. * @param fileinfo {object} 文件信息
  87. */
  88. U.MD.O.W.Panel.loadPlayUser = function (fileinfo) {
  89. var _coopwindow, _frienddiv, _example, _shareLink, _cBox, _person;
  90. console.log(fileinfo);
  91. //如果不存在团队成员窗口,则创建一个团队成员窗口。
  92. if (!$("#U_MD_O_H_body_left_invite_user")[0]) {
  93. //创建邀请协助人员窗口
  94. _coopwindow = $("#U_MD_O_H_body_left")[0];
  95. _cBox = $$("div", {});
  96. _shareLink = $$("div", {
  97. className: 'U_MD_O_H_body_left_invite_linkTxt', "onclick": function () {
  98. // U.MD.O.W.Panel.isSynergy(U.MD.O.W.Panel.shareLink);
  99. U.MD.D.I.isOpenRoomConfirm();
  100. }, "innerText": "第三方链接邀请"
  101. }, _cBox);
  102. _frienddiv = $$("div", { "className": "U_MD_O_H_body_left_invite_user", "id": "U_MD_O_H_body_left_invite_user" }, _cBox); //好友内容区域
  103. // _example = $$("div", {
  104. // "className": "U_MD_O_H_body_left_invite_user_a", "onclick": function () {
  105. // U.MD.O.W.Panel.displayInsertUser();
  106. // }
  107. // }, _frienddiv); //默认邀请按钮
  108. _example = $$("div", {
  109. "className": "U_MD_O_H_body_left_invite_user_a",
  110. }, _frienddiv);
  111. for (i = 0; i <= 2; i++) {
  112. _person = $$("div", { "className": "U_MD_O_H_body_left_person", }, _example);
  113. $$("div", { "className": "U_MD_O_H_body_left_invite_user_a_img" }, _person);
  114. $$("div", { "className": "U_MD_O_H_body_left_invite_user_a_div", "innerHTML": "陈慧" }, _person);
  115. }
  116. _person = $$("div", { "className": "U_MD_O_H_body_left_person", }, _example);
  117. $$("div", {
  118. "className": "U_MD_O_H_body_left_invite_user_a_img_add", "onclick": function () {
  119. U.MD.D.I.addPerson();
  120. }
  121. }, _person);
  122. new U.UF.UI.form("邀请协作人员", _cBox, { id: "LoadPlayUser", style: { border: "none", position: "absolute", width: "300px", "min-width": "200px", height: "250px", top: "310px", left: "auto", "box-shadow": "none" } },
  123. { isenlarge: false, isnarrow: false }, { style: { margin: "0px 5px", "border-bottom": "1px solid #d6def0", color: "#000", background: "#fff" } }, null, null, _coopwindow);
  124. }
  125. U.MD.O.W.Panel.disPlayUser(fileinfo); //获取协作人员
  126. }
  127. /**
  128. * 初始化查看团队成员
  129. *
  130. * @param fileinfo {object} 文件信息
  131. */
  132. U.MD.O.W.Panel.disPlayUser = function (fileinfo, el) {
  133. el = $("#U_MD_O_H_body_left_invite_user")[0]; //获取团队成员初始化的位置
  134. var _elchild = el.children[0] //获取元素的子元素;
  135. el.innerHTML = ""//清空内容
  136. $(el).append(_elchild);
  137. if (fileinfo) {//判断是否有文件信息
  138. var _userinfo = [];// U.Json.select(US.friend.groupusers, { "GroupManageID": fileinfo.GroupID }); //获取所有在群里的成员
  139. if (_userinfo) {//判断是否拥有群成员
  140. for (i = 0; i < _userinfo.length; i++) {//循环打印所有的群成员
  141. U.MD.O.W.Panel.createUser(_userinfo[i], el);
  142. }
  143. }
  144. }
  145. }
  146. /**
  147. * 打印团队编辑成员
  148. *
  149. * @param fileinfo {object} 文件信息
  150. */
  151. U.MD.O.W.Panel.createUser = function (userinfo, el) {
  152. var _elparent = $$("div", {
  153. "className": "U_MD_O_H_body_left_invite_user_a", "onclick": U.UF.C.closure(function (userid) {
  154. top.U.MD.U.V.ViewOtherUserInfo(userid);
  155. }, [userInfo.userid])
  156. }, el); //好友头像父级元素
  157. var _elcontant = $$("div", { "className": "U_MD_O_H_body_left_invite_user_a_user", "style": { "background": "" } }, _elparent); //好友头像元素
  158. $$("img", { "onerror": U.MD.C.imgError, "src": top.U.MD.C.getHeadImage(userinfo.UserThumbnailImageHead) }, _elcontant); //好友头像图片
  159. $$("div", { "className": "U_MD_O_H_body_left_invite_user_a_div", "innerHTML": userinfo.UserNickName }, _elparent); //好友名称
  160. }
  161. /**
  162. * 单击邀请时,从普通文档转换为协同文档的过程!
  163. * 判断是否是已经新建过 弹出添加成员 异步回调
  164. *
  165. * @param {element} Wrod信息数组
  166. */
  167. U.MD.O.W.Panel.displayInsertUser = function () {
  168. //判断是否是协同文档
  169. if (U.MD.O.W.Panel.isSynergy()) {
  170. var _fileinfo = U.MD.O.W["fileinfo"];
  171. top.U.MD.F.J.selectFriendForm(function (groupid) {
  172. //或者是什么意思?不严谨
  173. var _filegroupid = _fileinfo.GroupID; //获取_filegroupid群id,判断是否是在自己的ftp下的文档
  174. var _groupinfo = U.Json.select(US.friend.group, { "GroupManageID": _filegroupid })[0]; //群信息
  175. var _needuser = top.U.MD.F.J.selectUserInfo.NeedUser; //选中好友集合
  176. var _groupname = _groupinfo.GroupManageName; // 群名
  177. var _groupdesc = _groupinfo.GroupManageDescript; //群描述
  178. var _selectfriend = U.Json.select(US.friend.groupusers, { "GroupManageID": _filegroupid }); //选择的好友信息
  179. //已经在群里的就不添加了
  180. var i;
  181. for (i = 0; i < _selectfriend.length; i++) {
  182. U.Json.del(_needuser, { "UserId": _selectfriend[i].UserId }); //删除所有在群里的用户id
  183. }
  184. //创建及添加群处理
  185. top.U.MD.F.J.determineCreateGroupAndAddGroupUser(_filegroupid, null, null, false, _groupname, _groupdesc, function (groupid, groupinfo) {
  186. var i, _userids = "";
  187. //U.MD.O.W.Panel.disPlayUser(_fileinfo);
  188. for (i = 0; i < _needuser.length; i++) {//循环打印所有的群成员
  189. _userids += _needuser[i].UserId + (i < _needuser.length - 1 ? "," : "");
  190. U.MD.O.W.Panel.createUser(_needuser[i]);
  191. }
  192. U.MD.O.W.Panel.addUser(_userids);
  193. });
  194. }, null, _fileinfo); //调用打印函数
  195. }
  196. }
  197. U.MD.O.W.Panel.addUser = function (userids) {
  198. var _type = U.MD.O.W["fileinfo"].UserDirectoryExtendType == "un" ? "nav" : "word";
  199. top.U.A.Request(US.SCOKET, ["addUser", _type, U.MD.O.W["fileinfo"].UserDirectoryID, userids, US.userInfo.userid, top.US.pageId], function () { });
  200. }
  201. U.MD.O.W.Panel.syncAddUser = function (userids, senduserid) {
  202. userids = userids.split(",");
  203. var i, _userinfo;
  204. for (i = 0; i < userids.length; i++) {
  205. _userinfo = U.Json.selectOne(US.friend.groupusers, { UserId: userids[i] });
  206. if (!_userinfo) {
  207. top.U.A.Request(US.CD, [US.DB, "UseStudio_Users", "GetUserinfoByUserId", userids[i]], function (r) {
  208. _userinfo = r.value[0];
  209. U.MD.O.W.Panel.createUser(_userinfo);
  210. })
  211. }
  212. }
  213. }
  214. //#endregion
  215. //#region 分享文档链接
  216. /**
  217. * ----------------------------添加团队成员
  218. *
  219. * @param {object} 文件信息
  220. * @param {string} 文件提交到哪个群的id
  221. * @param {array} 用户id的数组
  222. */
  223. //U.MD.O.W.Panel.insertUser = function (fileinfo, groupid) {
  224. // // if (!fileinfo.UserId && !fileinfo.UserallDirectoryName) {
  225. // // fileinfo.GroupId = fileinfo.UserDirectoryEncrypt = groupid;
  226. // // var _groupuserid = U.Json.select(US.friend.group, { 'GroupManageID': groupid })[0].GroupManageUserID;
  227. // // var _dirinfo, _dirid, _diskinfo = US.disk.Disks[US.userInfo.userid];
  228. // // if (_groupuserid == US.userInfo.userid) {
  229. // // _dirinfo = U.Json.select(_diskinfo.directoryOrFiles, { 'UserDirectoryName': "我的协同" })[0];
  230. // // } else {
  231. // // _dirinfo = U.Json.select(_diskinfo.directoryOrFiles, { 'UserDirectoryName': "他人邀请" })[0];
  232. // // }
  233. // // var _dirchild = top.$('#L' + _dirinfo.UserDirectoryID).Child();
  234. // // !_dirchild[1] && _dirchild[0].onclick()
  235. // // top.$('#L' + groupid).Child()[0].onclick();
  236. // // } else if ((fileinfo.UserDirectoryEncrypt || fileinfo.GroupID) == US.userInfo.userid) { //如果是新创建的文件,同时文件不在群里 就把文件拷贝到群里进行处理
  237. // // var _userid = fileinfo.UserId,
  238. // // _diskinfo = US.disk.Disks[US.userInfo.userid],
  239. // // _dirinfo = U.Json.select(_diskinfo.directoryOrFiles, { "UserDirectoryID": groupid }, 1)[0]; //当前目录的信息
  240. // // var _pastecontent = US.disk.Disks[_userid].pasteDirOrFile = {
  241. // // "type": "shear", //复制或者剪切 "copy" || "shear"
  242. // // "UserDirectoryID": groupid, //在哪个目录复制或者剪切
  243. // // "dirorfile": fileinfo, //复制的内容
  244. // // "userid": _userid //用户id
  245. // // }
  246. // // top.U.A.Request(US.AUTH, ["CutAndPasteFiles", fileinfo.UserId, groupid, fileinfo.UserDirectoryID, groupid, groupid],
  247. // // top.U.MD.DK.RE.asynPaste, ["", _dirinfo, groupid, _pastecontent, _diskinfo]
  248. // // );
  249. // // fileinfo.GroupId = fileinfo.UserDirectoryEncrypt = groupid;
  250. // // }
  251. // // U.MD.O.W.Panel.disPlayUser(fileinfo);
  252. //}
  253. /**
  254. * 分享文档链接
  255. *
  256. * @param fileinfo {object} 文件信息
  257. */
  258. U.MD.O.W.Panel.shareLink = function (fileinfo) {
  259. var _template = U.MD.O.W.Panel.shareLinkTemplate(fileinfo); //生成窗体内容
  260. new U.UF.UI.form("邀请协助链接", _template, { id: "U_MD_O_W_Panel_InviteForm", style: { cssText: "width:600px; height:450px;" } }); //创建窗体
  261. }
  262. /**
  263. * 创建分享链接窗体内容模板
  264. *
  265. * @param {fileinfo} 文件信息
  266. */
  267. U.MD.O.W.Panel.shareLinkTemplate = function (fileinfo) {
  268. var _cBox = $$('div', { className: "U_MD_O_H_body_left_invite_form" }), //创建最外层元素
  269. _shareLinkEl = $$('div', { className: "U_MD_O_H_body_left_invite_formShare" }, _cBox), //分享链接盒子元素
  270. _QRCodeEl = $$('div', { className: "U_MD_O_H_body_left_invite_formQRCode" }, _cBox); //二维码元素
  271. $$('p', { innerText: "通过链接邀请:", style: { cssText: "font-size:18px; font-weight: bold;" } }, _shareLinkEl) //文字提示
  272. var _shareLinkInpBlock = $$('div', { className: "U_MD_O_H_body_left_invite_shareInpMargin" }, _shareLinkEl); //分享链接文本框
  273. $$('p', { style: { cssText: "margin-top: 8px;" }, innerText: "将下面的邀请链接通过QQ或微信发送给需要邀请的人" }, _shareLinkInpBlock); //文字提示
  274. var _fileType; //文档类型
  275. switch (fileinfo.UserDirectoryExtendType.toLowerCase()) { //字符串转换
  276. case 'uw':
  277. _fileType = 'word'; break;
  278. case 'ue':
  279. _fileType = 'execl'; break;
  280. case 'un':
  281. _fileType = 'word'; break;
  282. default:
  283. _fileType = false; break;
  284. }
  285. var _shareLinkInpBlockShow = $$('input', { style: { cssText: "margin-top: 5px;" }, className: "U_MD_O_H_body_left_invite_shareInp", value: "http://www.1473.cn/#" + _fileType + '/join/' + fileinfo.UserDirectoryID, disabled: "disabled" }, _shareLinkInpBlock), //输出
  286. _shareLinkInpBlockBtn = $$('div', {
  287. style: { cssText: "margin-top: 5px;" }, className: "U_MD_O_H_body_left_invite_shareBtn", innerText: "复制", onclick: function () { //复制按钮
  288. var _inp = $$('input', { value: _shareLinkInpBlockShow.value }, $('body')[0]); //创建复制文本框
  289. _inp.select(); //选中
  290. document.execCommand("Copy"); //复制
  291. $(_inp).remove();
  292. U.Alert('复制成功,赶紧分享给小伙伴吧!'); //提示
  293. }
  294. }, _shareLinkInpBlock)
  295. $$('p', { innerText: "通过二维码邀请:", style: { cssText: "font-size:18px; font-weight: bold;" } }, _QRCodeEl); //文字
  296. var _QRCodeImg = $$('div', { style: { cssText: "margin-left:40px;margin-top: 20px;position:absolute;" } }, _QRCodeEl);
  297. $$('div', { innerHTML: "<span style='font-size:16px'>通过扫码,邀请好友</span><br>扫描二维码获取邀请函,转发给微信好友/群,<br/>即可邀请他们加入你的文档", style: { cssText: "margin-left: 270px;margin-top:40px;line-height:30px;" } }, _QRCodeEl);
  298. top.U.UF.QR.generate("150", "150", "black", "white", _shareLinkInpBlockShow.value, _QRCodeImg); //调用生成二维码函数
  299. return _cBox; //返回最外层元素
  300. }
  301. //#endregion
  302. //#region 热门模板
  303. /**
  304. * 创建热门模板窗体
  305. *
  306. * @param {element} 换页元素
  307. */
  308. U.MD.O.W.Panel.loadHotTemplates = function (fileinfo) {
  309. var _leftel, _el;
  310. //判断是否加载热门模板
  311. if (!$("#U_MD_O_H_body_left_template_hot")[0]) {
  312. _leftel = $("#U_MD_O_H_body_left")[0];
  313. //创建热门模板窗体
  314. _el = $$("div", { "className": "U_MD_O_H_body_left_template_user", id: "U_MD_O_H_body_left_template_hot" });
  315. new U.UF.UI.form("热门模板提供", _el, { id: "LoadHotTemplates", style: { border: "none", width: "300px", height: "477px", position: "absolute", top: "695px", left: "auto", "box-shadow": "none" } }, { isenlarge: false, isnarrow: false }, { style: { margin: "0px 5px", "border-bottom": "1px solid #d6def0", color: "#000", background: "#fff" } }, null, null, _leftel);
  316. }
  317. U.MD.O.W.Panel.getHotTemplates("00000000-0000-0000-0000-000000000000", 1, 10); //热门模板
  318. }
  319. /**
  320. * 初始化加载模板
  321. *
  322. * @param {element} 换页元素
  323. */
  324. U.MD.O.W.Panel.getHotTemplates = function (hid, start, end) {
  325. var _el = $("#U_MD_O_H_body_left_template_hot")[0];
  326. U.A.Request(US.CD, [US.DB, "UseStudio_Office", "SelectHotTemplate", hid, start, end], U.MD.O.W.Panel.asynGetHotTemplates, [null, _el]);
  327. }
  328. /**
  329. * 获取热门模板
  330. *
  331. * @param {element} 换页元素
  332. */
  333. U.MD.O.W.Panel.asynGetHotTemplates = function (r) {
  334. var i, _el,
  335. _frag = $$("frag"),
  336. _hel = r.context[1];
  337. r = r.value;
  338. //循环答应热门模板
  339. for (i = 0; i < r.length; i++) {
  340. _el = $$("div", {
  341. "className": "U_MD_O_H_body_left_template_user_m",
  342. "onclick": U.UF.C.closure(function (info) {
  343. parent.U.A.Request(US.DISK, ["GetFileContent", info.FileId], function (r) {
  344. //获取到内容
  345. if (r.value && r.value.UsOffice !== undefined) {
  346. r = r.value.UsOffice;
  347. }
  348. //打开新的word处理
  349. top.U.MD.O.word(US.userInfo, { UserDirectoryID: Guid.newGuid(), UsOffice: r || "" });
  350. });
  351. }, [r[i]])
  352. }, _frag);
  353. $$("div", { "className": "U_MD_O_H_body_left_template_user_m_s", "style": { "background-image": "url(" + (r[i].UseFilesServerThumbnailName || "http://www.1473.cn/Boomyun/img/pc/NImg.png") + ")" } }, _el);
  354. $$("div", { "className": "U_MD_O_H_body_left_template_user_m_x", "innerHTML": r[i]["UserFilesName"] }, _el);
  355. }
  356. $(_hel).append(_frag);
  357. }
  358. //#endregion
  359. //#region 链接查看
  360. /**
  361. *
  362. * 加载,生成连接区域
  363. *
  364. * @param wordinfo {object} 当前文档信息
  365. */
  366. U.MD.O.W.Panel.loadlink = function (wordinfo) {
  367. var _linkareael = $("#U_MD_O_H_body_left_href_pay_a")[0];
  368. //如果不存在添加链接区域,则创建。
  369. if (!_linkareael || (_linkareael && _linkareael.innerHTML == "")) {
  370. U.MD.O.W.Panel.formloadlink([]); //加载链接,这里有可能没有设置过短连接
  371. //加载word文件的短链接
  372. // U.A.Request('http://cd.1473.cn/php', ["db.1473.cn", "UseStudio_DNS", 'GetDnsInfoByFileId', wordinfo.UserDirectoryID], function (r) {
  373. // var _date = r.value; //获取短连接信息
  374. // U.MD.O.W.Panel.formloadlink(_date); //加载链接,这里有可能没有设置过短连接
  375. // });
  376. }
  377. }
  378. /**
  379. *
  380. * 加载,生成连接区域
  381. *
  382. * @param wordinfo {object} 当前文档信息
  383. */
  384. U.MD.O.W.Panel.formloadlink = function (date) {
  385. var _url,
  386. _linkdiv,
  387. _wordinfo = U.MD.O.W.fileinfo,
  388. _rightwindow = $("#U_MD_O_H_body_left")[0], //右边功能区
  389. _linkareael = $("#U_MD_O_H_body_left_href_pay_a")[0]
  390. ;
  391. //设置过域名的加载
  392. if (date.length) {
  393. _url = date[0].AppId + ".1473.cn/" + date[0].Domain
  394. _linkdiv = $$("div", { "className": "U_MD_O_H_body_left_href_pay_a", id: "U_MD_O_H_body_left_href_pay_a" });
  395. $$("a", { className: "U_MD_O_H_body_left_href_pay_aText", href: "//" + _url, innerText: _url, target: "_Blank" }, _linkdiv);
  396. //只有编辑权限才显示修改和分享按钮
  397. if (U.MD.O.W.permission.edit) {
  398. $$('div', {
  399. innerText: '分享', className: "U_MD_O_H_body_left_href_pay_Btn", onclick: function () {
  400. //判断是否保持文档
  401. if (U.MD.O.W.isSave()) {
  402. var _iframe = $$('iframe', { src: '//domain.1473.cn/DomainSystem.aspx/?fileId=' + _wordinfo.UserDirectoryID + '&type=word&mode=share', frameborder: "0", style: { cssText: "width:100%;height:100%;border:0px" } });
  403. new U.UF.UI.form("域名管理", _iframe, { id: "U_MD_DS_DomainShare", style: { "width": "370px", "height": "390px" } });
  404. }
  405. //点击保存处理
  406. else {
  407. $('#U_MD_O_H_save')[0].onclick();
  408. }
  409. }
  410. }, _linkdiv);
  411. $$("div", {
  412. innerText: '修改', className: "U_MD_O_H_body_left_href_pay_Btn", onclick: function () {
  413. //判断是否保持文档
  414. if (U.MD.O.W.isSave()) {
  415. var _iframe = $$('iframe', { src: '//domain.1473.cn/DomainSystem.aspx/?fileId=' + _wordinfo.UserDirectoryID + '&type=word&mode=base', frameborder: "0", style: { cssText: "width:100%;height:100%;border:0px" } });
  416. new U.UF.UI.form("域名管理", _iframe, { id: "U_MD_DS_DomainManage", style: { cssText: 'width: 1040px; height: 555px' } });
  417. }
  418. //点击保存处理
  419. else {
  420. $('#U_MD_O_H_save')[0].onclick();
  421. }
  422. }
  423. }, _linkdiv);
  424. }
  425. }
  426. //未设置过的
  427. else {
  428. // _linkdiv = $$("div", {
  429. // "className": "U_MD_O_H_body_left_href_pay_a", id: "U_MD_O_H_body_left_href_pay_a", "innerHTML": "将此站点生成链接", "onclick": function () { //生成链接
  430. // //判断文件是否保存,此判断未成功
  431. // if (U.MD.O.W.isSave()) { //如果保存的文档,点击直接弹出网页
  432. // //得到编辑器
  433. // var _wordContent = document.getElementById("U_MD_O_H_wordEditor");
  434. // //如果文件变量中的word内容存在,编辑器内容不同于文件变量中的内容,则保存内容,否则,返回true
  435. // if (_wordinfo.UsOffice && _wordinfo.UsOffice != _wordContent.innerHTML) {
  436. // //保存到数据库
  437. // top.U.A.Request(US.DISK, ["SaveFileContent", US.userInfo.UserId, _wordinfo.UserDirectoryID, _wordContent.innerHTML.escapeQuotes(), _wordinfo.UserallDirectoryName, "uw"], function (r) {
  438. // //跳转新页面显示word内容
  439. // window.open("http://" + U.MD.O.W.fileinfo.UserDirectoryID + ".1473.cn");
  440. // }, ([''])); //保存到数据库
  441. // }
  442. // else {
  443. // //先判断数据库是否存在该文件
  444. // parent.U.A.Request(US.DISK, ["GetFileContent", _wordinfo.UserDirectoryID], function (r) {
  445. // //能够获取到内容
  446. // if (r.value && r.value.UsOffice !== null) {
  447. // //跳转新页面显示word内容
  448. // window.open("http://" + U.MD.O.W.fileinfo.UserDirectoryID + ".1473.cn");
  449. // }
  450. // else {
  451. // //保存到数据库
  452. // top.U.A.Request(US.DISK, ["SaveFileContent", US.userInfo.UserId, _wordinfo.UserDirectoryID, _wordContent.innerHTML.escapeQuotes(), _wordinfo.UserallDirectoryName, "uw"], function (r) {
  453. // //跳转新页面显示word内容
  454. // window.open("http://" + U.MD.O.W.fileinfo.UserDirectoryID + ".1473.cn");
  455. // }, ([''])); //保存到数据库
  456. // }
  457. // });
  458. // }
  459. // }
  460. // else { //未保存的文档查看站点,触发保存事件
  461. // $('#U_MD_O_H_save')[0].onclick();
  462. // }
  463. // }
  464. // });
  465. }
  466. //如果已经创建
  467. if (_linkareael && _linkareael.innerHTML == "") {
  468. _linkareael.appendChild(_linkdiv);
  469. }
  470. //如果生成链接的处理
  471. else {
  472. // new U.UF.UI.form("生成链接", _linkdiv, { style: { border: "none", position: "absolute", width: "300px", height: "70px", top: "60px", left: "auto", "box-shadow": "none" } }, { isenlarge: false, isnarrow: false }, { style: { margin: "0px 5px", "border-bottom": "1px solid #d6def0", color: "#000", background: "#fff" } }, null, null, _rightwindow);
  473. }
  474. }
  475. //#endregion
  476. //#region 历史记录
  477. /**
  478. * 初始化历史记录
  479. *
  480. * @param
  481. */
  482. U.MD.O.W.Panel.loadOfficeHistory = function (fileinfo) {
  483. var _el, _leftel;
  484. //判断是否有历史记录
  485. if (!$("#U_MD_O_H_body_left_invite_history")[0]) {
  486. _leftel = $("#U_MD_O_H_body_left")[0];
  487. //编辑历史
  488. _el = $$("div", { "className": "U_MD_O_H_body_left_invite_user", "id": "U_MD_O_H_body_left_invite_history" });
  489. new U.UF.UI.form("编辑历史", _el, { id: "LoadOfficeHistory", style: { width: "300px", height: "284px", position: "absolute", top: "400px", left: "auto", "border-radius": "0px", border: "none", "box-shadow": "none", "border-radius": "5px" } }, { isenlarge: false, isnarrow: false }, { style: { margin: "0px 5px", "border-bottom": "1px solid #d6def0", color: "#000", background: "#fff" } }, null, null, _leftel);
  490. }
  491. //判断文件是否保持的文件,如果保持的文件则有历史记录,未保存的没有
  492. if (U.MD.O.W.isSave()) {
  493. U.MD.O.W.Panel.viewEditHistory(fileinfo.UserDirectoryID, U.MD.O.W.historyid, 1, 100); //历史记录
  494. }
  495. //没有历史记录
  496. else {
  497. $$("div", { "innerHTML": "暂无历史", "style": { "text-align": "center", "margin-top": "50px" } }, _el);
  498. }
  499. }
  500. /**
  501. * 查看编辑历史
  502. *
  503. * @param {element} 换页元素
  504. * 创始人id 文件id 空的id 选取开始 选取长度 获取编辑历史的框
  505. */
  506. U.MD.O.W.Panel.viewEditHistory = function (id, hid, start, end) {
  507. var _el = $("#U_MD_O_H_body_left_invite_history")[0];
  508. U.A.Request(US.CD, [US.DB, "UseStudio_Office", "SelectOfficeHistory", id, hid, start, end], U.MD.O.W.Panel.asynViewEditHistory, [null, _el]);
  509. }
  510. /**
  511. * 查看编辑历史异步
  512. *
  513. * @param {element} 换页元素
  514. */
  515. U.MD.O.W.Panel.asynViewEditHistory = function (r) {
  516. $('#U_MD_O_H_body_left_invite_history')[0].innerHTML = '';
  517. var _value = r.value,
  518. _el = $('#U_MD_O_H_body_left_invite_history')[0]
  519. for (var i = 0; i < _value.length; i++) {
  520. _el.appendChild(U.MD.O.W.Panel.createHis(_value[i]))
  521. }
  522. }
  523. /**
  524. * 添加详细历史记录布局
  525. *
  526. * @param {object} data 数据
  527. */
  528. U.MD.O.W.Panel.createHis = function (data) {
  529. var _hisel, _imgel, _infoel, _textel, _btnel;
  530. _hisel = $$('div', { style: { cssText: 'min-height: 85px; border-bottom: 1px solid silver; margin: 0 3px' } });
  531. _imgel = $$('div', { style: { margin: '22px 12px 0', float: 'left' } }, _hisel);
  532. $$('img', { "onerror": U.MD.C.imgError, style: { cssText: 'width:40px; height: 40px;' }, src: top.U.MD.C.getHeadImage(data.UserThumbnailImageHead) }, _imgel);
  533. _infoel = $$('div', { style: { cssText: 'margin-left: 62px;' } }, _hisel);
  534. _textel = $$('div', { style: { 'padding-top': '25px', 'white-space': 'nowrap' } }, _infoel);
  535. $$('span', { innerText: data.UserName }, _textel);
  536. $$('span', { innerText: U.UF.D.getDateInterval(data.CreateTime) + '保存一次', style: { 'padding-left': '10px' } }, _textel);
  537. _btnel = $$('div', { style: { 'margin-top': '10px', 'white-space': 'nowrap' } }, _infoel);
  538. //判断是否是自己编辑历史记录,是则不打印对话
  539. if (data.UserId != U.MD.O.W.userInfo.userid) {
  540. $$('button', {
  541. innerText: '对话', style: { cssText: 'color: #fff; background-color:#6d81a4; border-radius: 4px; border:none; outline:none; padding: 4px 8px; cursor: pointer;' }, onclick: function () {
  542. //这里有问题,这样获取不一定能获取用户数据,同时数据没有分离
  543. var _friendel = U.Json.select(US.friend.friends, { UserId: data.UserId });
  544. //如果未添加好友,则弹出添加好友框,否则直接弹出聊天窗口
  545. if (_friendel.length == 0) {
  546. top.U.MD.U.V.ViewOtherUserInfo(data.UserId);
  547. } else {
  548. _data = !_friendel.length ? U.Json.select(US.friend.recentcontacts, { UserId: data.UserId }) : _friendel;
  549. top.U.MD.F.W.popupFriendsForm(_data[0], this);
  550. }
  551. }
  552. }, _btnel);
  553. }
  554. $$('button', {
  555. innerText: '详细', style: { cssText: 'color: #fff; background-color:#6d81a4; border-radius: 4px; border:none; outline:none; padding: 4px 8px; margin-left: 4px;cursor: pointer;' },
  556. onclick: function () {
  557. U.MD.O.W.Panel.EditHistory(data)
  558. }
  559. }, _btnel);
  560. //返回最外的元素
  561. return _hisel
  562. }
  563. /**
  564. * 插入历史
  565. *
  566. * @param _fileinfo {string} 文件信息
  567. * @param {string} 历史记录内容
  568. *
  569. */
  570. U.MD.O.W.Panel.InsertOfficeHistory = function (fileinfo, html, name, contentel) {
  571. var _fileid = fileinfo.UserDirectoryID; //文件ID
  572. if (U.MD.O.W.permission.web) {
  573. //html,
  574. top.U.A.Request(US.SCOKET, ["insertModifyRecord", "word", _fileid, name, html, US.userInfo.userid, US.pageId], function (r) {
  575. if (r.value) {
  576. var _historyid = r.value;
  577. U.MD.O.W.Panel.syncHistory(US.userInfo.userid, _historyid);
  578. U.MD.O.W.fileinfo.UsOffice = contentel.innerHTML;
  579. U.Alert("保存成功");
  580. } else {
  581. U.Alert("系统有误,请稍后重试..");
  582. }
  583. });
  584. } else {
  585. //插入历史
  586. U.A.Request(US.CD, [US.DB, "UseStudio_Office", "InsertDocumentModifyRecord", US.userInfo.userid, _fileid, html, name], function (r) {
  587. if (r.value[0]) {
  588. U.MD.O.W.Panel.syncHistory(US.userInfo.userid, r.value[0].historyid);
  589. U.MD.O.W.fileinfo.UsOffice = contentel.innerHTML;
  590. U.Alert("保存成功");
  591. } else {
  592. U.Alert("系统有误,请稍后重试..");
  593. }
  594. });
  595. }
  596. }
  597. U.MD.O.W.Panel.syncHistory = function (userid, historyid, isbool) {
  598. if (!isbool) {
  599. var _data, _fileinfo = U.MD.O.W.fileinfo;
  600. _fileinfo.HistoryId = historyid; //记录历史ID
  601. if (userid == US.userInfo.userid) {
  602. _data = U.MD.O.W.dataStructure(_fileinfo.UserDirectoryModifyTime, US.userInfo.username, US.userInfo.UserThumbnailImageHead, historyid, US.userInfo.userid);
  603. } else {
  604. var _userinfo = U.Json.select(US.friend.groupusers, { UserId: userid })[0];
  605. _data = U.MD.O.W.dataStructure(_fileinfo.UserDirectoryModifyTime, _userinfo.UserName, _userinfo.UserThumbnailImageHead, historyid, _userinfo);
  606. }
  607. var _el = U.MD.O.W.Panel.createHis(_data), //创建历史记录
  608. _addel = $('#U_MD_O_H_body_left_invite_history')[0]; //历史记录区域
  609. $(_el).appendTo(_addel, 0, _addel.firstElementChild); //置顶插入
  610. }
  611. }
  612. /**
  613. * 历史数据结构
  614. *
  615. * @param creattime {string} 创建时间
  616. * @param username {string} 用户名
  617. * @param userbgimg {string} 用户头像
  618. * @param historyid {string} 历史ID
  619. * @param userid {string} 用户ID
  620. *
  621. */
  622. U.MD.O.W.dataStructure = function (creattime, username, userbgimg, historyid, userid) {
  623. return {
  624. CreateTime: creattime || U.UF.D.toTimeStamp(new Date()), //创建时间
  625. UserName: username, //用户名
  626. UserThumbnailImageHead: userbgimg, //用户头像
  627. HistoryId: historyid, //历史ID
  628. UserId: userid //用户ID
  629. }
  630. }
  631. /**
  632. * 添加详细历史记录
  633. *
  634. * @param {element} e 子元素
  635. * @param {element} el 父亲元素
  636. * @param {object} data 数据
  637. */
  638. U.MD.O.W.Panel.AddDetailedHis = function (e, el, data) {
  639. var _conEl = e.lastElementChild,
  640. _hisInfoDate = $$('span', {
  641. innerText: U.UF.D.getDateInterval(new Date(parseInt(data.CreateTime.replace(/[^0-9]/ig, "")))) + '修改了一次',
  642. style: { 'padding-left': '10px' }
  643. }, _conEl.firstElementChild),
  644. _conText = $$('div', { innerHTML: data.OfficeContent }, _conEl)
  645. el.appendChild(e);
  646. }
  647. /**
  648. * 编辑历史弹出全部
  649. *
  650. */
  651. U.MD.O.W.Panel.EditHistoryc = function (UDE) {//此参数为历史记录的信息
  652. var _el = $$("div"),
  653. // _UCT = new U.UF.UI.form("<div _el='U_MD_F_S_TI'>历史记录</div>",_el,{"className": "Bjlsall", "style": {"width": "950px", "height": "550px","overflow": "hidden"} },{isdrag: false,isenlarge: false, isnarrow: false }, null, null, null, _UDTD);
  654. _UCT = new U.UF.UI.form("历史记录", _el, { className: 'Bjlsall', style: { width: "950px", height: "550px", overflow: "hidden" } }, { isdrag: false, isenlarge: false, isnarrow: false }, null, null, null);
  655. var i, _UDBD, _UDTD, _UDSD;
  656. for (var a = 0; a < UDE.length; a++) {//循环历史记录的长度 用来显示多个历史记录在"显示按钮"的打开的窗体上
  657. _UDBD = $$("div", { "className": "U_MD_O_W_History_all", "id": UDE[a].HistoryId + "-" + a }, _el);
  658. _UDTD = $$("div", { "className": "U_MD_O_W_History_Head" }, _UDBD);
  659. _UDBB = $$("div", {
  660. "className": "U_MD_O_H_body_btn",
  661. "innerHTML": "展开",
  662. "onclick": U.MD.O.W.Panel.btn
  663. },
  664. _UDBD);
  665. $$("div", { "className": "U_MD_O_H_body_btn_img1" }, _UDBB);
  666. $$("img",
  667. {
  668. "src": U.MD.C.getHeadImage(UDE[a].UserThumbnailImageHead),
  669. "onerror": U.MD.C.imgError,
  670. "alt": UDE[a].UserName,
  671. "title": UDE[a].UserName
  672. },
  673. _UDTD);
  674. $$("div", { "innerHTML": (UDE[a].UserNickName) + " " + U.UF.D.getDateInterval(UDE[a].CreateTime) + " 更改了以下内容" }, _UDTD);
  675. $$("div", { "className": "U_MD_O_H_body_right_user_o_r_all_nr", "innerHTML": UDE[a].OfficeContent }, _UDTD);
  676. }
  677. }
  678. /**
  679. * 点击显示全部
  680. *
  681. */
  682. U.MD.O.W.Panel.EditHistoryonc = function () {
  683. var _wordinfo = U.MD.O.W; //word全局变量 包含了uw文件的文件信息 等
  684. var _fileinfo = _wordinfo["fileinfo"]; //uw文件的文件信息
  685. var _fileid = _fileinfo.UserDirectoryID;
  686. var UDOD = $("#U_MD_O_H_body_left_invite_history")[0]; //历史记录框
  687. U.A.Request(US.CD, [US.DB, "UseStudio_Office", "SelectOfficeHistory", _fileid, "00000000-0000-0000-0000-000000000000", 1, 10], U.MD.O.W.Panel.OnDisplayD, [null, UDOD]); //
  688. }
  689. /**
  690. * 更新历史弹出全部
  691. *
  692. */
  693. U.MD.O.W.Panel.OnDisplayD = function (r) {
  694. if ($(".U_MD_O_H_body_right_user_o_r_all")) {//如果存在则删除
  695. $(".U_MD_O_H_body_right_user_o_r_all").remove();
  696. }
  697. divall = $$("div", { "className": "U_MD_O_H_body_right_user_o_r_all" }, r.context[1].parentNode.parentNode);
  698. $$("div",
  699. {
  700. "className": "U_MD_O_H_body_right_user_o_r_all_a",
  701. "innerHTML": "显示全部",
  702. "onclick": [U.MD.O.W.Panel.EditHistoryonc]
  703. },
  704. divall);
  705. U.MD.O.W.Panel.EditHistoryc(r.value);
  706. }
  707. /**
  708. * 编辑历史的展开与关闭
  709. *
  710. */
  711. U.MD.O.W.Panel.btn = function () {//编辑历史记录底端的显示全部的展开与关闭
  712. if (this.parentNode.children[0].lastChild.children[0].scrollHeight > 100) {//根据内容的高度来判断
  713. if (this.innerText == "展开") {
  714. this.innerHTML = "收起<div class='U_MD_O_H_body_btn_img2'></div>";
  715. this.parentNode.style.cssText = "height:100%;min-height:100px;overflow:visible;float:left;width:95%;"
  716. this.style.cssText = "margin-right:-7px;"
  717. }
  718. else if (this.innerText == "收起") {
  719. this.innerHTML = "展开<div class='U_MD_O_H_body_btn_img1'></div>";
  720. this.parentNode.style.cssText = "height:100px;overflow:hidden;float:none;width:none";
  721. this.style.cssText = "margin-right: 0px; "
  722. }
  723. } else {
  724. if (this.innerText == "展开") {
  725. this.innerHTML = "收起<div class='U_MD_O_H_body_btn_img2'></div>";
  726. this.parentNode.style.cssText = "height:100%;min-height:100px;overflow:visible;float:left;width:95%;"
  727. this.style.cssText = "margin-right:-7px;"
  728. }
  729. else if (this.innerText == "收起") {
  730. this.innerHTML = "展开<div class='U_MD_O_H_body_btn_img1'></div>";
  731. this.parentNode.style.cssText = "height:100px;overflow:hidden;";
  732. this.style.cssText = "margin-right: 0px;"
  733. }
  734. }
  735. }
  736. /**
  737. * 编辑历史弹出
  738. *
  739. */
  740. U.MD.O.W.Panel.EditHistory = function (UDE) {//此参数为历史记录的信息
  741. var _el = $$("div", { style: { cssText: "padding: 0 10px;" } }),
  742. _UCT = new U.UF.UI.form("历史记录", _el, { id: "Bjls", style: { width: "680px", height: "550px", overflow: "hidden", 'box-shadow': 'rgb(180, 180, 180) 1px 1px 5px 2px', 'border-radius': '0', 'border': 'none' } }, { isdrag: false, isenlarge: false, isnarrow: false }, { style: { 'background-color': '#3c475b', 'padding': '4px' } });
  743. if (UDE.OfficeContent == undefined) {
  744. U.A.Request(US.CD, [US.DB, "Usestudio_Office", "SelectHistoryDetails", UDE.HistoryId], function (r) {
  745. UDE.OfficeContent = r.value[0].OfficeContent.unEscapeQuotes().unEscapeQuotes();
  746. U.MD.O.W.Panel.AsynEditHistory(UDE, _el);
  747. }, [_el]);
  748. } else {
  749. U.MD.O.W.Panel.AsynEditHistory(UDE, _el);
  750. }
  751. }
  752. /**
  753. * 编辑历史弹出异步
  754. *
  755. */
  756. U.MD.O.W.Panel.AsynEditHistory = function (docinfo, element) {
  757. var _UDBD = $$("div", { "class": "U_MD_O_W_History" }, element);
  758. var _UDTD = $$("div", { "class": "U_MD_O_W_History_Head" }, element);
  759. $$("img",
  760. {
  761. "onerror": U.MD.C.imgError,
  762. "src": (top.U.MD.C.getHeadImage(docinfo.UserThumbnailImageHead) || 'http://www.1473.cn/img/UserHead/UseHead.jpg'),
  763. "alt": docinfo.UserNickName || docinfo.UserName,
  764. "title": docinfo.UserNickName || docinfo.UserName
  765. },
  766. _UDTD);
  767. $$("div", { "innerHTML": (docinfo.UserNickName || docinfo.UserName) + " " + U.UF.D.getDateInterval(docinfo.CreateTime || new Date()) + " 更改了以下内容", style: { cssText: "display: inline-block; margin-left:10px" } }, _UDTD);
  768. $$("div", { "className": "U_MD_O_H_body_right_user_o_r_nr", "innerHTML": docinfo.OfficeContent }, _UDTD);
  769. }
  770. //#endregion