index.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. var app = getApp();
  2. var that;
  3. var chart1;
  4. var chart2;
  5. Page({
  6. data: {
  7. userData: {},
  8. isBh: false,
  9. chartData: [],//折线图数据
  10. pieData: [1],//饼型图数据
  11. isAdministrator:app.globalData.isAdministrator,//是否管理员角色
  12. },
  13. onLoad() {
  14. that = this;
  15. chart1, chart2 = '';
  16. },
  17. onShow(query) {
  18. // that.getUserData();
  19. // that.getIncidentLsit();
  20. // that.getIncidentNum();
  21. if (app.globalData.userData) {
  22. that.getUserData();
  23. that.getIncidentLsit();
  24. that.getIncidentNum();
  25. that.setData({isAdministrator:app.globalData.isAdministrator})
  26. } else {
  27. app.login(app.globalData.corpId, function (is) {
  28. if (is) {
  29. that.getUserData();
  30. that.getIncidentLsit();
  31. that.getIncidentNum();
  32. that.setData({isAdministrator:app.globalData.isAdministrator})
  33. } else {
  34. dd.reLaunch({
  35. url: '../noJurisdiction/noJurisdiction'
  36. })
  37. }
  38. })
  39. }
  40. },
  41. showText() {
  42. this.setData({ isBh: !this.data.isBh })
  43. },
  44. //跳转
  45. openView(e) {
  46. var index = e.target.dataset.index - 1;
  47. var urls;
  48. if (e.target.dataset.item) {
  49. urls = [
  50. { url: '../statistics_B/statistics_B', query: '' },
  51. { url: '../statistics_A/statistics_A', query: '' },
  52. { url: '../jk_B/jk_B', query: 'type=B' },
  53. { url: '../jk_B/jk_B', query: 'type=A' },
  54. { url: '../apply/apply', query: '' },
  55. { url: '../my_approve/my_approve', query: '' },
  56. { url: '../prize_buckle/prize_buckle', query: '' },
  57. { url: '../../statistics/prizeBuckleDetail/prizeBuckleDetail', query: 'id=' + e.target.dataset.item.id },
  58. { url: '../../statistics/integralEvent/integralEvent', query: '' },
  59. ];
  60. } else {
  61. urls = [
  62. { url: '../statistics_B/statistics_B', query: '' },
  63. { url: '../statistics_A/statistics_A', query: '' },
  64. { url: '../jk_B/jk_B', query: 'type=B' },
  65. { url: '../jk_B/jk_B', query: 'type=A' },
  66. { url: '../apply/apply', query: '' },
  67. { url: '../my_approve/my_approve', query: '' },
  68. { url: '../prize_buckle/prize_buckle', query: '' },
  69. { url: '../../statistics/prizeBuckleDetail/prizeBuckleDetail', query: '' },
  70. { url: '../../statistics/integralEvent/integralEvent', query: '' },
  71. ];
  72. }
  73. dd.navigateTo({
  74. url: urls[index].url + '?' + urls[index].query
  75. })
  76. },
  77. //则线图
  78. onInitChart(F2, config) {
  79. chart1 = new F2.Chart(config);
  80. chart1.source(that.data.chartData, {
  81. date: {
  82. // range: [0, 1],
  83. tickCount: 5
  84. }
  85. });
  86. chart1.tooltip({
  87. showCrosshairs: true,
  88. showItemMarker: false,
  89. onShow: function onShow(ev) {
  90. const items = ev.items;
  91. items[0].name = "月份:" + items[0].origin.date;
  92. items[0].value = "分值:" + items[0].value;
  93. }
  94. });
  95. chart1.line().position('date*value');
  96. chart1.point().position('date*value').style({
  97. stroke: '#fff',
  98. lineWidth: 1
  99. });
  100. chart1.render();
  101. return chart1;
  102. },
  103. //饼型图
  104. onInitChart2(F2, config) {
  105. chart2 = new F2.Chart(config);
  106. chart2.source(that.data.pieData, {
  107. percent: {
  108. formatter: function formatter(val) {
  109. return val * 100 + '%';
  110. }
  111. }
  112. });
  113. chart2.legend({
  114. position: 'right',
  115. itemFormatter: function itemFormatter(val, index) {
  116. var str = '';
  117. that.data.pieData.forEach(item => {
  118. if (item.name == val) {
  119. str = val + ' ' + item.point + '分';
  120. }
  121. })
  122. return str;
  123. }
  124. });
  125. chart2.tooltip(false);
  126. chart2.coord('polar', {
  127. transposed: true,
  128. radius: 0.85
  129. });
  130. chart2.axis(false);
  131. chart2.interval()
  132. .position('a*percent')
  133. .color('name', ['#1890FF', '#13C2C2', '#2FC25B', '#FACC14', '#F04864', '#8543E0'])
  134. .adjust('stack')
  135. .style({ lineWidth: 1, stroke: '#fff', lineJoin: 'round', lineCap: 'round' }).animate({
  136. appear: { duration: 1200, easing: 'bounceOut' }
  137. });
  138. chart2.render();
  139. // 注意:需要把chart return 出来
  140. // that.getLsit();
  141. return chart2;
  142. },
  143. //获取统计数据
  144. getLsit() {
  145. var date1 = new Date();
  146. var date2 = new Date(date1);
  147. date2.setDate(date1.getDate() - 30);
  148. var start_date= date2.getFullYear() + "-" + (date2.getMonth() + 1) + "-" + date2.getDate();
  149. var incident = app.$get("api/integral/statistics/b", { employee_id: 0, start_date: start_date, end_date: app.globalData.day, show_type: '1' });
  150. var pei = app.$get("api/integral/statistics/pie/b", { employee_id: 0, month: that.data.date });
  151. Promise.all([incident, pei]).then(resArr => {
  152. if (resArr[0].data.code == 1) {
  153. const { b, chart, good, bad } = resArr[0].data.data
  154. const points = chart.reward.map((rewardItem, index) => {
  155. return { date: rewardItem.date, value: rewardItem.point - (chart.deduction[index].point || 0) }
  156. })
  157. chart1.changeData(points);
  158. that.setData({
  159. data_b: b,
  160. data_good: good,
  161. data_bad: bad,
  162. });
  163. }
  164. if (resArr[1].data.code == 1) {
  165. const pieData = resArr[1].data.data.list.map((item) => {
  166. return { name: item.name, percent: item.point < 0 ? 0 : item.point, a: '1',point:item.point }
  167. })
  168. var isData=pieData.every(itme=>{
  169. return itme.percent == 0;
  170. })
  171. that.setData({
  172. pieData:isData?[]:pieData
  173. });
  174. chart2.changeData(pieData);
  175. }
  176. }).catch(e => {
  177. console.error(e)
  178. })
  179. },
  180. //获取个人统计
  181. getUserData() {
  182. app.$get("api/integral/statistics", { employee_id: 0, month: app.globalData.month }).then((res) => {
  183. var data = res.data.data;
  184. var task = data.task;
  185. dd.setNavigationBar({ title: data.name });
  186. var ratio = task.reward.point === 0 || task.deduction.point === 0 ? '-' : `${task.ratio.ratio}:1`
  187. var target_ratio = task.ratio.target_ratio <= 0 ? '0:0' : `${task.ratio.target_ratio}:1`
  188. data.ratio = {
  189. ratio: ratio,
  190. target_ratio: target_ratio
  191. }
  192. that.getLsit();
  193. this.setData({
  194. userData: data
  195. })
  196. }, (err) => { })
  197. },
  198. //获取积分事件
  199. getIncidentLsit() {
  200. app.$get("api/integral/statistics/integral", { month: app.globalData.month, page: 1, page_size: 5,employee_ids:app.globalData.userData.id }).then((res) => {
  201. var data = res.data.data.list;
  202. data.map((item) => {
  203. item.ptObj = app.getTypesItem(item.pt_id);
  204. })
  205. this.setData({
  206. incidentLsit: data,
  207. incidentLsitTotal: res.data.data.total
  208. })
  209. }, (err) => { })
  210. },
  211. getIncidentNum() {
  212. app.$get("api/integral/review/list", { type: 'waiting', page: 1, pt_id: 0 }).then((res) => {
  213. var data = res.data.data;
  214. this.setData({
  215. total: data.total
  216. })
  217. }, (err) => { })
  218. },
  219. });