MWF.xApplication.TeamWork = MWF.xApplication.TeamWork || {}; MWF.xApplication.TeamWork.ProjectSetting = new Class({ Extends: MWF.xApplication.TeamWork.Common.Popup, options:{ "closeByClickMask" : false }, open: function (e) { //设置css 和 lp等 var css = this.css; this.cssPath = "/x_component_TeamWork/$ProjectSetting/"+this.options.style+"/css.wcss"; this._loadCss(); if(css) this.css = Object.merge( css, this.css ); this.rootActions = this.app.rootActions; this.actions = this.rootActions.ProjectAction; this.lp = this.app.lp.projectSetting; this.fireEvent("queryOpen"); this.isNew = false; this.isEdited = false; this._open(); this.fireEvent("postOpen"); }, _createTableContent: function () { this.projectInfor(function(rs){ this.groups = rs.groups; this.groupsArr = []; this.projectSettingTop = new Element("div.projectSettingTop",{styles:this.css.projectSettingTop}).inject(this.formTableArea); this.projectSettingTopText = new Element("div.projectSettingTopText",{styles:this.css.projectSettingTopText,text:this.lp.title}).inject(this.projectSettingTop); this.projectSettingTopClose = new Element("div.projectSettingTopClose",{styles:this.css.projectSettingTopClose}).inject(this.projectSettingTop); this.projectSettingTopClose.addEvents({ click:function(){this.close()}.bind(this) }); this.projectSettingContent = new Element("div.projectSettingContent",{styles:this.css.projectSettingContent}).inject(this.formTableArea); this.projectSettingNaviLayout = new Element("div.projectSettingNaviLayout",{styles:this.css.projectSettingNaviLayout}).inject(this.projectSettingContent); this.projectSettingLayout = new Element("div.projectSettingLayout",{styles:this.css.projectSettingLayout}).inject(this.projectSettingContent); this.createNavi(); }.bind(this)); }, createNavi:function(){ var _self = this; this.projectSettingNaviLayout.empty(); //概况 this.naviGeneral = new Element("div.naviGeneral",{styles:this.css.naviItem}).inject(this.projectSettingNaviLayout); this.naviGeneralHover = new Element("div.naviItemHover",{styles:this.css.naviItemHover}).inject(this.naviGeneral); this.naviGeneralHover.setStyles({"height":"58px","margin-top":"2px"}); this.naviGeneralIcon = new Element("div.naviItemIcon",{styles:this.css.naviItemIcon}).inject(this.naviGeneral); this.naviGeneralIcon.setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_general.png)"}); this.naviGeneralText = new Element("div.naviItemText",{styles:this.css.naviItemText,text:this.lp.general}).inject(this.naviGeneral); this.naviGeneral.addEvents({ mouseover:function(){ if(_self.curNavi == "general") return; this.getElements(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_general_click.png)"}); this.getElements(".naviItemText").setStyles({"color":"#4a90e2"}); }, mouseout:function(){ if(_self.curNavi == "general") return; this.getElement(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_general.png)"}); this.getElement(".naviItemText").setStyles({"color":""}); }, click:function(){ _self.curNavi = "general"; _self.changeNavi(this); _self.loadGeneral(); } }); //自定义字段 this.naviCustom = new Element("div.naviCustom",{styles:this.css.naviItem}).inject(this.projectSettingNaviLayout); this.naviCustomHover = new Element("div.naviItemHover",{styles:this.css.naviItemHover}).inject(this.naviCustom); this.naviCustomIcon = new Element("div.naviItemIcon",{styles:this.css.naviItemIcon}).inject(this.naviCustom); this.naviCustomIcon.setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom.png)"}); this.naviCustomText = new Element("div.naviItemText",{styles:this.css.naviItemText,text:this.lp.customField}).inject(this.naviCustom); this.naviCustom.addEvents({ mouseover:function(){ if(_self.curNavi == "custom") return; this.getElements(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom_click.png)"}); this.getElements(".naviItemText").setStyles({"color":"#4a90e2"}); }, mouseout:function(){ if(_self.curNavi == "custom") return; this.getElement(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom.png)"}); this.getElement(".naviItemText").setStyles({"color":""}); }, click:function(){ _self.curNavi = "custom"; _self.changeNavi(this); _self.loadCustom() } }); this.naviCustom = new Element("div.naviCustom",{styles:this.css.naviItem}).inject(this.projectSettingNaviLayout); this.naviCustomHover = new Element("div.naviItemHover",{styles:this.css.naviItemHover}).inject(this.naviCustom); this.naviCustomIcon = new Element("div.naviItemIcon",{styles:this.css.naviItemIcon}).inject(this.naviCustom); this.naviCustomIcon.setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom.png)"}); this.naviCustomText = new Element("div.naviItemText",{styles:this.css.naviItemText,text:"任务设置"}).inject(this.naviCustom); this.naviCustom.addEvents({ mouseover:function(){ if(_self.curNavi == "custom") return; this.getElements(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom_click.png)"}); this.getElements(".naviItemText").setStyles({"color":"#4a90e2"}); }, mouseout:function(){ if(_self.curNavi == "custom") return; this.getElement(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom.png)"}); this.getElement(".naviItemText").setStyles({"color":""}); }, click:function(){ _self.curNavi = "custom"; _self.changeNavi(this); _self.loadCustom() } }); this.naviCustom = new Element("div.naviCustom",{styles:this.css.naviItem}).inject(this.projectSettingNaviLayout); this.naviCustomHover = new Element("div.naviItemHover",{styles:this.css.naviItemHover}).inject(this.naviCustom); this.naviCustomIcon = new Element("div.naviItemIcon",{styles:this.css.naviItemIcon}).inject(this.naviCustom); this.naviCustomIcon.setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom.png)"}); this.naviCustomText = new Element("div.naviItemText",{styles:this.css.naviItemText,text:"更多设置"}).inject(this.naviCustom); this.naviCustom.addEvents({ mouseover:function(){ if(_self.curNavi == "custom") return; this.getElements(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom_click.png)"}); this.getElements(".naviItemText").setStyles({"color":"#4a90e2"}); }, mouseout:function(){ if(_self.curNavi == "custom") return; this.getElement(".naviItemIcon").setStyles({"background-image":"url(/x_component_TeamWork/$ProjectSetting/default/icon/icon_custom.png)"}); this.getElement(".naviItemText").setStyles({"color":""}); }, click:function(){ _self.curNavi = "custom"; _self.changeNavi(this); _self.loadCustom() } }); this.naviGeneral.click() }, changeNavi:function(obj){ this.projectSettingNaviLayout.getElements(".naviItemHover").setStyles({"background-color":"#ffffff"}); this.projectSettingNaviLayout.getElements(".naviItemText").setStyles({"color":""}); this.projectSettingNaviLayout.getElements(".naviItemIcon").each(function(dom){ var bgurl = dom.getStyle("background-image"); if(bgurl.indexOf("_click")>-1){ bgurl = bgurl.replace("_click",""); } dom.setStyles({"background-image":bgurl}); }.bind(this)); obj.getElement(".naviItemHover").setStyles({"background-color":"#4a90e2"}); obj.getElement(".naviItemIcon").setStyles({"background-image":obj.getElement(".naviItemIcon").getStyle("background-image").replace(".png","_click.png")}); obj.getElement(".naviItemText").setStyles({"color":"#4a90e2"}); }, loadCustom:function(){ this.projectSettingLayout.empty(); this.customTopLayout = new Element("div.customTopLayout",{styles:this.css.customTopLayout}).inject(this.projectSettingLayout); this.customTopText = new Element("div.customTopText",{styles:this.css.customTopText,text:this.lp.customTip}).inject(this.customTopLayout); this.customTopNew = new Element("div.customTopNew",{styles:this.css.customTopNew,text:this.lp.customNew}).inject(this.customTopLayout); this.customTopNew.addEvents({ mouseover:function(){this.setStyles({"opacity":"0.7"})}, mouseout:function(){this.setStyles({"opacity":"1"})}, click:function(){ MWF.xDesktop.requireApp("TeamWork", "ExtField", function(){ var pc = new MWF.xApplication.TeamWork.ExtField(this,this.container, this.customTopNew, this.app, {projectId:this.data.id}, { axis : "x", position : { //node 固定的位置 x : "left", y : "middle" }, nodeStyles : { "min-width":"200px", "width":"300px", "padding":"2px", "border-radius":"5px", "box-shadow":"0px 0px 4px 0px #999999", "z-index" : "201" }, onPostLoad:function(){ pc.node.setStyles({"opacity":"0","top":(pc.node.getStyle("top").toInt())+"px"}); var fx = new Fx.Tween(pc.node,{duration:400}); fx.start(["opacity"] ,"0", "1"); }, onClose:function(rd){ if(!rd) return; if(rd.value && rd.value !=""){ this.chatTextarea.set("value",this.chatTextarea.get("value")+"["+rd.value+"]") } }.bind(this) }); pc.load(); }.bind(this)); }.bind(this) }); this.customContent = new Element("div.customContent",{styles:this.css.customContent}).inject(this.projectSettingLayout); this.createExtFieldList(); }, createExtFieldList:function(){ this.customContent.empty(); this.app.setLoading(this.customContent); this.rootActions.ProjectExtFieldReleAction.listFieldsWithProject(this.data.id,function(json){ this.customContent.empty(); json.data.each(function(data){ this.createExtFieldItem(data); }.bind(this)); }.bind(this)) }, createExtFieldItem:function(data){ var _self = this; var customExtItem = new Element("div.customExtItem",{styles:this.css.customExtItem,id:data.id}).inject(this.customContent); customExtItem.addEvents({ mouseover:function(){ this.setStyles({"background-color":"#f5f5f5"}); customExitItemRemove.show(); customExitItemEdit.show(); }, mouseout:function(){ this.setStyles({"background-color":""}); customExitItemRemove.hide(); customExitItemEdit.hide(); } }); var customExtItemTop = new Element("div.customExtItemTop",{styles:this.css.customExtItemTop}).inject(customExtItem); var customExtName = new Element("div.customExtName",{styles:this.css.customExtName,text:data.displayName}).inject(customExtItemTop); var customExitItemRemove = new Element("div.customExitItemRemove",{styles:this.css.customExitItemAction,text:this.lp.remove}).inject(customExtItemTop); customExitItemRemove.addEvents({ click:function(e){ _self.app.confirm("warn",e,_self.app.lp.common.confirm.removeTitle,_self.app.lp.common.confirm.removeContent,300,120,function(){ _self.actions.projectExtFieldRemove(data.id,function(json){ customExtItem.destroy(); this.close(); }.bind(this)) },function(){ this.close(); }); } }); var customExitItemEdit = new Element("div.customExitItemEdit",{styles:this.css.customExitItemAction,text:this.lp.edit}).inject(customExtItemTop); customExitItemEdit.addEvents({ click:function(){ MWF.xDesktop.requireApp("TeamWork", "ExtField", function(){ var pc = new MWF.xApplication.TeamWork.ExtField(this,this.container, this.customTopNew, this.app, {projectId:this.data.id,id:data.id}, { axis : "x", position : { //node 固定的位置 x : "left", y : "middle" }, nodeStyles : { "min-width":"200px", "width":"300px", "padding":"2px", "border-radius":"5px", "box-shadow":"0px 0px 4px 0px #999999", "z-index" : "201" }, onPostLoad:function(){ pc.node.setStyles({"opacity":"0","top":(pc.node.getStyle("top").toInt())+"px"}); var fx = new Fx.Tween(pc.node,{duration:400}); fx.start(["opacity"] ,"0", "1"); }, onClose:function(rd){ if(!rd) return; if(rd.value && rd.value !=""){ this.chatTextarea.set("value",this.chatTextarea.get("value")+"["+rd.value+"]") } }.bind(this) }); pc.load(); }.bind(this)); }.bind(this) }); var customExtValueList = new Element("div.customExtValueList",{styles:this.css.customExtValueList}).inject(customExtItem); new Element("span.customExtCreator",{styles:this.customExtText,text:this.lp.description+":"+data.description}).inject(customExtValueList); customExtValueList = new Element("div.customExtValueList",{styles:this.css.customExtValueList}).inject(customExtItem); new Element("span.customExtCreator",{styles:this.customExtText,text:this.lp.option + ":"+data.optionsData}).inject(customExtValueList); }, loadGeneral:function(){ this.projectSettingLayout.empty(); this.groupsArr = []; this.projectSettingBgText = new Element("div.projectSettingBgText",{styles:this.css.projectSettingBgText,"text":this.lp.projectSettingBgText}).inject(this.projectSettingLayout); this.projectSettingBgContainer = new Element("div.projectSettingBgContainer",{styles:this.css.projectSettingBgContainer}).inject(this.projectSettingLayout); this.projectSettingBgImg = new Element("div.projectSettingBgImg",{styles:this.css.projectSettingBgImg}).inject(this.projectSettingBgContainer); if(this.data.icon && this.data.icon!=""){ this.projectSettingBgImg.setStyles({ "background-image":"url('"+MWF.xDesktop.getImageSrc( this.data.icon )+"')" }); } this.projectSettingBgUpload = new Element("div.projectSettingBgUpload",{styles:this.css.projectSettingBgUpload,text:this.lp.upload}).inject(this.projectSettingBgContainer); this.projectSettingBgUpload.addEvents({ click:function(){ var data = {}; MWF.xDesktop.requireApp("TeamWork", "UploadImage", function(){ var ui = new MWF.xApplication.TeamWork.UploadImage(this, data, { documentId : this.data.id ||"", onPostOk : function( id ){ this.data.icon = id; this.projectSettingBgImg.setStyles({ "background-image":"url('"+MWF.xDesktop.getImageSrc( id )+"')" }); }.bind(this) }); ui.open() }.bind(this)); }.bind(this) }); this.projectSettingContainer = new Element("div.projectSettingContainer",{styles:this.css.projectSettingContainer}).inject(this.projectSettingLayout); this.projectSettingTitleContainer = new Element("div.projectSettingTitleContainer",{styles:this.css.projectSettingTitleContainer}).inject(this.projectSettingContainer); this.projectSettingTitleText = new Element("div.projectSettingTitleText",{styles:this.css.projectSettingTitleText,text:this.lp.projectTitle}).inject(this.projectSettingTitleContainer); this.projectSettingTitleDiv = new Element("div.projectSettingTitleDiv",{styles:this.css.projectSettingTitleDiv}).inject(this.projectSettingTitleContainer); this.projectSettingTitleIn = new Element("input.projectSettingTitleIn",{styles:this.css.projectSettingTitleIn,value:this.projectData.title || ""}).inject(this.projectSettingTitleDiv); this.projectSettingTitleIn.addEvents({ focus:function(){ this.projectSettingTitleIn.setStyles({"border":"1px solid #4A90E2"}); }.bind(this), blur:function(){ this.projectSettingTitleIn.setStyles({"border":"1px solid #A6A6A6"}); }.bind(this) }); // this.projectSettingContainer = new Element("div.projectSettingContainer",{styles:this.css.projectSettingContainer}).inject(this.formTableArea); this.projectSettingGroupContainer = new Element("div.projectSettingGroupContainer",{styles:this.css.projectSettingGroupContainer}).inject(this.projectSettingContainer); this.projectSettingGroupText = new Element("div.projectSettingGroupText",{styles:this.css.projectSettingGroupText,text:this.lp.projectGroup}).inject(this.projectSettingGroupContainer); this.projectSettingGroupDiv = new Element("div.projectSettingGroupDiv",{styles:this.css.projectSettingGroupDiv}).inject(this.projectSettingGroupContainer); this.projectSettingGroupDiv.addEvents({ click:function(){ var data = {groups:this.groups}; MWF.xDesktop.requireApp("TeamWork", "GroupSelect", function(){ var gs = new MWF.xApplication.TeamWork.GroupSelect(this.container, this.projectSettingGroupDiv, this.app, data, { axis : "y", nodeStyles : { "min-width":"190px", "z-index" : "102" }, onClose:function(d){ this.projectSettingGroupDiv.setStyles({"border":"1px solid #A6A6A6"}); if(d){ this.rootActions.ProjectGroupAction.listWithIds({ids:d},function(json){ this.groups = json.data; var tmp = []; json.data.each(function(ddd){ tmp.push(ddd.name); }); this.projectSettingGroupValue.set("text",tmp.join()); this.projectSettingGroupValue.set("title",tmp.join()) }.bind(this)); }else{ this.groups = []; } //this.newProjectGroupValue.set("text",d) }.bind(this) }); gs.load(); }.bind(this)); this.projectSettingGroupDiv.setStyles({"border":"1px solid #4A90E2"}); }.bind(this) }); this.projectSettingGroupValue = new Element("div.projectSettingGroupValue",{styles:this.css.projectSettingGroupValue}).inject(this.projectSettingGroupDiv); this.projectSettingGroupIcon = new Element("div.projectSettingGroupIcon",{styles:this.css.projectSettingGroupIcon}).inject(this.projectSettingGroupDiv); if(this.groups){ this.groups.each(function(data){ this.groupsArr.push(data.name); }.bind(this)); } this.projectSettingGroupValue.set("text",this.groupsArr.join()); this.projectSettingGroupValue.set("title",this.groupsArr.join()); this.projectSettingContainer = new Element("div.projectSettingContainer",{styles:this.css.projectSettingContainer}).inject(this.projectSettingLayout); this.projectSettingContainer.setStyles({"height":"120px"}); this.projectSettingDesText = new Element("div.projectSettingDesText",{styles:this.css.projectSettingDesText,text:this.lp.projectDes}).inject(this.projectSettingContainer); this.projectSettingDesContainer = new Element("div.projectSettingDesContainer",{styles:this.css.projectSettingDesContainer}).inject(this.projectSettingContainer); this.projectSettingDesIn = new Element("textarea.projectSettingDesIn",{styles:this.css.projectSettingDesIn,value:this.projectData.description||""}).inject(this.projectSettingDesContainer); this.projectSettingDesIn.addEvents({ focus:function(){ this.projectSettingDesIn.setStyles({"border":"1px solid #4A90E2"}); }.bind(this), blur:function(){ this.projectSettingDesIn.setStyles({"border":"1px solid #A6A6A6"}); }.bind(this) }); this.projectSettingContainer = new Element("div.projectSettingContainer",{styles:this.css.projectSettingContainer}).inject(this.projectSettingLayout); this.projectSettingConfirm = new Element("div.projectSettingConfirm",{styles:this.css.projectSettingConfirm,text:this.lp.confirm}).inject(this.projectSettingContainer); this.projectSettingConfirm.addEvents({ click:function(){ if(this.projectSettingTitleIn.get("value").trim()=="") return; var groups = []; if(this.groups){ this.groups.each(function(d){ groups.push(d.id); }); } var data = { "id":this.data.id, "icon":this.data.icon || "", "title":this.projectSettingTitleIn.get("value").trim(), "description":this.projectSettingDesIn.get("value"), "groups":groups }; this.actions.save(data,function(json){ this.projectSettingLayout.empty(); this.app.setLoading(this.projectSettingLayout); this.projectInfor(function(json){ this.loadGeneral(json); if(this.explorer.currentListType == "block"){ this.explorer.loadSingleBlockItem(this.explorer.container.getElementById(json.id),json) }else if(this.explorer.currentListType == "list"){ this.explorer.loadSingleListItem(this.explorer.container.getElementById(json.id),json) } }.bind(this)); }.bind(this)); }.bind(this) }); // this.projectSettingClose = new Element("div.projectSettingClose",{styles:this.css.projectSettingClose,text:this.lp.close}).inject(this.projectSettingContainer); // this.projectSettingClose.addEvents({ // click:function(){ // this.close(); // }.bind(this) // }); //this.projectSettingAction = new Element("div.projectSettingAction",{styles:this.css.projectSettingAction,text:this.lp.confirm}).inject(this.formTableArea); }, projectInfor:function(callback){ if(this.data.id){ this.actions.get(this.data.id,function(json){ this.projectData = json.data; if(callback)callback(json.data) }.bind(this)); } }, groupInfor:function(ids){ if(!ids) return; var resGroups = []; ids.each(function(data){ this.rootActions.ProjectGroupAction.get(data,function(json){ }.bind(this)) }.bind(this)) } });