cmsDocMobile.js 36 KB

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