MWF.APPFD = MWF.xApplication.process.FormDesigner;
MWF.APPFD.options = {
"multitask": true,
"executable": false
};
//MWF.xDesktop.requireApp("process.ProcessManager", "Actions.RestActions", null, false);
MWF.xDesktop.requireApp("process.FormDesigner", "Module.Package", null, false);
MWF.xApplication.process.FormDesigner.Main = new Class({
Extends: MWF.xApplication.Common.Main,
Implements: [Options, Events],
options: {
"style": "default",
"template": "form_classical.json",
"templateId": "",
"name": "process.FormDesigner",
"icon": "icon.png",
"title": MWF.APPFD.LP.title,
"appTitle": MWF.APPFD.LP.title,
"id": "",
"actions": null,
"category": null,
"processData": null,
"mvcStyle": "style.css"
},
onQueryLoad: function(){
this._loadCss();
this.shortcut = true;
if (this.status){
if(this.status.id)this.options.id = this.status.id;
}
if (!this.options.id){
this.options.desktopReload = false;
this.options.title = this.options.title + "-"+MWF.APPFD.LP.newForm;
}
this.actions = MWF.Actions.get("x_processplatform_assemble_designer");
this.lp = MWF.xApplication.process.FormDesigner.LP;
if( !this.application && this.options.application ){
this.application = this.options.application;
}
},
loadApplication: function(callback){
this.createNode();
if (!this.options.isRefresh){
this.maxSize(function(){
this.openForm();
}.bind(this));
}else{
this.openForm();
}
this.addKeyboardEvents();
if (callback) callback();
},
addKeyboardEvents: function(){
this.addEvent("copy", function(){
this.copyModule();
}.bind(this));
this.addEvent("paste", function(e){
if( e.target && e.target.tagName && e.target.tagName.toLowerCase() === "textarea" )return;
this.pasteModule();
e.preventDefault();
}.bind(this));
this.addEvent("cut", function(){
this.cutModule();
}.bind(this));
this.addEvent("keySave", function(e){
this.keySave(e);
}.bind(this));
this.addEvent("keyDelete", function(e){
this.keyDelete(e);
}.bind(this));
},
keySave: function(e){
if (this.shortcut) {
if (this.form) this.saveForm();
e.preventDefault();
}
},
keyDelete: function(e){
if (this.form){
if (this.shortcut){
if (this.form.currentSelectedModule){
var module = this.form.currentSelectedModule;
if (module.moduleType!="form" && module.moduleName.indexOf("$")==-1){
module["delete"](module.node);
}
}
}
}
},
copyModule: function(){
if (this.shortcut) {
if (this.form) {
if (this.form.currentSelectedModule) {
var module = this.form.currentSelectedModule;
if (module.moduleType != "form" && module.moduleName.indexOf("$") == -1) {
this.form.fireEvent("queryGetFormData", [module.node]);
var html = module.getHtml();
var json = module.getJson();
this.form.fireEvent("postGetFormData", [module.node]);
MWF.clipboard.data = {
"type": "form",
"data": {
"html": html,
"json": json
}
};
} else {
MWF.clipboard.data = null;
}
}
// }
}
}
},
cutModule: function(){
if (this.shortcut) {
if (this.form) {
if (this.form.currentSelectedModule) {
var module = this.form.currentSelectedModule;
if (module.moduleType != "form" && module.moduleName.indexOf("$") == -1) {
this.copyModule();
var _form = module.form;
if( _form.history ){
module.addHistoryLog("cut");
}
module.destroy();
_form.currentSelectedModule = null;
_form.selected();
_form = null;
}
}
}
}
},
pasteModule: function(){
if (this.shortcut) {
if (this.form) {
if (MWF.clipboard.data) {
if (MWF.clipboard.data.type == "form") {
var datatemplateJsons = [];
var idMap = {};
var html = MWF.clipboard.data.data.html;
var json = Object.clone(MWF.clipboard.data.data.json);
var tmpNode = Element("div", {
"styles": {"display": "none"},
"html": html
}).inject(this.content);
Object.each(json, function (moduleJson) {
var oid = moduleJson.id;
var id = moduleJson.id;
var idx = 1;
while (this.form.json.moduleList[id]) {
id = oid + "_" + idx;
idx++;
}
if (oid != id) {
idMap[oid] = id;
moduleJson.id = id;
var moduleNode = tmpNode.getElementById(oid);
if (moduleNode) moduleNode.set("id", id);
}
if( moduleJson.type === "Datatemplate" )datatemplateJsons.push(moduleJson);
this.form.json.moduleList[moduleJson.id] = moduleJson;
}.bind(this));
json = null;
datatemplateJsons.each(function (json) {
this.checkDatatemplateRelativeId(json, idMap);
}.bind(this));
var injectNode = this.form.node;
var where = "bottom";
var parent = this.form;
if (this.form.currentSelectedModule) {
var toModule = this.form.currentSelectedModule;
injectNode = toModule.node;
parent = toModule;
if (toModule.moduleType != "container" && toModule.moduleType != "form") {
where = "after";
parent = toModule.parentContainer;
}
}
var moduleList = [];
var copyModuleNode = tmpNode.getFirst();
while (copyModuleNode) {
copyModuleNode.inject(injectNode, where);
var copyModuleJson = this.form.getDomjson(copyModuleNode);
var module = this.form.loadModule(copyModuleJson, copyModuleNode, parent);
module._setEditStyle_custom("id");
module.selected();
moduleList.push( module );
copyModuleNode = tmpNode.getFirst();
}
tmpNode.destroy();
tmpNode = null;
if( this.form.history && moduleList.length){
moduleList[0].addHistoryLog("paste", moduleList);
}
}
}
}
}
},
createNode: function(){
this.content.setStyle("overflow", "hidden");
this.node = new Element("div", {
"styles": {"width": "100%", "height": "100%", "overflow": "hidden"}
}).inject(this.content);
},
openForm: function(){
this.initOptions();
this.loadNodes();
this.loadToolbar();
this.loadFormNode();
this.loadProperty();
this.loadTools(function(){
this.resizeNode();
this.addEvent("resize", this.resizeNode.bind(this));
}.bind(this));
this.loadForm();
MWF.require("MWF.widget.ScrollBar", function(){
new MWF.widget.ScrollBar(this.propertyDomScrollArea, {
"style":"default", "where": "before", "distance": 30, "friction": 4, "indent": false, "axis": {"x": false, "y": true}
});
}.bind(this));
MWF.require("MWF.widget.ScrollBar", function(){
new MWF.widget.ScrollBar(this.historyScrollArea, {
"style":"default", "where": "before", "distance": 30, "friction": 4, "indent": false, "axis": {"x": false, "y": true}
});
}.bind(this));
this.checkSidebars();
},
checkSidebars: function(){
this.positionSidebarsFun = this.positionSidebars.bind(this);
this.positionSidebarsId = window.setInterval(this.positionSidebarsFun, 1000);
this.addEvent("queryClose", function(){
if (this.positionSidebarsId){
window.clearInterval(this.positionSidebarsId);
this.positionSidebarsId = "";
}
}.bind(this));
},
positionSidebars: function(){
if (this.pcForm){
this.pcForm.moduleList.each(function(module){
if (module.moduleName === "sidebar") module.position();
}.bind(this));
}
},
initOptions: function(){
this.toolsData = null;
this.toolbarMode = "all";
this.tools = [];
this.toolGroups = [];
this.toolbarDecrease = 0;
this.designNode = null;
this.form = null;
},
loadNodes: function(){
this.toolbarNode = new Element("div", {
"styles": this.css.toolbarNode,
"events": {"selectstart": function(e){e.preventDefault();}}
}).inject(this.node);
this.propertyNode = new Element("div", {
"styles": this.css.propertyNode
}).inject(this.node)
this.formNode = new Element("div", {
"styles": this.css.formNode
}).inject(this.node);
if (this.options.style=="bottom") this.propertyNode.inject(this.formNode, "after");
},
//loadToolbar----------------------
loadToolbar: function(){
this.toolbarTitleNode = new Element("div", {
"styles": this.css.toolbarTitleNode,
"text": MWF.APPFD.LP.tools
}).inject(this.toolbarNode);
this.toolbarTitleActionNode = new Element("div", {
"styles": this.css.toolbarTitleActionNode,
"events": {
"click": function(e){
this.switchToolbarMode();
}.bind(this)
}
}).inject(this.toolbarNode);
this.toolbarTitleCategoryActionNode = new Element("div", {
"styles": this.css.toolbarTitleCategoryActionNode
}).inject(this.toolbarNode);
this.categoryActionMenu = new o2.xDesktop.Menu(this.toolbarTitleCategoryActionNode, {
"event": "click", "style": "flatUser", "offsetX": 0, "offsetY": 0, "container": this.node,
"onQueryShow": this.showCategoryMenu.bind(this)
});
this.categoryActionMenu.load();
this.toolbarGroupContentNode = new Element("div", {"styles": this.css.toolbarGroupContentNode}).inject(this.toolbarNode);
this.toolbarGroupContentNode.addEvent("selectstart", function(e){
e.preventDefault();
e.stopPropagation();
});
},
showCategoryMenu: function(){
this.categoryActionMenu.items.each(function(item){
if (this.currentToolGroup && this.currentToolGroup.data.text==item.options.text){
item.setDisable(true);
var imgDiv = item.item.getFirst();
var img = imgDiv.getElement("img");
if (!img) img = new Element("img", {"styles": item.menu.css.menuItemImg}).inject(imgDiv);
img.set("src", this.path+this.options.style+"/check.png");
}else{
item.setDisable(false);
var imgDiv = item.item.getFirst();
var img = imgDiv.getElement("img");
if (img) img.destroy();
}
}.bind(this));
},
switchToolbarMode: function(){
if (this.toolbarMode=="all"){
var size = this.toolbarNode.getSize();
this.toolbarDecrease = (size.x.toFloat())-60;
this.tools.each(function(node){
node.getLast().setStyle("display", "none");
});
this.toolbarTitleNode.set("text", "");
this.toolbarNode.setStyle("width", "60px");
var formMargin = this.formNode.getStyle("margin-left").toFloat();
formMargin = formMargin - this.toolbarDecrease;
this.formNode.setStyle("margin-left", ""+formMargin+"px");
this.toolbarTitleActionNode.setStyles(this.css.toolbarTitleActionNodeRight);
this.toolbarGroupContentNode.getElements(".o2formModuleTools").hide();
this.toolbarMode="simple";
}else{
sizeX = 60 + this.toolbarDecrease;
var formMargin = this.formNode.getStyle("margin-left").toFloat();
formMargin = formMargin + this.toolbarDecrease;
this.toolbarNode.setStyle("width", ""+sizeX+"px");
this.formNode.setStyle("margin-left", ""+formMargin+"px");
this.tools.each(function(node){
node.getLast().setStyle("display", "block");
});
this.toolbarTitleNode.set("text", MWF.APPFD.LP.tools);
this.toolbarTitleActionNode.setStyles(this.css.toolbarTitleActionNode);
this.toolbarGroupContentNode.getElements(".o2formModuleTools").show();
this.toolbarMode="all";
}
},
//loadFormNode------------------------------
loadFormNode: function(){
this.formToolbarNode = new Element("div", {
"styles": this.css.formToolbarNode
}).inject(this.formNode);
this.loadFormToolbar();
this.formContentNode = new Element("div", {
"styles": this.css.formContentNode
}).inject(this.formNode);
this.loadFormContent(function(){
if (this.designDcoument) this.designDcoument.body.setStyles(this.css.designBody);
if (this.designNode) this.designNode.setStyles(this.css.designNode);
}.bind(this));
},
loaddesignerActionNode: function(){
this.pcDesignerActionNode = this.formToolbarNode.getElement("#MWFFormPCDesignerAction");
this.mobileDesignerActionNode = this.formToolbarNode.getElement("#MWFFormMobileDesignerAction");
this.currentDesignerMode = "PC";
this.pcDesignerActionNode.setStyles(this.css.designerActionNode_current);
this.mobileDesignerActionNode.setStyles(this.css.designerActionNode);
var iconNode = new Element("div", {"styles": this.css.designerActionPcIconNode}).inject(this.pcDesignerActionNode);
iconNode = new Element("div", {"styles": this.css.designerActionMobileIconNode}).inject(this.mobileDesignerActionNode);
var textNode = new Element("div", {"styles": this.css.designerActiontextNode, "text": "PC"}).inject(this.pcDesignerActionNode);
textNode = new Element("div", {"styles": this.css.designerActiontextNode, "text": "Mobile"}).inject(this.mobileDesignerActionNode);
this.pcDesignerActionNode.addEvent("click", function(){
if (this.currentDesignerMode!="PC"){
this.changeDesignerModeToPC();
}
}.bind(this));
this.mobileDesignerActionNode.addEvent("click", function(){
if (this.currentDesignerMode=="PC"){
this.changeDesignerModeToMobile();
}
}.bind(this));
this.formToolbarNode.setStyles({"position":"relative"});
},
changeDesignerModeToPC: function(){
this.pcDesignerActionNode.setStyles(this.css.designerActionNode_current);
this.mobileDesignerActionNode.setStyles(this.css.designerActionNode);
this.designMobileNode.setStyle("display", "none");
this.designNode.setStyle("display", "block");
if (this.form.currentSelectedModule){
if (this.form.currentSelectedModule==this){
return true;
}else{
this.form.currentSelectedModule.unSelected();
}
}
if (this.form.propertyMultiTd){
this.form.propertyMultiTd.hide();
this.form.propertyMultiTd = null;
}
this.form.unSelectedMulti();
if (this.form.designTabPageScriptAreaNode) this.form.designTabPageScriptAreaNode.hide();
this.form = this.pcForm;
if ((this.scriptPage && this.scriptPage.isShow) || this.scriptPanel){
this.loadAllScript();
}
this.currentDesignerMode = "PC";
this.historyArea.show();
this.historyAreaMobile.hide();
this.currentHistoryNode = this.historyArea;
},
changeDesignerModeToMobile: function(){
this.pcDesignerActionNode.setStyles(this.css.designerActionNode);
this.mobileDesignerActionNode.setStyles(this.css.designerActionNode_current);
this.designMobileNode.setStyle("display", "block");
this.designNode.setStyle("display", "none");
if (this.form.currentSelectedModule){
if (this.form.currentSelectedModule==this){
return true;
}else{
this.form.currentSelectedModule.unSelected();
}
}
if (this.form.propertyMultiTd){
this.form.propertyMultiTd.hide();
this.form.propertyMultiTd = null;
}
this.form.unSelectedMulti();
if (!this.mobileForm){
this.mobileForm = new MWF.FCForm(this, this.designMobileNode, {"mode": "Mobile"});
if (!Object.keys(this.formMobileData.json.moduleList).length){
this.formMobileData = Object.clone(this.formData);
}
this.mobileForm.load(this.formMobileData);
}
if (this.form.designTabPageScriptAreaNode) this.form.designTabPageScriptAreaNode.hide();
this.form = this.mobileForm;
if ((this.scriptPage && this.scriptPage.isShow) || this.scriptPanel){
this.loadAllScript();
}
this.currentDesignerMode = "Mobile";
this.historyArea.hide();
this.historyAreaMobile.show();
this.currentHistoryNode = this.historyAreaMobile;
},
loadFormToolbar: function(callback){
this.getFormToolbarHTML(function(toolbarNode){
var spans = toolbarNode.getElements("span");
spans.each(function(item, idx){
var img = item.get("MWFButtonImage");
if (img){
item.set("MWFButtonImage", this.path+""+this.options.style+"/formtoolbar/"+img);
}
}.bind(this));
$(toolbarNode).inject(this.formToolbarNode);
MWF.require("MWF.widget.Toolbar", function(){
this.formToolbar = new MWF.widget.Toolbar(toolbarNode, {"style": "ProcessCategory"}, this);
this.formToolbar.load();
this.loaddesignerActionNode();
if (callback) callback();
}.bind(this));
}.bind(this));
},
getFormToolbarHTML: function(callback){
var toolbarUrl = this.path+this.options.style+"/formToolbars.html";
MWF.getRequestText(toolbarUrl, function(responseText, responseXML){
var htmlString = responseText;
htmlString = o2.bindJson(htmlString, {"lp": this.lp.formToolbar});
var temp = new Element('div').set('html', htmlString);
if (callback) callback( temp.childNodes[0] );
}.bind(this));
},
loadFormContent: function(callback){
//var iframe = new Element("iframe#iframeaa", {
// "styles": {
// "width": "100%",
// "height": "100%"
// },
// //"src": "../x_component_process_FormDesigner/$Main/blank.html",
// "border": "0"
//}).inject(this.formContentNode);
// window.setTimeout(function(){
// iframe.contentDocument.designMode = "on";
//
//
// var x = document.id("iframeaa");
// this.designNode = document.id(iframe.contentDocument.body, false, iframe.contentDocument);
// this.designNode.setStyle("margin", "0px");
// this.designNode.setStyles(this.css.designNode);
MWF.require("MWF.widget.Tab", null, false);
this.designTabNode = new Element("div").inject(this.formContentNode);
this.designTab = new MWF.widget.Tab(this.designTabNode, {"style": "design"});
this.designTab.load();
this.designTabPageAreaNode = Element("div");
this.designNode = new Element("div", {
"styles": this.css.designNode
}).inject(this.designTabPageAreaNode);
//this.designContentNode = new Element("div", {
// "styles": {"overflow": "visible"}
//}).inject(this.designNode);
//MWF.require("MWF.widget.ScrollBar", function(){
// new MWF.widget.ScrollBar(this.designNode, {"distance": 100});
//}.bind(this));
this.designMobileNode = new Element("div", {
"styles": this.css.designMobileNode
}).inject(this.designTabPageAreaNode);
//MWF.require("MWF.widget.ScrollBar", function(){
// new MWF.widget.ScrollBar(this.designMobileNode, {"distance": 50, "style": "xApp_mobileForm"});
//}.bind(this));
// }.bind(this), 2000);
this.designTabScriptAreaNode = Element("div", {"styles": this.css.designTabScriptAreaNode});
this.designPage = this.designTab.addTab(this.designTabPageAreaNode, this.lp.design);
this.scriptPage = this.designTab.addTab(this.designTabScriptAreaNode, this.lp.script);
this.setScriptPageEvent();
this.designPage.showTabIm();
this.scriptPage.addEvent("postShow", function(){
this.checkLoadAllScript();
this.fireEvent("resize");
}.bind(this));
this.designPage.addEvent("postShow", function(){
this.fireEvent("resize");
}.bind(this));
},
createScriptPanel: function(p, s){
MWF.require("MWF.widget.Panel", function(){
this.scriptPanel = new MWF.widget.Panel(this.designTabScriptAreaNode, {
"title": this.lp.script,
"minLeft": "500",
"minTop": "1",
"style": "page",
"target": this.content,
"limitMove": false,
"isClose": false,
"width": s.x,
"height": s.y,
"top": p.y,
"left": p.x,
"onPostLoad": function(){
this.loadAllScript();
this.fireEvent("resize");
}.bind(this),
"onResize": function(){
this.fireEvent("resize");
}.bind(this),
"onDrag": function(el, e){
if (el.getStyle("top").toInt()<0) el.setStyle("top", "0px");
if (!this.scriptPage.tab.tabNodeContainer.isOutside(e)){
this.scriptPage.tabNode.show();
this.scriptPanel.container.setStyle("opacity", "0.5");
}else{
this.scriptPage.tabNode.hide();
this.scriptPanel.container.setStyle("opacity", "1");
}
}.bind(this),
"onCompleteMove": function(el, e){
if (!this.scriptPage.tab.tabNodeContainer.isOutside(e)){
this.scriptPage.tabNode.show();
this.designTabScriptAreaNode.inject(this.designTab.contentNodeContainer.getLast());
this.fireEvent("resize");
this.scriptPage.showTabIm();
this.scriptPanel.closePanel();
this.scriptPanel = null;
}
}.bind(this)
});
this.scriptPanel.load();
}.bind(this));
},
createScriptPageDragNode: function(e){
var size = this.scriptPage.tab.contentNodeContainer.getSize();
var position = this.scriptPage.tab.contentNodeContainer.getPosition(this.content);
if (!this.scriptPageContentDrag){
var dragNode = new Element("div", {"styles": this.css.scriptPageDragNode}).inject(this.content);
this.scriptPageContentDrag = new Drag.Move(dragNode, {
"droppables": [this.scriptPage.tab.tabNodeContainer],
"onEnter": function(el, drop){
this.scriptPage.tabNode.show();
this.designTabScriptAreaNode.show();
// this.scriptPageContentDrag.stop();
// this.scriptPageContentDrag.detach();
this.scriptPageContentDrag = null;
dragNode.destroy();
this.scriptPageDrag.start(e);
}.bind(this),
"onComplete": function(el, e){
if (this.scriptPage.tab.tabNodeContainer.isOutside(e)){
this.createScriptPanel(dragNode.getPosition(this.content), dragNode.getSize());
this.designPage.showTabIm();
}
this.scriptPageContentDrag = null;
if (dragNode) dragNode.destroy();
this.designTabScriptAreaNode.show();
}.bind(this)
});
}
var tabPosition = this.scriptPage.tabNode.getPosition();
var dx = e.page.x-tabPosition.x;
var dy = e.page.y-tabPosition.y;
this.scriptPage.tabNode.hide();
this.designTabScriptAreaNode.hide();
var w = size.x*0.7;
var h = size.y*0.7;
var x = position.x+dx;
var y = position.y+dy-20;
dragNode.setStyles({
"width": ""+w+"px",
"height": ""+h+"px",
"top": ""+y+"px",
"left": ""+x+"px"
});
this.scriptPageContentDrag.start(e);
},
setScriptPageEvent: function(){
this.scriptPageDrag = new Drag(this.scriptPage.tabNode, {
"snap": 20,
"onStart": function(el,e){
el.setStyle("position", "static");
},
"onDrag": function(el,e){
if (this.scriptPage.tab.tabNodeContainer.isOutside(e)){
this.scriptPageDrag.stop();
el.setStyle("left", "auto");
this.createScriptPageDragNode(e);
}
}.bind(this),
"onComplete": function(el){
el.setStyle("left", "auto");
//el.setStyle("position", "relative");
}.bind(this)
});
},
checkLoadAllScript: function(){
if (this.form){
this.loadAllScript();
}else{
this.designPage.showTabIm();
}
},
loadAllScript: function(){
if (!this.form.designTabPageScriptAreaNode) this.form.designTabPageScriptAreaNode = Element("div", {"styles": this.css.designTabScriptPcAreaNode}).inject(this.designTabScriptAreaNode);
this.form.designTabPageScriptAreaNode.show();
if (!this.form.scriptDesigner){
MWF.xDesktop.requireApp("portal.PageDesigner", "Script", function(){
this.form.scriptDesigner = new MWF.xApplication.portal.PageDesigner.Script(this, this.form.designTabPageScriptAreaNode, this.form.json);
// var moduleJson = this.pageData.json;
// if (moduleJson.jsheader){
// if (moduleJson.jsheader.code){
//
// }
// }
}.bind(this));
}
},
reloadPropertyStyles: function(){
//MWF.release(this.css);
this.css = null;
this.cssPath = "../x_component_"+this.options.name.replace(/\./g, "_")+"/$Main/"+this.options.style+"/css.wcss";
this._loadCss();
if (this.options.style=="bottom"){
this.propertyNode.inject(this.formNode, "after");
this.propertyTitleNode.setStyle("cursor", "row-resize");
this.loadPropertyResizeBottom();
}else{
this.propertyNode.inject(this.formNode, "before");
this.propertyTitleNode.setStyle("cursor", "default");
if (this.propertyResizeBottom) this.propertyResizeBottom.detach();
}
this.formNode.clearStyles(false);
this.formNode.setStyles(this.css.formNode);
this.propertyNode.clearStyles(false);
this.propertyNode.setStyles(this.css.propertyNode);
this.propertyTitleNode.clearStyles(false);
this.propertyTitleNode.setStyles(this.css.propertyTitleNode);
this.propertyResizeBar.clearStyles(false);
this.propertyResizeBar.setStyles(this.css.propertyResizeBar);
this.propertyContentNode.clearStyles(false);
this.propertyContentNode.setStyles(this.css.propertyContentNode);
this.propertyDomContentArea.clearStyles(false);
this.propertyDomContentArea.setStyles(this.css.propertyDomContentArea);
this.propertyDomScrollArea.clearStyles(false);
this.propertyDomScrollArea.setStyles(this.css.propertyDomScrollArea);
this.propertyDomArea.clearStyles(false);
this.propertyDomArea.setStyles(this.css.propertyDomArea);
this.propertyContentArea.clearStyles(false);
this.propertyContentArea.setStyles(this.css.propertyContentArea);
this.propertyContentResizeNode.clearStyles(false);
this.propertyContentResizeNode.setStyles(this.css.propertyContentResizeNode);
this.propertyTitleActionNode.clearStyles(false);
this.propertyTitleActionNode.setStyles(this.css.propertyTitleActionNode);
this.resizeNode();
},
//loadProperty------------------------
loadProperty: function(){
this.propertyTitleActionNode = new Element("div", {
"styles": this.css.propertyTitleActionNode
}).inject(this.propertyNode);
this.propertyTitleActionNode.addEvent("click", function(){
this.options.style = (this.options.style=="default") ? "bottom" : "default";
MWF.UD.putData("formDesignerStyle", {"style": this.options.style});
this.reloadPropertyStyles();
}.bind(this));
this.propertyTitleNode = new Element("div", {
"styles": this.css.propertyTitleNode,
"text": MWF.APPFD.LP.property
}).inject(this.propertyNode);
if (this.options.style=="bottom"){
this.propertyTitleNode.setStyle("cursor", "row-resize");
this.loadPropertyResizeBottom();
}
this.propertyResizeBar = new Element("div", {
"styles": this.css.propertyResizeBar
}).inject(this.propertyNode);
this.loadPropertyResize();
this.propertyContentNode = new Element("div", {
"styles": this.css.propertyContentNode
}).inject(this.propertyNode);
this.propertyDomContentArea = new Element("div", {
"styles": this.css.propertyDomContentArea
}).inject(this.propertyContentNode);
this.propertyDomTabArea = new Element("div").inject(this.propertyDomContentArea);
// this.propertyDomArea = new Element("div", {
// "styles": this.css.propertyDomArea
// }).inject(this.propertyDomScrollArea);
this.loadPropertyTab();
this.propertyDomPercent = 0.3;
this.propertyContentResizeNode = new Element("div", {
"styles": this.css.propertyContentResizeNode
}).inject(this.propertyContentNode);
this.propertyContentArea = new Element("div", {
"styles": this.css.propertyContentArea
}).inject(this.propertyContentNode);
this.loadPropertyContentResize();
},
loadPropertyTab: function (callback) {
var _self = this;
MWF.require("MWF.widget.Tab", null, false);
this.propertyDomTab = new MWF.widget.Tab(this.propertyDomTabArea, {"style": "formPropertyList"});
this.propertyDomTab.load();
this.tabDomNode = Element("div");
this.propertyDomScrollArea = new Element("div", {
"styles": this.css.propertyDomScrollArea
}).inject(this.tabDomNode);
this.propertyDomArea = new Element("div", {
"styles": this.css.propertyDomArea
}).inject(this.propertyDomScrollArea);
this.tabHistoryNode = Element("div");
this.historyScrollArea = new Element("div", {
"styles": this.css.propertyDomScrollArea
}).inject(this.tabHistoryNode);
this.historyArea = new Element("div", {
"styles": this.css.propertyDomArea
}).inject(this.historyScrollArea);
this.historyAreaMobile = new Element("div", {
"styles": this.css.propertyDomArea
}).inject(this.historyScrollArea);
this.historyAreaMobile.hide();
this.currentHistoryNode = this.historyArea;
this.domPage = this.propertyDomTab.addTab(this.tabDomNode, this.lp.componentTree);
this.historyPage = this.propertyDomTab.addTab(this.tabHistoryNode, this.lp.history);
this.domPage.showTabIm();
this.domPage.addEvent("postShow", function () {
var module = this.form.currentSelectedModule;
if (module && module.treeNode){
(new Fx.Scroll(this.propertyDomScrollArea)).toElement(module.treeNode.node);
}
}.bind(this));
// this.runPage.addEvent("postShow", function () {
// this.selected();
// }.bind(this));
},
loadPropertyResizeBottom: function(){
if (!this.propertyResizeBottom){
this.propertyResizeBottom = new Drag(this.propertyTitleNode,{
"snap": 1,
"onStart": function(el, e){
var x = (Browser.name=="firefox") ? e.event.clientX : e.event.x;
var y = (Browser.name=="firefox") ? e.event.clientY : e.event.y;
el.store("position", {"x": x, "y": y});
var size = this.propertyNode.getSize();
el.store("initialWidth", size.x);
el.store("initialHeight", size.y);
}.bind(this),
"onDrag": function(el, e){
// var x = e.event.x;
var y = (Browser.name=="firefox") ? e.event.clientY : e.event.y;
var bodySize = this.content.getSize();
var position = el.retrieve("position");
var initialHeight = el.retrieve("initialHeight").toFloat();
var dy = position.y.toFloat()-y.toFloat();
var height = initialHeight+dy;
if (height> bodySize.y/1.5) height = bodySize.y/1.5;
if (height<40) height = 40;
var percent = 1-(height/bodySize.y);
this.resizeNode(percent);
//var formNodeHeight = bodySize.y-height;
//this.formNode.setStyle("height", ""+formNodeHeight+"px");
//this.propertyNode.setStyle("height", ""+height+"px");
}.bind(this)
});
}else{
this.propertyResizeBottom.attach();
}
},
loadPropertyResize: function(){
// var size = this.propertyNode.getSize();
// var position = this.propertyResizeBar.getPosition();
this.propertyResize = new Drag(this.propertyResizeBar,{
"snap": 1,
"onStart": function(el, e){
var x = (Browser.name=="firefox") ? e.event.clientX : e.event.x;
var y = (Browser.name=="firefox") ? e.event.clientY : e.event.y;
el.store("position", {"x": x, "y": y});
var size = this.propertyNode.getSize();
el.store("initialWidth", size.x);
}.bind(this),
"onDrag": function(el, e){
var x = (Browser.name=="firefox") ? e.event.clientX : e.event.x;
// var y = e.event.y;
var bodySize = this.content.getSize();
var position = el.retrieve("position");
var initialWidth = el.retrieve("initialWidth").toFloat();
var dx = position.x.toFloat()-x.toFloat();
var width = initialWidth+dx;
if (width> bodySize.x/2) width = bodySize.x/2;
if (width<40) width = 40;
this.formNode.setStyle("margin-right", width+1);
this.propertyNode.setStyle("width", width);
}.bind(this)
});
},
propertyResizeDragTopBottom: function(el, e){
var size = this.propertyContentNode.getSize();
// var x = e.event.x;
var y = e.event.y;
var position = el.retrieve("position");
var dy = y.toFloat()-position.y.toFloat();
var initialHeight = el.retrieve("initialHeight").toFloat();
var height = initialHeight+dy;
if (height<40) height = 40;
if (height> size.y-40) height = size.y-40;
this.propertyDomPercent = height/size.y;
this.setPropertyContentResize();
},
propertyResizeDragLeftRight: function(el, e){
var size = this.propertyContentNode.getSize();
var x = (Browser.name=="firefox") ? e.event.clientX : e.event.x;
//var y = e.event.y;
var position = el.retrieve("position");
var dx = x.toFloat()-position.x.toFloat();
var initialWidth = el.retrieve("initialWidth").toFloat();
var width = initialWidth+dx;
if (width<40) width = 40;
if (width> size.x-40) width = size.x-40;
this.propertyDomPercent = width/size.x;
this.setPropertyContentResizeBottom();
},
loadPropertyContentResize: function(){
this.propertyContentResize = new Drag(this.propertyContentResizeNode, {
"snap": 1,
"onStart": function(el, e){
var x = (Browser.name=="firefox") ? e.event.clientX : e.event.x;
var y = (Browser.name=="firefox") ? e.event.clientY : e.event.y;
el.store("position", {"x": x, "y": y});
var size = this.propertyDomContentArea.getSize();
el.store("initialHeight", size.y);
el.store("initialWidth", size.x);
}.bind(this),
"onDrag": function(el, e){
if (this.options.style=="bottom"){
this.propertyResizeDragLeftRight(el, e);
}else{
this.propertyResizeDragTopBottom(el, e);
}
}.bind(this)
});
},
setPropertyContentResizeBottom: function(){
var size = this.propertyContentNode.getSize();
var resizeNodeSize = this.propertyContentResizeNode.getSize();
var width = size.x-resizeNodeSize.x-6;
var domWidth = this.propertyDomPercent*width;
var contentMargin = domWidth+resizeNodeSize.x+6;
this.propertyDomContentArea.setStyle("width", ""+domWidth+"px");
this.propertyContentArea.setStyle("margin-left", ""+contentMargin+"px");
},
setPropertyContentResize: function(){
var size = this.propertyContentNode.getSize();
var resizeNodeSize = this.propertyContentResizeNode.getSize();
var height = size.y-resizeNodeSize.y;
var domHeight = this.propertyDomPercent*height;
var contentHeight = height-domHeight;
this.propertyDomContentArea.setStyle("height", ""+domHeight+"px");
this.propertyDomScrollArea.setStyle("height", ""+(domHeight-28)+"px");
this.historyScrollArea.setStyle("height", ""+(domHeight-28)+"px");
this.propertyContentArea.setStyle("height", ""+contentHeight+"px");
if (this.form){
if (this.form.currentSelectedModule){
if (this.form.currentSelectedModule.property){
var tab = this.form.currentSelectedModule.property.propertyTab;
if (tab){
var tabTitleSize = tab.tabNodeContainer.getSize();
tab.pages.each(function(page){
var topMargin = page.contentNodeArea.getStyle("margin-top").toFloat();
var bottomMargin = page.contentNodeArea.getStyle("margin-bottom").toFloat();
var tabContentNodeAreaHeight = contentHeight - topMargin - bottomMargin - tabTitleSize.y.toFloat()-15;
page.contentNodeArea.setStyle("height", tabContentNodeAreaHeight);
}.bind(this));
}
}
}
}
},
//loadTools------------------------------
loadTools: function(callback){
o2.loadCss("../o2_lib/vue/element/index.css");
this.getToolResource(function(){
this.toolsGroupData.forEach(function(o){
//var o = this.toolsGroupData[key];
this.toolGroups.push(new MWF.xApplication.process.FormDesigner.ToolsGroup(o, this, o.name === this.currentUserDefaultTool));
}, this);
if (callback) callback();
}.bind(this));
},
getToolResource: function(callback){
var check = function () {
var list = this.toolsGroupData.filter(function(o){
return o.name === this.currentUserDefaultTool
}.bind(this));
if( list.length < 1 )this.currentUserDefaultTool = "default";
callback();
}.bind(this);
this.getGroups(function(){
if(this.toolsGroupData && this.currentUserDefaultTool )check();
}.bind(this));
this.getDefaultTool(function(){
if(this.toolsGroupData && this.currentUserDefaultTool )check();
}.bind(this));
},
getGroups: function(callback){
if (this.toolsGroupData){
if (callback) callback();
}else{
var toolsGroupDataUrl = this.path+this.options.style+"/toolsGroup.json";
o2.JSON.get(toolsGroupDataUrl, function(responseJSON){
this.toolsGroupData = responseJSON;
if (callback) callback();
}.bind(this));
}
},
getDefaultTool: function(callback){
if( typeOf(this.currentUserDefaultTool) === "string" ){
if (callback) callback();
}else{
o2.UD.getDataJson("processTools", function (json) {
this.currentUserDefaultTool = (json && json.defaultTool) || "default";
if (callback) callback();
}.bind(this));
}
},
setDefaultTool: function(defaultTools, callback){
o2.UD.getDataJson("processTools", function (json) {
if(!json)json = {};
json.defaultTool = defaultTools;
o2.UD.putData("processTools", json, function () {
if (callback) callback();
}.bind(this));
}.bind(this));
},
//resizeNode------------------------------------------------
resizeNodeLeftRight: function(){
var nodeSize = this.node.getSize();
this.toolbarNode.setStyle("height", ""+nodeSize.y+"px");
this.formNode.setStyle("height", ""+nodeSize.y+"px");
this.propertyNode.setStyle("height", ""+nodeSize.y+"px");
//nodeSize = {"x": nodeSize.x, "y": nodeSize.y*0.6};
var formToolbarMarginTop = this.formToolbarNode.getStyle("margin-top").toFloat();
var formToolbarMarginBottom = this.formToolbarNode.getStyle("margin-bottom").toFloat();
var allFormToolberSize = this.formToolbarNode.getComputedSize();
var y = nodeSize.y - allFormToolberSize.totalHeight - formToolbarMarginTop - formToolbarMarginBottom;
this.formContentNode.setStyle("height", ""+y+"px");
var tabSize = this.designTab.tabNodeContainer.getComputedSize();
var tabMarginTop = this.designTab.tabNodeContainer.getStyle("margin-top").toFloat();
var tabMarginBottom = this.designTab.tabNodeContainer.getStyle("margin-bottom").toFloat();
y = y-tabSize.totalHeight-tabMarginTop-tabMarginBottom;
this.designTab.contentNodeContainer.setStyle("height", ""+y+"px");
if (this.designNode){
var designMarginTop = this.designNode.getStyle("margin-top").toFloat();
var designMarginBottom = this.designNode.getStyle("margin-bottom").toFloat();
y = y - designMarginTop - designMarginBottom;
this.designNode.setStyle("height", ""+y+"px");
}
var titleSize = this.toolbarTitleNode.getSize();
var titleMarginTop = this.toolbarTitleNode.getStyle("margin-top").toFloat();
var titleMarginBottom = this.toolbarTitleNode.getStyle("margin-bottom").toFloat();
var titlePaddingTop = this.toolbarTitleNode.getStyle("padding-top").toFloat();
var titlePaddingBottom = this.toolbarTitleNode.getStyle("padding-bottom").toFloat();
y = titleSize.y+titleMarginTop+titleMarginBottom+titlePaddingTop+titlePaddingBottom;
y = nodeSize.y-y;
this.toolbarGroupContentNode.setStyle("height", ""+y+"px");
var groupHeight = 0;
// this.toolGroups.each(function(g){
// groupHeight += g.toolbarGroupTitleNode.getSize().y;
// });
var contentHeight = y-groupHeight-5;
this.toolGroups.each(function(g){
g.setContentHeight(contentHeight);
//g.toolbarContentNode.setStyle("height", ""+contentHeight+"px");
});
titleSize = this.propertyTitleNode.getSize();
titleMarginTop = this.propertyTitleNode.getStyle("margin-top").toFloat();
titleMarginBottom = this.propertyTitleNode.getStyle("margin-bottom").toFloat();
titlePaddingTop = this.propertyTitleNode.getStyle("padding-top").toFloat();
titlePaddingBottom = this.propertyTitleNode.getStyle("padding-bottom").toFloat();
y = titleSize.y+titleMarginTop+titleMarginBottom+titlePaddingTop+titlePaddingBottom;
y = nodeSize.y-y;
this.propertyContentNode.setStyle("height", ""+y+"px");
this.propertyResizeBar.setStyle("height", ""+y+"px");
},
resizeNodeTopBottom: function(percent){
var nodeSize = this.node.getSize();
this.toolbarNode.setStyle("height", ""+nodeSize.y+"px");
var percentNumber = percent || 0.6
var designerHeight = nodeSize.y*percentNumber;
var propertyHeight = nodeSize.y - designerHeight;
this.formNode.setStyle("height", ""+designerHeight+"px");
this.propertyNode.setStyle("height", ""+propertyHeight+"px");
var formToolbarMarginTop = this.formToolbarNode.getStyle("margin-top").toFloat();
var formToolbarMarginBottom = this.formToolbarNode.getStyle("margin-bottom").toFloat();
var allFormToolberSize = this.formToolbarNode.getComputedSize();
var y = designerHeight - allFormToolberSize.totalHeight - formToolbarMarginTop - formToolbarMarginBottom;
// this.formContentNode.setStyle("height", ""+designerHeight+"px");
var tabSize = this.designTab.tabNodeContainer.getComputedSize();
var tabMarginTop = this.designTab.tabNodeContainer.getStyle("margin-top").toFloat();
var tabMarginBottom = this.designTab.tabNodeContainer.getStyle("margin-bottom").toFloat();
y = y-tabSize.totalHeight-tabMarginTop-tabMarginBottom;
this.designTab.contentNodeContainer.setStyle("height", ""+y+"px");
if (this.designNode){
var designMarginTop = this.designNode.getStyle("margin-top").toFloat();
var designMarginBottom = this.designNode.getStyle("margin-bottom").toFloat();
y = y - designMarginTop - designMarginBottom;
this.designNode.setStyle("height", ""+y+"px");
}
var titleSize = this.toolbarTitleNode.getSize();
var titleMarginTop = this.toolbarTitleNode.getStyle("margin-top").toFloat();
var titleMarginBottom = this.toolbarTitleNode.getStyle("margin-bottom").toFloat();
var titlePaddingTop = this.toolbarTitleNode.getStyle("padding-top").toFloat();
var titlePaddingBottom = this.toolbarTitleNode.getStyle("padding-bottom").toFloat();
y = titleSize.y+titleMarginTop+titleMarginBottom+titlePaddingTop+titlePaddingBottom;
y = nodeSize.y-y;
this.toolbarGroupContentNode.setStyle("height", ""+y+"px");
var groupHeight = 0;
// this.toolGroups.each(function(g){
// groupHeight += g.toolbarGroupTitleNode.getSize().y;
// });
var contentHeight = y-groupHeight-5;
this.toolGroups.each(function(g){
g.setContentHeight(contentHeight);
});
titleSize = this.propertyTitleNode.getSize();
titleMarginTop = this.propertyTitleNode.getStyle("margin-top").toFloat();
titleMarginBottom = this.propertyTitleNode.getStyle("margin-bottom").toFloat();
titlePaddingTop = this.propertyTitleNode.getStyle("padding-top").toFloat();
titlePaddingBottom = this.propertyTitleNode.getStyle("padding-bottom").toFloat();
y = titleSize.y+titleMarginTop+titleMarginBottom+titlePaddingTop+titlePaddingBottom;
y = propertyHeight-y;
this.propertyContentNode.setStyle("height", ""+y+"px");
this.propertyResizeBar.setStyle("height", ""+y+"px");
this.propertyDomContentArea.setStyle("height", ""+y+"px");
this.propertyDomScrollArea.setStyle("height", ""+(y-28)+"px");
this.historyScrollArea.setStyle("height", ""+(y-28)+"px");
this.propertyContentResizeNode.setStyle("height", ""+y+"px");
this.propertyContentArea.setStyle("height", ""+y+"px");
if (this.form){
if (this.form.currentSelectedModule){
if (this.form.currentSelectedModule.property){
var tab = this.form.currentSelectedModule.property.propertyTab;
if (tab){
var tabTitleSize = tab.tabNodeContainer.getSize();
tab.pages.each(function(page){
var topMargin = page.contentNodeArea.getStyle("margin-top").toFloat();
var bottomMargin = page.contentNodeArea.getStyle("margin-bottom").toFloat();
var tabContentNodeAreaHeight = y - topMargin - bottomMargin - tabTitleSize.y.toFloat()-15;
page.contentNodeArea.setStyle("height", tabContentNodeAreaHeight);
}.bind(this));
}
}
}
}
},
resizeNode: function(percent){
if (this.options.style=="bottom"){
this.resizeNodeTopBottom(percent);
this.setPropertyContentResizeBottom();
}else{
this.resizeNodeLeftRight(percent);
this.setPropertyContentResize();
}
},
//loadForm------------------------------------------
loadForm: function(){
// try{
this.getFormData(function(){
this.pcForm = new MWF.FCForm(this, this.designNode);
this.pcForm.load(this.formData);
this.form = this.pcForm;
}.bind(this));
// }catch(e){
// layout.notice("error", {x: "right", y:"top"}, e.message, this.designNode);
// }
// MWF.getJSON(COMMON.contentPath+"/res/js/testform.json", {
// "onSuccess": function(obj){
// this.form = new MWF.FCForm(this);
// this.form.load(obj);
// }.bind(this),
// "onerror": function(text){
// layout.notice("error", {x: "right", y:"top"}, text, this.designNode);
// }.bind(this),
// "onRequestFailure": function(xhr){
// layout.notice("error", {x: "right", y:"top"}, xhr.responseText, this.designNode);
// }
// });
},
getFormData: function(callback){
if (!this.options.id){
if (this.options.templateId){
this.loadNewFormDataFormTemplate(callback);
}else{
this.loadNewFormData(callback);
}
}else{
this.loadFormData(callback);
}
},
loadNewFormData: function(callback){
var url = "../x_component_process_FormDesigner/Module/Form/template/"+this.options.template;
//MWF.getJSON("../x_component_process_FormDesigner/Module/Form/template.json", {
MWF.getJSON(url, {
"onSuccess": function(obj){
this.formData = obj.pcData;
this.formData.id="";
this.formData.isNewForm = true;
this.formMobileData = obj.mobileData;
this.formMobileData.id="";
this.formMobileData.isNewForm = true;
if( typeOf( this.options.templateCode ) === "object" ){
var count = 0, total = Object.keys(this.options.templateCode).length;
Object.each(this.options.templateCode, function ( url, key ) {
MWF.getRequestText( url, function (text) {
var obj, keys = key.split(".");
keys.each(function (k, i) {
if( i === 0 ) {
obj = k === "pc" ? this.formData : this.formMobileData;
}else if( i === keys.length - 1 ){
obj[k] = text;
count++;
if( count === total ) {
if (callback) callback();
}
}else{
if( !obj[k] )obj[k] = {};
obj = obj[k];
}
}.bind(this))
}.bind(this))
}.bind(this))
}else{
if (callback) callback();
}
}.bind(this),
"onerror": function(text){
this.notice(text, "error");
}.bind(this),
"onRequestFailure": function(xhr){
this.notice(xhr.responseText, "error");
}.bind(this)
});
},
loadNewFormDataFormTemplate: function(callback){
this.actions.getFormTemplate(this.options.templateId, function(form){
if (form){
this.formData = JSON.decode(MWF.decodeJsonString(form.data.data));
this.formData.isNewForm = true;
this.formData.json.id = "";
if (form.data.mobileData){
this.formMobileData = JSON.decode(MWF.decodeJsonString(form.data.mobileData));
this.formMobileData.isNewForm = true;
this.formMobileData.json.id = "";
}else{
this.formMobileData = Object.clone(this.formData);
}
if (callback) callback();
//this.actions.getFormCategory(this.formData.json.formCategory, function(category){
// this.category = {"data": {"name": category.data.name, "id": category.data.id}};
// if (callback) callback();
//}.bind(this));
}
}.bind(this));
},
loadFormData: function(callback){
this.actions.getForm(this.options.id, function(form){
debugger;
if (form){
var formTemplete = null;
MWF.getJSON("../x_component_process_FormDesigner/Module/Form/template/form.json", {
"onSuccess": function(obj){ formTemplete = obj; }.bind(this)
}, false);
this.formData = JSON.decode(MWF.decodeJsonString(form.data.data));
if (formTemplete.pcData){
Object.merge(formTemplete.pcData, this.formData);
Object.merge(this.formData, formTemplete.pcData);
}
this.formData.isNewForm = false;
this.formData.json.id = form.data.id;
if (form.data.mobileData){
this.formMobileData = JSON.decode(MWF.decodeJsonString(form.data.mobileData));
if (formTemplete.mobileData){
Object.merge(formTemplete.mobileData, this.formMobileData);
Object.merge(this.formMobileData, formTemplete.mobileData);
}
this.formMobileData.isNewForm = false;
this.formMobileData.json.id = form.data.id;
}else{
this.formMobileData = Object.clone(this.formData);
}
this.setTitle(this.options.appTitle + "-"+this.formData.json.name);
if (this.taskitem) this.taskitem.setText(this.options.appTitle + "-"+this.formData.json.name);
this.options.appTitle = this.options.appTitle + "-"+this.formData.json.name;
if (!this.application){
this.actions.getApplication(form.data.application, function(json){
this.application = {"name": json.data.name, "id": json.data.id};
if (callback) callback();
}.bind(this));
}else{
if (callback) callback();
}
//this.actions.getFormCategory(this.formData.json.formCategory, function(category){
// this.category = {"data": {"name": category.data.name, "id": category.data.id}};
// if (callback) callback();
//}.bind(this));
}
}.bind(this));
},
getFieldList: function(){
//fieldTypes = ["calender", "checkbox", "datagrid", "htmledit", "number", "personfield", "radio", "select", "textarea", "textfield"];
dataTypes = {
"string": ["htmledit", "radio", "select", "textarea", "textfield","imageclipper","htmleditor","tinymceeditor"],
"person": ["personfield","orgfield","org"],
"date": ["calender"],
"number": ["number","currency"],
"array": ["checkbox"]
};
fieldList = [];
this.pcForm.moduleList.each(function(moudle){
var key = "";
for (k in dataTypes){
if (dataTypes[k].indexOf(moudle.moduleName.toLowerCase())!=-1){
key = k;
break;
}
}
if (key){
fieldList.push({
"name": moudle.json.id,
"dataType": key
});
}
}.bind(this));
return fieldList;
},
checkSubform: function(){
var pcSubforms = [];
if (this.pcForm){
this.pcForm.data.json.subformList = [];
this.pcForm.moduleList.each(function(module){
if (module.moduleName==="subform"){
if (module.json.subformSelected && module.json.subformSelected!=="none" && module.json.subformType!=="script"){
if (this.pcForm.data.json.subformList.indexOf(module.json.subformSelected) === -1) this.pcForm.data.json.subformList.push(module.json.subformSelected);
}
if (module.regetSubformData()){
module.subformData.updateTime = "";
var moduleNames = module.getConflictFields();
if (moduleNames.length){
var o = {
"id": module.json.id,
"fields": moduleNames
};
pcSubforms.push(o);
}
}
}
}.bind(this));
}
var mobileSubforms = [];
if (this.mobileForm){
this.mobileForm.data.json.subformList = [];
this.mobileForm.moduleList.each(function(module){
if (module.moduleName==="subform"){
if (module.json.subformSelected && module.json.subformSelected!=="none" && module.json.subformType!=="script"){
if (this.mobileForm.data.json.subformList.indexOf(module.json.subformSelected) === -1) this.mobileForm.data.json.subformList.push(module.json.subformSelected);
}
if (module.regetSubformData()){
module.subformData.updateTime = "";
var moduleNames = module.getConflictFields();
if (moduleNames.length){
var o = {
"id": module.json.id,
"fields": moduleNames
};
mobileSubforms.push(o);
}
}
}
}.bind(this));
}
var txt = "";
if (pcSubforms.length){
var pctxt = "";
pcSubforms.each(function(subform){
pctxt += subform.id+" ( "+subform.fields.join(", ")+" )
";
});
txt += this.lp.checkSubformPcInfor.replace("{subform}", pctxt);
}
if (mobileSubforms.length){
var mobiletxt = "";
mobileSubforms.each(function(subform){
mobiletxt += subform.id+" ( "+subform.fields.join(", ")+" )
";
});
txt += this.lp.checkSubformMobileInfor.replace("{subform}", mobiletxt);
}
return txt;
},
saveForm: function(){
if (!this.isSave){
var txt = this.checkSubform();
if (txt){
txt = this.lp.checkFormSaveError+txt;
// var p = this.node.getPosition(document.body);
// this.alert("error", {
// "event": {
// "x": p.x+150,
// "y": p.y+80
// }
// }, this.lp.checkSubformTitle, {"html": txt}, 400, 200);
this.notice(txt, "error", this.form.node);
return false;
}
// if (this.pcForm){
// this.pcForm.moduleList.each(function(module){
// if (module.moduleName==="subform"){
// module.refreshSubform();
// }
// }.bind(this));
// }
// if (this.mobileForm){
// this.mobileForm.moduleList.each(function(module){
// if (module.moduleName==="subform"){
// module.refreshSubform();
// }
// }.bind(this));
// }
// @todo 预先整理表单样式
// var loadedPcForm = !this.pcForm;
// var loadedMobileForm = !this.mobileForm;
// var checkLoad = function(){
// if (loadedPcForm && loadedMobileForm){
// this.isSave = true;
// var fieldList = this.getFieldList();
// this.actions.saveForm(pcData, mobileData, fieldList, function(responseJSON){
// this.notice(MWF.APPFD.LP.notice["save_success"], "ok", null, {x: "left", y:"bottom"});
// if (!this.pcForm.json.name) this.pcForm.treeNode.setText("<"+this.json.type+"> "+this.json.id);
// this.pcForm.treeNode.setTitle(this.pcForm.json.id);
// this.pcForm.node.set("id", this.pcForm.json.id);
//
// if (this.mobileForm){
// if (!this.mobileForm.json.name) this.mobileForm.treeNode.setText("<"+this.mobileForm.json.type+"> "+this.mobileForm.json.id);
// this.mobileForm.treeNode.setTitle(this.mobileForm.json.id);
// this.mobileForm.node.set("id", this.mobileForm.json.id+"_"+this.options.mode);
// }
//
// var name = this.pcForm.json.name;
// if (this.pcForm.data.isNewForm) this.setTitle(this.options.appTitle + "-"+name);
// this.pcForm.data.isNewForm = false;
// if (this.mobileForm) this.mobileForm.data.isNewForm = false;
//
// this.options.desktopReload = true;
// this.options.id = this.pcForm.json.id;
//
// if (this.pcForm) this.pcForm.fireEvent("postSave");
// if (this.mobileForm) this.mobileForm.fireEvent("postSave");
//
// this.isSave = false;
//
// }.bind(this), function(xhr, text, error){
// this.isSave = false;
//
// if (this.pcForm) this.pcForm.fireEvent("postSaveError");
// if (this.mobileForm) this.mobileForm.fireEvent("postSaveError");
//
// var errorText = error+":"+text;
// if (xhr) errorText = xhr.responseText;
// MWF.xDesktop.notice("error", {x: "right", y:"top"}, "request json error: "+errorText);
// }.bind(this));
// }
// }.bind(this);
//
//
// var pcData, mobileData;
// if (this.pcForm){
// this.pcForm._getFormData(function(){
// pcData = this.pcForm.data;
// loadedPcForm = true;
// checkLoad();
// });
// }
// if (this.mobileForm){
// this.mobileForm._getFormData(function(){
// mobileData = this.mobileForm.data;
// loadedMobileForm = true;
// checkLoad();
// });
// }else{
// if (this.formMobileData) mobileData = this.formMobileData;
// loadedMobileForm = true;
// checkLoad();
// }
var pcData, mobileData;
if (this.pcForm){
pcData = this.pcForm._getFormData();
//pcData = this.pcForm.data;
}
if (this.mobileForm){
mobileData = this.mobileForm._getFormData();
//mobileData = this.mobileForm.data;
}else{
if (this.formMobileData) mobileData = this.formMobileData;
}
this.isSave = true;
var fieldList = this.getFieldList();
//var subFormList = this.getSubformList();
this.actions.saveForm(pcData, mobileData, fieldList, function(responseJSON){
this.notice(MWF.APPFD.LP.notice["save_success"], "ok", null, {x: "left", y:"bottom"});
if (!this.pcForm.json.name) this.pcForm.treeNode.setText("<"+this.json.type+"> "+this.json.id);
this.pcForm.treeNode.setTitle(this.pcForm.json.id);
this.pcForm.node.set("id", this.pcForm.json.id);
if (this.mobileForm){
if (!this.mobileForm.json.name) this.mobileForm.treeNode.setText("<"+this.mobileForm.json.type+"> "+this.mobileForm.json.id);
this.mobileForm.treeNode.setTitle(this.mobileForm.json.id);
this.mobileForm.node.set("id", this.mobileForm.json.id+"_"+this.options.mode);
}
var name = this.pcForm.json.name;
if (this.pcForm.data.isNewForm) this.setTitle(this.options.appTitle + "-"+name);
this.pcForm.data.isNewForm = false;
if (this.mobileForm) this.mobileForm.data.isNewForm = false;
this.options.desktopReload = true;
this.options.id = this.pcForm.json.id;
if (this.pcForm) this.pcForm.fireEvent("postSave");
if (this.mobileForm) this.mobileForm.fireEvent("postSave");
this.isSave = false;
}.bind(this), function(xhr, text, error){
this.isSave = false;
if (this.pcForm) this.pcForm.fireEvent("postSaveError");
if (this.mobileForm) this.mobileForm.fireEvent("postSaveError");
// if (xhr.status!=0){
// var errorText = error;
// if (xhr){
// var json = JSON.decode(xhr.responseText);
// if (json){
// errorText = json.message.trim() || "request json error";
// }else{
// errorText = "request json error: "+xhr.responseText;
// }
// }
// errorText = errorText.replace(/\" +
"