MWF.xDesktop.requireApp("process.ProcessManager", "Explorer", null, false); MWF.xApplication.process.ProcessManager.FormExplorer = new Class({ Extends: MWF.xApplication.process.ProcessManager.Explorer, Implements: [Options, Events], options: { "create": MWF.APPPM.LP.form.create, "search": MWF.APPPM.LP.form.search, "searchText": MWF.APPPM.LP.form.searchText, "noElement": MWF.APPPM.LP.form.noFormNoticeText, "name": 'process.FormExplorer' }, //ev.dataTransfer.setData("text/plain", ev.target.id); keyCopy: function(e){ if (this.selectMarkItems.length){ var items = []; var i = 0; var checkItems = function(e){ if (i>=this.selectMarkItems.length){ if (items.length){ var str = JSON.encode(items); if (e){ e.clipboardData.setData('text/plain', str); }else { window.clipboardData.setData("Text", str); } this.app.notice(this.app.lp.copyed, "success"); } } }.bind(this); this.selectMarkItems.each(function(item){ this.app.restActions.getForm(item.data.id, function(json){ this.app.restActions.listFormFieldWithForm(item.data.id, function(fieldJson){ var fieldList = []; if (fieldJson.data.number) fieldJson.data.number.each(function(f){ fieldList.push({"dataType": "number", "name": f.name}) }); if (fieldJson.data.person) fieldJson.data.person.each(function(f){ fieldList.push({"dataType": "person", "name": f.name}) }); if (fieldJson.data.string) fieldJson.data.string.each(function(f){ fieldList.push({"dataType": "string", "name": f.name}) }); json.data.fieldList = fieldList; }.bind(this), null, false); json.data.elementType = "form"; items.push(json.data); i++; checkItems(e); }.bind(this), null, false) }.bind(this)); if (e) e.preventDefault(); } }, keyPaste: function(e){ var dataStr = ""; if (e){ dataStr = e.clipboardData.getData('text/plain'); }else{ dataStr = window.clipboardData.getData("Text"); } var data = JSON.decode(dataStr); this.pasteItem(data, 0); }, pasteItem: function(data, i){ if (i"; html += "
"+lp.copySource+" "+someItem.name+"
"; html += "
"+someItem.lastUpdateTime+"
" + "
"+MWF.name.cn(someItem.lastUpdatePerson)+"
" + "
"+((d1>=d2) ? "": lp.copynew)+"
"; html += "
"+lp.copyTarget+" "+data.name+"
"; html += "
"+data.lastUpdateTime+"
" + "
"+MWF.name.cn(data.lastUpdatePerson)+"
" + "
"+((d1<=d2) ? "": lp.copynew)+"
"; // html += "<>" this.app.dlg("inofr", null, this.app.lp.copyConfirmTitle, {"html": html}, 500, 290, [ { "text": lp.copyConfirm_overwrite, "action": function(){_self.saveItemAsUpdate(someItem, data, success, failure);this.close();} }, { "text": lp.copyConfirm_new, "action": function(){_self.saveItemAsNew(dJson, data, success, failure);this.close();} }, { "text": lp.copyConfirm_skip, "action": function(){/*nothing*/ this.close(); if (success) success();} }, { "text": lp.copyConfirm_cancel, "action": function(){this.close(); if (cancel) cancel();} } ]); }else{ this.saveItemAsNew(dJson, data, success, failure) } }.bind(this), function(){if (failure) failure();}.bind(this)); }, saveItemAsUpdate: function(someItem, form, success, failure){ var item = this.app.options.application; var pcdata = JSON.decode(MWF.decodeJsonString(form.data)); var mobiledata = JSON.decode(MWF.decodeJsonString(form.mobileData)); pcdata.id = someItem.id; pcdata.isNewForm = false; pcdata.json.id = someItem.id; pcdata.json.application = item.id; pcdata.json.applicationName = item.name; pcdata.json.name = someItem.name; pcdata.json.alias = someItem.alias; mobiledata.json.id = someItem.id; mobiledata.json.application = item.id; mobiledata.applicationName = item.name; mobiledata.json.name = someItem.name; mobiledata.json.alias = someItem.alias; this.app.restActions.saveForm(pcdata, mobiledata, form.fieldList, function(){ if (success) success(); }.bind(this), function(){ if (failure) failure(); }.bind(this)); }, saveItemAsNew: function(formsJson, form, success, failure){ var item = this.app.options.application; var id = item.id; var name = item.name; var pcdata = JSON.decode(MWF.decodeJsonString(form.data)); var mobiledata = JSON.decode(MWF.decodeJsonString(form.mobileData)); var isSameApp = pcdata.application === id; var oldName = pcdata.json.name; var i=1; while (formsJson.data.some(function(d){ return d.name==pcdata.json.name })){ pcdata.json.name = oldName+"_copy"+i; mobiledata.json.name = oldName+"_copy"+i; i++; } if (!isSameApp) pcdata.id = ""; pcdata.isNewForm = true; if (!isSameApp) pcdata.json.id = ""; pcdata.json.application = id; pcdata.json.applicationName = name; pcdata.json.alias = ""; mobiledata.json.id = ""; mobiledata.json.application = id; mobiledata.applicationName = name; mobiledata.json.alias = ""; this.app.restActions.saveForm(pcdata, mobiledata, form.fieldList, function(){ if (success) success(); }.bind(this), function(){ if (failure) failure(); }.bind(this)); }, _createElement: function(e){ this.formTemplateList = null; this.defalutFormTemplateList = null; var _self = this; var createDefaultForm = function(e, template, templateCode){ layout.desktop.getFormDesignerStyle(function(){ var options = { "style": layout.desktop.formDesignerStyle, "template": template, "templateCode": templateCode, "application":{ "name": _self.app.options.application.name, "id": _self.app.options.application.id }, "onQueryLoad": function(){ this.actions = _self.app.restActions; this.application = _self.app.options.application; } }; layout.desktop.openApplication(e, "process.FormDesigner", options); }.bind(this)); }; var createForm = function(e, template){ layout.desktop.getFormDesignerStyle(function(){ var options = { "style": layout.desktop.formDesignerStyle, "templateId": template, "application":{ "name": _self.app.options.application.name, "id": _self.app.options.application.id }, "onQueryLoad": function(){ this.actions = _self.app.restActions; this.application = _self.app.options.application; } }; layout.desktop.openApplication(e, "process.FormDesigner", options); }.bind(this)); }; var createTemplateMaskNode = new Element("div", {"styles": this.css.createTemplateMaskNode}).inject(this.app.content); var createTemplateAreaNode = new Element("div", {"styles": this.css.createFormTemplateAreaNode}).inject(this.app.content); createTemplateAreaNode.fade("in"); var createTemplateTitleNode = new Element("div", {"styles": this.css.createTemplateFormTitleNode, "text": this.app.lp.createSelectTemplate}).inject(createTemplateAreaNode); var createTemplateCategoryCloseNode = new Element("div.createTemplateCategoryCloseNode", {"styles": this.css.createTemplateCategoryCloseNode }).inject(createTemplateTitleNode); var createTemplateCategoryNode = new Element("div", {"styles": this.css.createTemplateFormCategoryNode}).inject(createTemplateAreaNode); var createTemplateCategoryTitleNode = new Element("div", {"styles": this.css.createTemplateFormCategoryTitleNode, "text": this.app.lp.templateCategory}).inject(createTemplateCategoryNode); var createTemplateContentNode = new Element("div", {"styles": this.css.createTemplateFormContentNode}).inject(createTemplateAreaNode); var createTemplateCategoryAllNode = new Element("div", {"styles": this.css.createTemplateFormCategoryItemNode, "text": this.app.lp.all}).inject(createTemplateCategoryNode); createTemplateCategoryAllNode.addEvent("click", function(){ loadAllTemplates(); }); debugger; this.app.restActions.listFormTemplateCategory(function(json){ json.data.each(function(d){ var createTemplateCategoryItemNode = new Element("div", {"styles": this.css.createTemplateFormCategoryItemNode, "text": d.name+"("+ d.count+")", "value": d.name}).inject(createTemplateCategoryNode); createTemplateCategoryItemNode.addEvent("click", function(){ createTemplateContentNode.empty(); createTemplateCategoryNode.getElements("div").each(function(node, i){ if (i>0) node.setStyles(_self.css.createTemplateFormCategoryItemNode); }); this.setStyles(_self.css.createTemplateFormCategoryItemNode_current); loadTemplates(this.get("value")); }); }.bind(this)); }.bind(this)); var resize = function(){ var size = this.app.content.getSize(); var y = (size.y*0.1)/2; var x = (size.x*0.1)/2; if (y<0) y=0; if (x<0) x=0; createTemplateAreaNode.setStyles({ "top": ""+y+"px", "left": ""+x+"px" }); y = size.y*0.9-createTemplateCategoryNode.getSize().y-70; createTemplateContentNode.setStyle("height", ""+y+"px"); }.bind(this); resize(); this.app.addEvent("resize", resize); var getDefaultFormTemplateList = function(callback){ if (this.defalutFormTemplateList){ if (callback) callback(); }else{ var url = "../x_component_process_FormDesigner/Module/Form/template/templates.json"; MWF.getJSON(url, function(json){ this.defalutFormTemplateList = json; if (callback) callback(); }.bind(this)); } }.bind(this); var loadDefaultTemplate = function(){ getDefaultFormTemplateList(function(){ this.defalutFormTemplateList.each(function(template){ var templateNode = new Element("div", {"styles": this.css.formTemplateNode}).inject(createTemplateContentNode); var templateIconNode = new Element("div", {"styles": this.css.formTemplateIconNode}).inject(templateNode); var templateTitleNode = new Element("div", {"styles": this.css.formTemplateTitleNode, "text": template.title}).inject(templateNode); templateNode.store("template", template.name); templateNode.store("templateCode", template.code); var templateIconImgNode = new Element("img", {"styles": this.css.formTemplateIconImgNode}).inject(templateIconNode); templateIconImgNode.set("src", "../x_component_process_FormDesigner/Module/Form/template/"+template.icon); templateNode.addEvents({ "mouseover": function(){this.setStyles(_self.css.formTemplateNode_over)}, "mouseout": function(){this.setStyles(_self.css.formTemplateNode)}, "mousedown": function(){this.setStyles(_self.css.formTemplateNode_down)}, "mouseup": function(){this.setStyles(_self.css.formTemplateNode_over)}, "click": function(e){ createDefaultForm(e, this.retrieve("template"), this.retrieve("templateCode")); _self.app.removeEvent("resize", resize); createTemplateAreaNode.destroy(); createTemplateMaskNode.destroy(); } }); }.bind(this)) }.bind(this)); }.bind(this); var getFormTemplateList = function(callback){ // if (this.formTemplateList){ // if (callback) callback(); // }else{ this.app.restActions.listFormTemplate(function(json){ this.formTemplateList = json.data; if (callback) callback(); }.bind(this)); // } }.bind(this); var loadTemplates = function(category){ getFormTemplateList(function(){ Object.each(this.formTemplateList, function(v, k){ var flag = (category) ? (k==category) : true; if (flag){ v.each(function(template){ var templateNode = new Element("div", {"styles": this.css.formTemplateNode}).inject(createTemplateContentNode); var templateIconNode = new Element("div", {"styles": this.css.formTemplatePreviewNode}).inject(templateNode); var templateTitleNode = new Element("div", {"styles": this.css.formTemplateTitleNode, "text": template.name}).inject(templateNode); templateNode.store("template", template.id); templateIconNode.set("html", template.outline); var templateActionNode = new Element("img", {"styles": this.css.formTemplateActionNode}).inject(templateIconNode); templateActionNode.addEvent("click", function(e){ var thisNode = this.getParent().getParent(); var id = thisNode.retrieve("template"); _self.app.confirm("wram", e, _self.app.lp.form.deleteFormTemplateTitle, _self.app.lp.form.deleteFormTemplate, 300, 120, function(){ _self.app.restActions.deleteFormTemplate(id, function(json){ thisNode.destroy(); }.bind(this)); this.close(); }, function(){ this.close(); }); e.stopPropagation(); }); //templateIconImgNode.set("src", "../x_component_process_FormDesigner/Module/Form/template/"+template.icon); templateNode.addEvents({ "mouseover": function(){ this.setStyles(_self.css.formTemplateNode_over); if (templateActionNode) templateActionNode.setStyle("display", "block"); }, "mouseout": function(){ this.setStyles(_self.css.formTemplateNode); if (templateActionNode) templateActionNode.setStyle("display", "none"); }, "mousedown": function(){this.setStyles(_self.css.formTemplateNode_down)}, "mouseup": function(){this.setStyles(_self.css.formTemplateNode_over)}, "click": function(e){ createForm(e, this.retrieve("template")); _self.app.removeEvent("resize", resize); createTemplateAreaNode.destroy(); createTemplateMaskNode.destroy(); } }); }.bind(this)); } }.bind(this)); }.bind(this)); }.bind(this); var loadAllTemplates = function(){ createTemplateContentNode.empty(); createTemplateCategoryNode.getElements("div").each(function(node, i){ if (i>0) node.setStyles(_self.css.createTemplateFormCategoryItemNode); }); createTemplateCategoryAllNode.setStyles(_self.css.createTemplateFormCategoryItemNode_current); loadDefaultTemplate(); loadTemplates(); }; loadAllTemplates(); createTemplateCategoryCloseNode.addEvent("click", function(){ this.app.removeEvent("resize", resize); createTemplateAreaNode.destroy(); createTemplateMaskNode.destroy(); }.bind(this)); createTemplateMaskNode.addEvent("click", function(){ this.app.removeEvent("resize", resize); createTemplateAreaNode.destroy(); createTemplateMaskNode.destroy(); }.bind(this)); }, _loadItemDataList: function(callback){ this.app.restActions.listForm(this.app.options.application.id,callback); }, _getItemObject: function(item){ return new MWF.xApplication.process.ProcessManager.FormExplorer.Form(this, item) }, setTooltip: function(){ this.options.tooltip = { "create": MWF.APPPM.LP.form.create, "search": MWF.APPPM.LP.form.search, "searchText": MWF.APPPM.LP.form.searchText, "noElement": MWF.APPPM.LP.form.noFormNoticeText }; }, deleteItems: function(){ this.hideDeleteAction(); while (this.deleteMarkItems.length){ var item = this.deleteMarkItems.shift(); if (this.deleteMarkItems.length){ item.deleteForm(); }else{ item.deleteForm(function(){ // this.reloadItems(); // this.hideDeleteAction(); }.bind(this)); } } } }); MWF.xApplication.process.ProcessManager.FormExplorer.Form = new Class({ Extends: MWF.xApplication.process.ProcessManager.Explorer.Item, _open: function(e){ layout.desktop.getFormDesignerStyle(function(){ var _self = this; var options = { "style": layout.desktop.formDesignerStyle, "appId": "process.FormDesigner"+_self.data.id, "id": _self.data.id, // "application": _self.explorer.app.options.application.id, "application":{ "name": _self.explorer.app.options.application.name, "id": _self.explorer.app.options.application.id }, "onQueryLoad": function(){ this.actions = _self.explorer.actions; this.category = _self; this.options.id = _self.data.id; this.application = _self.explorer.app.options.application; } }; this.explorer.app.desktop.openApplication(e, "process.FormDesigner", options); }.bind(this)); }, _getIcon: function(){ var x = (Math.random()*49).toInt(); return "process_icon_"+x+".png"; }, _getLnkPar: function(){ return { "icon": this.explorer.path+this.explorer.options.style+"/formIcon/lnk.png", "title": this.data.name, "par": "process.FormDesigner#{\"id\": \""+this.data.id+"\"}" }; }, // deleteItem: function(e){ // var _self = this; // this.explorer.app.confirm("info", e, this.explorer.app.lp.form.deleteFormTitle, this.explorer.app.lp.form.deleteForm, 320, 110, function(){ // _self.deleteForm(); // this.close(); // },function(){ // this.close(); // }); // }, deleteForm: function(callback){ this.explorer.app.restActions.deleteForm(this.data.id, function(){ this.node.destroy(); if (callback) callback(); }.bind(this)); }, saveItemAs: function(item){ var id = item.id; var name = item.name; this.explorer.app.restActions.getForm(this.data.id, function(json){ var pcdata = JSON.decode(MWF.decodeJsonString(json.data.data)); var mobiledata = JSON.decode(MWF.decodeJsonString(json.data.mobileData)); pcdata.json.alias = ""; mobiledata.json.alias = ""; var oldName = pcdata.json.name; this.explorer.app.restActions.listForm(id, function(formsJson){ var i=1; while (formsJson.data.some(function(d){ return d.name==pcdata.json.name })){ pcdata.json.name = oldName+"_copy"+i; mobiledata.json.name = oldName+"_copy"+i; i++; } pcdata.id = ""; pcdata.isNewForm = true; pcdata.json.id = ""; pcdata.json.application = id; pcdata.json.applicationName = name; mobiledata.json.id = ""; mobiledata.json.application = id; mobiledata.applicationName = name; this.explorer.app.restActions.listFormFieldWithForm(this.data.id, function(fieldJson){ var fieldList = []; if (fieldJson.data.number) fieldJson.data.number.each(function(f){ fieldList.push({"dataType": "number", "name": f.name}) }); if (fieldJson.data.person) fieldJson.data.person.each(function(f){ fieldList.push({"dataType": "person", "name": f.name}) }); if (fieldJson.data.string) fieldJson.data.string.each(function(f){ fieldList.push({"dataType": "string", "name": f.name}) }); this.explorer.app.restActions.saveForm(pcdata, mobiledata, fieldList, function(){ if (id == this.explorer.app.options.application.id) this.explorer.reload(); }.bind(this)); }.bind(this)); }.bind(this)); }.bind(this)); } });