You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

128 lines
4.3KB

  1. var app = new Vue({
  2. el: '#app-report-index',
  3. data: {
  4. loading: true,
  5. showLoading: true,
  6. showReport: false,
  7. tableReport: [],
  8. currentSection: 'users',
  9. sections: [
  10. {
  11. name: 'Utilisateurs',
  12. id: 'users',
  13. icon: 'fa-users',
  14. },
  15. {
  16. name: 'Points de vente',
  17. id: 'points-sale',
  18. icon: 'fa-map-marker',
  19. },
  20. {
  21. name: 'Distributions',
  22. id: 'distributions',
  23. icon: 'fa-calendar',
  24. }
  25. ],
  26. termSearchUser: '',
  27. usersArray: [],
  28. pointsSaleArray: [],
  29. distributionYearsArray: [],
  30. distributionYear: null,
  31. distributionsByMonthArray: []
  32. },
  33. mounted: function() {
  34. this.init() ;
  35. },
  36. methods: {
  37. init: function() {
  38. var app = this ;
  39. axios.get("ajax-init",{params: {}})
  40. .then(function(response) {
  41. app.usersArray = response.data.usersArray ;
  42. app.pointsSaleArray = response.data.pointsSaleArray ;
  43. app.distributionYearsArray = response.data.distributionYearsArray ;
  44. app.distributionYear = app.distributionYearsArray[app.distributionYearsArray.length - 1] ;
  45. app.distributionsByMonthArray = response.data.distributionsByMonthArray ;
  46. app.loading = false ;
  47. app.showLoading = false ;
  48. });
  49. },
  50. changeSection: function(section) {
  51. this.currentSection = section.id ;
  52. },
  53. countUsers: function() {
  54. var count = 0 ;
  55. for(var i = 0; i < this.usersArray.length; i++) {
  56. if(this.usersArray[i].checked) {
  57. count ++ ;
  58. }
  59. }
  60. return count ;
  61. },
  62. countPointsSale: function() {
  63. var count = 0 ;
  64. for(var i = 0; i < this.pointsSaleArray.length; i++) {
  65. if(this.pointsSaleArray[i].checked) {
  66. count ++ ;
  67. }
  68. }
  69. return count ;
  70. },
  71. countDistributions: function() {
  72. var count = 0 ;
  73. for(var i in this.distributionsByMonthArray) {
  74. for(var j = 0; j < this.distributionsByMonthArray[i].distributions.length; j++) {
  75. if(this.distributionsByMonthArray[i].distributions[j].checked) {
  76. count ++ ;
  77. }
  78. }
  79. }
  80. return count ;
  81. },
  82. generateReport: function() {
  83. var app = this ;
  84. app.showLoading = true ;
  85. var data = new FormData();
  86. var idsUsersArray = [] ;
  87. for(var i = 0; i < app.usersArray.length; i++) {
  88. if(app.usersArray[i].checked) {
  89. idsUsersArray.push(app.usersArray[i].user_id) ;
  90. }
  91. }
  92. var idsPointsSaleArray = [] ;
  93. for(var i = 0; i < app.pointsSaleArray.length; i++) {
  94. if(app.pointsSaleArray[i].checked) {
  95. idsPointsSaleArray.push(app.pointsSaleArray[i].id) ;
  96. }
  97. }
  98. var idsDistributionsArray = [] ;
  99. for(var i in this.distributionsByMonthArray) {
  100. for(var j = 0; j < this.distributionsByMonthArray[i].distributions.length; j++) {
  101. if(this.distributionsByMonthArray[i].distributions[j].checked) {
  102. idsDistributionsArray.push(app.distributionsByMonthArray[i].distributions[j].id) ;
  103. }
  104. }
  105. }
  106. data.append('users', idsUsersArray);
  107. data.append('pointsSale', idsPointsSaleArray);
  108. data.append('distributions', idsDistributionsArray);
  109. axios.post("ajax-report",data)
  110. .then(function(response) {
  111. app.tableReport = response.data ;
  112. app.showLoading = false ;
  113. app.showReport = true ;
  114. });
  115. },
  116. reportChange: function() {
  117. this.showReport = false;
  118. }
  119. }
  120. });