index.js 13 KB

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