TaskCompletedContent.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. MWF.xApplication.BAM.summary = MWF.xApplication.BAM.summary || {};
  2. MWF.xDesktop.requireApp("BAM", "summary.TaskContent", null, false);
  3. MWF.xApplication.BAM.summary.TaskCompletedContent = new Class({
  4. Extends: MWF.xApplication.BAM.summary.TaskContent,
  5. Implements: [Options, Events],
  6. options: {
  7. "style": "default"
  8. },
  9. initialize: function(summary, node, data, options){
  10. this.setOptions(options);
  11. this.summary = summary;
  12. this.app = this.summary.app;
  13. this.css = this.app.css;
  14. this.lp = this.app.lp;
  15. this.container = $(node);
  16. this.category = "application";
  17. this.data = this.summary.categoryData;
  18. this.maxColumn = 10;
  19. this.barOptions = {"style": "task"};
  20. this.load();
  21. },
  22. load: function(){
  23. this.loadArea(this.lp.taskCompleted);
  24. this.loadBarData(this.loadBar.bind(this));
  25. },
  26. loadTab: function(){
  27. this.tab = new MWF.widget.Tab(this.chartAreaNode, {"style": "BAM_content"});
  28. this.tab.load();
  29. this.countNode = new Element("div", {"styles": this.css.contentTabAreaNode});
  30. this.expiredNode = new Element("div", {"styles": this.css.contentTabAreaNode});
  31. this.expiredCountNode = new Element("div", {"styles": this.css.contentTabAreaNode});
  32. this.timeoutRateNode = new Element("div", {"styles": this.css.contentTabAreaNode});
  33. this.timelinessRateNode = new Element("div", {"styles": this.css.contentTabAreaNode});
  34. this.countPage = this.tab.addTab(this.countNode, this.lp.contentTypeCount);
  35. this.expiredPage = this.tab.addTab(this.expiredNode, this.lp.contentTypeDuration);
  36. this.expiredCountPage = this.tab.addTab(this.expiredCountNode, this.lp.contentTypeExpiredCount);
  37. this.timeoutRatePage = this.tab.addTab(this.timeoutRateNode, this.lp.timeout);
  38. this.timelinessRatePage = this.tab.addTab(this.timelinessRateNode, this.lp.timeliness);
  39. },
  40. loadBar: function(){
  41. MWF.require("MWF.widget.chart.Bar", function(){
  42. this.countPage.addEvent("show", function(){
  43. if (!this.countBar){
  44. this.countBar = this.loadBarChart(this.countNode, this[this.category+"Data"].taskCompletedCount.slice(0,this.maxColumn),this.barOptions);
  45. } else {
  46. this.countBar.transition();
  47. }
  48. }.bind(this));
  49. this.expiredPage.addEvent("show", function(){
  50. if (!this.elapsedBar){
  51. this.elapsedBar = this.loadBarChart(this.expiredNode, this[this.category+"Data"].taskCompletedDuration.slice(0,this.maxColumn),this.barOptions);
  52. } else {
  53. this.elapsedBar.transition();
  54. }
  55. }.bind(this));
  56. this.expiredCountPage.addEvent("show", function(){
  57. if (!this.elapsedCountBar){
  58. this.elapsedCountBar = this.loadBarChart(this.expiredCountNode, this[this.category+"Data"].taskCompletedElapsedCount.slice(0,this.maxColumn),this.barOptions);
  59. } else {
  60. this.elapsedCountBar.transition();
  61. }
  62. }.bind(this));
  63. this.timeoutRatePage.addEvent("show", function(){
  64. if (!this.timeoutRateBar){
  65. var options = (this.barOptions) ? Object.clone(this.barOptions) : {};
  66. options.tickFormat = ".0%";
  67. options.dataFormat = ".1%";
  68. this.timeoutRateBar = this.loadBarChart(this.timeoutRateNode, this[this.category+"Data"].taskTimeoutRate.slice(0,this.maxColumn),options);
  69. } else {
  70. this.timeoutRateBar.transition();
  71. }
  72. }.bind(this));
  73. this.timelinessRatePage.addEvent("show", function(){
  74. if (!this.timelinessRateBar){
  75. var options = (this.barOptions) ? Object.clone(this.barOptions) : {};
  76. options.tickFormat = ".0%";
  77. options.dataFormat = ".1%";
  78. this.timelinessRateBar = this.loadBarChart(this.timelinessRateNode, this[this.category+"Data"].taskTimelinessRate.slice(0,this.maxColumn),options);
  79. } else {
  80. this.timelinessRateBar.transition();
  81. }
  82. }.bind(this));
  83. if (this.countPage.isShow){
  84. this.countPage.showIm();
  85. }else{
  86. this.countPage.showTabIm();
  87. }
  88. }.bind(this));
  89. },
  90. loadBarChart: function(node, data, options){
  91. var bar = new MWF.widget.chart.Bar(node, data, "name", options);
  92. bar.addBar("value");
  93. bar.addEvents({
  94. "mouseover": function(rects, texts, d, i){
  95. texts.filter(function(data, idx){return (idx==i);}).attr("display", "block");
  96. var rect = rects.filter(function(data, idx){return (idx==i);});
  97. var color = rect.attr("fill");
  98. rect.node().store("color", color);
  99. rect.attr("fill", "brown");
  100. }.bind(this),
  101. "mouseout": function(rects, texts, d, i){
  102. texts.filter(function(data, idx){return (idx==i);}).attr("display", "none");
  103. var rect = rects.filter(function(data, idx){return (idx==i);});
  104. var color = rect.node().retrieve("color");
  105. rect.attr("fill", color);
  106. }.bind(this)
  107. });
  108. bar.load();
  109. return bar;
  110. },
  111. loadCategory: function(){
  112. var id = new MWF.widget.UUID();
  113. var html = "<input name='"+id+"TaskRankCategory' type='radio' value='application' checked>"+this.lp.application+
  114. "<input name='"+id+"TaskRankCategory' type='radio' value='process'>"+this.lp.process+
  115. "<input name='"+id+"TaskRankCategory' type='radio' value='activity'>"+this.lp.activity;
  116. this.categoryNode.set("html", html);
  117. var _self = this;
  118. this.categoryNode.getElements("input").addEvent("click", function(){
  119. _self.category = this.value;
  120. _self.reload();
  121. });
  122. },
  123. loadApplicationData: function(callback){
  124. if (!this.applicationData){
  125. this.applicationData = this.app.actions.getTaskCompletedContentData(this.summary.categoryData.application || []);
  126. if (callback) callback();
  127. }else{
  128. if (callback) callback();
  129. }
  130. },
  131. loadProcessData: function(callback){
  132. if (!this.processData){
  133. this.processData = this.app.actions.getTaskCompletedContentData(this.summary.categoryData.process || []);
  134. if (callback) callback();
  135. }else{
  136. if (callback) callback();
  137. }
  138. },
  139. loadActivityData: function(callback){
  140. if (!this.activityData){
  141. this.activityData = this.app.actions.getTaskCompletedContentData(this.summary.categoryData.activity || [], function(i){return i.processName+"-"+i.name});
  142. if (callback) callback();
  143. }else{
  144. if (callback) callback();
  145. }
  146. }
  147. });