prize_buckle.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. var app = getApp()
  2. var that;
  3. var chart1;
  4. var chart2;
  5. Page({
  6. data: {
  7. date: app.globalData.month,
  8. employee_id:0,
  9. },
  10. onLoad(e) {
  11. that = this;
  12. dd.setNavigationBar({ title: "奖扣统计" });
  13. console.log(e);
  14. if (e.id && e.month) {
  15. that.setData({
  16. date: e.month,
  17. employee_id: e.id
  18. })
  19. }
  20. that.getUserData();
  21. that.getIncidentLsit();
  22. },
  23. onInitChart(F2, config) {
  24. chart1 = new F2.Chart(config);
  25. chart1.source(that.data.chartData, {
  26. time: {
  27. type: 'timeCat',
  28. tickCount: 4,
  29. range: [0, 1]
  30. }
  31. });
  32. chart1.legend(false);
  33. chart1.axis('time', {
  34. line: {
  35. lineWidth: 2,
  36. stroke: '#F56C6C',
  37. top: true, // 展示在最上层
  38. },
  39. label: function label(text, index, total) {
  40. const textCfg = {};
  41. if (index === 0) {
  42. textCfg.textAlign = 'left';
  43. } else if (index === total - 1) {
  44. textCfg.textAlign = 'right';
  45. }
  46. return textCfg;
  47. },
  48. });
  49. chart1.line().position('time*value').color('type');
  50. chart1.render();
  51. return chart1;
  52. },
  53. onInitChart2(F2, config) {
  54. chart2 = new F2.Chart(config);
  55. chart2.source(that.data.chartData, {
  56. time: {
  57. type: 'timeCat',
  58. tickCount: 4,
  59. range: [0, 1]
  60. }
  61. });
  62. chart2.legend(false);
  63. chart2.axis('time', {
  64. line: {
  65. lineWidth: 2,
  66. stroke: '#F56C6C',
  67. top: true, // 展示在最上层
  68. },
  69. label: function label(text, index, total) {
  70. const textCfg = {};
  71. if (index === 0) {
  72. textCfg.textAlign = 'left';
  73. } else if (index === total - 1) {
  74. textCfg.textAlign = 'right';
  75. }
  76. return textCfg;
  77. },
  78. });
  79. chart2.line().position('time*value').color('type');
  80. chart2.render();
  81. return chart2;
  82. },
  83. //获取个人统计
  84. getUserData() {
  85. app.$get("api/integral/statistics", { employee_id: that.data.employee_id, month: that.data.date }).then((res) => {
  86. var data = res.data.data;
  87. var task = data.task;
  88. dd.setNavigationBar({ title: data.name });
  89. var ratio = task.reward.point === 0 || task.deduction.point === 0 ? '-' : `${task.ratio.ratio}:1`
  90. var target_ratio = task.ratio.target_ratio <= 0 ? '0:0' : `${task.ratio.target_ratio}:1`
  91. data.ratio = {
  92. ratio: ratio,
  93. target_ratio: target_ratio
  94. }
  95. this.setData({
  96. userData: data
  97. })
  98. })
  99. },
  100. getIncidentLsit() {
  101. app.$get("api/integral/statistics/prize", { employee_id: that.data.employee_id, month: that.data.date }).then((res) => {
  102. const { img_url, name, chart } = res.data.data;
  103. const { reward, deduct } = chart;
  104. var rewardArr = reward.map((item) => {
  105. return { time: item.date, value: item.point, type: '奖扣' };
  106. })
  107. var deductArr = deduct.map((item) => {
  108. return { time: item.date, value: item.point, type: '扣分' };
  109. })
  110. var rewardArrCount = reward.map((item) => {
  111. return { time: item.date, value: item.count, type: '奖扣' };
  112. })
  113. var deductArrCount = deduct.map((item) => {
  114. return { time: item.date, value: item.count, type: '扣分' };
  115. })
  116. var charData = rewardArr.concat(deductArr);
  117. var charData2 = rewardArrCount.concat(deductArrCount);
  118. chart1.changeData(charData);
  119. chart2.changeData(charData2);
  120. that.setData({
  121. img_url: img_url,
  122. name: name
  123. });
  124. })
  125. },
  126. //时间选择
  127. openDate() {
  128. dd.datePicker({
  129. format: 'yyyy-MM',
  130. currentDate: that.data.date,
  131. success: (res) => {
  132. that.setData({
  133. date: res.date
  134. })
  135. },
  136. });
  137. }
  138. });