workmobilewithaction.js 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553
  1. layout = window.layout || {};
  2. var locate = window.location;
  3. layout.protocol = locate.protocol;
  4. var href = locate.href;
  5. if (href.indexOf("debugger")!=-1) layout.debugger = true;
  6. layout.mobile = true;
  7. layout.desktop = layout;
  8. layout.desktop.session = {};
  9. layout.session = layout.session || {};
  10. o2.addReady(function(){
  11. o2.load(["../o2_lib/mootools/plugin/mBox.Notice.js", "../o2_lib/mootools/plugin/mBox.Tooltip.js"], {"sequence": true}, function(){
  12. //MWF.defaultPath = "/x_desktop"+MWF.defaultPath;
  13. MWF.loadLP("zh-cn");
  14. // MWF.require("MWF.widget.Mask", null, false);
  15. // layout.mask = new MWF.widget.Mask({"style": "desktop"});
  16. // layout.mask.load();
  17. MWF.require("MWF.xDesktop.Layout", function(){
  18. MWF.require("MWF.xDesktop.Authentication", null, false);
  19. (function(){
  20. layout.load = function(){
  21. if (this.isAuthentication()){
  22. //var preview = window.frameElement.retrieve("preview");
  23. //layout.desktop = window.frameElement.ownerDocument.window.layout.desktop;
  24. //
  25. this.node = $("layout");
  26. this.content = $(document.body);
  27. this.path = "/x_component_process_Work/$Main/";
  28. this.cssPath = "/x_component_process_Work/$Main/default/css.wcss";
  29. this._loadCss();
  30. MWF.require("MWF.xDesktop.MessageMobile", function(){
  31. layout.message = new MWF.xDesktop.MessageMobile();
  32. layout.message.load();
  33. }.bind(this));
  34. // MWF.xDesktop.requireApp("process.Work", "Actions.RestActions", null, false);
  35. // this.action = new MWF.xApplication.process.Work.Actions.RestActions();
  36. this.action = MWF.Actions.get("x_processplatform_assemble_surface");
  37. //MWF.xDesktop.requireApp("process.Work", "lp."+MWF.language, null, false);
  38. MWF.xDesktop.requireApp("process.Work", "lp."+MWF.language, {
  39. "onRequestFailure": function(){
  40. MWF.xDesktop.requireApp("process.Work", "lp.zh-cn", null, false);
  41. }.bind(this),
  42. "onSuccess": function(){}.bind(this)
  43. }, false);
  44. this.lp = MWF.xApplication.process.Work.LP;
  45. this.options = this.getIds();
  46. this.loadWork(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.message = {
  79. // "node": (function(){
  80. // var node = new Element("div", {
  81. // "styles": {
  82. // "width": "100%",
  83. // "position": "absolute",
  84. // "top": "0px",
  85. // "left": "0px",
  86. // "background-color": "#FFF",
  87. // "overflow": "hidden"
  88. // }
  89. // }).inject($(document.body));
  90. // return node
  91. // })(),
  92. //
  93. // addMessage: function(msg){
  94. // var subjectNode = new Element("div", {
  95. // "styles": {
  96. // "margin": "0px 10px",
  97. // "height": "20px",
  98. // "line-height": "20px",
  99. // "font-size": "14px",
  100. // "color": "#4387cd"
  101. // }
  102. // }).inject(this.node);
  103. // var contentNode = new Element("div", {
  104. // "styles": {
  105. // "width": "100%",
  106. // "position": "absolute",
  107. // "top": "0px",
  108. // "left": "0px",
  109. // "background-color": "#FFF",
  110. // "overflow": "hidden"
  111. // }
  112. // }).inject(this.node);
  113. // }
  114. //
  115. //},
  116. layout.getIds = function(){
  117. var href = window.location.href;
  118. var qStr = href.substr(href.indexOf("?")+1, href.length);
  119. var qDatas = qStr.split("&");
  120. var obj = {};
  121. qDatas.each(function(d){
  122. var q = d.split("=");
  123. obj[q[0].toLowerCase()] = q[1];
  124. });
  125. return obj;
  126. };
  127. layout.loadWork = function(options){
  128. var method = "";
  129. var id = "";
  130. if (options.taskid){
  131. method = "getTask";
  132. id = options.taskid;
  133. }else if (options.taskcompletedid) {
  134. method = "getTaskCompleted";
  135. id = options.taskcompletedid;
  136. }else if (options.readid) {
  137. method = "getRead";
  138. id = options.readid;
  139. }else if (options.readid) {
  140. method = "getReaded";
  141. id = options.readid;
  142. }else if (options.reviewid) {
  143. method = "getReview";
  144. id = options.reviewid;
  145. }
  146. var workMethod = "";
  147. var workid = "";
  148. if (method && id){
  149. this.action[method](id, function(json){
  150. if (json.data.workCompleted){
  151. workMethod = "getJobByWorkCompletedMobile";
  152. workid = json.data.workCompleted
  153. }else{
  154. workMethod = "getJobByWorkMobile";
  155. workid = json.data.work
  156. }
  157. }.bind(this), null, false);
  158. }
  159. if (!workMethod || !workid){
  160. if (options.workid) {
  161. workMethod = "getJobByWorkMobile";
  162. workid = options.workid;
  163. }else if (options.workcompletedid){
  164. workMethod = "getJobByWorkCompletedMobile";
  165. workid = options.workcompletedid;
  166. }
  167. }
  168. if (workMethod && workid){
  169. this.action[workMethod](function(json){
  170. if (this.mask) this.mask.hide();
  171. this.parseData(json.data);
  172. this.openWork();
  173. if( this.control.allowSave || this.control.allowProcessing ){
  174. $("MWF_form_action_save").getParent().setStyle("display","");
  175. }else{
  176. $("MWF_form_action_save").getParent().getPrevious().setStyle("height","100%");
  177. }
  178. if( this.control.allowSave ){
  179. var action = $("MWF_form_action_save");
  180. action.setStyle("display","");
  181. action.addEvents({
  182. "click": function(){
  183. this.appForm.saveWork();
  184. }.bind(this),
  185. "touchstart": function(){
  186. this.setStyle("background-color", "#EEEEEE");
  187. },
  188. "touchcancel": function(){
  189. this.setStyle("background-color", "#ffffff");
  190. },
  191. "touchend": function(){
  192. this.setStyle("background-color", "#ffffff");
  193. }
  194. });
  195. }else{
  196. $("MWF_form_action_save").setStyle("display","none")
  197. }
  198. if( this.control.allowProcessing ){
  199. var action = $("MWF_form_action_process");
  200. action.setStyle("display","");
  201. action.addEvents({
  202. "click": function(){
  203. this.appForm.processWork();
  204. }.bind(this),
  205. "touchstart": function(){
  206. this.setStyle("background-color", "#EEEEEE");
  207. },
  208. "touchcancel": function(){
  209. this.setStyle("background-color", "#ffffff");
  210. },
  211. "touchend": function(){
  212. this.setStyle("background-color", "#ffffff");
  213. }
  214. });
  215. }else{
  216. $("MWF_form_action_process").setStyle("display","none")
  217. }
  218. }.bind(this), function(xhr){
  219. this.errorWork(xhr);
  220. }.bind(this), workid);
  221. }
  222. // var method = "";
  223. // var id = "";
  224. //
  225. // if (options.taskid){
  226. // method = "getJobByTaskMobile";
  227. // id = options.taskid;
  228. // }else if (options.workid) {
  229. // method = "getJobByWorkMobile";
  230. // id = options.workid;
  231. // }else if (options.workCompletedId) {
  232. // method = "getJobByWorkCompletedMobile";
  233. // id = options.workCompletedId;
  234. // }
  235. // if (method && id){
  236. // this.action[method](function(json){
  237. // if (this.mask) this.mask.hide();
  238. // this.parseData(json.data);
  239. // this.openWork();
  240. // }.bind(this), function(xhr){
  241. // this.errorWork();
  242. // }.bind(this), id);
  243. // }
  244. };
  245. layout.addEvent = window.addEvent.bind(window);
  246. layout.addEvents = window.addEvents.bind(window);
  247. layout.errorWork = function(xhr){
  248. if (this.mask) this.mask.hide();
  249. var json = JSON.decode(xhr.responseText);
  250. if (json.prompt.indexOf("ExceptionWorkAccessDenied")!=-1){
  251. if (this.authentication) this.authentication.loadLogin(this.node);
  252. }else{
  253. this.node.set("text", "openError");
  254. }
  255. };
  256. layout.getCurrentTaskData = function(data){
  257. if ((data.currentTaskIndex || data.currentTaskIndex===0) && data.currentTaskIndex != -1){
  258. this.options.taskid = this.taskList[data.currentTaskIndex].id;
  259. return this.taskList[data.currentTaskIndex];
  260. }
  261. //if (this.taskList){
  262. // if (this.taskList.length==1){
  263. // this.options.taskid = this.taskList[0].id;
  264. // return this.taskList[0];
  265. // }
  266. //}
  267. return null;
  268. };
  269. layout.parseData = function(data){
  270. // this.setTitle(this.options.title+"-"+data.work.title);
  271. this.activity = data.activity;
  272. this.data = data.data;
  273. this.taskList = data.taskList;
  274. this.currentTask = this.getCurrentTaskData(data);
  275. this.taskList = data.taskList;
  276. this.readList = data.readList;
  277. this.work = data.work;
  278. this.workCompleted = data.workCompleted;
  279. this.workLogList = data.workLogList;
  280. this.attachmentList = data.attachmentList;
  281. this.inheritedAttachmentList = data.inheritedAttachmentList;
  282. this.control = data.control;
  283. this.form = (data.form) ? JSON.decode(MWF.decodeJsonString(data.form.data)): null;
  284. this.formInfor = data.form;
  285. };
  286. layout.openWork = function(){
  287. if (this.form){
  288. MWF.xDesktop.requireApp("process.Xform", "Form", function(){
  289. this.appForm = new MWF.APPForm(this.node, this.form, {"readonly": (this.currentTask) ? false : true});
  290. this.appForm.businessData = {
  291. "data": this.data,
  292. "taskList": this.taskList,
  293. "readList": this.readList,
  294. "work": this.work,
  295. "workCompleted": this.workCompleted,
  296. "control": this.control,
  297. "activity": this.activity,
  298. "task": this.currentTask,
  299. "workLogList": this.workLogList,
  300. "attachmentList": this.attachmentList,
  301. "inheritedAttachmentList": this.inheritedAttachmentList,
  302. "formInfor": this.formInfor,
  303. "status": {
  304. "readonly": (this.currentTask) ? false : true
  305. }
  306. };
  307. this.appForm.workAction = this.action;
  308. this.appForm.app = this;
  309. this.appForm.load();
  310. if (window.o2android && window.o2android.appFormLoaded){
  311. window.o2android.appFormLoaded('true');
  312. }
  313. if (window.webkit && window.webkit.messageHandlers && window.webkit.messageHandlers.appFormLoaded){
  314. window.webkit.messageHandlers.appFormLoaded.postMessage('true')
  315. }
  316. }.bind(this));
  317. }
  318. };
  319. layout.isAuthentication = function(){
  320. layout.authentication = new MWF.xDesktop.Authentication({
  321. "onLogin": layout.load.bind(layout)
  322. });
  323. var returnValue = true;
  324. this.authentication.isAuthenticated(function(json){
  325. this.user = json.data;
  326. this.session.user = json.data;
  327. }.bind(this), function(){
  328. if (layout.mask) layout.mask.hide();
  329. this.authentication.loadLogin(document.body);
  330. returnValue = false;
  331. }.bind(this));
  332. return returnValue;
  333. };
  334. //layout.getServiceAddress = function(callback){
  335. // var host = layout.config.center.host || window.location.hostname;
  336. // var port = layout.config.center.port;
  337. // var uri = "";
  338. // if (!port || port=="80"){
  339. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  340. // }else{
  341. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  342. // }
  343. // var currenthost = window.location.hostname;
  344. // uri = uri.replace(/{source}/g, currenthost);
  345. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  346. // MWF.restful("get", uri, null, function(json){
  347. // this.serviceAddressList = json.data;
  348. // if (callback) callback();
  349. // }.bind(this));
  350. //};
  351. //layout.getServiceAddress = function(callback){
  352. // if (typeOf(layout.config.center)=="object"){
  353. // this.getServiceAddressConfigObject(callback);
  354. // }else if (typeOf(layout.config.center)=="array"){
  355. // this.getServiceAddressConfigArray(callback);
  356. // }
  357. //
  358. //};
  359. //layout.getServiceAddressConfigArray = function(callback) {
  360. // var requests = [];
  361. // layout.config.center.each(function(center){
  362. // requests.push(
  363. // this.getServiceAddressConfigObject(function(){
  364. // requests.each(function(res){
  365. // if (res.isRunning()){res.cancel();}
  366. // });
  367. // if (callback) callback();
  368. // }.bind(this), center)
  369. // );
  370. // }.bind(this));
  371. //};
  372. //layout.getServiceAddressConfigObject = function(callback, center){
  373. // var centerConfig = center;
  374. // if (!centerConfig) centerConfig = layout.config.center;
  375. // var host = centerConfig.host || window.location.hostname;
  376. // var port = centerConfig.port;
  377. // var uri = "";
  378. // if (!port || port=="80"){
  379. // uri = "http://"+host+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  380. // }else{
  381. // uri = "http://"+host+":"+port+"/x_program_center/jaxrs/distribute/assemble/source/{source}";
  382. // }
  383. // var currenthost = window.location.hostname;
  384. // uri = uri.replace(/{source}/g, currenthost);
  385. // //var uri = "http://"+layout.config.center+"/x_program_center/jaxrs/distribute/assemble";
  386. // return MWF.restful("get", uri, null, function(json){
  387. // this.serviceAddressList = json.data;
  388. // this.centerServer = center;
  389. // if (callback) callback();
  390. // }.bind(this));
  391. //};
  392. layout.confirm = function(type, e, title, text, width, height, ok, cancel, callback, mask, style){
  393. MWF.require("MWF.xDesktop.Dialog", function(){
  394. var size = this.content.getSize();
  395. var x = 0;
  396. var y = 0;
  397. if (typeOf(e)=="element"){
  398. var position = e.getPosition(this.content);
  399. x = position.x;
  400. y = position.y;
  401. }else{
  402. if (Browser.name=="firefox"){
  403. x = parseFloat(e.event.clientX);
  404. y = parseFloat(e.event.clientY);
  405. }else{
  406. x = parseFloat(e.event.x);
  407. y = parseFloat(e.event.y);
  408. }
  409. // if (!x || !y){
  410. if (e.target){
  411. var position = e.target.getPosition(this.content);
  412. x = position.x;
  413. y = position.y;
  414. }
  415. // }
  416. }
  417. if (x+parseFloat(width)>size.x){
  418. x = x-parseFloat(width);
  419. }
  420. if (x<0) x = 0;
  421. if (y+parseFloat(height)>size.y){
  422. y = y-parseFloat(height);
  423. }
  424. if (y<0) y = 0;
  425. var ctext = "";
  426. var chtml = "";
  427. if (typeOf(text).toLowerCase()=="object"){
  428. ctext = text.text;
  429. chtml = text.html;
  430. }else{
  431. ctext = text;
  432. }
  433. var dlg = new MWF.xDesktop.Dialog({
  434. "title": title,
  435. "style": style || "flat",
  436. "top": y,
  437. "left": x-20,
  438. "fromTop":y,
  439. "fromLeft": x-20,
  440. "width": width,
  441. "height": height,
  442. "text": ctext,
  443. "html": chtml,
  444. "mark": false,
  445. "container": this.content,
  446. "maskNode": mask || this.content,
  447. "buttonList": [
  448. {
  449. "text": MWF.LP.process.button.ok,
  450. "action": ok
  451. },
  452. {
  453. "text": MWF.LP.process.button.cancel,
  454. "action": cancel
  455. }
  456. ]
  457. });
  458. switch (type.toLowerCase()){
  459. case "success":
  460. dlg.content.setStyle("background-image", "url()");
  461. break;
  462. case "error":
  463. dlg.content.setStyle("background-image", "url()");
  464. break;
  465. case "info":
  466. dlg.content.setStyle("background-image", "url()");
  467. break;
  468. case "warn":
  469. dlg.content.setStyle("background-image", "url()");
  470. break;
  471. default:
  472. //dlg.content.setStyle("background-image", "");
  473. }
  474. dlg.show();
  475. if (callback) callback(dlg);
  476. }.bind(this));
  477. };
  478. layout.notice = function(content, type, target, where, offset){
  479. if (!where) where = {"x": "right", "y": "top"};
  480. if (!target) target = this.content;
  481. if (!type) type = "ok";
  482. var noticeTarget = target || $(document.body);
  483. var off = offset;
  484. if (!off){
  485. off = {
  486. x: 10,
  487. y: where.y.toString().toLowerCase()=="bottom" ? 10 : 10
  488. };
  489. }
  490. new mBox.Notice({
  491. type: type,
  492. position: where,
  493. move: false,
  494. target: noticeTarget,
  495. delayClose: (type=="error") ? 10000 : 5000,
  496. offset: off,
  497. content: content
  498. });
  499. };
  500. layout.reload = function(){
  501. window.location.reload();
  502. };
  503. MWF.getJSON("res/config/config.json", function(config){
  504. layout.config = config;
  505. if (layout.config.app_protocol=="auto"){
  506. layout.config.app_protocol = window.location.protocol;
  507. }
  508. MWF.xDesktop.getServiceAddress(layout.config, function(service, center){
  509. layout.serviceAddressList = service;
  510. layout.centerServer = center;
  511. layout.load();
  512. }.bind(this));
  513. //layout.getServiceAddress(function(){
  514. // layout.load();
  515. //});
  516. });
  517. })();
  518. });
  519. });
  520. });