Attachment.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560
  1. MWF.xDesktop.requireApp("process.Xform", "$Module", null, false);
  2. MWF.require("MWF.widget.AttachmentController", null, false);
  3. MWF.xApplication.process.Xform.AttachmentController = new Class({
  4. Extends: MWF.widget.ATTER,
  5. checkDeleteAction: function(){
  6. if (this.options.readonly){
  7. this.setActionDisabled(this.deleteAction);
  8. this.setActionDisabled(this.min_deleteAction);
  9. return false;
  10. }
  11. if (this.options.isDeleteOption!=="y" && this.options.isDeleteOption!=="n"){
  12. if (this.selectedAttachments.length){
  13. var flag = true;
  14. if (this.options.isDeleteOption==="o"){
  15. for (var i=0; i<this.selectedAttachments.length; i++){
  16. if (this.selectedAttachments[i].data.person!==layout.desktop.session.user.distinguishedName){
  17. flag = false;
  18. break;
  19. }
  20. }
  21. }else if (this.options.isDeleteOption==="a"){
  22. for (var i=0; i<this.selectedAttachments.length; i++){
  23. if (this.selectedAttachments[i].data.activity!==this.module.form.businessData.activity.id){
  24. flag = false;
  25. break;
  26. }
  27. }
  28. }else if (this.options.isDeleteOption==="ao"){
  29. for (var i=0; i<this.selectedAttachments.length; i++){
  30. if ((this.selectedAttachments[i].data.activity!==this.module.form.businessData.activity.id) || (this.selectedAttachments[i].data.person!==layout.desktop.session.user.distinguishedName)){
  31. flag = false;
  32. break;
  33. }
  34. }
  35. }
  36. if (flag){
  37. this.setActionEnabled(this.deleteAction);
  38. this.setActionEnabled(this.min_deleteAction);
  39. }else{
  40. this.setActionDisabled(this.deleteAction);
  41. this.setActionDisabled(this.min_deleteAction);
  42. }
  43. }else{
  44. this.setActionDisabled(this.deleteAction);
  45. this.setActionDisabled(this.min_deleteAction);
  46. }
  47. }else{
  48. if (!this.options.isDelete){
  49. this.setActionDisabled(this.deleteAction);
  50. this.setActionDisabled(this.min_deleteAction);
  51. }else{
  52. if (this.selectedAttachments.length){
  53. this.setActionEnabled(this.deleteAction);
  54. this.setActionEnabled(this.min_deleteAction);
  55. }else{
  56. this.setActionDisabled(this.deleteAction);
  57. this.setActionDisabled(this.min_deleteAction);
  58. }
  59. }
  60. }
  61. },
  62. checkReplaceAction: function(){
  63. if (this.options.readonly){
  64. this.setActionDisabled(this.replaceAction);
  65. this.setActionDisabled(this.min_replaceAction);
  66. return false;
  67. }
  68. if (this.options.isReplaceOption!=="y" && this.options.isReplaceOption!=="n") {
  69. if (this.selectedAttachments.length && this.selectedAttachments.length===1){
  70. var flag;
  71. if (this.options.isReplaceOption==="o"){
  72. flag = this.selectedAttachments[0].data.person === layout.desktop.session.user.distinguishedName;
  73. }
  74. if (this.options.isReplaceOption==="a"){
  75. flag = this.selectedAttachments[0].data.activity===this.module.form.businessData.activity.id;
  76. }
  77. if (this.options.isReplaceOption==="ao"){
  78. flag = (this.selectedAttachments[0].data.person === layout.desktop.session.user.distinguishedName && this.selectedAttachments[0].data.activity===this.module.form.businessData.activity.id);
  79. }
  80. if (flag) {
  81. this.setActionEnabled(this.replaceAction);
  82. this.setActionEnabled(this.min_replaceAction);
  83. }else{
  84. this.setActionDisabled(this.replaceAction);
  85. this.setActionDisabled(this.min_replaceAction);
  86. }
  87. } else {
  88. this.setActionDisabled(this.replaceAction);
  89. this.setActionDisabled(this.min_replaceAction);
  90. }
  91. }else{
  92. if (!this.options.isReplace){
  93. this.setActionDisabled(this.replaceAction);
  94. this.setActionDisabled(this.min_replaceAction);
  95. }else{
  96. if (this.selectedAttachments.length && this.selectedAttachments.length===1){
  97. this.setActionEnabled(this.replaceAction);
  98. this.setActionEnabled(this.min_replaceAction);
  99. }else{
  100. this.setActionDisabled(this.replaceAction);
  101. this.setActionDisabled(this.min_replaceAction);
  102. }
  103. }
  104. }
  105. }
  106. });
  107. MWF.xApplication.process.Xform.Attachment = MWF.APPAttachment = new Class({
  108. Extends: MWF.APP$Module,
  109. options: {
  110. "moduleEvents": ["upload", "delete"]
  111. },
  112. initialize: function(node, json, form, options){
  113. this.node = $(node);
  114. this.node.store("module", this);
  115. this.json = json;
  116. this.form = form;
  117. this.field = true;
  118. },
  119. _loadUserInterface: function(){
  120. this.node.empty();
  121. this.loadAttachmentController();
  122. },
  123. loadAttachmentController: function(){
  124. //MWF.require("MWF.widget.AttachmentController", function() {
  125. var options = {
  126. "title": "附件区域",
  127. "listStyle": this.json.listStyle || "icon",
  128. "size": this.json.size || "max",
  129. "resize": (this.json.size==="true"),
  130. "attachmentCount": this.json.attachmentCount || 0,
  131. "isUpload": (this.json.isUpload==="y"),
  132. "isDelete": (this.json.isDelete==="y"),
  133. "isReplace": (this.json.isReplace==="y"),
  134. "isDownload": (this.json.isDownload==="y"),
  135. "isSizeChange": (this.json.isSizeChange==="y"),
  136. "readonly": (this.json.readonly==="y"),
  137. "isDeleteOption": this.json.isDelete,
  138. "isReplaceOption": this.json.isReplace
  139. };
  140. if (this.readonly) options.readonly = true;
  141. //this.attachmentController = new MWF.widget.ATTER(this.node, this, options);
  142. this.attachmentController = new MWF.xApplication.process.Xform.AttachmentController(this.node, this, options);
  143. this.attachmentController.load();
  144. this.form.businessData.attachmentList.each(function (att) {
  145. if (att.site===this.json.id) this.attachmentController.addAttachment(att);
  146. }.bind(this));
  147. //}.bind(this));
  148. },
  149. _loadEvents: function(editorConfig){
  150. Object.each(this.json.events, function(e, key){
  151. if (e.code){
  152. if (this.options.moduleEvents.indexOf(key)!==-1){
  153. this.addEvent(key, function(event){
  154. return this.form.Macro.fire(e.code, this, event);
  155. }.bind(this));
  156. }else{
  157. this.node.addEvent(key, function(event){
  158. return this.form.Macro.fire(e.code, this, event);
  159. }.bind(this));
  160. }
  161. }
  162. }.bind(this));
  163. },
  164. getData: function(){
  165. return this.attachmentController.getAttachmentNames();
  166. },
  167. createUploadFileNode: function(){
  168. this.attachmentController.doUploadAttachment({"site": this.json.id}, this.form.workAction.action, "uploadAttachment", {"id": this.form.businessData.work.id}, null, function(o){
  169. if (o.id){
  170. this.form.workAction.getAttachment(o.id, this.form.businessData.work.id, function(json){
  171. if (json.data) this.attachmentController.addAttachment(json.data);
  172. this.attachmentController.checkActions();
  173. this.fireEvent("upload", [json.data]);
  174. }.bind(this))
  175. }
  176. this.attachmentController.checkActions();
  177. }.bind(this), function(files){
  178. if (files.length){
  179. if ((files.length+this.attachmentController.attachments.length > this.attachmentController.options.attachmentCount) && this.attachmentController.options.attachmentCount>0){
  180. var content = MWF.xApplication.process.Xform.LP.uploadMore;
  181. content = content.replace("{n}", this.attachmentController.options.attachmentCount);
  182. this.form.notice(content, "error");
  183. return false;
  184. }
  185. }
  186. return true;
  187. }.bind(this));
  188. // this.uploadFileAreaNode = new Element("div");
  189. // var html = "<input name=\"file\" type=\"file\" multiple/>";
  190. // this.uploadFileAreaNode.set("html", html);
  191. //
  192. // this.fileUploadNode = this.uploadFileAreaNode.getFirst();
  193. // this.fileUploadNode.addEvent("change", function(){
  194. //
  195. // var files = this.fileUploadNode.files;
  196. // if (files.length){
  197. // if ((files.length+this.attachmentController.attachments.length > this.attachmentController.options.attachmentCount) && this.attachmentController.options.attachmentCount>0){
  198. // var content = MWF.xApplication.process.Xform.LP.uploadMore;
  199. // content = content.replace("{n}", this.attachmentController.options.attachmentCount);
  200. // this.form.notice(content, "error");
  201. // }else{
  202. // for (var i = 0; i < files.length; i++) {
  203. // var file = files.item(i);
  204. //
  205. // var formData = new FormData();
  206. // formData.append('site', this.json.id);
  207. // formData.append('file', file);
  208. //
  209. // //formData.append('folder', folderId);
  210. //
  211. // this.form.workAction.uploadAttachment(this.form.businessData.work.id ,function(o, text){
  212. // if (o.id){
  213. // this.form.workAction.getAttachment(o.id, this.form.businessData.work.id, function(json){
  214. // if (json.data) this.attachmentController.addAttachment(json.data);
  215. // this.attachmentController.checkActions();
  216. //
  217. // this.fireEvent("upload", [json.data]);
  218. // }.bind(this))
  219. // }
  220. // this.attachmentController.checkActions();
  221. // }.bind(this), null, formData, file);
  222. // }
  223. // }
  224. // }
  225. // }.bind(this));
  226. },
  227. uploadAttachment: function(e, node){
  228. if (window.o2 && window.o2.uploadAttachment){
  229. window.o2.uploadAttachment(this.json.id);
  230. }else if(window.webkit && window.webkit.messageHandlers) {
  231. window.webkit.messageHandlers.uploadAttachment.postMessage({"site": this.json.id});
  232. }else{
  233. // if (!this.uploadFileAreaNode){
  234. this.createUploadFileNode();
  235. // }
  236. // this.fileUploadNode.click();
  237. }
  238. },
  239. deleteAttachments: function(e, node, attachments){
  240. var names = [];
  241. attachments.each(function(attachment){
  242. names.push(attachment.data.name);
  243. }.bind(this));
  244. // if ((window.o2 && window.o2.replaceAttachment) || (window.webkit && window.webkit.messageHandlers)){
  245. // if (window.confirm(MWF.xApplication.process.Xform.LP.deleteAttachment+"( "+names.join(", ")+" )")){
  246. // while (attachments.length){
  247. // attachment = attachments.shift();
  248. // this.deleteAttachment(attachment);
  249. // }
  250. // }
  251. // }else {
  252. // var tmpNode = new Element("div", {
  253. // "styles": {
  254. // "background-color": "#0000ff",
  255. // "border-style": "solid",
  256. // "border-color": "#fff",
  257. // "border-width": "1",
  258. // "box-shadow": "0px 0px 20px #999",
  259. // "z-index": "20000",
  260. // "overflow": "hidden",
  261. // "font-size": "14px",
  262. // "height": "160px",
  263. // "padding": "0px",
  264. // "width": "300px",
  265. // "position": "absolute",
  266. // "top": "50px",
  267. // "left": "20px",
  268. // "opacity": 1,
  269. // "border-radius": "5px"
  270. // }
  271. // }).inject(this.form.app.content);
  272. var _self = this;
  273. this.form.confirm("warn", e, MWF.xApplication.process.Xform.LP.deleteAttachmentTitle, MWF.xApplication.process.Xform.LP.deleteAttachment+"( "+names.join(", ")+" )", 300, 120, function(){
  274. while (attachments.length){
  275. var attachment = attachments.shift();
  276. _self.deleteAttachment(attachment);
  277. }
  278. this.close();
  279. }, function(){
  280. this.close();
  281. }, null);
  282. },
  283. deleteAttachment: function(attachment){
  284. this.fireEvent("delete", [attachment.data]);
  285. this.form.workAction.deleteAttachment(attachment.data.id, this.form.businessData.work.id, function(josn){
  286. this.attachmentController.removeAttachment(attachment);
  287. this.attachmentController.checkActions();
  288. }.bind(this));
  289. },
  290. replaceAttachment: function(e, node, attachment){
  291. if (window.o2 && window.o2.replaceAttachment){
  292. window.o2.replaceAttachment(attachment.data.id, this.json.id);
  293. }else if(window.webkit && window.webkit.messageHandlers) {
  294. window.webkit.messageHandlers.replaceAttachment.postMessage({"id": attachment.data.id, "site": this.json.id});
  295. }else {
  296. var _self = this;
  297. this.form.confirm("warn", e, MWF.xApplication.process.Xform.LP.replaceAttachmentTitle, MWF.xApplication.process.Xform.LP.replaceAttachment+"( "+attachment.data.name+" )", 350, 120, function(){
  298. _self.replaceAttachmentFile(attachment);
  299. this.close();
  300. }, function(){
  301. this.close();
  302. }, null);
  303. }
  304. },
  305. createReplaceFileNode: function(attachment){
  306. this.attachmentController.doUploadAttachment({"site": this.json.id}, this.form.workAction.action, "replaceAttachment",
  307. {"id": attachment.data.id, "workid": this.form.businessData.work.id}, null, function(o){
  308. this.form.workAction.getAttachment(attachment.data.id, this.form.businessData.work.id, function(json){
  309. attachment.data = json.data;
  310. attachment.reload();
  311. this.attachmentController.checkActions();
  312. }.bind(this))
  313. }.bind(this), null);
  314. // this.replaceFileAreaNode = new Element("div");
  315. // var html = "<input name=\"file\" type=\"file\" multiple/>";
  316. // this.replaceFileAreaNode.set("html", html);
  317. //
  318. // this.fileReplaceNode = this.replaceFileAreaNode.getFirst();
  319. // this.fileReplaceNode.addEvent("change", function(){
  320. //
  321. // var files = this.fileReplaceNode.files;
  322. // if (files.length){
  323. // for (var i = 0; i < files.length; i++) {
  324. // var file = files.item(i);
  325. //
  326. // var formData = new FormData();
  327. // formData.append('file', file);
  328. // // formData.append('site', this.json.id);
  329. //
  330. // this.form.workAction.replaceAttachment(attachment.data.id, this.form.businessData.work.id ,function(o, text){
  331. // this.form.workAction.getAttachment(attachment.data.id, this.form.businessData.work.id, function(json){
  332. // attachment.data = json.data;
  333. // attachment.reload();
  334. // this.attachmentController.checkActions();
  335. // }.bind(this))
  336. // }.bind(this), null, formData, file);
  337. // }
  338. // }
  339. // }.bind(this));
  340. },
  341. replaceAttachmentFile: function(attachment){
  342. //if (!this.replaceFileAreaNode){
  343. this.createReplaceFileNode(attachment);
  344. // }
  345. // this.fileReplaceNode.click();
  346. },
  347. downloadAttachment: function(e, node, attachments){
  348. if (this.form.businessData.work){
  349. attachments.each(function(att){
  350. if (window.o2 && window.o2.downloadAttachment){
  351. window.o2.downloadAttachment(att.data.id);
  352. }else if(window.webkit && window.webkit.messageHandlers) {
  353. window.webkit.messageHandlers.downloadAttachment.postMessage({"id": att.data.id, "site": this.json.id});
  354. }else{
  355. this.form.workAction.getAttachmentStream(att.data.id, this.form.businessData.work.id);
  356. }
  357. }.bind(this));
  358. }else{
  359. attachments.each(function(att){
  360. if (window.o2 && window.o2.downloadAttachment){
  361. window.o2.downloadAttachment(att.data.id);
  362. }else if(window.webkit && window.webkit.messageHandlers) {
  363. window.webkit.messageHandlers.downloadAttachment.postMessage({"id": att.data.id, "site": this.json.id});
  364. }else{
  365. this.form.workAction.getWorkcompletedAttachmentStream(att.data.id, this.form.businessData.workCompleted.id);
  366. }
  367. }.bind(this));
  368. }
  369. },
  370. openAttachment: function(e, node, attachments){
  371. if (this.form.businessData.work){
  372. attachments.each(function(att){
  373. if (window.o2 && window.o2.downloadAttachment){
  374. window.o2.downloadAttachment(att.data.id);
  375. }else if(window.webkit && window.webkit.messageHandlers) {
  376. window.webkit.messageHandlers.downloadAttachment.postMessage({"id": att.data.id, "site": this.json.id});
  377. }else {
  378. this.form.workAction.getAttachmentData(att.data.id, this.form.businessData.work.id);
  379. }
  380. }.bind(this));
  381. }else{
  382. attachments.each(function(att){
  383. if (window.o2 && window.o2.downloadAttachment){
  384. window.o2.downloadAttachment(att.data.id);
  385. }else if(window.webkit && window.webkit.messageHandlers) {
  386. window.webkit.messageHandlers.downloadAttachment.postMessage(att.data.id, this.json.id);
  387. }else {
  388. this.form.workAction.getWorkcompletedAttachmentData(att.data.id, this.form.businessData.workCompleted.id);
  389. }
  390. }.bind(this));
  391. }
  392. //this.downloadAttachment(e, node, attachment);
  393. },
  394. getAttachmentUrl: function(attachment, callback){
  395. if (this.form.businessData.work){
  396. this.form.workAction.getAttachmentUrl(attachment.data.id, this.form.businessData.work.id, callback);
  397. }else{
  398. this.form.workAction.getAttachmentWorkcompletedUrl(attachment.data.id, this.form.businessData.workCompleted.id, callback);
  399. }
  400. },
  401. createErrorNode: function(text){
  402. var node = new Element("div");
  403. var iconNode = new Element("div", {
  404. "styles": {
  405. "width": "20px",
  406. "height": "20px",
  407. "float": "left",
  408. "background": "url("+"/x_component_process_Xform/$Form/default/icon/error.png) center center no-repeat"
  409. }
  410. }).inject(node);
  411. var textNode = new Element("div", {
  412. "styles": {
  413. "line-height": "20px",
  414. "margin-left": "20px",
  415. "color": "red"
  416. },
  417. "text": text
  418. }).inject(node);
  419. return node;
  420. },
  421. notValidationMode: function(text){
  422. if (!this.isNotValidationMode){
  423. this.isNotValidationMode = true;
  424. this.node.store("borderStyle", this.node.getStyles("border-left", "border-right", "border-top", "border-bottom"));
  425. this.node.setStyle("border", "1px solid red");
  426. this.errNode = this.createErrorNode(text).inject(this.node, "after");
  427. this.showNotValidationMode(this.node);
  428. }
  429. },
  430. showNotValidationMode: function(node){
  431. var p = node.getParent("div");
  432. if (p){
  433. if (p.get("MWFtype") == "tab$Content"){
  434. if (p.getParent("div").getStyle("display")=="none"){
  435. var contentAreaNode = p.getParent("div").getParent("div");
  436. var tabAreaNode = contentAreaNode.getPrevious("div");
  437. var idx = contentAreaNode.getChildren().indexOf(p.getParent("div"));
  438. var tabNode = tabAreaNode.getChildren()[idx];
  439. tabNode.click();
  440. p = tabAreaNode.getParent("div");
  441. }
  442. }
  443. this.showNotValidationMode(p);
  444. }
  445. },
  446. validationMode: function(){
  447. if (this.isNotValidationMode){
  448. this.isNotValidationMode = false;
  449. this.node.setStyles(this.node.retrieve("borderStyle"));
  450. if (this.errNode){
  451. this.errNode.destroy();
  452. this.errNode = null;
  453. }
  454. }
  455. },
  456. validationConfigItem: function(routeName, data){
  457. var flag = (data.status=="all") ? true: (routeName == data.decision);
  458. if (flag){
  459. var n = this.getData();
  460. var v = (data.valueType=="value") ? n : n.length;
  461. switch (data.operateor){
  462. case "isnull":
  463. if (!v){
  464. this.notValidationMode(data.prompt);
  465. return false;
  466. }
  467. break;
  468. case "notnull":
  469. if (v){
  470. this.notValidationMode(data.prompt);
  471. return false;
  472. }
  473. break;
  474. case "gt":
  475. if (v>data.value){
  476. this.notValidationMode(data.prompt);
  477. return false;
  478. }
  479. break;
  480. case "lt":
  481. if (v<data.value){
  482. this.notValidationMode(data.prompt);
  483. return false;
  484. }
  485. break;
  486. case "equal":
  487. if (v==data.value){
  488. this.notValidationMode(data.prompt);
  489. return false;
  490. }
  491. break;
  492. case "neq":
  493. if (v!=data.value){
  494. this.notValidationMode(data.prompt);
  495. return false;
  496. }
  497. break;
  498. case "contain":
  499. if (v.indexOf(data.value)!=-1){
  500. this.notValidationMode(data.prompt);
  501. return false;
  502. }
  503. break;
  504. case "notcontain":
  505. if (v.indexOf(data.value)==-1){
  506. this.notValidationMode(data.prompt);
  507. return false;
  508. }
  509. break;
  510. }
  511. }
  512. return true;
  513. },
  514. validationConfig: function(routeName, opinion){
  515. if (this.json.validationConfig){
  516. if (this.json.validationConfig.length){
  517. for (var i=0; i<this.json.validationConfig.length; i++) {
  518. var data = this.json.validationConfig[i];
  519. if (!this.validationConfigItem(routeName, data)) return false;
  520. }
  521. }
  522. return true;
  523. }
  524. return true;
  525. },
  526. validation: function(routeName, opinion){
  527. if (!this.validationConfig(routeName, opinion)) return false;
  528. if (!this.json.validation) return true;
  529. if (!this.json.validation.code) return true;
  530. var flag = this.form.Macro.exec(this.json.validation.code, this);
  531. if (!flag) flag = MWF.xApplication.process.Xform.LP.notValidation;
  532. if (flag.toString()!="true"){
  533. this.notValidationMode(flag);
  534. return false;
  535. }
  536. return true;
  537. }
  538. });