index.js 14 KB

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