cmsDocMobile.js 33 KB

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