cmsDocMobile.js 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535
  1. layout = window.layout || {};
  2. var locate = window.location;
  3. layout.protocol = locate.protocol;
  4. layout.mobile = true;
  5. layout.desktop = layout;
  6. layout.session = layout.session || {};
  7. var href = locate.href;
  8. if (href.indexOf("debugger") != -1) layout.debugger = true;
  9. o2.addReady(function () {
  10. o2.load(["../o2_lib/mootools/plugin/mBox.Notice.js", "../o2_lib/mootools/plugin/mBox.Tooltip.js"], { "sequence": true }, function () {
  11. //MWF.defaultPath = "../x_desktop"+MWF.defaultPath;
  12. MWF.loadLP("zh-cn");
  13. MWF.require("MWF.xDesktop.Common", null, false);
  14. MWF.require("MWF.widget.Mask", null, false);
  15. //修改支持x-token
  16. var uri = new URI(window.location.href);
  17. var options = uri.get("data");
  18. if (options["x-token"]) {
  19. Cookie.write("x-token", options["x-token"]);
  20. }
  21. layout.mask = new MWF.widget.Mask({ "style": "desktop" });
  22. layout.mask.load();
  23. MWF.require("MWF.xDesktop.Layout", function () {
  24. MWF.require("MWF.xDesktop.Authentication", null, false);
  25. MWF.require("MWF.xAction.RestActions", null, false);
  26. (function () {
  27. layout.load = function () {
  28. if (this.isAuthentication()) {
  29. //var preview = window.frameElement.retrieve("preview");
  30. //layout.desktop = window.frameElement.ownerDocument.window.layout.desktop;
  31. //
  32. this.node = $("appContent")||$("layout");
  33. this.content = $(document.body);
  34. this.path = "../x_component_cms_Document/$Main/";
  35. this.cssPath = "../x_component_cms_Document/$Main/default/css.wcss";
  36. this._loadCss();
  37. // MWF.require("MWF.xDesktop.MessageMobile", function(){
  38. // layout.message = new MWF.xDesktop.MessageMobile();
  39. // layout.message.load();
  40. // }.bind(this));
  41. //MWF.xDesktop.requireApp("cms.Document", "Actions.RestActions", null, false);
  42. //this.action = new MWF.xApplication.cms.Document.Actions.RestActions();
  43. this.action = MWF.Actions.get("x_cms_assemble_control");
  44. MWF.xDesktop.requireApp("cms.Document", "lp." + MWF.language, null, false);
  45. //MWF.xDesktop.requireApp("cms.Document", "lp."+MWF.language, {
  46. // "onRequestFailure": function(){
  47. // MWF.xDesktop.requireApp("cms.Document", "lp.zh-cn", null, false);
  48. // }.bind(this),
  49. // "onSuccess": function(){}.bind(this)
  50. //}, false);
  51. this.lp = MWF.xApplication.cms.Document.LP;
  52. this.options = this.getIds();
  53. this.options.name = "cms.Document";
  54. this.loadDocument(this.options);
  55. //MWF.require("MWF.xApplication.process.Xform.Form", function(){
  56. // layout.appForm = new MWF.APPForm($("layout"), preview.data);
  57. // layout.appForm.load();
  58. //});
  59. }
  60. };
  61. layout.addEvent = function () { };
  62. layout.close = function () {
  63. if (window.o2android && window.o2android.closeDocumentWindow) {
  64. window.o2android.closeDocumentWindow('close');
  65. }
  66. if (window.webkit && window.webkit.messageHandlers && window.webkit.messageHandlers.closeDocumentWindow) {
  67. window.webkit.messageHandlers.closeDocumentWindow.postMessage('close');
  68. }
  69. };
  70. layout._loadCss = function () {
  71. var key = encodeURIComponent(this.cssPath);
  72. if (MWF.widget.css[key]) {
  73. this.css = MWF.widget.css[key];
  74. } else {
  75. var r = new Request.JSON({
  76. url: this.cssPath,
  77. secure: false,
  78. async: false,
  79. method: "get",
  80. noCache: false,
  81. onSuccess: function (responseJSON, responseText) {
  82. this.css = responseJSON;
  83. MWF.widget.css[key] = responseJSON;
  84. }.bind(this),
  85. onError: function (text, error) {
  86. alert(error + text);
  87. }
  88. });
  89. r.send();
  90. }
  91. };
  92. layout.getIds = function () {
  93. var href = window.location.href;
  94. var qStr = href.substr(href.indexOf("?") + 1, href.length);
  95. var qDatas = qStr.split("&");
  96. var obj = {};
  97. qDatas.each(function (d) {
  98. var q = d.split("=");
  99. obj[q[0].toLowerCase()] = q[1];
  100. });
  101. return obj;
  102. };
  103. layout.loadDocument = function (options) {
  104. // this.action.viewDocument( options.id, function(document){
  105. o2.Actions.invokeAsync([
  106. { "action": this.action, "name": "getDocument" },
  107. { "action": this.action, "name": "listAttachment" }
  108. ], {
  109. "success": function (json_document, json_att) {
  110. if (this.mask) this.mask.hide();
  111. if (json_document) {
  112. if (json_att && typeOf(json_att.data) === "array") {
  113. json_document.data.attachmentList = json_att.data;
  114. } else {
  115. json_document.data.attachmentList = [];
  116. }
  117. this.parseData(json_document.data);
  118. if (!this.formId || this.formId === "") {
  119. this.notice(this.document.categoryName + this.lp.formNotSetted, "error");
  120. } else {
  121. this.loadForm(this.formId);
  122. }
  123. } else {
  124. this.notice(this.lp.documentGettedError + ":" + error.responseText, "error");
  125. this.close();
  126. }
  127. }.bind(this), "failure": function () {
  128. this.notice(this.lp.documentGettedError + ":" + error.responseText, "error");
  129. this.close();
  130. }.bind(this)
  131. }, options.id);
  132. //this.action.getDocument( options.id, function(document){
  133. // if (this.mask) this.mask.hide();
  134. // this.parseData(document.data);
  135. // if( !this.formId || this.formId==="" ){
  136. // this.notice( this.document.categoryName + this.lp.formNotSetted , "error");
  137. // }else{
  138. // this.loadForm( this.formId );
  139. // }
  140. //}.bind(this), null);
  141. };
  142. //layout.loadDocument = function(options){
  143. // this.action.getDocument( options.id, function(document){
  144. // if (this.mask) this.mask.hide();
  145. // this.parseData(document.data);
  146. // this.action.getCategory( this.document.categoryId, function( js ){
  147. // this.categoryData = js.data;
  148. // var formId = this.categoryData.formId || this.categoryData.readFormId;
  149. // if( this.readonly == true && this.categoryData.readFormId && this.categoryData.readFormId != "" ){
  150. // formId = this.categoryData.readFormId;
  151. // }
  152. // if( !formId || formId=="" ){
  153. // this.notice( this.document.categoryName + this.lp.formNotSetted , "error");
  154. // }else{
  155. // this.loadForm( formId );
  156. // }
  157. // }.bind(this))
  158. // }.bind(this), null);
  159. //};
  160. layout.loadForm = function (formId) {
  161. this.action.getForm(formId, function (json) {
  162. //if (this.mask) this.mask.hide();
  163. this.form = (json.data.mobileData) ? JSON.decode(MWF.decodeJsonString(json.data.mobileData)) : null;
  164. if (!this.form) {
  165. this.form = (json.data.data) ? JSON.decode(MWF.decodeJsonString(json.data.data)) : null;
  166. }
  167. //this.listAttachment();
  168. if (this.mask) this.mask.hide();
  169. // this.attachmentList = [];
  170. this.openDocument();
  171. }.bind(this), function (error) {
  172. if (this.mask) this.mask.hide();
  173. this.notice(this.lp.formGettedError + ":" + error.responseText, "error");
  174. //this.close();
  175. }.bind(this));
  176. };
  177. //layout.listAttachment = function(){
  178. // if( this.document.attachmentList && this.document.attachmentList.length > 0 ){
  179. // this.action.listAttachment(this.document.id, function( json ){
  180. // if (this.mask) this.mask.hide();
  181. // this.attachmentList = json.data;
  182. // this.attachmentList.each(function(att){
  183. // att.lastUpdateTime = att.updateTime;
  184. // att.person = att.creatorUid;
  185. // })
  186. // this.openDocument();
  187. // }.bind(this), function(error){
  188. // this.notice( this.lp.attachmentGettedError + ":" + error.responseText, "error");
  189. // this.close();
  190. // }.bind(this));
  191. // }else{
  192. // if (this.mask) this.mask.hide();
  193. // this.attachmentList = [];
  194. // this.openDocument();
  195. // }
  196. //},
  197. layout.errorDocument = function () {
  198. if (this.mask) this.mask.hide();
  199. this.node.set("text", "openError");
  200. };
  201. layout.parseData = function (data) {
  202. window.document.title = data.document.title;
  203. data.document.subject = data.document.title;
  204. this.data = data.data;
  205. this.document = data.document;
  206. this.attachmentList = data.attachmentList || [];
  207. this.attachmentList.each(function (att) {
  208. att.lastUpdateTime = att.updateTime;
  209. att.person = att.creatorUid;
  210. });
  211. //控制权限
  212. var isControl = false;
  213. if (data.isAppAdmin) {//应用管理员
  214. isControl = true;
  215. }
  216. if (data.isCategoryAdmin) {//分类管理员
  217. isControl = true;
  218. }
  219. if (data.isManager) {//管理员
  220. isControl = true;
  221. }
  222. if (data.isCreator) {//创建者
  223. isControl = true;
  224. }
  225. if (data.isEditor) { //编辑权限
  226. isControl = true;
  227. }
  228. if (this.options.readonly === false) {
  229. this.readonly = false;
  230. } else {
  231. this.readonly = true;
  232. if (this.document.docStatus === "draft") {
  233. this.readonly = false
  234. }
  235. }
  236. this.formId = this.document.form || this.document.readFormId;
  237. //当前模式 阅读还是编辑 移动端上使用
  238. var currentMode = "read";
  239. if (this.readonly === true && this.document.readFormId && this.document.readFormId !== "") {
  240. this.formId = this.document.readFormId; //阅读表单
  241. currentMode = "read";
  242. } else {
  243. this.formId = this.document.form;//编辑表单
  244. currentMode = "edit";
  245. }
  246. this.control = data.control || {
  247. "allowRead": true,
  248. "allowPublishDocument": isControl && this.document.docStatus === "draft",
  249. "allowSave": isControl && this.document.docStatus === "published",
  250. "allowPopularDocument": false,
  251. "allowEditDocument": isControl,
  252. "allowDeleteDocument": isControl,
  253. "allowArchiveDocument": false,
  254. "allowRedraftDocument": false,
  255. "currentMode": currentMode
  256. };
  257. };
  258. layout.openDocument = function () {
  259. if (this.form) {
  260. MWF.xDesktop.requireApp("cms.Xform", "Form", function () {
  261. this.appForm = new MWF.CMSForm(this.node, this.form, {
  262. "readonly": this.readonly,
  263. "autoSave": !this.readonly,
  264. "saveOnClose": false,
  265. "showAttachment": true,
  266. "onPostPublish": null
  267. });
  268. this.appForm.businessData = {
  269. "data": this.data,
  270. "document": this.document,
  271. "control": this.control,
  272. "attachmentList": this.attachmentList,
  273. "status": {
  274. //"readonly": (this.options.readonly) ? true : false
  275. "readonly": this.readonly
  276. },
  277. //work.job 图片编辑器控件 使用上传图片到云盘的关联id
  278. "work": {
  279. "referencetype": "cmsDocument",
  280. "job": this.document.id
  281. }
  282. };
  283. this.appForm.documentAction = this.action;
  284. this.appForm.app = this;
  285. this.appForm.load(function () {
  286. console.log('加载表单完成。。。。。。。。。。。。。');
  287. //告诉移动端表单加载完成
  288. if (window.o2android && window.o2android.cmsFormLoaded) {
  289. layout.appForm = this.appForm;
  290. window.o2android.cmsFormLoaded(JSON.stringify(this.control));
  291. }
  292. if (window.webkit && window.webkit.messageHandlers && window.webkit.messageHandlers.cmsFormLoaded) {
  293. layout.appForm = this.appForm;
  294. window.webkit.messageHandlers.cmsFormLoaded.postMessage(JSON.stringify(this.control));
  295. }
  296. }.bind(this));
  297. }.bind(this));
  298. }
  299. };
  300. layout.isAuthentication = function () {
  301. layout.authentication = new MWF.xDesktop.Authentication({
  302. "onLogin": layout.load.bind(layout)
  303. });
  304. var returnValue = true;
  305. this.authentication.isAuthenticated(function (json) {
  306. this.user = json.data;
  307. layout.session.user = json.data;
  308. }.bind(this), function () {
  309. // if (layout.config.loginPage && layout.config.loginPage.enable && layout.config.loginPage.portal){
  310. // MWF.xDesktop.loadPortal(layout.config.loginPage.portal);
  311. // }else{
  312. // this.authentication.loadLogin(document.body);
  313. // }
  314. this.authentication.loadLogin(this.node);
  315. returnValue = false;
  316. }.bind(this));
  317. return returnValue;
  318. };
  319. //layout.getServiceAddress = function(callback){
  320. // var host = layout.config.center.host || window.location.hostname;
  321. // var port = layout.config.center.port;
  322. // var uri = "";
  323. // if (!port || port=="80"){
  324. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  325. // }else{
  326. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  327. // }
  328. // var currenthost = window.location.hostname;
  329. // uri = uri.replace(/{source}/g, currenthost);
  330. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  331. // MWF.restful("get", uri, null, function(json){
  332. // this.serviceAddressList = json.data;
  333. // if (callback) callback();
  334. // }.bind(this));
  335. //};
  336. //layout.getServiceAddress = function(callback){
  337. // if (typeOf(layout.config.center)=="object"){
  338. // this.getServiceAddressConfigObject(callback);
  339. // }else if (typeOf(layout.config.center)=="array"){
  340. // this.getServiceAddressConfigArray(callback);
  341. // }
  342. //
  343. //};
  344. //layout.getServiceAddressConfigArray = function(callback) {
  345. // var requests = [];
  346. // layout.config.center.each(function(center){
  347. // requests.push(
  348. // this.getServiceAddressConfigObject(function(){
  349. // requests.each(function(res){
  350. // if (res.isRunning()){res.cancel();}
  351. // });
  352. // if (callback) callback();
  353. // }.bind(this), center)
  354. // );
  355. // }.bind(this));
  356. //};
  357. //layout.getServiceAddressConfigObject = function(callback, center){
  358. // var centerConfig = center;
  359. // if (!centerConfig) centerConfig = layout.config.center;
  360. // var host = centerConfig.host || window.location.hostname;
  361. // var port = centerConfig.port;
  362. // var uri = "";
  363. // if (!port || port=="80"){
  364. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  365. // }else{
  366. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  367. // }
  368. // var currenthost = window.location.hostname;
  369. // uri = uri.replace(/{source}/g, currenthost);
  370. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  371. // return MWF.restful("get", uri, null, function(json){
  372. // this.serviceAddressList = json.data;
  373. // this.centerServer = center;
  374. // if (callback) callback();
  375. // }.bind(this));
  376. //};
  377. layout.confirm = function (type, e, title, text, width, height, ok, cancel, callback, mask, style) {
  378. MWF.require("MWF.xDesktop.Dialog", function () {
  379. var size = this.content.getSize();
  380. var x = 0;
  381. var y = 0;
  382. if (typeOf(e) == "element") {
  383. var position = e.getPosition(this.content);
  384. x = position.x;
  385. y = position.y;
  386. } else {
  387. if (Browser.name == "firefox") {
  388. x = parseFloat(e.event.clientX);
  389. y = parseFloat(e.event.clientY);
  390. } else {
  391. x = parseFloat(e.event.x);
  392. y = parseFloat(e.event.y);
  393. }
  394. // if (!x || !y){
  395. if (e.target) {
  396. var position = e.target.getPosition(this.content);
  397. x = position.x;
  398. y = position.y;
  399. }
  400. // }
  401. }
  402. if (x + parseFloat(width) > size.x) {
  403. x = x - parseFloat(width);
  404. }
  405. if (x < 0) x = 0;
  406. if (y + parseFloat(height) > size.y) {
  407. y = y - parseFloat(height);
  408. }
  409. if (y < 0) y = 0;
  410. var ctext = "";
  411. var chtml = "";
  412. if (typeOf(text).toLowerCase() == "object") {
  413. ctext = text.text;
  414. chtml = text.html;
  415. } else {
  416. ctext = text;
  417. }
  418. var dlg = new MWF.xDesktop.Dialog({
  419. "title": title,
  420. "style": style || "flat",
  421. "top": y,
  422. "left": x - 20,
  423. "fromTop": y,
  424. "fromLeft": x - 20,
  425. "width": width,
  426. "height": height,
  427. "text": ctext,
  428. "html": chtml,
  429. "container": this.content,
  430. "maskNode": mask,
  431. "buttonList": [
  432. {
  433. "text": MWF.LP.process.button.ok,
  434. "action": ok
  435. },
  436. {
  437. "text": MWF.LP.process.button.cancel,
  438. "action": cancel
  439. }
  440. ]
  441. });
  442. switch (type.toLowerCase()) {
  443. case "success":
  444. dlg.content.setStyle("background-image", "url()");
  445. break;
  446. case "error":
  447. dlg.content.setStyle("background-image", "url()");
  448. break;
  449. case "info":
  450. dlg.content.setStyle("background-image", "url()");
  451. break;
  452. case "warn":
  453. dlg.content.setStyle("background-image", "url()");
  454. break;
  455. default:
  456. //dlg.content.setStyle("background-image", "");
  457. }
  458. dlg.show();
  459. if (callback) callback(dlg);
  460. }.bind(this));
  461. };
  462. layout.notice = function (content, type, target, where, offset) {
  463. if (!where) where = { "x": "right", "y": "top" };
  464. if (!target) target = this.content;
  465. if (!type) type = "ok";
  466. var noticeTarget = target || $(document.body);
  467. var off = offset;
  468. if (!off) {
  469. off = {
  470. x: 10,
  471. y: where.y.toString().toLowerCase() == "bottom" ? 10 : 10
  472. };
  473. }
  474. new mBox.Notice({
  475. type: type,
  476. position: where,
  477. move: false,
  478. target: noticeTarget,
  479. delayClose: (type == "error") ? 10000 : 5000,
  480. offset: off,
  481. content: content
  482. });
  483. };
  484. layout.reload = function () {
  485. window.location.reload();
  486. };
  487. MWF.getJSON("res/config/config.json", function (config) {
  488. layout.config = config;
  489. MWF.xDesktop.getServiceAddress(layout.config, function (service, center) {
  490. layout.serviceAddressList = service;
  491. layout.centerServer = center;
  492. layout.load();
  493. }.bind(this));
  494. //layout.getServiceAddress(function(){
  495. // layout.load();
  496. //});
  497. });
  498. })();
  499. });
  500. });
  501. });