123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762 |
- o2.xApplication.ConfigDesigner.options = {
- "multitask": true,
- "executable": false
- };
- o2.xDesktop.requireApp("ConfigDesigner", "Script", null, false);
- o2.require("o2.xDesktop.UserData", null, false);
- o2.xApplication.ConfigDesigner.Main = new Class({
- Extends: o2.xApplication.Common.Main,
- Implements: [Options, Events],
- options: {
- "style": "default",
- "name": "ConfigDesigner",
- "icon": "icon.png",
- "title": o2.xApplication.ConfigDesigner.LP.title,
- "appTitle": o2.xApplication.ConfigDesigner.LP.title,
- "id": "node_127.0.0.1.json",
- "actions": null,
- "category": null,
- "portalData": null
- },
- onQueryLoad: function(){
- this.actions = o2.Actions.load("x_program_center");
- this.lp = o2.xApplication.ConfigDesigner.LP;
- this.addEvent("queryClose", function(e){
- if (this.explorer){
- this.explorer.reload();
- }
- }.bind(this));
- },
- loadApplication: function(callback){
- this.createNode();
- if (!this.options.isRefresh){
- this.maxSize(function(){
- this.openScript();
- }.bind(this));
- }else{
- this.openScript();
- }
- if (callback) callback();
- },
- createNode: function(){
- this.content.setStyle("overflow", "hidden");
- this.node = new Element("div", {
- "styles": {"width": "100%", "height": "100%", "overflow": "hidden"}
- }).inject(this.content);
- },
- getApplication:function(callback){
- if (callback) callback();
- },
- openScript: function(){
- this.getApplication(function(){
- this.loadNodes();
- this.loadScriptListNodes();
- this.loadContentNode(function(){
- this.loadProperty();
- // this.loadTools();
- this.resizeNode();
- this.addEvent("resize", this.resizeNode.bind(this));
- this.loadScript();
- if (this.toolbarContentNode){
- this.setScrollBar(this.toolbarContentNode, null, {
- "V": {"x": 0, "y": 0},
- "H": {"x": 0, "y": 0}
- });
- this.setScrollBar(this.propertyDomArea, null, {
- "V": {"x": 0, "y": 0},
- "H": {"x": 0, "y": 0}
- });
- }
- }.bind(this));
- }.bind(this));
- },
- loadNodes: function(){
- this.scriptListNode = new Element("div", {
- "styles": this.css.scriptListNode
- }).inject(this.node);
- this.propertyNode = new Element("div", {
- "styles": this.css.propertyNode
- }).inject(this.node);
- this.contentNode = new Element("div", {
- "styles": this.css.contentNode
- }).inject(this.node);
- },
- //loadScriptList-------------------------------
- loadScriptListNodes: function(){
- this.scriptListTitleNode = new Element("div", {
- "styles": this.css.scriptListTitleNode,
- "text": o2.xApplication.ConfigDesigner.LP.scriptLibrary
- }).inject(this.scriptListNode);
- this.scriptListResizeNode = new Element("div", {"styles": this.css.scriptListResizeNode}).inject(this.scriptListNode);
- this.scriptListAreaSccrollNode = new Element("div", {"styles": this.css.scriptListAreaSccrollNode}).inject(this.scriptListNode);
- this.scriptListAreaNode = new Element("div", {"styles": this.css.scriptListAreaNode}).inject(this.scriptListAreaSccrollNode);
- this.loadScriptListResize();
- this.loadScriptList();
- },
- setScroll: function(){
- o2.require("o2.widget.ScrollBar", function(){
- this.listScrollBar = new o2.widget.ScrollBar(this.scriptListAreaSccrollNode, {
- "style":"xDesktop_Message", "where": "before", "indent": false, "distance": 100, "friction": 6, "axis": {"x": false, "y": true}
- });
- }.bind(this));
- },
- loadScriptListResize: function(){
- // var size = this.propertyNode.getSize();
- // var position = this.propertyResizeBar.getPosition();
- this.scriptListResize = new Drag(this.scriptListResizeNode,{
- "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.scriptListAreaSccrollNode.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 = x.toFloat() - position.x.toFloat();
- var width = initialWidth+dx;
- if (width> bodySize.x/2) width = bodySize.x/2;
- if (width<40) width = 40;
- this.contentNode.setStyle("margin-left", width+1);
- this.scriptListNode.setStyle("width", width);
- }.bind(this)
- });
- },
- loadScriptList: function() {
- this.actions.ConfigAction.getList(function( json ){
- data = json.data;
- var config = JSON.parse(data.config);
- this.config = config;
- for (var key in config) {
- if(key.indexOf("node_")>-1){
- this.options.id = key;
- }
- this.createListScriptItem(key,config[key]);
- }
- this.setScroll();
- }.bind(this), null, false);
- },
- createListScriptItem: function(id, name){
- var _self = this;
- var listScriptItem = new Element("div", {"styles": this.css.listScriptItem}).inject(this.scriptListAreaNode, "bottom");
- var listScriptItemIcon = new Element("div", {"styles": this.css.listScriptItemIcon}).inject(listScriptItem);
- var listScriptItemText = new Element("div", {"styles": this.css.listScriptItemText, "text":id.replace(".json","")+" ("+name+")" }).inject(listScriptItem);
- listScriptItem.store("script", {id:id,name:name});
- listScriptItem.addEvents({
- "click": function(e){_self.loadScriptByData(this, e);},
- "mouseover": function(){if (_self.currentListScriptItem!=this) this.setStyles(_self.css.listScriptItem_over);},
- "mouseout": function(){if (_self.currentListScriptItem!=this) this.setStyles(_self.css.listScriptItem);}
- });
- this.listScriptItemMove(listScriptItem);
- },
- createScriptListCopy: function(node){
- var copyNode = node.clone().inject(this.node);
- copyNode.position({
- "relativeTo": node,
- "position": "upperLeft",
- "edge": "upperLeft"
- });
- var size = copyNode.getSize();
- copyNode.setStyles({
- "width": ""+size.x+"px",
- "height": ""+size.y+"px",
- "z-index": 50001,
- });
- return copyNode;
- },
- listDragEnter: function(dragging, inObj){
- var markNode = inObj.retrieve("markNode");
- if (!markNode){
- var size = inObj.getSize();
- markNode = new Element("div", {"styles": this.css.dragListItemMark}).inject(this.node);
- markNode.setStyles({
- "width": ""+size.x+"px",
- "height": ""+size.y+"px",
- "position": "absolute",
- "background-color": "#666",
- "z-index": 50000,
- "opacity": 0.3
- // "border": "2px solid #ffba00"
- });
- markNode.position({
- "relativeTo": inObj,
- "position": "upperLeft",
- "edge": "upperLeft"
- });
- var y = markNode.getStyle("top").toFloat()-1;
- var x = markNode.getStyle("left").toFloat()-2;
- markNode.setStyles({
- "left": ""+x+"px",
- "top": ""+y+"px",
- });
- inObj.store("markNode", markNode);
- }
- },
- listDragLeave: function(dragging, inObj){
- var markNode = inObj.retrieve("markNode");
- if (markNode) markNode.destroy();
- inObj.eliminate("markNode");
- },
- listScriptItemMove: function(node){
- var iconNode = node.getFirst();
- iconNode.addEvent("mousedown", function(e){
- var script = node.retrieve("script");
- if (script.id!=this.scriptTab.showPage.script.data.id){
- var copyNode = this.createScriptListCopy(node);
- var droppables = [this.designNode, this.propertyDomArea];
- var listItemDrag = new Drag.Move(copyNode, {
- "droppables": droppables,
- "onEnter": function(dragging, inObj){
- this.listDragEnter(dragging, inObj);
- }.bind(this),
- "onLeave": function(dragging, inObj){
- this.listDragLeave(dragging, inObj);
- }.bind(this),
- "onDrag": function(e){
- //nothing
- }.bind(this),
- "onDrop": function(dragging, inObj){
- if (inObj){
- this.addIncludeScript(script);
- this.listDragLeave(dragging, inObj);
- copyNode.destroy();
- }else{
- copyNode.destroy();
- }
- }.bind(this),
- "onCancel": function(dragging){
- copyNode.destroy();
- }.bind(this)
- });
- listItemDrag.start(e);
- }
- }.bind(this));
- },
- addIncludeScript: function(script){
- var currentScript = this.scriptTab.showPage.script;
- if (currentScript.data.dependScriptList.indexOf(script.name)==-1){
- currentScript.data.dependScriptList.push(script.name);
- this.addIncludeToList(script.name);
- }
- },
- addIncludeToList: function(name){
- this.actions.getScriptByName(name, this.application.id, function(json){
- var script = json.data;
- var includeScriptItem = new Element("div", {"styles": this.css.includeScriptItem}).inject(this.propertyIncludeListArea);
- var includeScriptItemAction = new Element("div", {"styles": this.css.includeScriptItemAction}).inject(includeScriptItem);
- var includeScriptItemText = new Element("div", {"styles": this.css.includeScriptItemText}).inject(includeScriptItem);
- includeScriptItemText.set("text", script.name+" ("+script.alias+")");
- includeScriptItem.store("script", script);
- var _self = this;
- includeScriptItemAction.addEvent("click", function(){
- var node = this.getParent();
- var script = node.retrieve("script");
- if (script){
- _self.scriptTab.showPage.script.data.dependScriptList.erase(script.name);
- }
- node.destroy();
- });
- }.bind(this), function(){
- this.scriptTab.showPage.script.data.dependScriptList.erase(name);
- }.bind(this));
- },
- loadScriptByData: function(node, e){
- var script = node.retrieve("script");
- var scriptName = script.name;
- var openNew = true;
- for (var i = 0; i<this.scriptTab.pages.length; i++){
- if (script.id==this.scriptTab.pages[i].script.data.id){
- this.scriptTab.pages[i].showTabIm();
- openNew = false;
- break;
- }
- }
- if (openNew){
- this.loadScriptData(script.id, function(data){
- data.name = scriptName;
- var script = new o2.xApplication.ConfigDesigner.Script(this, data);
- script.load();
- }.bind(this), true);
- }
- },
- //loadContentNode------------------------------
- loadContentNode: function(toolbarCallback, contentCallback){
- this.contentToolbarNode = new Element("div#contentToolbarNode", {
- "styles": this.css.contentToolbarNode
- }).inject(this.contentNode);
- this.loadContentToolbar(toolbarCallback);
- this.editContentNode = new Element("div", {
- "styles": this.css.editContentNode
- }).inject(this.contentNode);
- this.loadEditContent(function(){
- // if (this.designDcoument) this.designDcoument.body.setStyles(this.css.designBody);
- if (this.designNode) this.designNode.setStyles(this.css.designNode);
- if (contentCallback) contentCallback();
- }.bind(this));
- },
- loadContentToolbar: 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+"/toolbar/"+img);
- }
- }.bind(this));
- $(toolbarNode).inject(this.contentToolbarNode);
- o2.require("o2.widget.Toolbar", function(){
- this.toolbar = new o2.widget.Toolbar(toolbarNode, {"style": "ProcessCategory"}, this);
- this.toolbar.load();
- var _self = this;
- //this.styleSelectNode = toolbarNode.getElement("select");
- //this.styleSelectNode.addEvent("change", function(){
- // _self.changeEditorStyle(this);
- //});
- this.styleSelectNode = toolbarNode.getElement("select[MWFnodetype='theme']");
- this.styleSelectNode.addEvent("change", function(){
- _self.changeEditorStyle(this);
- });
- this.fontsizeSelectNode = toolbarNode.getElement("select[MWFnodetype='fontSize']");
- this.fontsizeSelectNode.addEvent("change", function(){
- _self.changeFontSize(this);
- });
- this.editorSelectNode = toolbarNode.getElement("select[MWFnodetype='editor']");
- this.editorSelectNode.addEvent("change", function(){
- _self.changeEditor(this);
- });
- this.monacoStyleSelectNode = toolbarNode.getElement("select[MWFnodetype='monaco-theme']");
- this.monacoStyleSelectNode.addEvent("change", function(){
- _self.changeEditorStyle(this);
- });
- if (callback) callback();
- }.bind(this));
- }.bind(this));
- },
- changeEditor: function(node){
- var idx = node.selectedIndex;
- var value = node.options[idx].value;
- if (!o2.editorData){
- o2.editorData = {
- "javascriptEditor": {
- "monaco_theme": "vs",
- "theme": "tomorrow",
- "fontSize" : "12px"
- }
- };
- }
- o2.editorData.javascriptEditor["editor"] = value;
- o2.UD.putData("editor", o2.editorData);
- this.scriptTab.pages.each(function(page){
- var editor = page.script.editor;
- if (editor) editor.changeEditor(value);
- }.bind(this));
- if (value=="ace"){
- this.monacoStyleSelectNode.hide();
- this.styleSelectNode.show();
- }else{
- this.monacoStyleSelectNode.show();
- this.styleSelectNode.hide();
- }
- },
- changeFontSize: function(node){
- var idx = node.selectedIndex;
- var value = node.options[idx].value;
- //var editorData = null;
- this.scriptTab.pages.each(function(page){
- //if (!editorData) editorData = page.invoke.editor.editorData;
- var editor = page.script.editor;
- if (editor) editor.setFontSize(value);
- }.bind(this));
- //if (!editorData) editorData = o2.editorData;
- //editorData.javainvokeEditor.theme = value;
- if (!o2.editorData){
- o2.editorData = {
- "javascriptEditor": {
- "monaco_theme": "vs",
- "theme": "tomorrow",
- "fontSize" : "12px"
- }
- };
- }
- o2.editorData.javascriptEditor["fontSize"] = value;
- o2.UD.putData("editor", o2.editorData);
- },
- changeEditorStyle: function(node){
- var idx = node.selectedIndex;
- var value = node.options[idx].value;
- //var editorData = null;
- this.scriptTab.pages.each(function(page){
- //if (!editorData) editorData = page.script.editor.editorData;
- var editor = page.script.editor;
- if (editor) editor.setTheme(value);
- }.bind(this));
- //if (!editorData) editorData = o2.editorData;
- //editorData.javascriptEditor.theme = value;
- if (!o2.editorData){
- o2.editorData = {
- "javascriptEditor": {
- "monaco_theme": "vs",
- "theme": "tomorrow",
- "fontSize" : "12px"
- }
- };
- }
- if (o2.editorData.javascriptEditor.editor === "monaco"){
- o2.editorData.javascriptEditor.monaco_theme = value;
- }else{
- o2.editorData.javascriptEditor.theme = value;
- }
- o2.UD.putData("editor", o2.editorData);
- },
- getFormToolbarHTML: function(callback){
- var toolbarUrl = this.path+this.options.style+"/toolbars.html";
- var r = new Request.HTML({
- url: toolbarUrl,
- method: "get",
- onSuccess: function(responseTree, responseElements, responseHTML, responseJavaScript){
- var toolbarNode = responseTree[0];
- if (callback) callback(toolbarNode);
- }.bind(this),
- onFailure: function(xhr){
- this.notice("request portalToolbars error: "+xhr.responseText, "error");
- }.bind(this)
- });
- r.send();
- },
- maxOrReturnEditor: function(){
- if (!this.isMax){
- this.designNode.inject(this.node);
- this.designNode.setStyles({
- "position": "absolute",
- "width": "100%",
- "height": "100%",
- "top": "0px",
- "margin": "0px",
- "left": "0px"
- });
- this.scriptTab.pages.each(function(page){
- page.script.setAreaNodeSize();
- });
- this.isMax = true;
- }else{
- this.isMax = false;
- this.designNode.inject(this.editContentNode);
- this.designNode.setStyles(this.css.designNode);
- this.designNode.setStyles({
- "position": "static"
- });
- this.resizeNode();
- this.scriptTab.pages.each(function(page){
- page.script.setAreaNodeSize();
- });
- }
- },
- loadEditContent: function(callback){
- this.designNode = new Element("div", {
- "styles": this.css.designNode
- }).inject(this.editContentNode);
- o2.require("o2.widget.Tab", function(){
- this.scriptTab = new o2.widget.Tab(this.designNode, {"style": "script"});
- this.scriptTab.load();
- }.bind(this), false);
- //o2.require("o2.widget.ScrollBar", function(){
- // new o2.widget.ScrollBar(this.designNode, {"distance": 100});
- //}.bind(this));
- },
- //loadProperty------------------------
- loadProperty: function(){
- this.propertyTitleNode = new Element("div", {
- "styles": this.css.propertyTitleNode,
- "text": o2.xApplication.ConfigDesigner.LP.property
- }).inject(this.propertyNode);
- 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.propertyDomArea = new Element("div", {
- "styles": this.css.propertyDomArea
- }).inject(this.propertyContentNode);
- 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();
- this.setPropertyContent();
- this.setIncludeNode();
- },
- setIncludeNode: function(){
- this.includeTitleNode = new Element("div", {"styles": this.css.includeTitleNode}).inject(this.propertyDomArea);
- this.includeTitleActionNode = new Element("div", {"styles": this.css.includeTitleActionNode}).inject(this.includeTitleNode);
- this.includeTitleTextNode = new Element("div", {"styles": this.css.includeTitleTextNode, "text": this.lp.include}).inject(this.includeTitleNode);
- this.includeTitleActionNode.addEvent("click", function(){
- this.addInclude();
- }.bind(this));
- this.propertyIncludeListArea = new Element("div", {
- "styles": {"overflow": "hidden"}
- }).inject(this.propertyDomArea);
- },
- addInclude: function(){
- },
- setPropertyContent: function(){
- var node = new Element("div", {"styles": this.css.propertyItemTitleNode, "text": this.lp.id+":"}).inject(this.propertyContentArea);
- this.propertyIdNode = new Element("div", {"styles": this.css.propertyTextNode, "text": ""}).inject(this.propertyContentArea);
- node = new Element("div", {"styles": this.css.propertyItemTitleNode, "text": this.lp.name+":"}).inject(this.propertyContentArea);
- this.propertyNameNode = new Element("div", {"styles": this.css.propertyTextNode, "text": ""}).inject(this.propertyContentArea);
- node = new Element("div", {"styles": this.css.propertyItemTitleNode, "text": this.lp.node+":"}).inject(this.propertyContentArea);
- this.propertyServerNode = new Element("select", {"styles": this.css.propertyTextNode}).inject(this.propertyContentArea);
- o2.Actions.load("x_program_center").CommandAction.getNodeInfoList(
- function( json ){
- var nodeList = json.data.nodeList;
- if(nodeList.length>1){
- new Element("option", {"value": "*", "text": "*"}).inject(this.propertyServerNode);
- }
- nodeList.each(function (node) {
- new Element("option", {
- "value": node.node.nodeAgentPort,
- "text": node.nodeAddress
- }).inject(this.propertyServerNode);
- }.bind(this));
- }.bind(this),null, false
- );
- node = new Element("div", {"styles": this.css.propertyItemTitleNode, "text": this.lp.description+":"}).inject(this.propertyContentArea);
- this.propertyDescriptionNode = new Element("div", {"styles": this.css.propertyTextNode, "text": ""}).inject(this.propertyContentArea);
- },
- 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.contentNode.setStyle("margin-right", width+1);
- this.propertyNode.setStyle("width", width);
- }.bind(this)
- });
- },
- 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.propertyDomArea.getSize();
- el.store("initialHeight", size.y);
- }.bind(this),
- "onDrag": function(el, e){
- var size = this.propertyContentNode.getSize();
- // var x = e.event.x;
- var y = (Browser.name=="firefox") ? e.event.clientY : 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();
- }.bind(this)
- });
- },
- 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.propertyDomArea.setStyle("height", ""+domHeight+"px");
- this.propertyContentArea.setStyle("height", ""+contentHeight+"px");
- },
- //resizeNode------------------------------------------------
- resizeNode: function(){
- if (!this.isMax){
- var nodeSize = this.node.getSize();
- this.contentNode.setStyle("height", ""+nodeSize.y+"px");
- this.propertyNode.setStyle("height", ""+nodeSize.y+"px");
- var contentToolbarMarginTop = this.contentToolbarNode.getStyle("margin-top").toFloat();
- var contentToolbarMarginBottom = this.contentToolbarNode.getStyle("margin-bottom").toFloat();
- var allContentToolberSize = this.contentToolbarNode.getComputedSize();
- var y = nodeSize.y - allContentToolberSize.totalHeight - contentToolbarMarginTop - contentToolbarMarginBottom;
- this.editContentNode.setStyle("height", ""+y+"px");
- if (this.designNode){
- var designMarginTop = this.designNode.getStyle("margin-top").toFloat();
- var designMarginBottom = this.designNode.getStyle("margin-bottom").toFloat();
- y = nodeSize.y - allContentToolberSize.totalHeight - contentToolbarMarginTop - contentToolbarMarginBottom - designMarginTop - designMarginBottom;
- this.designNode.setStyle("height", ""+y+"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");
- this.setPropertyContentResize();
- titleSize = this.scriptListTitleNode.getSize();
- titleMarginTop = this.scriptListTitleNode.getStyle("margin-top").toFloat();
- titleMarginBottom = this.scriptListTitleNode.getStyle("margin-bottom").toFloat();
- titlePaddingTop = this.scriptListTitleNode.getStyle("padding-top").toFloat();
- titlePaddingBottom = this.scriptListTitleNode.getStyle("padding-bottom").toFloat();
- nodeMarginTop = this.scriptListAreaSccrollNode.getStyle("margin-top").toFloat();
- nodeMarginBottom = this.scriptListAreaSccrollNode.getStyle("margin-bottom").toFloat();
- y = titleSize.y+titleMarginTop+titleMarginBottom+titlePaddingTop+titlePaddingBottom+nodeMarginTop+nodeMarginBottom;
- y = nodeSize.y-y;
- this.scriptListAreaSccrollNode.setStyle("height", ""+y+"px");
- this.scriptListResizeNode.setStyle("height", ""+y+"px");
- }
- },
- //loadForm------------------------------------------
- loadScript: function(){
- //this.scriptTab.addTab(node, title);
- this.getScriptData(this.options.id, function(data){
- data.name = this.config[this.options.id];
- this.script = new o2.xApplication.ConfigDesigner.Script(this, data);
- this.script.load();
- }.bind(this));
- },
- getScriptData: function(id, callback){
- this.loadScriptData(id, callback);
- },
- loadScriptData: function(id, callback, notSetTile){
- this.actions.ConfigAction.open({fileName:id}, function(json){
- if (json){
- var data = json.data;
- data.id = id;
- data.text = data.fileContent;
- if (callback) callback(data);
- }
- }.bind(this));
- },
- saveScript: function(){
- if (this.scriptTab.showPage){
- var script = this.scriptTab.showPage.script;
- script.save(function(){
- if (script==this.script){
- var name = script.data.name;
- this.setTitle(o2.xApplication.ConfigDesigner.LP.title + "-"+name);
- this.options.desktopReload = true;
- this.options.id = script.data.id;
- }
- }.bind(this));
- }
- },
- saveDictionaryAs: function(){
- this.dictionary.saveAs();
- },
- dictionaryExplode: function(){
- this.dictionary.explode();
- },
- dictionaryImplode: function(){
- this.dictionary.implode();
- }
- });
|