index.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380
  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:'',
  19. menuList: [
  20. { name: '审批', imgUrl: '../../../image/sp.png', url: '../my_approve/my_approve', code: 'creator admin' },
  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/all2.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. // if(url=='../apply/apply'){
  69. // var item = {
  70. // cycle_type: 1,
  71. // id: 578,
  72. // is_attendance: 0,
  73. // max_point: 10,
  74. // min_point: 10,
  75. // prize_type: 0,
  76. // pt_Obj: {
  77. // code: "BF",
  78. // id: 3,
  79. // name: "B分",
  80. // },
  81. // pt_id: 3,
  82. // range_type: 1,
  83. // remark: "分类1-测试缓存",
  84. // rule_id: 185,
  85. // }
  86. // dd.navigateTo({
  87. // url: '../apply/apply?item='+JSON.stringify(item)
  88. // })
  89. // return
  90. // }
  91. dd.navigateTo({
  92. url: url
  93. })
  94. },
  95. setMenuList(str){
  96. var arr=[];
  97. that.data.menuList.forEach(item=>{
  98. if(item.code.indexOf(str)>=0){
  99. arr.push(item)
  100. }
  101. })
  102. that.setData({
  103. menuList:arr
  104. })
  105. },
  106. showText() {
  107. this.setData({ isBh: !this.data.isBh })
  108. },
  109. openViewRanking(e) {
  110. var item = e.target.dataset.item;
  111. var url = '';
  112. if (item.type == 'normal') {
  113. url = '../../statistics/sectionRanking/sectionRanking';
  114. } else if (item.type == 'all') {
  115. url = '../../statistics/B_ranking/B_ranking';
  116. } else {
  117. url = '../../statistics/C_ranking/C_ranking?id=' + item.target_id + '&name=' + item.group_name + '&date_interval=' + item.date_interval;
  118. }
  119. dd.navigateTo({
  120. url: url
  121. })
  122. },
  123. //跳转
  124. openView(e) {
  125. var index = e.target.dataset.index - 1;
  126. var urls;
  127. if (e.target.dataset.item) {
  128. urls = [
  129. { url: '../statistics_B/statistics_B', query: '' },
  130. { url: '../statistics_A/statistics_A', query: '' },
  131. { url: '../jk_B/jk_B', query: 'type=B' },
  132. { url: '../jk_B/jk_B', query: 'type=A' },
  133. { url: '../apply/apply', query: '' },
  134. { url: '../my_approve/my_approve', query: '' },
  135. { url: '../prize_buckle/prize_buckle', query: '' },
  136. { url: '../../statistics/prizeBuckleDetail/prizeBuckleDetail', query: 'id=' + e.target.dataset.item.id },
  137. { url: '../../statistics/integralEvent/integralEvent', query: '' },
  138. { url: '../../statistics/userRamking/userRamking', query: '' },
  139. { url: '../../statistics/glz_execute/glz_execute', query: '' },
  140. ];
  141. } else {
  142. urls = [
  143. { url: '../statistics_B/statistics_B', query: '' },
  144. { url: '../statistics_A/statistics_A', query: '' },
  145. { url: '../jk_B/jk_B', query: 'type=B' },
  146. { url: '../jk_B/jk_B', query: 'type=A' },
  147. { url: '../apply/apply', query: '' },
  148. { url: '../my_approve/my_approve', query: '' },
  149. { url: '../prize_buckle/prize_buckle', query: '' },
  150. { url: '../../statistics/prizeBuckleDetail/prizeBuckleDetail', query: '' },
  151. { url: '../../statistics/integralEvent/integralEvent', query: '' },
  152. { url: '../../statistics/userRamking/userRamking', query: '' },
  153. { url: '../../statistics/glz_execute/glz_execute', query: '' },
  154. ];
  155. }
  156. dd.navigateTo({
  157. url: urls[index].url + '?' + urls[index].query
  158. })
  159. },
  160. //则线图
  161. onInitChart(F2, config) {
  162. chart1 = new F2.Chart(config);
  163. chart1.source(that.data.chartData, {
  164. date: { tickCount: 4 }
  165. });
  166. chart1.tooltip({
  167. showCrosshairs: true,
  168. showItemMarker: true,
  169. onShow: function onShow(ev) {
  170. const items = ev.items;
  171. items[0].name = "月份:" + items[0].origin.date;
  172. items[0].value = "分值:" + items[0].value;
  173. }
  174. });
  175. chart1.axis('date', {
  176. label: function label(text, index, total) {
  177. const textCfg = {};
  178. if (index === 0) {
  179. textCfg.textAlign = 'left';
  180. } else if (index === total - 1) {
  181. textCfg.textAlign = 'right';
  182. }
  183. return textCfg;
  184. }
  185. });
  186. chart1.line().position('date*value');
  187. chart1.point().position('date*value').style({
  188. stroke: '#fff',
  189. lineWidth: 1
  190. });
  191. chart1.render();
  192. return chart1;
  193. },
  194. //饼型图
  195. onInitChart2(F2, config) {
  196. chart2 = new F2.Chart(config);
  197. chart2.source(that.data.pieData, {
  198. percent: {
  199. formatter: function formatter(val) {
  200. return val * 100 + '%';
  201. }
  202. }
  203. });
  204. chart2.legend({
  205. position: 'right',
  206. itemFormatter: function itemFormatter(val, index) {
  207. var str = '';
  208. that.data.pieData.forEach(item => {
  209. if (item.name == val) {
  210. str = val + ' ' + item.point + '分';
  211. }
  212. })
  213. return str;
  214. }
  215. });
  216. chart2.tooltip(false);
  217. chart2.coord('polar', {
  218. transposed: true,
  219. radius: 0.85
  220. });
  221. chart2.axis(false);
  222. chart2.interval()
  223. .position('a*percent')
  224. .color('name', ['#1890FF', '#13C2C2', '#2FC25B', '#FACC14', '#F04864', '#8543E0'])
  225. .adjust('stack')
  226. .style({ lineWidth: 1, stroke: '#fff', lineJoin: 'round', lineCap: 'round' }).animate({
  227. appear: { duration: 1200, easing: 'bounceOut' }
  228. });
  229. chart2.render();
  230. // 注意:需要把chart return 出来
  231. // that.getLsit();
  232. return chart2;
  233. },
  234. //柱形图
  235. onInitChart3(F2, config) {
  236. chart3 = new F2.Chart(config);
  237. chart3.source(that.data.setECharts, {
  238. date: { tickCount: 5 }
  239. });
  240. chart3.axis('field', {
  241. grid: {
  242. lineDash: null,
  243. stroke: '#e8e8e8',
  244. lineWidth: 1
  245. }
  246. });
  247. chart3.legend(false);
  248. chart3.interval().position('name*val').color('type', (type) => { // 通过回调函数
  249. if (type === '奖分') {
  250. return 'l(90) 0:#4ECFFF 1:#26A2FF';
  251. }
  252. return 'l(90) 0:#F8C748 1:#F2A640';
  253. }).adjust({
  254. type: 'dodge',
  255. marginRatio: 0.05 // 设置分组间柱子的间距
  256. });
  257. chart3.render()
  258. return chart3;
  259. },
  260. //获取统计数据
  261. getLsit() {
  262. var date1 = new Date();
  263. var date2 = new Date(date1);
  264. date2.setDate(date1.getDate() - 30);
  265. var start_date = date2.getFullYear() + "-" + (date2.getMonth() + 1) + "-" + date2.getDate();
  266. var incident = app.$get2("api/integral/statistics/b", { employee_id: 0, start_date: start_date, end_date: app.globalData.day, show_type: '1' });
  267. Promise.all([incident]).then(resArr => {
  268. if (resArr[0].data.code == 1) {
  269. const { b, chart, good, bad } = resArr[0].data.data
  270. const points = chart.reward.map((rewardItem, index) => {
  271. return { date: rewardItem.date, value: rewardItem.point - (chart.deduction[index].point || 0) }
  272. })
  273. chart1.changeData(points);
  274. that.setData({
  275. data_b: b,
  276. data_good: good,
  277. data_bad: bad,
  278. });
  279. }
  280. }).catch(e => {
  281. console.error(e)
  282. })
  283. },
  284. //获取个人统计
  285. getUserData() {
  286. var http1 = app.$get2("api/integral/statistics", { employee_id: 0, month: app.globalData.month })
  287. var http2 = app.$get2("api/integral/statistics/integral", { month: app.globalData.month, page: 1, page_size: 5, employee_ids: app.globalData.userData.id })
  288. var http3 = app.$get2("api/integral/review/list", { type: 'waiting',source_type:0, page: 1, pt_id: 0 })
  289. var ranking = app.$get('api/integral/statistics/ranking/list', { page: 1, page_size: 5 })// 获取排行榜
  290. var task = app.$get('api/integral/statistics/task/pie', { month: app.globalData.month })// 管理者奖扣任务柱状图
  291. var work = app.$get('api/integral/work/list', { status: 'running',page: 1,pt_id: 0})// 管理者奖扣任务柱状图
  292. Promise.all([http1, http2, http3, ranking, task,work]).then(function (values) {
  293. if (values[0]) {
  294. let data = values[0].data.data;
  295. var task = data.task;
  296. dd.setNavigationBar({ title: data.name });
  297. var ratio = task.reward.point === 0 || task.deduction.point === 0 ? '-' : `${task.ratio.ratio}:1`
  298. var target_ratio = task.ratio.target_ratio <= 0 ? '0:0' : `${task.ratio.target_ratio}:1`
  299. data.ratio = {
  300. ratio: ratio,
  301. target_ratio: target_ratio
  302. }
  303. that.getLsit();
  304. that.setData({
  305. userData: data
  306. })
  307. }
  308. if (values[1]) {
  309. let data = values[1].data.data.list;
  310. data.map((item) => {
  311. item.ptObj = app.getTypesItem(item.pt_id);
  312. })
  313. that.setData({
  314. incidentLsit: data,
  315. incidentLsitTotal: values[1].data.data.total
  316. })
  317. }
  318. if (values[2]) {
  319. let data = values[2].data.data;
  320. that.setData({
  321. total: data.total
  322. })
  323. }
  324. if (values[3]) {
  325. that.setData({
  326. rankingList: values[3].data.data.list,
  327. rankingTotal: values[3].data.data.total
  328. })
  329. }
  330. if (values[4]) {
  331. if (that.data.isAdministrator) {
  332. var data = values[4].data.data.list
  333. if (data.length > 5) {
  334. data.pop()
  335. }
  336. that.setData({
  337. pieTotal: values[4].data.data.total
  338. })
  339. if (that.data.pieTotal != 0) {
  340. var employees = [];
  341. data.forEach((item) => {
  342. var obj = [{
  343. type: '奖分',
  344. name: item.employee_name,
  345. val: item.deduction
  346. }, {
  347. type: '扣分',
  348. name: item.employee_name,
  349. val: item.reward
  350. }]
  351. employees.push(...obj)
  352. })
  353. chart3.changeData(employees);
  354. }
  355. }
  356. }
  357. if (values[5]) {
  358. let data = values[5].data.data;
  359. that.setData({
  360. workTotal: data.total
  361. })
  362. }
  363. })
  364. },
  365. //获取积分事件
  366. getIncidentLsit() {
  367. app.$get("api/integral/statistics/integral", { month: app.globalData.month, page: 1, page_size: 5, employee_ids: app.globalData.userData.id }).then((res) => {
  368. var data = res.data.data.list;
  369. data.map((item) => {
  370. item.ptObj = app.getTypesItem(item.pt_id);
  371. })
  372. this.setData({
  373. incidentLsit: data,
  374. incidentLsitTotal: res.data.data.total
  375. })
  376. }, (err) => { })
  377. },
  378. });