Task.js 97 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985
  1. MWF.xApplication.TeamWork = MWF.xApplication.TeamWork || {};
  2. MWF.xApplication.TeamWork.Task = new Class({
  3. Extends: MPopupForm,
  4. Implements: [Options, Events],
  5. options: {
  6. "style": "default",
  7. "width": 1000,
  8. "height": "90%",
  9. "top": null,
  10. "left": null,
  11. "bottom" : null,
  12. "right" : null,
  13. "minWidth" : 300,
  14. "minHeight" : 220,
  15. "isLimitSize": true,
  16. "ifFade": false,
  17. "hasTop": false,
  18. "hasTopIcon" : false,
  19. "hasTopContent" : false,
  20. "hasIcon": false,
  21. "hasBottom": false,
  22. "hasMask" : true,
  23. "closeByClickMask" : false,
  24. "hasScroll" : false,
  25. "scrollType" : "",
  26. "title": "",
  27. "draggable": false,
  28. "resizeable" : false,
  29. "maxAction" : false,
  30. "closeAction": false,
  31. "relativeToApp" : true,
  32. "sizeRelateTo" : "app", //desktop
  33. "resultSeparator" : ","
  34. },
  35. initialize: function (explorer, data, options, para) {
  36. this.setOptions(options);
  37. this.explorer = explorer;
  38. if( para ){
  39. if( this.options.relativeToApp ){
  40. this.app = para.app || this.explorer.app;
  41. this.container = para.container || this.app.content;
  42. this.lp = para.lp || this.explorer.lp || this.app.lp;
  43. this.css = para.css || this.explorer.css || this.app.css;
  44. this.actions = para.actions || this.explorer.actions || this.app.actions || this.app.restActions;
  45. }else{
  46. this.container = para.container;
  47. this.lp = para.lp || this.explorer.lp;
  48. this.css = para.css || this.explorer.css;
  49. this.actions = para.actions || this.explorer.actions;
  50. }
  51. }else{
  52. if( this.options.relativeToApp ){
  53. this.app = this.explorer.app;
  54. this.container = this.app.content;
  55. this.lp = this.explorer.lp || this.app.lp;
  56. this.css = this.explorer.css || this.app.css;
  57. this.actions = this.explorer.actions || this.app.actions || this.app.restActions;
  58. }else{
  59. this.container = window.document.body;
  60. this.lp = this.explorer.lp;
  61. this.css = this.explorer.css;
  62. this.actions = this.explorer.actions;
  63. }
  64. }
  65. this.data = data || {};
  66. this.css = {};
  67. this.cssPath = "/x_component_TeamWork/$Task/"+this.options.style+"/css.wcss";
  68. this.load();
  69. this.lp = this.app.lp.task;
  70. },
  71. close: function (data) {
  72. //愤愤愤愤
  73. this.fireEvent("queryClose");
  74. this._close();
  75. //if( this.form ){
  76. // this.form.destroy();
  77. //}
  78. if(this.setFormNodeSizeFun && this.app && this.app.removeEvent ){
  79. this.app.removeEvent("resize",this.setFormNodeSizeFun);
  80. }
  81. if( this.formMaskNode )this.formMaskNode.destroy();
  82. if( this.formAreaNode )this.formAreaNode.destroy();
  83. this.fireEvent("postClose",[data]);
  84. delete this;
  85. },
  86. openTask:function(data){
  87. //this.data.taskId = data.id;
  88. //alert("id="+this.data.taskId)
  89. // this.formAreaNode.setStyles({"opacity":"1"});
  90. // var fx = new Fx.Tween(this.formAreaNode,{duration:400});
  91. // fx.start(["opacity"] ,"1", "0");
  92. var ef = new Fx.Morph(this.formAreaNode, {
  93. duration: 200,
  94. transition: Fx.Transitions.Sine.easeOut,
  95. onStart:function(){},
  96. onComplete:function(){
  97. this._createTableContent();
  98. }.bind(this)
  99. });
  100. ef.start({
  101. 'opacity': [1, 0]
  102. });
  103. //this.formAreaNode.setStyles({"opacity":0});
  104. //this._createTableContent();
  105. },
  106. _createTableContent: function () {
  107. var _self = this;
  108. this.getTaskData(function(){
  109. this.formTableArea.empty();
  110. this.topLayout = new Element("div.topLayout",{styles:this.css.topLayout}).inject(this.formTableArea);
  111. //this.topImage = new Element("div.topImage",{styles:this.css.topImage}).inject(this.topLayout);
  112. this.topContent = new Element("div.topContent",{styles:this.css.topContent,text:this.taskData.name}).inject(this.topLayout);
  113. if(this.isNew){
  114. this.topContent.set("text",this.lp.newTask)
  115. }
  116. this.topIconContainer = new Element("div.topIconContainer",{styles:this.css.topIconContainer}).inject(this.topLayout);
  117. //更多
  118. this.topIconMore = new Element("div.topIconMore",{styles:this.css.topIconMore,title:this.lp.more}).inject(this.topIconContainer);
  119. this.topIconMore.addEvents({
  120. click:function(){
  121. var tm = new MWF.xApplication.TeamWork.Task.TaskMore(this.container, this.topIconMore, this.app, {data:this.taskData}, {
  122. css:this.css, lp:this.lp, axis : "y",
  123. position : { //node 固定的位置
  124. x : "auto",
  125. y : "middle"
  126. },
  127. nodeStyles : {
  128. "min-width":"200px",
  129. "padding":"2px",
  130. "border-radius":"5px",
  131. "box-shadow":"0px 0px 4px 0px #999999",
  132. "z-index" : "201"
  133. },
  134. onPostLoad:function(){
  135. tm.node.setStyles({"opacity":"0","top":(tm.node.getStyle("top").toInt()+4)+"px"});
  136. var fx = new Fx.Tween(tm.node,{duration:400});
  137. fx.start(["opacity"] ,"0", "1");
  138. },
  139. onClose:function(rd){
  140. if(!rd) return;
  141. if(rd.act == "remove"){
  142. this.close(rd);
  143. if(this.data.projectObj){ //reload project
  144. this.data.projectObj.createTaskGroup()
  145. }
  146. }
  147. }.bind(this)
  148. },null,this);
  149. tm.load();
  150. }.bind(this),
  151. mouseover:function(){
  152. this.setStyles({"background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_more_click.png)"});
  153. },
  154. mouseout:function(){
  155. this.setStyles(_self.css.topIconMore)
  156. }
  157. });
  158. //关闭
  159. this.topIconClose = new Element("div.topIconClose",{styles:this.css.topIconClose,title:this.lp.close}).inject(this.topIconContainer);
  160. this.topIconClose.addEvents({
  161. click:function(){
  162. this.close()
  163. }.bind(this),
  164. mouseover:function(){
  165. this.setStyles({"background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_off_click.png)"});
  166. },
  167. mouseout:function(){
  168. this.setStyles(_self.css.topIconClose)
  169. }
  170. });
  171. this.contentLayout = new Element("div.contentLayout",{styles:this.css.contentLayout}).inject(this.formTableArea);
  172. this.createContentLayout();
  173. this.createDetailLayout();
  174. this.formAreaNode.setStyles({"opacity":1})
  175. }.bind(this));
  176. },
  177. createContentLayout:function(){
  178. var _self = this;
  179. this.taskInforContainer = new Element("div.taskInforContainer",{styles:this.css.taskInforContainer}).inject(this.contentLayout);
  180. this.taskActionBar = new Element("div.taskActionBar",{styles:this.css.taskActionBar}).inject(this.taskInforContainer);
  181. if(this.taskData.parent!="0"){
  182. this.taskActionParentContent = new Element("div.taskActionParentContent").inject(this.taskActionBar);
  183. this.taskActionParentIcon = new Element("div.taskActionParentIcon",{styles:this.css.taskActionParentIcon}).inject(this.taskActionParentContent);
  184. this.taskActionParentText = new Element("div.taskActionParentText",{styles:this.css.taskActionParentText,text:this.lp.taskBelongText+":"}).inject(this.taskActionParentContent);
  185. this.taskActionParentValue = new Element("div.taskActionParentValue",{styles:this.css.taskActionParentValue}).inject(this.taskActionParentContent);
  186. this.actions.taskGet(this.taskData.parent,function(json){
  187. this.taskActionParentValue.set("text",json.data.name);
  188. this.taskActionParentValue.addEvents({
  189. click:function(){
  190. this.data.taskId = json.data.id;
  191. this.openTask()
  192. }.bind(this)
  193. });
  194. }.bind(this))
  195. }
  196. // this.taskActionSave = new Element("div.taskActionSave",{styles:this.css.taskActionSave,text:this.lp.save}).inject(this.taskActionBar);
  197. // this.taskActionSave.addEvents({
  198. // click:function(){
  199. // this.saveTaskData();
  200. // }.bind(this),
  201. // mouseover:function(){
  202. // this.setStyles({
  203. // "color":"#ffffff",
  204. // "background-color":"#4A90E2",
  205. // "border":"1px solid #4A90E2"
  206. // })
  207. // },
  208. // mouseout:function(){
  209. // this.setStyles(_self.css.taskActionSave)
  210. // }
  211. // });
  212. this.taskInforLayout = new Element("div.taskInforLayout",{styles:this.css.taskInforLayout}).inject(this.taskInforContainer);
  213. this.taskInforContent = new Element("div.taskInforContent",{styles:this.css.taskInforContent}).inject(this.taskInforLayout);
  214. this.app.setScrollBar(this.taskInforContent);
  215. //名称
  216. this.taskNameContainer = Element("div.taskNameContainer",{styles:this.css.taskNameContainer}).inject(this.taskInforContent);
  217. //状态
  218. this.taskStatusContainer = Element("div.taskStatusContainer",{styles:this.css.taskStatusContainer}).inject(this.taskInforContent);
  219. this.taskStatusIcon = Element("div.taskStatusIcon",{styles:this.css.taskStatusIcon}).inject(this.taskStatusContainer);
  220. this.taskStatusText = Element("div.taskStatusText",{styles:this.css.taskStatusText,text:this.lp.taskStatus}).inject(this.taskStatusContainer);
  221. this.taskStatusValue = Element("div.taskStatusValue",{styles:this.css.taskStatusValue}).inject(this.taskStatusContainer);
  222. //责任人
  223. this.taskDutyContainer = Element("div.taskDutyContainer",{styles:this.css.taskDutyContainer}).inject(this.taskInforContent);
  224. this.taskDutyIcon = Element("div.taskDutyIcon",{styles:this.css.taskDutyIcon}).inject(this.taskDutyContainer);
  225. this.taskDutyText = Element("div.taskDutyText",{styles:this.css.taskDutyText,text:this.lp.taskDuty}).inject(this.taskDutyContainer);
  226. this.taskDutyValue = Element("div.taskDutyValue",{styles:this.css.taskDutyValue}).inject(this.taskDutyContainer);
  227. //时间
  228. this.taskTimeContainer = Element("div.taskTimeContainer",{styles:this.css.taskTimeContainer}).inject(this.taskInforContent);
  229. this.taskTimeIcon = Element("div.taskTimeIcon",{styles:this.css.taskTimeIcon}).inject(this.taskTimeContainer);
  230. this.taskTimeText = Element("div.taskTimeText",{styles:this.css.taskTimeText,text:this.lp.taskTime}).inject(this.taskTimeContainer);
  231. this.taskTimeValue = Element("div.taskTimeValue",{styles:this.css.taskTimeValue}).inject(this.taskTimeContainer);
  232. //备注
  233. this.taskRemarkContainer = Element("div.taskRemarkContainer",{styles:this.css.taskRemarkContainer}).inject(this.taskInforContent);
  234. this.taskRemarkIcon = Element("div.taskRemarkIcon",{styles:this.css.taskRemarkIcon}).inject(this.taskRemarkContainer);
  235. this.taskRemarkText = Element("div.taskRemarkText",{styles:this.css.taskRemarkText,text:this.lp.taskRemark}).inject(this.taskRemarkContainer);
  236. this.taskRemarkValue = Element("div.taskRemarkValue",{styles:this.css.taskRemarkValue}).inject(this.taskRemarkContainer);
  237. //优先级
  238. this.taskPriorityContainer = Element("div.taskPriorityContainer",{styles:this.css.taskPriorityContainer}).inject(this.taskInforContent);
  239. this.taskPriorityIcon = Element("div.taskPriorityIcon",{styles:this.css.taskPriorityIcon}).inject(this.taskPriorityContainer);
  240. this.taskPriorityText = Element("div.taskPriorityText",{styles:this.css.taskPriorityText,text:this.lp.taskPriority}).inject(this.taskPriorityContainer);
  241. this.taskPriorityValue = Element("div.taskPriorityValue",{styles:this.css.taskPriorityValue}).inject(this.taskPriorityContainer);
  242. //扩展字段
  243. if(this.taskData.extFieldConfigs && this.taskData.extFieldConfigs.length>0){
  244. this.taskExtFieldContainer = new Element("div.taskExtFieldContainer",{styles:this.css.taskExtFieldContainer}).inject(this.taskInforContent);
  245. this.loadTaskExtField();
  246. }
  247. //标签
  248. this.taskTagContainer = Element("div.taskTagContainer",{styles:this.css.taskTagContainer}).inject(this.taskInforContent);
  249. this.taskTagIcon = Element("div.taskTagIcon",{styles:this.css.taskTagIcon}).inject(this.taskTagContainer);
  250. this.taskTagText = Element("div.taskTagText",{styles:this.css.taskTagText,text:this.lp.taskTag}).inject(this.taskTagContainer);
  251. this.taskTagValue = Element("div.taskTagValue",{styles:this.css.taskTagValue}).inject(this.taskTagContainer);
  252. //附件 -- 换成其他样式
  253. // this.taskAttachmentContainer = Element("div.taskAttachmentContainer",{styles:this.css.taskAttachmentContainer}).inject(this.taskInforContent);
  254. // this.taskAttachmentIcon = Element("div.taskAttachmentIcon",{styles:this.css.taskAttachmentIcon}).inject(this.taskAttachmentContainer);
  255. // this.taskAttachmentText = Element("div.taskAttachmentText",{styles:this.css.taskAttachmentText,text:this.lp.taskAttachment}).inject(this.taskAttachmentContainer);
  256. // this.taskAttachmentValue = Element("div.taskAtchatBarEmojitachmentValue",{styles:this.css.taskAttachmentValue}).inject(this.taskAttachmentContainer);
  257. //附件
  258. this.taskAttachmentListContainer = new Element("div.taskAttachmentListContainer",{styles:this.css.taskAttachmentListContainer}).inject(this.taskInforContent);
  259. this.loadTaskAttachmentListContainer();
  260. this.setTaskData();
  261. //this.setAuth();
  262. //子任务
  263. this.subTaskContainer = new Element("div.subTaskContainer",{styles:this.css.subTaskContainer}).inject(this.taskInforContent);
  264. this.loadSubTaskContainer();
  265. //占位
  266. new Element("div",{styles:{"width":"100%","height":"100px"}}).inject(this.taskInforContent)
  267. },
  268. loadTaskExtField:function(){
  269. this.taskData.extFieldConfigs.each(function(data){
  270. this.loadTaskExtFieldItem(data);
  271. }.bind(this))
  272. },
  273. loadTaskExtFieldItem:function(data){
  274. var taskExtFieldItem = new Element("div.taskExtFieldItem",{styles:this.css.taskExtFieldItem}).inject(this.taskExtFieldContainer);
  275. var taskExtFieldIcon = new Element("div.taskExtFieldIcon",{styles:this.css.taskExtFieldIcon}).inject(taskExtFieldItem);
  276. var taskExtFieldText = new Element("div.taskExtFieldText",{styles:this.css.taskExtFieldText}).inject(taskExtFieldItem);
  277. new Element("p",{styles:{
  278. "justify-content": "center",
  279. "align-items":"center"
  280. },text:data.displayName}).inject(taskExtFieldText);
  281. if(data.displayType.toUpperCase() == "TEXT"){
  282. }
  283. },
  284. createDetailLayout:function(){
  285. this.taskDetailLayout = new Element("div.taskDetailLayout",{styles:this.css.taskDetailLayout}).inject(this.contentLayout);
  286. this.taskParticipateContainer = new Element("div.taskParticipateContainer",{styles:this.css.taskParticipateContainer}).inject(this.taskDetailLayout);
  287. this.createParticipateContainer();
  288. this.taskDynamicContainer = new Element("div.taskDynamicContainer",{styles:this.css.taskDynamicContainer}).inject(this.taskDetailLayout);
  289. this.createDynamicContainer();
  290. this.taskChatContainer = new Element("div.taskChatContainer",{styles:this.css.taskChatContainer}).inject(this.taskDetailLayout);
  291. this.createChatContainer();
  292. },
  293. createParticipateContainer:function(){
  294. this.taskParticipateContainer.empty();
  295. this.participateTitle = new Element("div.participateTitle",{styles:this.css.participateTitle}).inject(this.taskParticipateContainer);
  296. this.participateTitleText = new Element("div.participateTitleText",{styles:this.css.participateTitleText}).inject(this.participateTitle);
  297. this.participateTitleIcon = new Element("div.participateTitleIcon",{styles:this.css.participateTitleIcon,title:this.lp.taskReaderAdd}).inject(this.participateTitle);
  298. this.participateTitleIcon.addEvents({
  299. click:function(){
  300. this.selectPerson(this.participateTitleIcon,null,["identity","unit"],0,
  301. function(json){
  302. if(json.length>0){
  303. this.taskData.participantList = this.taskData.participantList.concat(json);
  304. this.actions.updateParticipantList(this.taskData.id,{participantList:this.taskData.participantList},function(json){
  305. if(json.data.dynamics){
  306. json.data.dynamics.each(function(dd){
  307. this.loadDynamicItem(dd,"bottom")
  308. }.bind(this))
  309. }
  310. this.dynamicContent.scrollTo(0,this.dynamicContent.getScrollSize().y);
  311. this.createParticipateContainer();
  312. }.bind(this))
  313. }
  314. }.bind(this)
  315. );
  316. }.bind(this)
  317. });
  318. this.participateValue = new Element("div.participateValue",{styles:this.css.participateValue}).inject(this.taskParticipateContainer);
  319. this.setScrollBar(this.participateValue);
  320. if(this.taskData.participantList){
  321. count = this.taskData.participantList.length;
  322. this.participateTitleText.set("text",this.lp.taskReader + " . " + count);
  323. this.taskData.participantList.each(function(d){
  324. var flag = true;
  325. if(this.taskData.executor){
  326. if(d === this.taskData.executor) flag = false
  327. }
  328. this.loadparticipantPerson(this.participateValue,d,flag);
  329. }.bind(this));
  330. }
  331. },
  332. createDynamicContainer:function(){
  333. var _self = this;
  334. this.taskDynamicContainer.empty();
  335. this.dynamicBar = new Element("div.dynamicBar",{styles:this.css.dynamicBar}).inject(this.taskDynamicContainer);
  336. this.dynamicBar.addEvents({
  337. mouseover:function(){
  338. this.dynamicText.setStyle("color","#4a90e2");
  339. this.dynamicIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/icon_dw_click.png)")
  340. }.bind(this),
  341. mouseout:function(){
  342. this.dynamicText.setStyle("color","#666666");
  343. this.dynamicIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/icon_dw.png)")
  344. }.bind(this),
  345. click:function(){
  346. var pc = new MWF.xApplication.TeamWork.Task.DynamicType(this.container, this.dynamicBar, this.app, {data:this.taskData}, {
  347. css:this.css, lp:this.lp, axis : "y",
  348. position : { //node 固定的位置
  349. x : "right",
  350. y : "middle"
  351. },
  352. nodeStyles : {
  353. "min-width":"150px",
  354. "padding":"2px",
  355. "border-radius":"5px",
  356. "box-shadow":"0px 0px 4px 0px #999999",
  357. "z-index" : "201"
  358. },
  359. onPostLoad:function(){
  360. pc.node.setStyles({"opacity":"0","top":(pc.node.getStyle("top").toInt()-6)+"px","left":(pc.node.getStyle("left").toInt()+10)+"px"});
  361. var fx = new Fx.Tween(pc.node,{duration:400});
  362. fx.start(["opacity"] ,"0", "1");
  363. },
  364. onClose:function(rd){
  365. if(!rd) return;
  366. if(rd.value == "all"){
  367. filter = {};
  368. this.dynamicText.set("text",this.lp.dynamicAll)
  369. }else if(rd.value == "chat"){
  370. filter = {objectType:"CHAT"};
  371. this.dynamicText.set("text",this.lp.dynamicChat)
  372. }else if(rd.value == "attachment"){
  373. this.dynamicText.set("text",this.lp.dynamicAttachment)
  374. filter = {objectType:"ATTACHMENT"};
  375. }
  376. this.dynamicContent.empty();
  377. this.dyncurCount = 0;
  378. this.createDynamicContent(null,filter,function(){
  379. this.dynamicContent.scrollTo(0,this.dynamicContent.getScrollSize().y);
  380. this.getDynamicStatus = false;
  381. }.bind(this))
  382. }.bind(this)
  383. });
  384. pc.load();
  385. }.bind(this),
  386. });
  387. this.dynamicText = new Element("div.dynamicText",{styles:this.css.dynamicText,text:this.lp.dynamicAll}).inject(this.dynamicBar);
  388. this.dynamicIcon = new Element("div.dynamicIcon",{styles:this.css.dynamicIcon}).inject(this.dynamicBar);
  389. this.dynamicContent = new Element("div.dynamicContent",{styles:this.css.dynamicContent}).inject(this.taskDynamicContainer);
  390. var filter = {};
  391. var _y = this.dynamicContent.getScrollSize().y;
  392. this.dynamicContent.addEvents({
  393. scroll:function(){
  394. if(this.getScrollTop()==0){
  395. //alert("top")
  396. //加载下一页
  397. if(_self.getDynamicStatus) return;
  398. if(_self.dyncurCount>=_self.dyntotal) return;
  399. _self.createDynamicContent(_self.curDynamicId,filter,function(){
  400. _self.dynamicContent.scrollTo(0,_y);
  401. _self.getDynamicStatus = false;
  402. });
  403. }
  404. }
  405. });
  406. this.createDynamicContent(null,filter,function(){
  407. this.dynamicContent.scrollTo(0,this.dynamicContent.getScrollSize().y);
  408. this.getDynamicStatus = false;
  409. }.bind(this));
  410. },
  411. createDynamicContent:function(id,data,callback){
  412. this.getDynamicStatus = true;
  413. var _self = this, id = id || "(0)", count = 15, taskId = this.taskData.id;
  414. this.curDynamicId = id;
  415. //this.dyntotal = 0;
  416. this.dyncurCount = this.dyncurCount || 0;
  417. this.tmpdynamicLoading = new Element("div").inject(this.dynamicContent,"top");
  418. this.app.setLoading(this.tmpdynamicLoading);
  419. this.actions.taskDynamicListNext(id,count,taskId,data||{},function(json){
  420. if(this.tmpdynamicLoading)this.tmpdynamicLoading.destroy();
  421. //this.getDynamicStatus = false;
  422. if(json.type == "success"){
  423. this.dyntotal = json.count;
  424. json.data.each(function(d,i){
  425. this.curDynamicId = d.id;
  426. this.loadDynamicItem(d);
  427. }.bind(this))
  428. if(callback)callback(json)
  429. }
  430. }.bind(this))
  431. },
  432. loadDynamicItem:function(data,where){
  433. this.dyncurCount = this.dyncurCount + 1;
  434. var dynamicItem = new Element("div.dynamicItem",{styles:this.css.dynamicItem}).inject(this.dynamicContent,where||"top");
  435. var dynamicItemIcon = new Element("div.dynamicItemIcon",{styles:this.css.dynamicItemIcon}).inject(dynamicItem);
  436. var optType = data.optType.toUpperCase();
  437. var objectType = data.objectType.toUpperCase();
  438. if(objectType == "CHAT"){
  439. //if(optType.toUpperCase() == "PUBLISH"){
  440. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_chat.png)")
  441. //}
  442. }else if(objectType == "ATTACHMENT"){
  443. if(optType == "DELETE"){ //UPLOAD、DOWNLOAD、DELETE
  444. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_remove.png)")
  445. }else{
  446. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_attachment.png)")
  447. }
  448. }else if(objectType == "TASK"){
  449. //UPDATE_NAME、UPDATE_EXECUTOR、UPDATE_STATUS、UPDATE_TIME、UPDATE_PROGRESS、ADD_TAGS、REMOVE_TAGS、
  450. //ADD_MANAGER、REMOVE_MANAGER、ADD_PARTICIPANTS、REMOVE_PARTICIPANTS、CREATE、DELETE
  451. if(optType=="SPLIT"){
  452. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_subtask.png)")
  453. }else if(optType=="DELETE_SUBTASK"){
  454. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_remove.png)")
  455. }else if(optType=="UPDATE_EXECUTOR"){
  456. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_duty.png)")
  457. }else if(optType=="UPDATE_NAME"){
  458. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_title.png)")
  459. }else if(optType=="UPDATE_WORKSTATUS"){
  460. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_status.png)")
  461. }else if(optType=="UPDATE_WORKDATE"){
  462. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_time.png)")
  463. }else if(optType=="UPDATE_DESCRIPTION"){
  464. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_remark.png)")
  465. }else if(optType=="ADD_PARTICIPANTS" || optType == "REMOVE_PARTICIPANTS"){
  466. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_participant.png)")
  467. }else if(optType=="CREATE"){
  468. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/icon_jia.png)")
  469. }else{
  470. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/icon_edit.png)")
  471. }
  472. }else if(objectType=="TASK_TAG"){
  473. if(optType=="REMOVE"){
  474. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_remove.png)")
  475. }else{
  476. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/dy_tag.png)")
  477. }
  478. }
  479. var dynamicItemText = new Element("div.dynamicItemText",{styles:this.css.dynamicItemText}).inject(dynamicItem);
  480. if(objectType == "CHAT"){
  481. new Element("div.dynamicItemUser",{styles:this.css.dynamicItemUser,text:data.operator.split("@")[0]}).inject(dynamicItemText);
  482. var chattext = data.description.split("\n").join("<br/>");
  483. //转换表情
  484. for(var item in this.app.lp.emoji){
  485. var val = this.app.lp.emoji[item]; //alert(val)
  486. chattext = chattext.split("["+val+"]").join('<img style="margin:0px 2px;" src="/x_component_TeamWork/$Emoji/default/icon/'+item+'.png" />');
  487. }
  488. new Element("div.dynamicItemUserChat",{styles:{"margin-top":"5px"},html:chattext}).inject(dynamicItemText);
  489. }else{
  490. dynamicItemText.set("text",data.description);
  491. }
  492. var dynamicItemTime = new Element("div.dynamicItemTime",{styles:this.css.dynamicItemTime}).inject(dynamicItem);
  493. var ct = Date.parse(data.createTime);
  494. var now = new Date();
  495. var sep = now.getTime()-ct.getTime();
  496. sep = sep/1000; //毫秒
  497. //一分钟内,刚刚,一小时内,多少分钟前,2小时内,显示一小时前,2小时到今天00:00:00 显示 今天几点,本周内,显示本周几,几点几分,其他显示几月几日
  498. var cttext = "";
  499. if(sep<60){
  500. cttext = "刚刚"
  501. }else if(sep<3600){
  502. cttext = Math.floor(sep/60)+"分钟前"
  503. }else if(sep<7200){
  504. cttext = "1小时前"
  505. }else if(sep>7200 && ct.getFullYear() == now.getFullYear() && ct.getMonth()==now.getMonth() && ct.getDate() == now.getDate()){
  506. cttext = "今天"+(ct.getHours()<10?("0"+ct.getHours()):ct.getHours())+":"+(ct.getMinutes()<10?"0"+ct.getMinutes():ct.getMinutes())
  507. }else if(ct.getFullYear() == now.getFullYear() && ct.getMonth()==now.getMonth() && ct.getDate() == now.getDate()-1){
  508. cttext = "昨天"+(ct.getHours()<10?("0"+ct.getHours()):ct.getHours())+":"+(ct.getMinutes()<10?"0"+ct.getMinutes():ct.getMinutes())
  509. }else{
  510. cttext = (ct.getMonth()+1) + "月"+ct.getDay()+"日"
  511. }
  512. dynamicItemTime.set("text",cttext);
  513. //最后加一层清除浮动
  514. new Element("div.dynamicItemTime",{styles:{"clear":"both"}}).inject(dynamicItem);
  515. },
  516. createChatContainer:function(){
  517. this.taskChatContainer.empty();
  518. var node = this.taskChatContainer;
  519. this.chatContent = new Element("div.chatContent",{styles:this.css.chatContent}).inject(node);
  520. this.chatTextarea = new Element("textarea.chatTextarea",{styles:this.css.chatTextarea,placeholder:this.lp.chatPlaceholder}).inject(this.chatContent);
  521. this.chatTextarea.addEvents({
  522. keypress:function(e){
  523. var keycode = (e.event.keyCode ? e.event.keyCode : e.event.which);
  524. if (e.event.ctrlKey && (keycode == 13 || keycode == 10)) {
  525. this.chatBarSend.click();
  526. }
  527. }.bind(this)
  528. });
  529. this.chatBarContent = new Element("div.chatBarContent",{styles:this.css.chatBarContent}).inject(node);
  530. this.chatBarTool = new Element("div.chatBarTool",{styles:this.css.chatBarTool}).inject(this.chatBarContent);
  531. this.chatBarEmoji = new Element("div.chatBarEmoji",{styles:this.css.chatBarEmoji,title:this.lp.chatInsertEmoji}).inject(this.chatBarTool);
  532. this.chatBarEmoji.addEvents({
  533. mouseover:function(){this.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/icon_emoji_click.png)")},
  534. mouseout:function(){this.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/icon_emoji.png)")},
  535. click:function(){
  536. MWF.xDesktop.requireApp("TeamWork", "Emoji", function(){
  537. var pc = new MWF.xApplication.TeamWork.Emoji(this,this.container, this.chatBarEmoji, this.app, {}, {
  538. css:this.css, lp:this.lp, axis : "y",
  539. position : { //node 固定的位置
  540. x : "right",
  541. y : "middle"
  542. },
  543. nodeStyles : {
  544. "min-width":"200px",
  545. "max-width":"210px",
  546. "height":"80px",
  547. "padding":"2px",
  548. "border-radius":"5px",
  549. "box-shadow":"0px 0px 4px 0px #999999",
  550. "z-index" : "201"
  551. },
  552. onPostLoad:function(){
  553. pc.node.setStyles({"opacity":"0","top":(pc.node.getStyle("top").toInt())+"px"});
  554. var fx = new Fx.Tween(pc.node,{duration:400});
  555. fx.start(["opacity"] ,"0", "1");
  556. },
  557. onClose:function(rd){
  558. if(!rd) return;
  559. if(rd.value && rd.value !=""){
  560. this.chatTextarea.set("value",this.chatTextarea.get("value")+"["+rd.value+"]")
  561. }
  562. }.bind(this)
  563. });
  564. pc.load();
  565. }.bind(this))
  566. }.bind(this)
  567. });
  568. this.chatBarSend = new Element("div.chatBarSend",{styles:this.css.chatBarSend,text:this.lp.chatSend}).inject(this.chatBarContent);
  569. this.chatBarSend.addEvents({
  570. click:function(){
  571. if(this.chatTextarea.get("value").trim()=="") return;
  572. var data = {
  573. taskId : this.taskData.id,
  574. content : this.chatTextarea.get("value").trim()
  575. };
  576. this.actions.chatCreate(data,function(json){
  577. if(json.data.id){
  578. this.actions.chatGet(json.data.id,function(json){
  579. var person = json.data.sender;
  580. var content = json.data.content;
  581. var dynamicItem = new Element("div.dynamicItem",{styles:this.css.dynamicItem}).inject(this.dynamicContent);
  582. var dynamicItemIcon = new Element("div.dynamicItemIcon",{styles:this.css.dynamicItemIcon}).inject(dynamicItem);
  583. dynamicItemIcon.setStyle("background-image","url(/x_component_TeamWork/$Task/default/icon/icon_chat.png)")
  584. var dynamicItemText = new Element("div.dynamicItemText",{styles:this.css.dynamicItemText}).inject(dynamicItem);
  585. new Element("div.dynamicItemUser",{styles:this.css.dynamicItemUser,text:person.split("@")[0]}).inject(dynamicItemText);
  586. var chattext = content.split("\n").join("<br/>");
  587. for(var item in this.app.lp.emoji){
  588. var val = this.app.lp.emoji[item];
  589. chattext = chattext.split("["+val+"]").join('<img style="margin:0 2px;" src="/x_component_TeamWork/$Emoji/default/icon/'+item+'.png" />');
  590. }
  591. new Element("div.dynamicItemUserChat",{styles:{"margin-top":"5px"},html:chattext}).inject(dynamicItemText);
  592. var dynamicItemTime = new Element("div.dynamicItemTime",{styles:this.css.dynamicItemTime}).inject(dynamicItem);
  593. dynamicItemTime.set("text","刚刚");
  594. new Element("div.dynamicItemTime",{styles:{"clear":"both"}}).inject(dynamicItem);
  595. this.dynamicContent.scrollTo(0,this.dynamicContent.getScrollSize().y);
  596. }.bind(this))
  597. }
  598. this.createChatContainer()
  599. }.bind(this))
  600. }.bind(this)
  601. })
  602. },
  603. addDynamicItem:function(){
  604. },
  605. getTaskData:function(callback){
  606. if(this.data.taskId){
  607. this.actions.taskGet(this.data.taskId,function(json){
  608. if(json.data) {
  609. this.taskData = json.data;
  610. if(callback)callback()
  611. }
  612. }.bind(this))
  613. }
  614. },
  615. setTaskData:function(){
  616. var _self = this;
  617. //名称
  618. if(this.taskNameContainer){
  619. this.loadNameValue();
  620. }
  621. //状态
  622. if(this.taskStatusValue){
  623. this.loadStatusValue()
  624. }
  625. //负责人
  626. if(this.taskDutyValue){
  627. this.loadDutyValue()
  628. }
  629. //时间
  630. if(this.taskTimeContainer){
  631. this.loadTimeValue()
  632. }
  633. //备注
  634. if(this.taskRemarkContainer){
  635. this.loadRemarkValue()
  636. }
  637. //优先级
  638. if(this.taskPriorityValue){
  639. this.loadPriorityValue()
  640. }
  641. //标签
  642. if(this.taskTagValue){
  643. this.loadTagValue()
  644. }
  645. //附件
  646. if(this.taskAttachmentValue){
  647. this.loadAttachment(this.taskAttachmentValue)
  648. }
  649. },
  650. saveTaskData:function(callback) {
  651. if(this.editor){
  652. this.taskData.description = encodeURI(this.editor.getData());
  653. }
  654. this.actions.taskSave(this.taskData,function(json){
  655. if(this.editor) delete this.editor;
  656. //alert(JSON.stringify(json));
  657. this.reload();
  658. //刷新project区域内的task,可能有更新,删除等 干脆直接载入区域
  659. var data = {
  660. "act":"save",
  661. "taskId":json.data.id
  662. };
  663. this.reloadOutContent(data);
  664. }.bind(this))
  665. },
  666. reloadOutContent:function(json){
  667. if(json.act == "save"){
  668. //保存操作,刷新task即可
  669. var taskNode = this.explorer.container.getElementById(json.taskId);
  670. if(!taskNode) return;
  671. this.actions.taskGet(json.taskId,function(d){
  672. this.explorer.loadTaskNode(taskNode,d.data)
  673. }.bind(this));
  674. }
  675. },
  676. updateSingleProperty:function(data,callback){
  677. this.actions.updateSingleProperty(data.taskId,data,function(json){
  678. if(json.data.dynamics){
  679. json.data.dynamics.each(function(dd){
  680. this.loadDynamicItem(dd,"bottom")
  681. }.bind(this))
  682. }
  683. this.dynamicContent.scrollTo(0,this.dynamicContent.getScrollSize().y);
  684. if(callback)callback(json.data)
  685. }.bind(this))
  686. },
  687. loadNameValue:function(){ //名称
  688. var _self = this;
  689. this.taskNameContainer.set("text",this.taskData.name);
  690. if(true){ //权限修改
  691. var node = this.taskNameContainer;
  692. var nameEdit = false;
  693. var overStatus = null;
  694. node.addEvents({
  695. mouseenter:function(){
  696. overStatus = window.setTimeout(function(){
  697. var opt={ axis: "y", position : { x : "auto", y : "top"} };
  698. //_self.app.showTips(node,{_html:"<div style='margin:2px 5px;'>"+_self.lp.editTip+"</div>"},opt);
  699. node.set("title",_self.lp.editTip);
  700. },300);
  701. if(this.getElement("input")) return;
  702. var name = this.get("text");
  703. node.empty();
  704. var input = new Element("input.taskNameInput",{type:"text",value:name,styles:_self.css.taskNameInput}).inject(node);
  705. input.addEvents({
  706. click:function(ev){
  707. nameEdit = true;
  708. if(_self.app.st&&_self.app.st.node)_self.app.st.node.destroy();
  709. delete _self.app.st;
  710. ev.stopPropagation()
  711. },
  712. blur:function(){
  713. var v = this.get("value").trim();
  714. if(v=="" || v == _self.taskData.name){
  715. _self.taskNameContainer.empty();
  716. _self.taskNameContainer.set("text",_self.taskData.name);
  717. _self.taskNameContainer.setStyles({"background-color":""});
  718. _self.taskData.name = v;
  719. }else{
  720. if(v != _self.taskData.name){
  721. var sd = {
  722. taskId:_self.taskData.id,
  723. property:"name",
  724. mainValue:v,
  725. secondaryValue:""
  726. }
  727. _self.updateSingleProperty(sd,function(json){
  728. _self.taskNameContainer.empty();
  729. _self.taskNameContainer.set("text",v);
  730. _self.taskNameContainer.setStyles({"background-color":""});
  731. _self.taskData.name = v;
  732. nameEdit = false;
  733. })
  734. }
  735. }
  736. }
  737. });
  738. },
  739. mouseleave:function(){
  740. window.clearTimeout(overStatus);
  741. if(!nameEdit){
  742. if(this.getElement("input")){
  743. var n = this.getElement("input").get("value");
  744. this.empty();
  745. this.set("text",n);
  746. }
  747. this.setStyles({"background-color":""})
  748. }
  749. }
  750. });
  751. }
  752. },
  753. loadStatusValue:function(){ //状态
  754. var _self = this;
  755. if(this.taskStatusValue) this.taskStatusValue.empty();
  756. this.taskStatusValueContainer = new Element("div.taskStatusValueContainer",{styles:this.css.taskStatusValueContainer}).inject(this.taskStatusValue);
  757. this.taskStatusValueIcon = new Element("div.taskStatusValueIcon",{styles:this.css.taskStatusValueIcon}).inject(this.taskStatusValueContainer);
  758. this.taskStatusValueText = new Element("div.taskStatusValueText",{styles:this.css.taskStatusValueText}).inject(this.taskStatusValueContainer);
  759. if(this.taskData.workStatus == "draft"){
  760. this.taskStatusValueContainer.setStyles({"color":"#666666"});
  761. this.taskStatusValueIcon.setStyles({"background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_draft.png)"});
  762. this.taskStatusValueText.set("text",this.lp.status.draft);
  763. }else if(this.taskData.workStatus == "flow"){
  764. this.taskStatusValueContainer.setStyles({"color":"#666666"});
  765. this.taskStatusValueIcon.setStyles({"background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_flow.png)"});
  766. this.taskStatusValueText.set("text",this.lp.status.flow);
  767. }else if(this.taskData.workStatus == "processing") {
  768. this.taskStatusValueContainer.setStyles({"color": "#666666"});
  769. this.taskStatusValueIcon.setStyles({"background-image": "url(/x_component_TeamWork/$Task/default/icon/icon_flow.png)"});
  770. this.taskStatusValueText.set("text",this.lp.status.processing);
  771. }else if(this.taskData.workStatus == "completed"){
  772. this.taskStatusValueContainer.setStyles({"color":"#69b439"});
  773. this.taskStatusValueIcon.setStyles({"background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_complete.png)"});
  774. this.taskStatusValueText.set("text",this.lp.status.completed);
  775. }
  776. if(true){ //权限
  777. this.taskStatusValueContainer.addEvents({
  778. click:function(){
  779. var sc = new MWF.xApplication.TeamWork.Task.StatusCheck(this.container, this.taskStatusValueContainer, this.app, {data:this.taskData}, {
  780. css:this.css, lp:this.lp, axis : "y",
  781. position : { //node 固定的位置
  782. x : "right",
  783. y : "middle"
  784. },
  785. nodeStyles : {
  786. "min-width":"200px",
  787. "padding":"2px",
  788. "border-radius":"5px",
  789. "box-shadow":"0px 0px 4px 0px #999999",
  790. "z-index" : "201"
  791. },
  792. onPostLoad:function(){
  793. sc.node.setStyles({"opacity":"0","top":(sc.node.getStyle("top").toInt()+4)+"px"});
  794. var fx = new Fx.Tween(sc.node,{duration:400});
  795. fx.start(["opacity"] ,"0", "1");
  796. },
  797. onClose:function(rd){
  798. if(!rd) return;
  799. if(rd.status){
  800. if(rd.status != this.taskData.workStatus){
  801. var sd = {
  802. taskId:_self.taskData.id,
  803. property:"workStatus",
  804. mainValue:rd.status,
  805. secondaryValue:""
  806. };
  807. _self.updateSingleProperty(sd,function(){
  808. this.taskData.workStatus = rd.status;
  809. this.loadStatusValue();
  810. }.bind(this))
  811. }
  812. }
  813. }.bind(this)
  814. });
  815. sc.load();
  816. }.bind(this),
  817. mouseover:function(){
  818. this.setStyles({"background-color":"#efefef"});
  819. this.getElement(".taskStatusValueIcon").setStyles({ "background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_down.png)"})
  820. },
  821. mouseout:function(){
  822. this.setStyles(_self.css.taskStatusValueContainer);
  823. var bgurl = "url(/x_component_TeamWork/$Task/default/icon/icon_draft.png)";
  824. if(_self.taskData.workStatus == "processing")bgurl = "url(/x_component_TeamWork/$Task/default/icon/icon_flow.png)";
  825. else if(_self.taskData.workStatus == "completed")bgurl = "url(/x_component_TeamWork/$Task/default/icon/icon_complete.png)";
  826. this.getElement(".taskStatusValueIcon").setStyles({"background-image":bgurl})
  827. }
  828. });
  829. }
  830. },
  831. loadDutyValue:function(){
  832. var _self = this;
  833. if(this.taskDutyValue) this.taskDutyValue.empty();
  834. this.taskDutyValueContainer = new Element("div.taskDutyValueContainer",{styles:this.css.taskDutyValueContainer}).inject(this.taskDutyValue);
  835. if(true){//权限
  836. if(this.taskData.executor==""){
  837. this.taskDutyAddIcon = new Element("div.taskDutyAddIcon",{styles:this.css.taskDutyAddIcon}).inject(this.taskDutyValueContainer);
  838. this.taskDutyAddText = new Element("div.taskDutyAddText",{styles:this.css.taskDutyAddText,text:this.lp.addDuty}).inject(this.taskDutyValueContainer);
  839. this.taskDutyAddText.addEvents({
  840. mouseover:function(){this.setStyles({"color":"#4a90e2"})},
  841. mouseout:function(){this.setStyles({"color":"#666666"})},
  842. click:function(){
  843. this.selectPerson(this.taskDutyAddText,"identity",null,1,
  844. function(json){
  845. if(json.length>0){
  846. this.taskData.executor = json[0];
  847. this.loadDutyValue()
  848. }
  849. }.bind(this));
  850. }.bind(this)
  851. })
  852. }else{
  853. this.loadTaskPerson(this.taskDutyValueContainer,this.taskData.executor,true);
  854. }
  855. }else{
  856. if(this.taskData.executor!=""){
  857. this.loadTaskPerson(this.taskDutyValueContainer,this.taskData.executor);
  858. }
  859. }
  860. },
  861. loadTimeValue:function(){
  862. var _self = this;
  863. this.taskStartTime = new Element("div.taskStartTime",{styles:this.css.taskStartTime}).inject(this.taskTimeContainer);
  864. this.taskTimeLine = new Element("div.taskTimeLine",{styles:this.css.taskTimeLine,text:"-"}).inject(this.taskTimeContainer);
  865. this.taskEndTime = new Element("div.taskEndTime",{styles:this.css.taskEndTime}).inject(this.taskTimeContainer);
  866. if(this.taskData.startTime && this.taskData.startTime!=""){
  867. this.taskStartTime.set("text",this.taskData.startTime);
  868. this.taskStartTime.setStyles({"color":"#333333"});
  869. }else{
  870. this.taskStartTime.set("text",this.lp.taskTimeStart);
  871. }
  872. if(this.taskData.endTime && this.taskData.endTime!=""){
  873. this.taskEndTime.set("text",this.taskData.endTime);
  874. this.taskEndTime.setStyles({"color":"#333333"});
  875. }else{
  876. this.taskEndTime.set("text",this.lp.taskTimeEnd);
  877. }
  878. if(true){ //权限
  879. this.taskStartTime.setStyles({"background-color":"#f5f5f5","cursor":"pointer"});
  880. this.taskEndTime.setStyles({"background-color":"#f5f5f5","cursor":"pointer"});
  881. this.taskStartTime.addEvents({
  882. click:function(){
  883. var opt = {
  884. type:"datetime"
  885. };
  886. this.app.selectCalendar(this.taskStartTime,this.container,opt,function(json){
  887. var sd = {
  888. taskId:_self.taskData.id,
  889. property:"startTime",
  890. secondaryValue:""
  891. }
  892. if(json.action == "ok"){
  893. this.taskStartTime.set("text",json.dateString+":00");
  894. sd.mainValue = json.dateString+":00"
  895. }else if(json.action == "clear"){
  896. this.taskStartTime.set("text",this.lp.taskTimeStart);
  897. sd.mainValue = ""
  898. }
  899. this.updateSingleProperty(sd)
  900. }.bind(this))
  901. }.bind(this)
  902. });
  903. this.taskEndTime.addEvents({
  904. click:function(){
  905. var opt = {
  906. type:"datetime"
  907. };
  908. this.app.selectCalendar(this.taskEndTime,this.container,opt,function(json){
  909. var sd = {
  910. taskId:_self.taskData.id,
  911. property:"startTime",
  912. secondaryValue:""
  913. }
  914. if(json.action == "ok"){
  915. this.taskEndTime.set("text",json.dateString+":00");
  916. sd.mainValue = json.dateString + ":00"
  917. }else if(json.action == "clear"){
  918. this.taskEndTime.set("text",this.lp.taskTimeEnd);
  919. sd.mainValue = ""
  920. }
  921. this.updateSingleProperty(sd)
  922. }.bind(this))
  923. }.bind(this)
  924. })
  925. }
  926. },
  927. loadRemarkValue:function(){
  928. var _self = this;
  929. var value = this.taskData.description || "";
  930. value = decodeURI(value);
  931. this.taskRemarkValue.set("html",value);
  932. if(this.taskRemarkValue.getFirst("p")){
  933. this.taskRemarkValue.getFirst("p").setStyles({"margin-top":"0px"})
  934. }
  935. if(this.editor) delete this.editor;
  936. if(true){ //权限
  937. if(value == ""){
  938. this.taskRemarkValue.set("text",this.lp.editTip);
  939. }
  940. this.taskRemarkValue.removeEvents(["click"])
  941. this.taskRemarkValue.addEvents({
  942. click:function(e){
  943. this.taskRemarkValue.setStyles({"background-color":"","color":""});
  944. this.taskRemarkValue.removeEvents(["mouseenter"]);
  945. if(!this.editor)this.taskRemarkValue.empty();
  946. this.loadRemarkEditor(this.taskRemarkValue,value,"taskRemark");
  947. e.stopPropagation();
  948. }.bind(this),
  949. mouseenter:function(){
  950. this.taskRemarkValue.setStyles({"background-color":"#f5f5f5","color":"#999999"})
  951. }.bind(this),
  952. mouseleave:function(){
  953. this.taskRemarkValue.setStyles({"background-color":"","color":""})
  954. }.bind(this)
  955. });
  956. }
  957. },
  958. loadPriorityValue:function(){
  959. if(this.taskPriorityValue)this.taskPriorityValue.empty();
  960. var node = new Element("div.taskPriorityValueText",{styles:this.css.taskPriorityValueText}).inject(this.taskPriorityValue);
  961. var curColor = "#999999";
  962. if(this.taskData.priority){
  963. node.set("text",this.taskData.priority);
  964. if(this.taskData.priority == this.lp.priority.urgency) curColor = "#ffaf38";
  965. else if(this.taskData.priority == this.lp.priority.emergency) curColor = "#ff4f3e";
  966. node.setStyles({"color":curColor,"border":"1px solid "+curColor+""})
  967. }else{
  968. node.set("text",this.lp.priority.normal)
  969. }
  970. node.addEvents({
  971. click:function(){
  972. var pc = new MWF.xApplication.TeamWork.Task.PriorityCheck(this.container, node, this.app, {data:this.taskData}, {
  973. css:this.css, lp:this.lp, axis : "y",
  974. position : { //node 固定的位置
  975. x : "right",
  976. y : "middle"
  977. },
  978. nodeStyles : {
  979. "min-width":"200px",
  980. "padding":"2px",
  981. "border-radius":"5px",
  982. "box-shadow":"0px 0px 4px 0px #999999",
  983. "z-index" : "201"
  984. },
  985. onPostLoad:function(){
  986. pc.node.setStyles({"opacity":"0","top":(pc.node.getStyle("top").toInt()+4)+"px"});
  987. var fx = new Fx.Tween(pc.node,{duration:400});
  988. fx.start(["opacity"] ,"0", "1");
  989. },
  990. onClose:function(rd){
  991. if(!rd) return;
  992. if(rd.value){
  993. if(rd.value != this.taskData.priority){
  994. var sd = {
  995. taskId:this.taskData.id,
  996. property:"priority",
  997. mainValue:rd.value,
  998. secondaryValue:""
  999. };
  1000. this.updateSingleProperty(sd,function(){
  1001. this.taskData.priority = rd.value;
  1002. this.loadPriorityValue();
  1003. }.bind(this))
  1004. }
  1005. }
  1006. this.loadPriorityValue();
  1007. }.bind(this)
  1008. });
  1009. pc.load();
  1010. }.bind(this),
  1011. mouseover:function(){
  1012. this.setStyles({"border":"1px solid #4A90E2","color":"#4A90E2"})
  1013. },
  1014. mouseout:function(){
  1015. this.setStyles({"border":"1px solid "+curColor+"","color":curColor})
  1016. }
  1017. })
  1018. },
  1019. loadTagValue:function(){
  1020. if(this.taskTagValue)this.taskTagValue.empty();
  1021. this.taskTagLayout = new Element("div.taskTagLayout",{styles:this.css.taskTagLayout}).inject(this.taskTagValue);
  1022. this.taskTagAddContainer = new Element("div.taskTagAddContainer",{styles:this.css.taskTagAddContainer}).inject(this.taskTagValue);
  1023. this.taskTagAddText = new Element("div.taskTagAddText",{styles:this.css.taskTagAddText,text:this.lp.taskTagAddText}).inject(this.taskTagAddContainer);
  1024. this.taskTagAddText.addEvents({
  1025. mouseover:function(){this.setStyles({"color":"#4A90E2"})},
  1026. mouseout:function(){this.setStyles({"color":"#666666"})},
  1027. click:function(){
  1028. this.loadTaskTag(this.taskTagAddText)
  1029. }.bind(this)
  1030. });
  1031. this.taskTagAdd = new Element("div.taskTagAdd",{styles:this.css.taskTagAdd}).inject(this.taskTagAddContainer);
  1032. this.taskTagAdd.addEvents({
  1033. mouseover:function(){this.setStyles({"background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_subtask_add.png)"})},
  1034. mouseout:function(){this.setStyles({"background-image":"url(/x_component_TeamWork/$Task/default/icon/icon_jia.png)"})},
  1035. click:function(){
  1036. this.loadTaskTag(this.taskTagAdd)
  1037. }.bind(this)
  1038. })
  1039. if(!this.taskData.tags || this.taskData.tags.length==0){
  1040. this.taskTagAdd.hide();
  1041. }else{
  1042. this.taskTagAddText.hide();
  1043. this.taskData.tags.each(function(json){
  1044. this.loadTagItem(json)
  1045. }.bind(this))
  1046. }
  1047. },
  1048. loadTagItem:function(data){
  1049. var _self = this;
  1050. var tagItemContainer = new Element("div.tagItemContainer",{styles:this.css.tagItemContainer,id:data.id}).inject(this.taskTagLayout);
  1051. tagItemContainer.setStyles({"background-color":data.tagColor});
  1052. tagItemContainer.addEvents({
  1053. mouseenter:function(){
  1054. var tagItemClose = new Element("div.tagItemClose",{styles:_self.css.tagItemClose}).inject(tagItemContainer);
  1055. tagItemContainer.setStyles({"width":(tagItemContainer.getWidth().toInt()+2)+"px"});
  1056. tagItemText.setStyles({"margin-right":"5px"});
  1057. tagItemText.set("title",data.tag);
  1058. tagItemClose.addEvents({
  1059. click:function(){
  1060. _self.actions.removeTagToTask(_self.taskData.id,data.id,function(json){
  1061. if(json.data.dynamics){
  1062. json.data.dynamics.each(function(dd){
  1063. _self.loadDynamicItem(dd,"bottom")
  1064. })
  1065. }
  1066. _self.dynamicContent.scrollTo(0,_self.dynamicContent.getScrollSize().y);
  1067. tagItemContainer.destroy();
  1068. _self.taskData.tags.each(function(ddd){
  1069. if(ddd.id == data.id){
  1070. _self.taskData.tags.erase(ddd)
  1071. }
  1072. })
  1073. })
  1074. }
  1075. })
  1076. },
  1077. mouseleave:function(){
  1078. //tagItemContainer.setStyles({"width":(tagItemContainer.getWidth().toInt()-this.getElement(".tagItemClose").getWidth()-2)+"px"});
  1079. tagItemContainer.setStyles({"width":""});
  1080. tagItemText.setStyles({"margin-right":"10px"});
  1081. this.getElement(".tagItemClose").destroy();
  1082. }
  1083. });
  1084. var tagItemText = new Element("div.tagItemText",{styles:this.css.tagItemText}).inject(tagItemContainer);
  1085. tagItemText.set("text",data.tag);
  1086. },
  1087. loadTaskTag:function(node){
  1088. MWF.xDesktop.requireApp("TeamWork", "TaskTag", function(){
  1089. //alert(JSON.stringify(this.taskData.tags))
  1090. var data = {
  1091. projectId:this.taskData.project,
  1092. taskId:this.taskData.id,
  1093. taskTags:this.taskData.tags||[]
  1094. };
  1095. var pc = new MWF.xApplication.TeamWork.TaskTag(this.container, node, this.app, data, {
  1096. axis : "y",
  1097. position : { //node 固定的位置
  1098. x : "right",
  1099. y : "middle"
  1100. },
  1101. nodeStyles : {
  1102. "min-width":"200px",
  1103. "width":"210px",
  1104. //"height":"80px",
  1105. "padding":"2px",
  1106. "border-radius":"2px",
  1107. "box-shadow":"0px 0px 4px 0px #999999",
  1108. "z-index" : "201"
  1109. },
  1110. onPostLoad:function(){
  1111. pc.node.setStyles({"opacity":"0","top":(pc.node.getStyle("top").toInt())+"px"});
  1112. var fx = new Fx.Tween(pc.node,{duration:400});
  1113. fx.start(["opacity"] ,"0", "1");
  1114. },
  1115. onClose:function(rd){
  1116. if(!rd) return;
  1117. // if(rd.value && rd.value !=""){
  1118. // this.chatTextarea.set("value",this.chatTextarea.get("value")+"["+rd.value+"]")
  1119. // }
  1120. }.bind(this)
  1121. },null,this);
  1122. pc.load();
  1123. }.bind(this))
  1124. },
  1125. loadRemarkEditor:function(parent,value,name){
  1126. if(this.editor)return;
  1127. COMMON.AjaxModule.load("ckeditor", function(){
  1128. //CKEDITOR.disableAutoInline = true;
  1129. var item = new Element("div",{
  1130. "name" : name,
  1131. "id" : name
  1132. });
  1133. //item.set( attr );
  1134. if(parent)item.inject(parent);
  1135. //if( value )item.set("html", value);
  1136. var editorConfig = {
  1137. "autoGrow_maxHeight": 400,
  1138. //"autoGrow_minHeight": 300,
  1139. "resize_enabled": true,
  1140. //"resize_maxHeight": "3000",
  1141. //"resize_minHeight": "200",
  1142. "autoParagraph": true,
  1143. "autoUpdateElement": true,
  1144. "enterMode": 1,
  1145. "height": 100,
  1146. "width": 480,
  1147. "readOnly": false,
  1148. "startupFocus" : true,
  1149. toolbar : [
  1150. //{ name: 'document', items : [ 'Preview' ] },
  1151. //{ name: 'clipboard', items : [ 'Cut','Copy','Paste','PasteText','PasteFromWord','-','Undo','Redo' ] },
  1152. { name: 'basicstyles', items : [ 'Bold','Underline','Strike','-','RemoveFormat' ] },
  1153. //{ name: 'paragraph', items : [ 'JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock' ] },
  1154. { name: 'styles', items : [ 'Font','FontSize' ] },
  1155. { name: 'colors', items : [ 'TextColor' ] },
  1156. { name: 'links', items : [ 'Link','Unlink' ] },
  1157. //{ name: 'insert', items : [ 'Image' ] },
  1158. { name: 'tools', items : [ 'Maximize','-' ] }
  1159. ]
  1160. };
  1161. if( this.options.RTFConfig ){
  1162. editorConfig = Object.merge( editorConfig, this.options.RTFConfig )
  1163. }
  1164. if( editorConfig.skin )editorConfig.skin = "moono-lisa";
  1165. this.editor = CKEDITOR.replace(item, editorConfig);
  1166. //this.items.push( this.editor );
  1167. this.editor.setData(value);
  1168. this.editor.on('instanceReady', function (e) {
  1169. this.editor.focus();
  1170. var range = this.editor.createRange();
  1171. range.moveToElementEditEnd(this.editor.editable());
  1172. this.editor.getSelection().selectRanges([range]);
  1173. this.taskRemarkActionContainer = new Element("div.taskRemarkActionContainer",{styles:this.css.taskRemarkActionContainer}).inject(parent);
  1174. this.taskRemarkActionOk = new Element("div.taskRemarkActionOk",{styles:this.css.taskRemarkActionOk,text:this.lp.save}).inject(this.taskRemarkActionContainer);
  1175. this.taskRemarkActionOk.addEvents({
  1176. mouseover:function(){this.setStyles({"opacity":"0.9"})},
  1177. mouseout:function(){this.setStyles({"opacity":"1"})},
  1178. click:function(e){
  1179. var sd = {
  1180. taskId:this.taskData.id,
  1181. property:"description",
  1182. dataType:"RichText",
  1183. mainValue:encodeURI(this.editor.getData()),
  1184. secondaryValue:this.editor.document.getBody().getText()
  1185. }
  1186. this.updateSingleProperty(sd,function(json){
  1187. this.taskData.description = encodeURI(this.editor.getData());
  1188. this.loadRemarkValue()
  1189. delete this.editor;
  1190. }.bind(this))
  1191. e.stopPropagation();
  1192. //this.taskData.description = encodeURI(this.editor.getData());
  1193. }.bind(this)
  1194. });
  1195. this.taskRemarkActionCancel = new Element("div.taskRemarkActionCancel",{styles:this.css.taskRemarkActionCancel,text:this.lp.cancel}).inject(this.taskRemarkActionContainer);
  1196. this.taskRemarkActionCancel.addEvents({
  1197. mouseover:function(){this.setStyles({"color":"#4A90E2"})},
  1198. mouseout:function(){this.setStyles({"color":"#999999"})},
  1199. click:function(e){
  1200. this.loadRemarkValue();
  1201. e.stopPropagation()
  1202. }.bind(this)
  1203. })
  1204. }.bind(this))
  1205. }.bind(this));
  1206. },
  1207. loadAttachment: function( area ){
  1208. MWF.xDesktop.requireApp("TeamWork", "TaskAttachment", function(){
  1209. this.attachment = new MWF.xApplication.TeamWork.TaskAttachment( area, this.app, this.actions, this.app.lp, {
  1210. size:"max",
  1211. documentId : this.taskData.id,
  1212. //isNew : this.options.isNew,
  1213. //isEdited : this.options.isEdited,
  1214. onQueryUploadAttachment : function(){
  1215. this.attachment.isQueryUploadSuccess = true;
  1216. if( !this.taskData.id || this.taskData.id=="" ){
  1217. }
  1218. }.bind(this)
  1219. });
  1220. this.attachment.load();
  1221. }.bind(this));
  1222. },
  1223. loadTaskAttachmentListContainer:function(){
  1224. MWF.xDesktop.requireApp("TeamWork", "TaskAttachmentList", function(){
  1225. var data = {
  1226. id:this.taskData.id
  1227. };
  1228. var opt = {};
  1229. this.attachment = new MWF.xApplication.TeamWork.TaskAttachmentList( this,this.taskAttachmentListContainer, data, opt);
  1230. this.attachment.load();
  1231. }.bind(this));
  1232. },
  1233. loadSubTaskContainer:function(){
  1234. this.subTaskContainer.empty();
  1235. this.subTaskTitleContent = new Element("div.subTaskTitleContent",{styles:this.css.subTaskTitleContent}).inject(this.subTaskContainer);
  1236. this.subTaskTitleIcon = new Element("div.subTaskTitleIcon",{styles:this.css.subTaskTitleIcon}).inject(this.subTaskTitleContent);
  1237. this.subTaskTitleText = new Element("div.subTaskTitleText",{styles:this.css.subTaskTitleText,text:this.lp.taskSubName+""}).inject(this.subTaskTitleContent);
  1238. this.subTaskValueContent = new Element("div.subTaskValueContent",{styles:this.css.subTaskValueContent}).inject(this.subTaskContainer);
  1239. this.subTaskAddContainer = new Element("div.subTaskAddContainer",{styles:this.css.subTaskAddContainer}).inject(this.subTaskValueContent);
  1240. //子任务列表
  1241. this.subTaskListContent = new Element("div.subTaskListContent",{styles:this.css.subTaskListContent}).inject(this.subTaskAddContainer);
  1242. this.loadSubTask();
  1243. //添加子任务
  1244. this.subTaskNewContent = new Element("div.subTaskNewContent",{styles:this.css.subTaskNewContent}).inject(this.subTaskAddContainer);
  1245. this.subTaskNewIcon = new Element("div.subTaskNewIcon",{styles:this.css.subTaskNewIcon}).inject(this.subTaskNewContent);
  1246. this.subTaskNewText = new Element("div.subTaskNewText",{styles:this.css.subTaskNewText,text:this.lp.taskSubText}).inject(this.subTaskNewContent);
  1247. this.subTaskNewContent.addEvents({
  1248. click:function(){
  1249. this.subTaskNewContent.hide();
  1250. if(this.subTaskNewContainer)this.subTaskNewContainer.destroy();
  1251. this.subTaskNewContainer = new Element("div.subTaskNewContainer",{styles:this.css.subTaskNewContainer}).inject(this.subTaskAddContainer);
  1252. this.subTaskNewValue = new Element("div.subTaskNewValue",{styles:this.css.subTaskNewValue}).inject(this.subTaskNewContainer);
  1253. this.subTaskNewInput = new Element("input.subTaskNewInput",{styles:this.css.subTaskNewInput,placeholder:this.lp.taskSubNamePlaceholder}).inject(this.subTaskNewValue);
  1254. this.subTaskNewPerson = new Element("div.subTaskNewPerson",{styles:this.css.subTaskNewPerson}).inject(this.subTaskNewValue);
  1255. this.subTaskNewPerson.addEvent("click",function(){
  1256. this.selectPerson(this.subTaskNewPerson,"identity",null,1,
  1257. function(json){
  1258. if(json.length>0){
  1259. this.taskSubNewPerson = json[0];
  1260. this.loadSubTaskPerson(this.subTaskNewPerson,json[0],true)
  1261. }
  1262. }.bind(this)
  1263. );
  1264. }.bind(this));
  1265. this.subTaskNewAction = new Element("div.subTaskNewAction",{styles:this.css.subTaskNewAction}).inject(this.subTaskNewContainer);
  1266. this.subTaskNewCancel = new Element("div.subTaskNewCancel",{styles:this.css.subTaskNewCancel,text:this.lp.cancel}).inject(this.subTaskNewAction);
  1267. this.subTaskNewCancel.addEvents({
  1268. click:function(){
  1269. this.subTaskNewContent.show();
  1270. this.subTaskNewContainer.destroy()
  1271. }.bind(this),
  1272. mouseover:function(){
  1273. this.setStyles({"color":"#4A90E2"})
  1274. },
  1275. mouseout:function(){
  1276. this.setStyles({"color":"#666666"})
  1277. }
  1278. });
  1279. this.subTaskNewOK = new Element("div.subTaskNewOK",{styles:this.css.subTaskNewOK,text:this.lp.save}).inject(this.subTaskNewAction);
  1280. this.subTaskNewOK.addEvents({
  1281. click:function(){
  1282. if(this.subTaskNewInput.get("value").trim()=="") return;
  1283. var data = {
  1284. name:this.subTaskNewInput.get("value").trim(),
  1285. project:this.taskData.project,
  1286. parent:this.taskData.id,
  1287. executor:this.taskSubNewPerson || ""
  1288. };
  1289. this.actions.taskSave(data,function(json){
  1290. this.taskSubNewPerson = ""
  1291. if(json.data.id){
  1292. this.actions.taskGet(json.data.id,function(d){
  1293. this.loadSubTaskItem(this.subTaskListContent,d.data);
  1294. }.bind(this))
  1295. }
  1296. this.subTaskNewContent.show();
  1297. this.subTaskNewContainer.destroy();
  1298. if(json.data.dynamics){
  1299. json.data.dynamics.each(function(dd){
  1300. this.loadDynamicItem(dd,"bottom")
  1301. }.bind(this));
  1302. }
  1303. this.dynamicContent.scrollTo(0,this.dynamicContent.getScrollSize().y);
  1304. }.bind(this))
  1305. }.bind(this)
  1306. })
  1307. }.bind(this)
  1308. });
  1309. },
  1310. loadSubTask:function(){
  1311. var node = this.subTaskListContent;
  1312. node.empty();
  1313. this.actions.taskSubList(this.taskData.id,function(json){
  1314. json.data.each(function(data){
  1315. this.loadSubTaskItem(node,data);
  1316. }.bind(this))
  1317. }.bind(this))
  1318. },
  1319. loadSubTaskItem:function(node,data){
  1320. var subTaskItemContainer = new Element("div.subTaskItemContainer",{styles:this.css.subTaskItemContainer,id:data.id}).inject(node);
  1321. var subTaskItemText = new Element("div.subTaskItemText",{styles:this.css.subTaskItemText,text:data.name,title:this.lp.taskSubDes}).inject(subTaskItemContainer);
  1322. subTaskItemText.addEvents({
  1323. mouseover:function(){
  1324. this.setStyles({"background-color":"#f5f5f5"})
  1325. },
  1326. mouseout:function(){
  1327. this.setStyles({"background-color":""})
  1328. },
  1329. click:function(){
  1330. var id = subTaskItemContainer.get("id");
  1331. if(id && id!=""){
  1332. this.data.taskId = id;
  1333. this.openTask()
  1334. }
  1335. }.bind(this)
  1336. });
  1337. var subTaskItemPerson = new Element("div.subTaskItemPerson",{styles:this.css.subTaskItemPerson}).inject(subTaskItemContainer);
  1338. // subTaskItemPerson.addEvent("click",function(){
  1339. // this.selectPerson(subTaskItemPerson,"identity",null,1,
  1340. // function(json){
  1341. // if(json.length>0){
  1342. // this.loadSubTaskPerson(subTaskItemPerson,json[0],true)
  1343. // }
  1344. // }.bind(this)
  1345. // );
  1346. // }.bind(this));
  1347. if(data.executor && data.executor!=""){
  1348. this.loadSubTaskPerson(subTaskItemPerson,data.executor)
  1349. }
  1350. },
  1351. loadSubTaskPerson:function(node,identity,flag){
  1352. if(flag==null) flag=false;
  1353. node.empty();
  1354. var taskSubNewPerson = identity;
  1355. var _self = this
  1356. var name = identity.split("@")[0];
  1357. var container = new Element("div",{styles:{"height":"30px","padding":"0px 8px 0px 2px","border-radius":"4px","float":"left","position":"relative"}}).inject(node);
  1358. container.set("title",name);
  1359. var circleStyles={
  1360. "width":"24px","height":"24px","border-radius":"20px","float":"left",
  1361. "background-color":"#4A90E2","color":"#ffffff","line-height":"22px",
  1362. "text-align":"center","margin-top":"3px","font-size":"12px"
  1363. };
  1364. var closeStyles={
  1365. "width":"16px","height":"16px","position":"absolute","right":"-5px","top":"-2px",
  1366. "background":"url(/x_component_TeamWork/$Task/default/icon/icon_off.png) no-repeat center"
  1367. };
  1368. var circleDiv = new Element("div",{styles:circleStyles,text:name.substr(0,1)}).inject(container);
  1369. if(flag){ //权限
  1370. container.addEvents({
  1371. mouseenter:function(){
  1372. var closeIcon = new Element("div.closeIcon",{styles:closeStyles}).inject(this);
  1373. closeIcon.addEvents({
  1374. click:function(e){
  1375. node.empty();
  1376. node.setStyles(_self.css.subTaskNewPerson);
  1377. container.destroy();
  1378. e.stopPropagation();
  1379. }
  1380. });
  1381. this.setStyles({"background-color":"#efefef","cursor":"pointer"});
  1382. },
  1383. mouseleave:function(){
  1384. if(this.getElement(".closeIcon"))this.getElement(".closeIcon").destroy();
  1385. this.setStyles({"background-color":""})
  1386. },
  1387. click:function(e){
  1388. this.selectPerson(this.subTaskNewPerson,"identity",null,1,
  1389. function(json){
  1390. if(json.length>0){
  1391. taskSubNewPerson = json[0];
  1392. this.loadSubTaskPerson(this.subTaskNewPerson,json[0],true)
  1393. }
  1394. }.bind(this)
  1395. );
  1396. e.stopPropagation();
  1397. }.bind(this)
  1398. })
  1399. }
  1400. },
  1401. loadTaskPerson:function(node,identity,flag){
  1402. var _self = this
  1403. var name = identity.split("@")[0];
  1404. var container = new Element("div",{styles:{"height":"30px","padding":"0 0px","border-radius":"4px","float":"left","position":"relative"}}).inject(node);
  1405. var circleStyles={
  1406. "width":"24px","height":"24px","border-radius":"20px","float":"left",
  1407. "background-color":"#4A90E2","color":"#ffffff","line-height":"22px",
  1408. "text-align":"center","margin-top":"3px","font-size":"12px"
  1409. };
  1410. var nameStyles={
  1411. "height":"24px","float":"left","margin-left":"2px","margin-right":"10px",
  1412. "color":"#333333","line-height":"22px","margin-top":"3px"
  1413. };
  1414. var closeStyles={
  1415. "width":"16px","height":"16px","position":"absolute","right":"0px",
  1416. "background":"url(/x_component_TeamWork/$Task/default/icon/icon_off.png) no-repeat center"
  1417. };
  1418. var circleDiv = new Element("div",{styles:circleStyles,text:name.substr(0,1)}).inject(container);
  1419. var nameDiv = new Element("div",{styles:nameStyles,text:name}).inject(container);
  1420. if(flag){ //权限
  1421. container.addEvents({
  1422. mouseenter:function(){
  1423. // var closeIcon = new Element("div.closeIcon",{styles:closeStyles}).inject(this);
  1424. // closeIcon.addEvents({
  1425. // click:function(e){
  1426. // // _self.taskData.executor = "";
  1427. // // _self.loadDutyValue();
  1428. //
  1429. // var sd = {
  1430. // taskId:_self.taskData.id,
  1431. // property:"executor",
  1432. // mainValue:"",
  1433. // secondaryValue:""
  1434. // };
  1435. // _self.updateSingleProperty(sd,function(){
  1436. // _self.taskData.executor = "";
  1437. // _self.loadDutyValue()
  1438. // })
  1439. //
  1440. // e.stopPropagation();
  1441. // }
  1442. // });
  1443. this.setStyles({"background-color":"#efefef","cursor":"pointer"});
  1444. },
  1445. mouseleave:function(){
  1446. if(this.getElement(".closeIcon"))this.getElement(".closeIcon").destroy();
  1447. this.setStyles({"background-color":""})
  1448. },
  1449. click:function(e){
  1450. _self.selectPerson(_self.taskDutyAddText,"identity",null,1,
  1451. function(json){
  1452. if(json.length>0){
  1453. if(_self.taskData.executor!=json[0]){
  1454. var sd = {
  1455. taskId:_self.taskData.id,
  1456. property:"executor",
  1457. mainValue:json[0],
  1458. secondaryValue:""
  1459. };
  1460. _self.updateSingleProperty(sd,function(){
  1461. _self.taskData.executor = json[0];
  1462. _self.loadDutyValue()
  1463. })
  1464. }
  1465. }
  1466. }
  1467. );
  1468. }
  1469. })
  1470. }
  1471. },
  1472. loadparticipantPerson:function(node,identity,flag){
  1473. var _self = this;
  1474. var name = identity.split("@")[0];
  1475. var container = new Element("div",{styles:{"height":"30px","padding":"0 0px","border-radius":"4px","float":"left","position":"relative"}}).inject(node);
  1476. var circleStyles={
  1477. "width":"24px","height":"24px","border-radius":"20px","float":"left",
  1478. "background-color":"#4A90E2","color":"#ffffff","line-height":"22px",
  1479. "text-align":"center","margin-top":"3px","font-size":"12px"
  1480. };
  1481. var nameStyles={
  1482. "height":"24px","float":"left","margin-left":"2px","margin-right":"16px",
  1483. "color":"#333333","line-height":"22px","margin-top":"3px"
  1484. };
  1485. var closeStyles={
  1486. "width":"16px","height":"16px","position":"absolute","right":"0px",
  1487. "background":"url(/x_component_TeamWork/$Task/default/icon/icon_off.png) no-repeat center"
  1488. };
  1489. var circleDiv = new Element("div",{styles:circleStyles,text:name.substr(0,1)}).inject(container);
  1490. var nameDiv = new Element("div",{styles:nameStyles,text:name}).inject(container);
  1491. if(flag){ //权限
  1492. container.addEvents({
  1493. mouseenter:function(){
  1494. var closeIcon = new Element("div.closeIcon",{styles:closeStyles}).inject(this);
  1495. closeIcon.addEvents({
  1496. click:function(e){
  1497. var index = _self.taskData.participantList.indexOf(identity);
  1498. if(index>-1){
  1499. _self.taskData.participantList.erase(identity)
  1500. }
  1501. _self.actions.updateParticipantList(_self.taskData.id,{participantList:_self.taskData.participantList},function(json){
  1502. _self.createParticipateContainer();
  1503. if(json.data.dynamics){
  1504. json.data.dynamics.each(function(dd){
  1505. _self.loadDynamicItem(dd,"bottom")
  1506. })
  1507. }
  1508. _self.dynamicContent.scrollTo(0,_self.dynamicContent.getScrollSize().y);
  1509. })
  1510. e.stopPropagation();
  1511. }
  1512. });
  1513. this.setStyles({"background-color":"#efefef","cursor":"pointer"});
  1514. },
  1515. mouseleave:function(){
  1516. if(this.getElement(".closeIcon"))this.getElement(".closeIcon").destroy();
  1517. this.setStyles({"background-color":""})
  1518. }
  1519. })
  1520. }
  1521. },
  1522. setAuth:function(){
  1523. var _self = this;
  1524. //名称
  1525. },
  1526. reload : function( keepData ){
  1527. // if( keepData ){
  1528. // this.data = this.form.getResult(false, this.options.resultSeparator, false, false, true);
  1529. // }
  1530. this.formTopNode = null;
  1531. if(this.setFormNodeSizeFun && this.app && this.app.removeEvent){
  1532. this.app.removeEvent("resize",this.setFormNodeSizeFun);
  1533. }
  1534. if( this.formMaskNode )this.formMaskNode.destroy();
  1535. if( this.formAreaNode )this.formAreaNode.destroy();
  1536. if( this.isNew ){
  1537. this.create();
  1538. }else if( this.isEdited ){
  1539. this.edit();
  1540. }else{
  1541. this.open();
  1542. }
  1543. },
  1544. selectPerson: function( item, type,types,count,callback ) {
  1545. MWF.xDesktop.requireApp("Selector", "package", null, false);
  1546. this.fireEvent("querySelect", this);
  1547. var value = [];
  1548. var options = {
  1549. "type": type,
  1550. "types":types,
  1551. "title": "选人",
  1552. "count": count,
  1553. "values": value || [],
  1554. "onComplete": function (items) {
  1555. var arr = [];
  1556. items.each(function (item) {
  1557. arr.push(item.data.distinguishedName);
  1558. }.bind(this));
  1559. if(callback)callback(arr);
  1560. }.bind(this)
  1561. };
  1562. var selector = new MWF.O2Selector(this.app.content, options);
  1563. }
  1564. });
  1565. MWF.xApplication.TeamWork.Task.TaskMore = new Class({
  1566. Extends: MWF.xApplication.TeamWork.Common.ToolTips,
  1567. options : {
  1568. // displayDelay : 300,
  1569. hasArrow:false,
  1570. event:"click"
  1571. },
  1572. _loadCustom : function( callback ){
  1573. var _self = this;
  1574. this.css = this.options.css;
  1575. this.lp = this.options.lp;
  1576. //this.data
  1577. //this.contentNode
  1578. var topMoreTitle = new Element("div.topMoreTitle",{styles:this.css.topMoreTitle,text:this.lp.taskMenu}).inject(this.contentNode);
  1579. var copyTask = new Element("div.copyTask",{styles:this.css.topMoreItem}).inject(this.contentNode);
  1580. copyTask.addEvents({
  1581. mouseenter:function(){this.setStyles({"background-color":"#F7F7F7"})},
  1582. mouseleave:function(){this.setStyles({"background-color":""})}
  1583. });
  1584. var copyTaskIcon = new Element("div.copyTaskIcon",{styles:this.css.topMoreItemIcon}).inject(copyTask);
  1585. copyTaskIcon.setStyles({"background":"url(/x_component_TeamWork/$Task/default/icon/taskcopy.png) no-repeat center"});
  1586. var copyTaskText = new Element("div.copyTaskText",{styles:this.css.topMoreItemText,text:this.lp.taskCopy}).inject(copyTask);
  1587. var moveTask = new Element("div.moveTask",{styles:this.css.topMoreItem}).inject(this.contentNode);
  1588. moveTask.addEvents({
  1589. mouseenter:function(){this.setStyles({"background-color":"#F7F7F7"})},
  1590. mouseleave:function(){this.setStyles({"background-color":""})},
  1591. click:function(){
  1592. var data = this.data;
  1593. var opt = {};
  1594. MWF.xDesktop.requireApp("TeamWork", "TaskMove", function(){
  1595. var taskmove = new MWF.xApplication.TeamWork.TaskMove(this.explorer,data,opt);
  1596. taskmove.open();
  1597. var fx = new Fx.Tween(this.node,{duration:200});
  1598. fx.start(["opacity"] ,"1", "0").chain(function(){this.close()}.bind(this));
  1599. }.bind(this));
  1600. }.bind(this)
  1601. });
  1602. var moveTaskIcon = new Element("div.moveTaskIcon",{styles:this.css.topMoreItemIcon}).inject(moveTask);
  1603. moveTaskIcon.setStyles({"background":"url(/x_component_TeamWork/$Task/default/icon/taskmove.png) no-repeat center"});
  1604. var moveTaskText = new Element("div.moveTaskText",{styles:this.css.topMoreItemText,text:this.lp.taskMove}).inject(moveTask);
  1605. var favTask = new Element("div.favTask",{styles:this.css.topMoreItem}).inject(this.contentNode);
  1606. favTask.addEvents({
  1607. mouseenter:function(){this.setStyles({"background-color":"#F7F7F7"})},
  1608. mouseleave:function(){this.setStyles({"background-color":""})}
  1609. });
  1610. var favTaskIcon = new Element("div.favTaskIcon",{styles:this.css.topMoreItemIcon}).inject(favTask);
  1611. favTaskIcon.setStyles({"background":"url(/x_component_TeamWork/$Task/default/icon/taskfav.png) no-repeat center"});
  1612. var favTaskText = new Element("div.favTaskText",{styles:this.css.topMoreItemText,text:this.lp.taskFav}).inject(favTask);
  1613. var subTask = new Element("div.subTask",{styles:this.css.topMoreItem}).inject(this.contentNode);
  1614. subTask.addEvents({
  1615. click:function(){
  1616. var data = this.data;
  1617. MWF.xDesktop.requireApp("TeamWork", "TaskSub", function(){
  1618. var opt = {
  1619. "onPostOpen":function(){
  1620. //tasksub.formAreaNode.setStyles({"height":"0px","width":"0px","overflow":"hidden"})
  1621. //tasksub.formAreaNode.setStyles({"top":"10px"});
  1622. var fx = new Fx.Tween(tasksub.formAreaNode,{duration:200});
  1623. fx.start(["top"] ,"10px", "100px");
  1624. }
  1625. };
  1626. var tasksub = new MWF.xApplication.TeamWork.TaskSub(this.explorer,data,opt);
  1627. tasksub.open();
  1628. var fx = new Fx.Tween(this.node,{duration:200});
  1629. fx.start(["opacity"] ,"1", "0").chain(function(){this.close()}.bind(this));
  1630. }.bind(this));
  1631. }.bind(this),
  1632. mouseenter:function(){this.setStyles({"background-color":"#F7F7F7"})},
  1633. mouseleave:function(){this.setStyles({"background-color":""})}
  1634. });
  1635. var subTaskIcon = new Element("div.subTaskIcon",{styles:this.css.topMoreItemIcon}).inject(subTask);
  1636. subTaskIcon.setStyles({"background":"url(/x_component_TeamWork/$Task/default/icon/tasksub.png) no-repeat center"});
  1637. var subTaskText = new Element("div.subTaskText",{styles:this.css.topMoreItemText,text:this.lp.taskSub}).inject(subTask);
  1638. var removeTask = new Element("div.removeTask",{styles:this.css.topMoreItem}).inject(this.contentNode);
  1639. removeTask.addEvents({
  1640. click:function(e){
  1641. _self.app.confirm("warn",e,_self.app.lp.common.confirm.removeTitle,_self.app.lp.common.confirm.removeContent,300,120,function(){
  1642. _self.actions.taskRemove(_self.data.data.id,function(){
  1643. var rd = {"act":"remove"};
  1644. _self.close(rd);
  1645. this.close()
  1646. }.bind(this))
  1647. },function(){
  1648. this.close();
  1649. });
  1650. },
  1651. mouseenter:function(){this.setStyles({"background-color":"#F7F7F7"})},
  1652. mouseleave:function(){this.setStyles({"background-color":""})}
  1653. });
  1654. var removeTaskIcon = new Element("div.removeTaskIcon",{styles:this.css.topMoreItemIcon}).inject(removeTask);
  1655. removeTaskIcon.setStyles({"background":"url(/x_component_TeamWork/$Task/default/icon/taskremove.png) no-repeat center"});
  1656. var removeTaskText = new Element("div.removeTaskText",{styles:this.css.topMoreItemText,text:this.lp.taskRemove}).inject(removeTask);
  1657. if(callback)callback();
  1658. }
  1659. });
  1660. MWF.xApplication.TeamWork.Task.StatusCheck = new Class({
  1661. Extends: MWF.xApplication.TeamWork.Common.ToolTips,
  1662. options : {
  1663. // displayDelay : 300,
  1664. hasArrow:false,
  1665. event:"click"
  1666. },
  1667. _loadCustom : function( callback ){
  1668. var _self = this;
  1669. this.css = this.options.css;
  1670. this.lp = this.options.lp;
  1671. //this.data
  1672. var container = {
  1673. "cursor":"pointer",
  1674. "height":"40px",
  1675. "width":"100%"
  1676. };
  1677. var text={
  1678. "height":"30px","line-height":"30px","float":"left",
  1679. "padding-left":"10px","padding-right":"10px","margin-left":"6px","margin-top":"5px",
  1680. "font-size":"13px","color":"#666666","border-radius":"2px"
  1681. };
  1682. var icon = {
  1683. "float":"right","width":"24px","height":"24px",
  1684. "margin-top":"6px","margin-right":"8px",
  1685. "background":"url(/x_component_TeamWork/$Task/default/icon/icon_dagou.png) no-repeat center"
  1686. };
  1687. var flowContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1688. var flowText = new Element("div",{styles:text,text:this.lp.status.processing}).inject(flowContainer);
  1689. flowText.setStyles({"background-color":"#f0f0f0"});
  1690. if(this.data.data.workStatus == "processing"){
  1691. var flowIcon = new Element("div",{styles:icon}).inject(flowContainer);
  1692. }
  1693. flowContainer.addEvents({
  1694. click:function(){
  1695. var data = {"status":"processing"};
  1696. this.close(data)
  1697. }.bind(this),
  1698. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1699. mouseout:function(){this.setStyles({"background-color":""})}
  1700. });
  1701. var completeContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1702. var completeText = new Element("div",{styles:text,text:this.lp.status.completed}).inject(completeContainer);
  1703. completeText.setStyles({"color":"#69b439","background-color":"#f1f9ec"});
  1704. if(this.data.data.workStatus == "completed"){
  1705. var completeIcon = new Element("div",{styles:icon}).inject(completeContainer);
  1706. }
  1707. completeContainer.addEvents({
  1708. click:function(){
  1709. var data = {"status":"completed"};
  1710. this.close(data)
  1711. }.bind(this),
  1712. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1713. mouseout:function(){this.setStyles({"background-color":""})}
  1714. });
  1715. if(callback)callback();
  1716. }
  1717. });
  1718. MWF.xApplication.TeamWork.Task.PriorityCheck = new Class({
  1719. Extends: MWF.xApplication.TeamWork.Common.ToolTips,
  1720. options : {
  1721. // displayDelay : 300,
  1722. hasArrow:false,
  1723. event:"click"
  1724. },
  1725. _loadCustom : function( callback ){
  1726. var _self = this;
  1727. this.css = this.options.css;
  1728. this.lp = this.options.lp;
  1729. //this.data
  1730. //this.contentNode
  1731. var container = {
  1732. "cursor":"pointer",
  1733. "height":"40px",
  1734. "width":"100%"
  1735. };
  1736. var text={
  1737. "height":"25px","line-height":"25px","float":"left","width":"50px","text-align":"center",
  1738. "margin-left":"6px","margin-top":"8px",
  1739. "font-size":"13px","color":"#666666","border-radius":"2px"
  1740. };
  1741. var icon = {
  1742. "float":"right","width":"24px","height":"24px",
  1743. "margin-top":"6px","margin-right":"8px",
  1744. "background":"url(/x_component_TeamWork/$Task/default/icon/icon_dagou.png) no-repeat center"
  1745. };
  1746. var normalContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1747. var normalText = new Element("div",{styles:text,text:this.lp.priority.normal}).inject(normalContainer);
  1748. normalText.setStyles({"color":"#999999","border":"1px solid #999999"});
  1749. if(this.data.data.priority == this.lp.priority.normal){
  1750. new Element("div",{styles:icon}).inject(normalContainer);
  1751. }
  1752. normalContainer.addEvents({
  1753. click:function(){
  1754. var data = {"value":this.lp.priority.normal};
  1755. this.close(data)
  1756. }.bind(this),
  1757. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1758. mouseout:function(){this.setStyles({"background-color":""})}
  1759. });
  1760. var urgencyContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1761. var urgencyText = new Element("div",{styles:text,text:this.lp.priority.urgency}).inject(urgencyContainer);
  1762. urgencyText.setStyles({"color":"#ffaf38","border":"1px solid #ffaf38"});
  1763. if(this.data.data.priority == this.lp.priority.urgency){
  1764. new Element("div",{styles:icon}).inject(urgencyContainer);
  1765. }
  1766. urgencyContainer.addEvents({
  1767. click:function(){
  1768. var data = {"value":this.lp.priority.urgency};
  1769. this.close(data)
  1770. }.bind(this),
  1771. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1772. mouseout:function(){this.setStyles({"background-color":""})}
  1773. });
  1774. var emergencyContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1775. var emergencyText = new Element("div",{styles:text,text:this.lp.priority.emergency}).inject(emergencyContainer);
  1776. emergencyText.setStyles({"color":"#ff4f3e","border":"1px solid #ff4f3e"});
  1777. if(this.data.data.priority == this.lp.priority.emergency){
  1778. new Element("div",{styles:icon}).inject(emergencyContainer);
  1779. }
  1780. emergencyContainer.addEvents({
  1781. click:function(){
  1782. var data = {"value":this.lp.priority.emergency};
  1783. this.close(data)
  1784. }.bind(this),
  1785. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1786. mouseout:function(){this.setStyles({"background-color":""})}
  1787. });
  1788. if(callback)callback();
  1789. }
  1790. });
  1791. MWF.xApplication.TeamWork.Task.DynamicType = new Class({
  1792. Extends: MWF.xApplication.TeamWork.Common.ToolTips,
  1793. options : {
  1794. // displayDelay : 300,
  1795. hasArrow:false,
  1796. event:"click"
  1797. },
  1798. _loadCustom : function( callback ){
  1799. var _self = this;
  1800. this.css = this.options.css;
  1801. this.lp = this.options.lp;
  1802. //this.data
  1803. //this.contentNode
  1804. var container = {
  1805. "cursor":"pointer",
  1806. "height":"40px",
  1807. "width":"100%"
  1808. };
  1809. var text={
  1810. "height":"25px","line-height":"25px","float":"left","width":"100%",
  1811. "margin-left":"6px","margin-top":"8px",
  1812. "font-size":"13px","color":"#666666","border-radius":"2px"
  1813. };
  1814. var icon = {
  1815. "float":"right","width":"24px","height":"24px",
  1816. "margin-top":"6px","margin-right":"8px",
  1817. "background":"url(/x_component_TeamWork/$Task/default/icon/icon_dagou.png) no-repeat center"
  1818. };
  1819. var allContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1820. var allText = new Element("div",{styles:text,text:this.lp.dynamicAll}).inject(allContainer);
  1821. allText.setStyles({"color":"#999999","border":"0px solid #999999"});
  1822. allContainer.addEvents({
  1823. click:function(){
  1824. var data = {"value":"all"};
  1825. this.close(data)
  1826. }.bind(this),
  1827. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1828. mouseout:function(){this.setStyles({"background-color":""})}
  1829. });
  1830. var attachmentContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1831. var attachmentText = new Element("div",{styles:text,text:this.lp.dynamicAttachment}).inject(attachmentContainer);
  1832. attachmentText.setStyles({"color":"#999999","border":"0px solid #999999"});
  1833. attachmentContainer.addEvents({
  1834. click:function(){
  1835. var data = {"value":"attachment"};
  1836. this.close(data)
  1837. }.bind(this),
  1838. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1839. mouseout:function(){this.setStyles({"background-color":""})}
  1840. });
  1841. var chatContainer = new Element("div",{styles:container}).inject(this.contentNode);
  1842. var chatText = new Element("div",{styles:text,text:this.lp.dynamicChat}).inject(chatContainer);
  1843. chatText.setStyles({"color":"#999999","border":"0px solid #999999"});
  1844. chatContainer.addEvents({
  1845. click:function(){
  1846. var data = {"value":"chat"};
  1847. this.close(data)
  1848. }.bind(this),
  1849. mouseover:function(){this.setStyles({"background-color":"#f2f5f7"})},
  1850. mouseout:function(){this.setStyles({"background-color":""})}
  1851. });
  1852. if(callback)callback();
  1853. }
  1854. });