cmsDocMobile.js 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516
  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. ], {"success": function(json_document, json_att){
  101. if (this.mask) this.mask.hide();
  102. if (json_document ){
  103. if( json_att && typeOf( json_att.data ) === "array" ){
  104. json_document.data.attachmentList = json_att.data ;
  105. }else{
  106. json_document.data.attachmentList = [];
  107. }
  108. this.parseData(json_document.data);
  109. if( !this.formId || this.formId==="" ){
  110. this.notice( this.document.categoryName + this.lp.formNotSetted , "error");
  111. }else{
  112. this.loadForm( this.formId );
  113. }
  114. }else{
  115. this.notice( this.lp.documentGettedError + ":" + error.responseText , "error");
  116. this.close();
  117. }
  118. }.bind(this), "failure": function(){
  119. this.notice( this.lp.documentGettedError + ":" + error.responseText , "error");
  120. this.close();
  121. }.bind(this)}, options.id);
  122. //this.action.getDocument( options.id, function(document){
  123. // if (this.mask) this.mask.hide();
  124. // this.parseData(document.data);
  125. // if( !this.formId || this.formId==="" ){
  126. // this.notice( this.document.categoryName + this.lp.formNotSetted , "error");
  127. // }else{
  128. // this.loadForm( this.formId );
  129. // }
  130. //}.bind(this), null);
  131. };
  132. //layout.loadDocument = function(options){
  133. // this.action.getDocument( options.id, function(document){
  134. // if (this.mask) this.mask.hide();
  135. // this.parseData(document.data);
  136. // this.action.getCategory( this.document.categoryId, function( js ){
  137. // this.categoryData = js.data;
  138. // var formId = this.categoryData.formId || this.categoryData.readFormId;
  139. // if( this.readonly == true && this.categoryData.readFormId && this.categoryData.readFormId != "" ){
  140. // formId = this.categoryData.readFormId;
  141. // }
  142. // if( !formId || formId=="" ){
  143. // this.notice( this.document.categoryName + this.lp.formNotSetted , "error");
  144. // }else{
  145. // this.loadForm( formId );
  146. // }
  147. // }.bind(this))
  148. // }.bind(this), null);
  149. //};
  150. layout.loadForm = function( formId ){
  151. this.action.getForm(formId, function( json ){
  152. //if (this.mask) this.mask.hide();
  153. this.form = (json.data.mobileData) ? JSON.decode(MWF.decodeJsonString(json.data.mobileData)): null;
  154. if( !this.form ){
  155. this.form = (json.data.data) ? JSON.decode(MWF.decodeJsonString(json.data.data)): null;
  156. }
  157. //this.listAttachment();
  158. if (this.mask) this.mask.hide();
  159. // this.attachmentList = [];
  160. this.openDocument();
  161. }.bind(this), function(error){
  162. if (this.mask) this.mask.hide();
  163. this.notice( this.lp.formGettedError + ":" + error.responseText , "error");
  164. //this.close();
  165. }.bind(this));
  166. };
  167. //layout.listAttachment = function(){
  168. // if( this.document.attachmentList && this.document.attachmentList.length > 0 ){
  169. // this.action.listAttachment(this.document.id, function( json ){
  170. // if (this.mask) this.mask.hide();
  171. // this.attachmentList = json.data;
  172. // this.attachmentList.each(function(att){
  173. // att.lastUpdateTime = att.updateTime;
  174. // att.person = att.creatorUid;
  175. // })
  176. // this.openDocument();
  177. // }.bind(this), function(error){
  178. // this.notice( this.lp.attachmentGettedError + ":" + error.responseText, "error");
  179. // this.close();
  180. // }.bind(this));
  181. // }else{
  182. // if (this.mask) this.mask.hide();
  183. // this.attachmentList = [];
  184. // this.openDocument();
  185. // }
  186. //},
  187. layout.errorDocument = function(){
  188. if (this.mask) this.mask.hide();
  189. this.node.set("text", "openError");
  190. };
  191. layout.parseData = function(data){
  192. // this.setTitle(this.options.title+"-"+data.work.title);
  193. data.document.subject = data.document.title;
  194. this.data = data.data;
  195. this.document = data.document;
  196. this.attachmentList = data.attachmentList || [];
  197. this.attachmentList.each(function(att){
  198. att.lastUpdateTime = att.updateTime;
  199. att.person = att.creatorUid;
  200. });
  201. //控制权限
  202. var isControl = false;
  203. if( data.isAppAdmin ){//应用管理员
  204. isControl = true;
  205. }
  206. if( data.isCategoryAdmin ){//分类管理员
  207. isControl = true;
  208. }
  209. if( data.isManager){//管理员
  210. isControl = true;
  211. }
  212. if( data.isCreator ){//创建者
  213. isControl = true;
  214. }
  215. if( data.isEditor ){ //编辑权限
  216. isControl = true;
  217. }
  218. // if( this.options.readonly ){ //强制只读
  219. // this.readonly = true;
  220. // }else{
  221. this.readonly = !(isControl && this.document.docStatus === "draft");
  222. // }
  223. this.formId = this.document.form || this.document.readFormId;
  224. if( this.readonly === true && this.document.readFormId && this.document.readFormId !== "" ){
  225. this.formId = this.document.readFormId; //阅读表单
  226. }else {
  227. this.formId = this.document.form;//编辑表单
  228. }
  229. this.control = data.control || {
  230. "allowRead": true,
  231. "allowPublishDocument": isControl && this.document.docStatus === "draft",
  232. "allowSave": isControl && this.document.docStatus === "published",
  233. "allowPopularDocument": false,
  234. "allowEditDocument": isControl ,
  235. "allowDeleteDocument": isControl ,
  236. "allowArchiveDocument" : false,
  237. "allowRedraftDocument" : false
  238. };
  239. };
  240. layout.openDocument = function(){
  241. if (this.form){
  242. MWF.xDesktop.requireApp("cms.Xform", "Form", function(){
  243. this.appForm = new MWF.CMSForm(this.node, this.form, {
  244. "readonly": this.readonly,
  245. "autoSave" : !this.readonly,
  246. "saveOnClose" : false,
  247. "showAttachment" : true,
  248. "onPostPublish" : null
  249. });
  250. this.appForm.businessData = {
  251. "data": this.data,
  252. "document": this.document,
  253. "control": this.control,
  254. "attachmentList": this.attachmentList,
  255. "status": {
  256. //"readonly": (this.options.readonly) ? true : false
  257. "readonly": this.readonly
  258. },
  259. //work.job 图片编辑器控件 使用上传图片到云盘的关联id
  260. "work": {
  261. "referencetype": "cmsDocument",
  262. "job": this.document.id
  263. }
  264. };
  265. this.appForm.documentAction = this.action;
  266. this.appForm.app = this;
  267. this.appForm.load(function(){
  268. console.log('加载表单完成。。。。。。。。。。。。。');
  269. //告诉移动端表单加载完成
  270. if (window.o2android && window.o2android.cmsFormLoaded){
  271. layout.appForm = this.appForm;
  272. window.o2android.cmsFormLoaded(JSON.stringify(this.control));
  273. }
  274. if (window.webkit && window.webkit.messageHandlers && window.webkit.messageHandlers.cmsFormLoaded){
  275. layout.appForm = this.appForm;
  276. window.webkit.messageHandlers.cmsFormLoaded.postMessage(JSON.stringify(this.control));
  277. }
  278. }.bind(this));
  279. }.bind(this));
  280. }
  281. };
  282. layout.isAuthentication = function(){
  283. layout.authentication = new MWF.xDesktop.Authentication({
  284. "onLogin": layout.load.bind(layout)
  285. });
  286. var returnValue = true;
  287. this.authentication.isAuthenticated(function(json){
  288. this.user = json.data;
  289. layout.session.user = json.data;
  290. }.bind(this), function(){
  291. // if (layout.config.loginPage && layout.config.loginPage.enable && layout.config.loginPage.portal){
  292. // MWF.xDesktop.loadPortal(layout.config.loginPage.portal);
  293. // }else{
  294. // this.authentication.loadLogin(document.body);
  295. // }
  296. this.authentication.loadLogin(this.node);
  297. returnValue = false;
  298. }.bind(this));
  299. return returnValue;
  300. };
  301. //layout.getServiceAddress = function(callback){
  302. // var host = layout.config.center.host || window.location.hostname;
  303. // var port = layout.config.center.port;
  304. // var uri = "";
  305. // if (!port || port=="80"){
  306. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  307. // }else{
  308. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  309. // }
  310. // var currenthost = window.location.hostname;
  311. // uri = uri.replace(/{source}/g, currenthost);
  312. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  313. // MWF.restful("get", uri, null, function(json){
  314. // this.serviceAddressList = json.data;
  315. // if (callback) callback();
  316. // }.bind(this));
  317. //};
  318. //layout.getServiceAddress = function(callback){
  319. // if (typeOf(layout.config.center)=="object"){
  320. // this.getServiceAddressConfigObject(callback);
  321. // }else if (typeOf(layout.config.center)=="array"){
  322. // this.getServiceAddressConfigArray(callback);
  323. // }
  324. //
  325. //};
  326. //layout.getServiceAddressConfigArray = function(callback) {
  327. // var requests = [];
  328. // layout.config.center.each(function(center){
  329. // requests.push(
  330. // this.getServiceAddressConfigObject(function(){
  331. // requests.each(function(res){
  332. // if (res.isRunning()){res.cancel();}
  333. // });
  334. // if (callback) callback();
  335. // }.bind(this), center)
  336. // );
  337. // }.bind(this));
  338. //};
  339. //layout.getServiceAddressConfigObject = function(callback, center){
  340. // var centerConfig = center;
  341. // if (!centerConfig) centerConfig = layout.config.center;
  342. // var host = centerConfig.host || window.location.hostname;
  343. // var port = centerConfig.port;
  344. // var uri = "";
  345. // if (!port || port=="80"){
  346. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  347. // }else{
  348. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  349. // }
  350. // var currenthost = window.location.hostname;
  351. // uri = uri.replace(/{source}/g, currenthost);
  352. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  353. // return MWF.restful("get", uri, null, function(json){
  354. // this.serviceAddressList = json.data;
  355. // this.centerServer = center;
  356. // if (callback) callback();
  357. // }.bind(this));
  358. //};
  359. layout.confirm = function(type, e, title, text, width, height, ok, cancel, callback, mask, style){
  360. MWF.require("MWF.xDesktop.Dialog", function(){
  361. var size = this.content.getSize();
  362. var x = 0;
  363. var y = 0;
  364. if (typeOf(e)=="element"){
  365. var position = e.getPosition(this.content);
  366. x = position.x;
  367. y = position.y;
  368. }else{
  369. if (Browser.name=="firefox"){
  370. x = parseFloat(e.event.clientX);
  371. y = parseFloat(e.event.clientY);
  372. }else{
  373. x = parseFloat(e.event.x);
  374. y = parseFloat(e.event.y);
  375. }
  376. // if (!x || !y){
  377. if (e.target){
  378. var position = e.target.getPosition(this.content);
  379. x = position.x;
  380. y = position.y;
  381. }
  382. // }
  383. }
  384. if (x+parseFloat(width)>size.x){
  385. x = x-parseFloat(width);
  386. }
  387. if (x<0) x = 0;
  388. if (y+parseFloat(height)>size.y){
  389. y = y-parseFloat(height);
  390. }
  391. if (y<0) y = 0;
  392. var ctext = "";
  393. var chtml = "";
  394. if (typeOf(text).toLowerCase()=="object"){
  395. ctext = text.text;
  396. chtml = text.html;
  397. }else{
  398. ctext = text;
  399. }
  400. var dlg = new MWF.xDesktop.Dialog({
  401. "title": title,
  402. "style": style || "flat",
  403. "top": y,
  404. "left": x-20,
  405. "fromTop":y,
  406. "fromLeft": x-20,
  407. "width": width,
  408. "height": height,
  409. "text": ctext,
  410. "html": chtml,
  411. "container": this.content,
  412. "maskNode": mask,
  413. "buttonList": [
  414. {
  415. "text": MWF.LP.process.button.ok,
  416. "action": ok
  417. },
  418. {
  419. "text": MWF.LP.process.button.cancel,
  420. "action": cancel
  421. }
  422. ]
  423. });
  424. switch (type.toLowerCase()){
  425. case "success":
  426. dlg.content.setStyle("background-image", "url()");
  427. break;
  428. case "error":
  429. dlg.content.setStyle("background-image", "url()");
  430. break;
  431. case "info":
  432. dlg.content.setStyle("background-image", "url()");
  433. break;
  434. case "warn":
  435. dlg.content.setStyle("background-image", "url()");
  436. break;
  437. default:
  438. //dlg.content.setStyle("background-image", "");
  439. }
  440. dlg.show();
  441. if (callback) callback(dlg);
  442. }.bind(this));
  443. };
  444. layout.notice = function(content, type, target, where, offset){
  445. if (!where) where = {"x": "right", "y": "top"};
  446. if (!target) target = this.content;
  447. if (!type) type = "ok";
  448. var noticeTarget = target || $(document.body);
  449. var off = offset;
  450. if (!off){
  451. off = {
  452. x: 10,
  453. y: where.y.toString().toLowerCase()=="bottom" ? 10 : 10
  454. };
  455. }
  456. new mBox.Notice({
  457. type: type,
  458. position: where,
  459. move: false,
  460. target: noticeTarget,
  461. delayClose: (type=="error") ? 10000 : 5000,
  462. offset: off,
  463. content: content
  464. });
  465. };
  466. layout.reload = function(){
  467. window.location.reload();
  468. };
  469. MWF.getJSON("res/config/config.json", function(config){
  470. layout.config = config;
  471. MWF.xDesktop.getServiceAddress(layout.config, function(service, center){
  472. layout.serviceAddressList = service;
  473. layout.centerServer = center;
  474. layout.load();
  475. }.bind(this));
  476. //layout.getServiceAddress(function(){
  477. // layout.load();
  478. //});
  479. });
  480. })();
  481. });
  482. });
  483. });