cmsDocMobile.js 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442
  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.close = function(){
  54. $(document.body).addEvent("click", function(){window.close();});
  55. };
  56. layout._loadCss = function(){
  57. var key = encodeURIComponent(this.cssPath);
  58. if (MWF.widget.css[key]){
  59. this.css = MWF.widget.css[key];
  60. }else{
  61. var r = new Request.JSON({
  62. url: this.cssPath,
  63. secure: false,
  64. async: false,
  65. method: "get",
  66. noCache: false,
  67. onSuccess: function(responseJSON, responseText){
  68. this.css = responseJSON;
  69. MWF.widget.css[key] = responseJSON;
  70. }.bind(this),
  71. onError: function(text, error){
  72. alert(error + text);
  73. }
  74. });
  75. r.send();
  76. }
  77. };
  78. layout.getIds = function(){
  79. var href = window.location.href;
  80. var qStr = href.substr(href.indexOf("?")+1, href.length);
  81. var qDatas = qStr.split("&");
  82. var obj = {};
  83. qDatas.each(function(d){
  84. var q = d.split("=");
  85. obj[q[0].toLowerCase()] = q[1];
  86. });
  87. return obj;
  88. };
  89. layout.loadDocument = function(options){
  90. this.action.viewDocument( options.id, function(document){
  91. if (this.mask) this.mask.hide();
  92. this.parseData(document.data);
  93. if( !this.formId || this.formId=="" ){
  94. this.notice( this.document.categoryName + this.lp.formNotSetted , "error");
  95. }else{
  96. this.loadForm( this.formId );
  97. }
  98. }.bind(this), null);
  99. };
  100. //layout.loadDocument = function(options){
  101. // this.action.getDocument( options.id, function(document){
  102. // if (this.mask) this.mask.hide();
  103. // this.parseData(document.data);
  104. // this.action.getCategory( this.document.categoryId, function( js ){
  105. // this.categoryData = js.data;
  106. // var formId = this.categoryData.formId || this.categoryData.readFormId;
  107. // if( this.readonly == true && this.categoryData.readFormId && this.categoryData.readFormId != "" ){
  108. // formId = this.categoryData.readFormId;
  109. // }
  110. // if( !formId || formId=="" ){
  111. // this.notice( this.document.categoryName + this.lp.formNotSetted , "error");
  112. // }else{
  113. // this.loadForm( formId );
  114. // }
  115. // }.bind(this))
  116. // }.bind(this), null);
  117. //};
  118. layout.loadForm = function( formId ){
  119. this.action.getForm(formId, function( json ){
  120. //if (this.mask) this.mask.hide();
  121. this.form = (json.data.mobileData) ? JSON.decode(MWF.decodeJsonString(json.data.mobileData)): null;
  122. if( !this.form ){
  123. this.form = (json.data.data) ? JSON.decode(MWF.decodeJsonString(json.data.data)): null;
  124. }
  125. //this.listAttachment();
  126. if (this.mask) this.mask.hide();
  127. this.attachmentList = [];
  128. this.openDocument();
  129. }.bind(this), function(error){
  130. if (this.mask) this.mask.hide();
  131. this.notice( this.lp.formGettedError + ":" + error.responseText , "error");
  132. //this.close();
  133. }.bind(this));
  134. };
  135. //layout.listAttachment = function(){
  136. // if( this.document.attachmentList && this.document.attachmentList.length > 0 ){
  137. // this.action.listAttachment(this.document.id, function( json ){
  138. // if (this.mask) this.mask.hide();
  139. // this.attachmentList = json.data;
  140. // this.attachmentList.each(function(att){
  141. // att.lastUpdateTime = att.updateTime;
  142. // att.person = att.creatorUid;
  143. // })
  144. // this.openDocument();
  145. // }.bind(this), function(error){
  146. // this.notice( this.lp.attachmentGettedError + ":" + error.responseText, "error");
  147. // this.close();
  148. // }.bind(this));
  149. // }else{
  150. // if (this.mask) this.mask.hide();
  151. // this.attachmentList = [];
  152. // this.openDocument();
  153. // }
  154. //},
  155. layout.errorDocument = function(){
  156. if (this.mask) this.mask.hide();
  157. this.node.set("text", "openError");
  158. };
  159. layout.parseData = function(data){
  160. // this.setTitle(this.options.title+"-"+data.work.title);
  161. data.document.subject = data.document.title;
  162. this.data = data.data;
  163. this.document = data.document;
  164. this.attachmentList = data.attachmentList || [];
  165. this.attachmentList.each(function(att){
  166. att.lastUpdateTime = att.updateTime;
  167. att.person = att.creatorUid;
  168. });
  169. this.readonly = true;
  170. this.formId = this.document.form || this.document.readFormId;
  171. if( this.readonly == true && this.document.readFormId && this.document.readFormId != "" ){
  172. this.formId = this.document.readFormId;
  173. }
  174. this.control = data.control || {
  175. "allowRead": true,
  176. "allowPublishDocument": false,
  177. "allowArchiveDocument" : false,
  178. "allowRedraftDocument" : false,
  179. "allowSave": false,
  180. "allowPopularDocument": false,
  181. "allowEditDocument": false,
  182. "allowDeleteDocument": false
  183. };
  184. };
  185. layout.openDocument = function(){
  186. if (this.form){
  187. MWF.xDesktop.requireApp("cms.Xform", "Form", function(){
  188. this.appForm = new MWF.CMSForm(this.node, this.form, {
  189. "readonly": this.readonly,
  190. "autoSave" : false,
  191. "saveOnClose" : false,
  192. "showAttachment" : false,
  193. "onPostPublish" : null
  194. });
  195. this.appForm.businessData = {
  196. "data": this.data,
  197. "document": this.document,
  198. "control": this.control,
  199. "attachmentList": this.attachmentList,
  200. "status": {
  201. //"readonly": (this.options.readonly) ? true : false
  202. "readonly": this.readonly
  203. }
  204. };
  205. this.appForm.documentAction = this.action;
  206. this.appForm.app = this;
  207. this.appForm.load();
  208. }.bind(this));
  209. }
  210. };
  211. layout.isAuthentication = function(){
  212. layout.authentication = new MWF.xDesktop.Authentication({
  213. "onLogin": layout.load.bind(layout)
  214. });
  215. var returnValue = true;
  216. this.authentication.isAuthenticated(function(json){
  217. this.user = json.data;
  218. layout.session.user = json.data;
  219. }.bind(this), function(){
  220. // if (layout.config.loginPage && layout.config.loginPage.enable && layout.config.loginPage.portal){
  221. // MWF.xDesktop.loadPortal(layout.config.loginPage.portal);
  222. // }else{
  223. // this.authentication.loadLogin(document.body);
  224. // }
  225. this.authentication.loadLogin(this.node);
  226. returnValue = false;
  227. }.bind(this));
  228. return returnValue;
  229. };
  230. //layout.getServiceAddress = function(callback){
  231. // var host = layout.config.center.host || window.location.hostname;
  232. // var port = layout.config.center.port;
  233. // var uri = "";
  234. // if (!port || port=="80"){
  235. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  236. // }else{
  237. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  238. // }
  239. // var currenthost = window.location.hostname;
  240. // uri = uri.replace(/{source}/g, currenthost);
  241. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  242. // MWF.restful("get", uri, null, function(json){
  243. // this.serviceAddressList = json.data;
  244. // if (callback) callback();
  245. // }.bind(this));
  246. //};
  247. //layout.getServiceAddress = function(callback){
  248. // if (typeOf(layout.config.center)=="object"){
  249. // this.getServiceAddressConfigObject(callback);
  250. // }else if (typeOf(layout.config.center)=="array"){
  251. // this.getServiceAddressConfigArray(callback);
  252. // }
  253. //
  254. //};
  255. //layout.getServiceAddressConfigArray = function(callback) {
  256. // var requests = [];
  257. // layout.config.center.each(function(center){
  258. // requests.push(
  259. // this.getServiceAddressConfigObject(function(){
  260. // requests.each(function(res){
  261. // if (res.isRunning()){res.cancel();}
  262. // });
  263. // if (callback) callback();
  264. // }.bind(this), center)
  265. // );
  266. // }.bind(this));
  267. //};
  268. //layout.getServiceAddressConfigObject = function(callback, center){
  269. // var centerConfig = center;
  270. // if (!centerConfig) centerConfig = layout.config.center;
  271. // var host = centerConfig.host || window.location.hostname;
  272. // var port = centerConfig.port;
  273. // var uri = "";
  274. // if (!port || port=="80"){
  275. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  276. // }else{
  277. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  278. // }
  279. // var currenthost = window.location.hostname;
  280. // uri = uri.replace(/{source}/g, currenthost);
  281. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  282. // return MWF.restful("get", uri, null, function(json){
  283. // this.serviceAddressList = json.data;
  284. // this.centerServer = center;
  285. // if (callback) callback();
  286. // }.bind(this));
  287. //};
  288. layout.confirm = function(type, e, title, text, width, height, ok, cancel, callback, mask, style){
  289. MWF.require("MWF.xDesktop.Dialog", function(){
  290. var size = this.content.getSize();
  291. var x = 0;
  292. var y = 0;
  293. if (typeOf(e)=="element"){
  294. var position = e.getPosition(this.content);
  295. x = position.x;
  296. y = position.y;
  297. }else{
  298. if (Browser.name=="firefox"){
  299. x = parseFloat(e.event.clientX);
  300. y = parseFloat(e.event.clientY);
  301. }else{
  302. x = parseFloat(e.event.x);
  303. y = parseFloat(e.event.y);
  304. }
  305. // if (!x || !y){
  306. if (e.target){
  307. var position = e.target.getPosition(this.content);
  308. x = position.x;
  309. y = position.y;
  310. }
  311. // }
  312. }
  313. if (x+parseFloat(width)>size.x){
  314. x = x-parseFloat(width);
  315. }
  316. if (x<0) x = 0;
  317. if (y+parseFloat(height)>size.y){
  318. y = y-parseFloat(height);
  319. }
  320. if (y<0) y = 0;
  321. var ctext = "";
  322. var chtml = "";
  323. if (typeOf(text).toLowerCase()=="object"){
  324. ctext = text.text;
  325. chtml = text.html;
  326. }else{
  327. ctext = text;
  328. }
  329. var dlg = new MWF.xDesktop.Dialog({
  330. "title": title,
  331. "style": style || "flat",
  332. "top": y,
  333. "left": x-20,
  334. "fromTop":y,
  335. "fromLeft": x-20,
  336. "width": width,
  337. "height": height,
  338. "text": ctext,
  339. "html": chtml,
  340. "container": this.content,
  341. "maskNode": mask,
  342. "buttonList": [
  343. {
  344. "text": MWF.LP.process.button.ok,
  345. "action": ok
  346. },
  347. {
  348. "text": MWF.LP.process.button.cancel,
  349. "action": cancel
  350. }
  351. ]
  352. });
  353. switch (type.toLowerCase()){
  354. case "success":
  355. dlg.content.setStyle("background-image", "url()");
  356. break;
  357. case "error":
  358. dlg.content.setStyle("background-image", "url()");
  359. break;
  360. case "info":
  361. dlg.content.setStyle("background-image", "url()");
  362. break;
  363. case "warn":
  364. dlg.content.setStyle("background-image", "url()");
  365. break;
  366. default:
  367. //dlg.content.setStyle("background-image", "");
  368. }
  369. dlg.show();
  370. if (callback) callback(dlg);
  371. }.bind(this));
  372. };
  373. layout.notice = function(content, type, target, where, offset){
  374. if (!where) where = {"x": "right", "y": "top"};
  375. if (!target) target = this.content;
  376. if (!type) type = "ok";
  377. var noticeTarget = target || $(document.body);
  378. var off = offset;
  379. if (!off){
  380. off = {
  381. x: 10,
  382. y: where.y.toString().toLowerCase()=="bottom" ? 10 : 10
  383. };
  384. }
  385. new mBox.Notice({
  386. type: type,
  387. position: where,
  388. move: false,
  389. target: noticeTarget,
  390. delayClose: (type=="error") ? 10000 : 5000,
  391. offset: off,
  392. content: content
  393. });
  394. };
  395. layout.reload = function(){
  396. window.location.reload();
  397. };
  398. MWF.getJSON("res/config/config.json", function(config){
  399. layout.config = config;
  400. MWF.xDesktop.getServiceAddress(layout.config, function(service, center){
  401. layout.serviceAddressList = service;
  402. layout.centerServer = center;
  403. layout.load();
  404. }.bind(this));
  405. //layout.getServiceAddress(function(){
  406. // layout.load();
  407. //});
  408. });
  409. })();
  410. });
  411. });
  412. });