index.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. var app = getApp();
  2. var that;
  3. var chart1;
  4. var chart2;
  5. var chart3;
  6. Page({
  7. data: {
  8. userData: {},
  9. isBh: false,
  10. chartData: [],//折线图数据
  11. pieData: [1],//饼型图数据
  12. isAdministrator: app.globalData.isAdministrator,//是否管理员角色
  13. rankingTotal: 0,
  14. rankingList: [],
  15. getRole_four: app.globalData.isCreator,//是否创始人
  16. setECharts: [],//柱形图数据
  17. pieTotal: 1,
  18. total:188,
  19. menuList: [
  20. { name: '审批', imgUrl: '../../../image/sp.png', url: '../my_approve/my_approve', code: 'creator admin employee' },
  21. { name: '任务', imgUrl: '../../../image/a7.png', url: '../../statistics/my_task/my_task', code: 'admin employee' },
  22. { name: '奖扣B分', imgUrl: '../../../image/point_entry.png', url: '../jk_B/jk_B?type=B', code: 'creator admin' },
  23. { name: '指派任务', imgUrl: '../../../image/my_publish.png', url: '../../statistics/assaign/assaign', code: 'creator admin' },
  24. { name: '申请积分', imgUrl: '../../../image/a_apply.png', url: '../apply/apply', code: 'admin employee' },
  25. { name: '奖扣A分', imgUrl: '../../../image/a_entry.png', url: '../jk_B/jk_B?type=A', code: 'creator admin' },
  26. { name: '领任务', imgUrl: '../../../image/task_hall.png', url: '../../statistics/getTask/getTask', code: 'admin employee' },
  27. { name: '发布悬赏', imgUrl: '../../../image/caback6.png', url: '../../statistics/offerAreward/offerAreward', code: 'creator admin' },
  28. { name: '发放奖票', imgUrl: '../../../image/add_ticket.png', url: '../../statistics/grant/grant', code: 'creator admin' },
  29. { name: '全部', imgUrl: '../../../image/all.png', url: 'all', code: 'creator admin employee' },
  30. ]
  31. },
  32. onLoad() {
  33. that = this;
  34. chart1, chart2, chart3 = '';
  35. },
  36. onShow(query) {
  37. if (app.globalData.userData) {
  38. // that.getUserData();
  39. that.setData({ isAdministrator: app.globalData.isAdministrator, getRole_four: app.globalData.isCreator })
  40. } else {
  41. app.login(app.globalData.corpId, function (is) {
  42. if (is) {
  43. if(app.globalData.isCreator){
  44. that.setMenuList("creator");
  45. }else if(app.globalData.isAdministrator){
  46. that.setMenuList("admin");
  47. }else if(!app.globalData.isCreator&&!app.globalData.isAdministrator){
  48. that.setMenuList("employee");
  49. }
  50. // that.getUserData();
  51. that.setData({ isAdministrator: app.globalData.isAdministrator, getRole_four: app.globalData.isCreator })
  52. } else {
  53. dd.reLaunch({
  54. url: '../noJurisdiction/noJurisdiction'
  55. })
  56. }
  57. })
  58. }
  59. },
  60. openUrl(e){
  61. var url = e.target.dataset.url;
  62. if(url=='all'){
  63. dd.switchTab({
  64. url: '../../statistics/index/index'
  65. })
  66. return
  67. }
  68. dd.navigateTo({
  69. url: url
  70. })
  71. },
  72. setMenuList(str){
  73. var arr=[];
  74. that.data.menuList.forEach(item=>{
  75. if(item.code.indexOf(str)>=0){
  76. arr.push(item)
  77. }
  78. })
  79. that.setData({
  80. menuList:arr
  81. })
  82. },
  83. showText() {
  84. this.setData({ isBh: !this.data.isBh })
  85. },
  86. openViewRanking(e) {
  87. var item = e.target.dataset.item;
  88. var url = '';
  89. if (item.type == 'normal') {
  90. url = '../../statistics/sectionRanking/sectionRanking';
  91. } else if (item.type == 'all') {
  92. url = '../../statistics/B_ranking/B_ranking';
  93. } else {
  94. url = '../../statistics/C_ranking/C_ranking?id=' + item.target_id + '&name=' + item.group_name + '&date_interval=' + item.date_interval;
  95. }
  96. dd.navigateTo({
  97. url: url
  98. })
  99. },
  100. //跳转
  101. openView(e) {
  102. var index = e.target.dataset.index - 1;
  103. var urls;
  104. if (e.target.dataset.item) {
  105. urls = [
  106. { url: '../statistics_B/statistics_B', query: '' },
  107. { url: '../statistics_A/statistics_A', query: '' },
  108. { url: '../jk_B/jk_B', query: 'type=B' },
  109. { url: '../jk_B/jk_B', query: 'type=A' },
  110. { url: '../apply/apply', query: '' },
  111. { url: '../my_approve/my_approve', query: '' },
  112. { url: '../prize_buckle/prize_buckle', query: '' },
  113. { url: '../../statistics/prizeBuckleDetail/prizeBuckleDetail', query: 'id=' + e.target.dataset.item.id },
  114. { url: '../../statistics/integralEvent/integralEvent', query: '' },
  115. { url: '../../statistics/userRamking/userRamking', query: '' },
  116. ];
  117. } else {
  118. urls = [
  119. { url: '../statistics_B/statistics_B', query: '' },
  120. { url: '../statistics_A/statistics_A', query: '' },
  121. { url: '../jk_B/jk_B', query: 'type=B' },
  122. { url: '../jk_B/jk_B', query: 'type=A' },
  123. { url: '../apply/apply', query: '' },
  124. { url: '../my_approve/my_approve', query: '' },
  125. { url: '../prize_buckle/prize_buckle', query: '' },
  126. { url: '../../statistics/prizeBuckleDetail/prizeBuckleDetail', query: '' },
  127. { url: '../../statistics/integralEvent/integralEvent', query: '' },
  128. { url: '../../statistics/userRamking/userRamking', query: '' },
  129. ];
  130. }
  131. dd.navigateTo({
  132. url: urls[index].url + '?' + urls[index].query
  133. })
  134. },
  135. //则线图
  136. onInitChart(F2, config) {
  137. chart1 = new F2.Chart(config);
  138. chart1.source(that.data.chartData, {
  139. date: { tickCount: 4 }
  140. });
  141. chart1.tooltip({
  142. showCrosshairs: true,
  143. showItemMarker: true,
  144. onShow: function onShow(ev) {
  145. const items = ev.items;
  146. items[0].name = "月份:" + items[0].origin.date;
  147. items[0].value = "分值:" + items[0].value;
  148. }
  149. });
  150. chart1.axis('date', {
  151. label: function label(text, index, total) {
  152. const textCfg = {};
  153. if (index === 0) {
  154. textCfg.textAlign = 'left';
  155. } else if (index === total - 1) {
  156. textCfg.textAlign = 'right';
  157. }
  158. return textCfg;
  159. }
  160. });
  161. chart1.line().position('date*value');
  162. chart1.point().position('date*value').style({
  163. stroke: '#fff',
  164. lineWidth: 1
  165. });
  166. chart1.render();
  167. return chart1;
  168. },
  169. //饼型图
  170. onInitChart2(F2, config) {
  171. chart2 = new F2.Chart(config);
  172. chart2.source(that.data.pieData, {
  173. percent: {
  174. formatter: function formatter(val) {
  175. return val * 100 + '%';
  176. }
  177. }
  178. });
  179. chart2.legend({
  180. position: 'right',
  181. itemFormatter: function itemFormatter(val, index) {
  182. var str = '';
  183. that.data.pieData.forEach(item => {
  184. if (item.name == val) {
  185. str = val + ' ' + item.point + '分';
  186. }
  187. })
  188. return str;
  189. }
  190. });
  191. chart2.tooltip(false);
  192. chart2.coord('polar', {
  193. transposed: true,
  194. radius: 0.85
  195. });
  196. chart2.axis(false);
  197. chart2.interval()
  198. .position('a*percent')
  199. .color('name', ['#1890FF', '#13C2C2', '#2FC25B', '#FACC14', '#F04864', '#8543E0'])
  200. .adjust('stack')
  201. .style({ lineWidth: 1, stroke: '#fff', lineJoin: 'round', lineCap: 'round' }).animate({
  202. appear: { duration: 1200, easing: 'bounceOut' }
  203. });
  204. chart2.render();
  205. // 注意:需要把chart return 出来
  206. // that.getLsit();
  207. return chart2;
  208. },
  209. //柱形图
  210. onInitChart3(F2, config) {
  211. chart3 = new F2.Chart(config);
  212. chart3.source(that.data.setECharts, {
  213. date: { tickCount: 5 }
  214. });
  215. chart3.axis('field', {
  216. grid: {
  217. lineDash: null,
  218. stroke: '#e8e8e8',
  219. lineWidth: 1
  220. }
  221. });
  222. chart3.legend(false);
  223. chart3.interval().position('name*val').color('type', (type) => { // 通过回调函数
  224. if (type === '奖分') {
  225. return 'l(90) 0:#4ECFFF 1:#26A2FF';
  226. }
  227. return 'l(90) 0:#F8C748 1:#F2A640';
  228. }).adjust({
  229. type: 'dodge',
  230. marginRatio: 0.05 // 设置分组间柱子的间距
  231. });
  232. chart3.render()
  233. return chart3;
  234. },
  235. //获取统计数据
  236. getLsit() {
  237. var date1 = new Date();
  238. var date2 = new Date(date1);
  239. date2.setDate(date1.getDate() - 30);
  240. var start_date = date2.getFullYear() + "-" + (date2.getMonth() + 1) + "-" + date2.getDate();
  241. var incident = app.$get2("api/integral/statistics/b", { employee_id: 0, start_date: start_date, end_date: app.globalData.day, show_type: '1' });
  242. Promise.all([incident]).then(resArr => {
  243. if (resArr[0].data.code == 1) {
  244. const { b, chart, good, bad } = resArr[0].data.data
  245. const points = chart.reward.map((rewardItem, index) => {
  246. return { date: rewardItem.date, value: rewardItem.point - (chart.deduction[index].point || 0) }
  247. })
  248. chart1.changeData(points);
  249. that.setData({
  250. data_b: b,
  251. data_good: good,
  252. data_bad: bad,
  253. });
  254. }
  255. }).catch(e => {
  256. console.error(e)
  257. })
  258. },
  259. //获取个人统计
  260. getUserData() {
  261. var http1 = app.$get2("api/integral/statistics", { employee_id: 0, month: app.globalData.month })
  262. var http2 = app.$get2("api/integral/statistics/integral", { month: app.globalData.month, page: 1, page_size: 5, employee_ids: app.globalData.userData.id })
  263. var http3 = app.$get2("api/integral/review/list", { type: 'waiting', page: 1, pt_id: 0 })
  264. var ranking = app.$get('api/integral/statistics/ranking/list', { page: 1, page_size: 5 })// 获取排行榜
  265. var task = app.$get('api/integral/statistics/task/pie', { month: app.globalData.month })// 管理者奖扣任务柱状图
  266. Promise.all([http1, http2, http3, ranking, task]).then(function (values) {
  267. if (values[0]) {
  268. let data = values[0].data.data;
  269. var task = data.task;
  270. dd.setNavigationBar({ title: data.name });
  271. var ratio = task.reward.point === 0 || task.deduction.point === 0 ? '-' : `${task.ratio.ratio}:1`
  272. var target_ratio = task.ratio.target_ratio <= 0 ? '0:0' : `${task.ratio.target_ratio}:1`
  273. data.ratio = {
  274. ratio: ratio,
  275. target_ratio: target_ratio
  276. }
  277. that.getLsit();
  278. that.setData({
  279. userData: data
  280. })
  281. }
  282. if (values[1]) {
  283. let data = values[1].data.data.list;
  284. data.map((item) => {
  285. item.ptObj = app.getTypesItem(item.pt_id);
  286. })
  287. that.setData({
  288. incidentLsit: data,
  289. incidentLsitTotal: values[1].data.data.total
  290. })
  291. }
  292. if (values[2]) {
  293. let data = values[2].data.data;
  294. that.setData({
  295. total: data.total
  296. })
  297. }
  298. if (values[3]) {
  299. that.setData({
  300. rankingList: values[3].data.data.list,
  301. rankingTotal: values[3].data.data.total
  302. })
  303. }
  304. if (values[4]) {
  305. if (that.data.isAdministrator) {
  306. var data = values[4].data.data.list
  307. if (data.length > 5) {
  308. data.pop()
  309. }
  310. that.setData({
  311. pieTotal: values[4].data.data.total
  312. })
  313. if (that.data.pieTotal != 0) {
  314. var employees = [];
  315. data.forEach((item) => {
  316. var obj = [{
  317. type: '奖分',
  318. name: item.employee_name,
  319. val: item.deduction
  320. }, {
  321. type: '扣分',
  322. name: item.employee_name,
  323. val: item.reward
  324. }]
  325. employees.push(...obj)
  326. })
  327. chart3.changeData(employees);
  328. }
  329. }
  330. }
  331. })
  332. },
  333. //获取积分事件
  334. getIncidentLsit() {
  335. app.$get("api/integral/statistics/integral", { month: app.globalData.month, page: 1, page_size: 5, employee_ids: app.globalData.userData.id }).then((res) => {
  336. var data = res.data.data.list;
  337. data.map((item) => {
  338. item.ptObj = app.getTypesItem(item.pt_id);
  339. })
  340. this.setData({
  341. incidentLsit: data,
  342. incidentLsitTotal: res.data.data.total
  343. })
  344. }, (err) => { })
  345. },
  346. getIncidentNum() {
  347. app.$get("api/integral/review/list", { type: 'waiting', page: 1, pt_id: 0 }).then((res) => {
  348. var data = res.data.data;
  349. this.setData({
  350. total: data.total
  351. })
  352. }, (err) => { })
  353. },
  354. });