dataTable.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. mgJsComponentHandler.addDefaultComponent('mg-datatable', {
  2. template : '#t-mg-datatable',
  3. props: [
  4. 'component_id',
  5. 'component_namespace',
  6. 'component_index',
  7. 'autoload_data_after_created',
  8. 'start_length'
  9. ],
  10. data : function() {
  11. return {
  12. dataRows: [],
  13. length: 10,
  14. iSortCol_0 : '',
  15. sSortDir_0 : '',
  16. addTimeout : false,
  17. sSearch : false,
  18. sSearchPrevious : false,
  19. dataShowing : 0,
  20. dataTo : 0,
  21. dataFrom : 0,
  22. curPage : 1,
  23. allPages : 1,
  24. pagesMap : [],
  25. loading : false,
  26. show : true,
  27. showModal : false,
  28. noData : false,
  29. onOffSwitchEnabled : false,
  30. children: [],
  31. searchEnabled: true
  32. };
  33. },
  34. created: function () {
  35. var self = this;
  36. mgEventHandler.runCallback('DatatableCreated', self.component_id, {datatable: self});
  37. self.length = self.start_length;
  38. this.addTimeout = true;
  39. if (this.autoload_data_after_created) {
  40. this.updateProjects();
  41. }
  42. this.$parent.$root.$on('reloadMgData', this.updateMgData);
  43. mgEventHandler.on('DatatableFilterUpdated', self.component_id, function(id, params){
  44. self.checkRequiredFilters();
  45. });
  46. this.$nextTick(function(){
  47. this.checkRequiredFilters();
  48. });
  49. },
  50. updated: function (){
  51. var self = this;
  52. initMassActionsOnDatatables(self.component_id);
  53. initTooltipsForDatatables(self.component_id);
  54. },
  55. methods: {
  56. checkRequiredFilters: function() {
  57. var requiredFilters = this.$store.getters.getComponentData(this.component_id, 'requiredFilters');
  58. if (typeof requiredFilters === 'object'){
  59. this.searchEnabled = true;
  60. for (var key in requiredFilters) {
  61. if (!requiredFilters.hasOwnProperty(key)) {
  62. continue;
  63. }
  64. if (requiredFilters[key] === true) {
  65. this.searchEnabled = false;
  66. }
  67. }
  68. }
  69. },
  70. updateMgData: function(toReloadId){
  71. var self = this;
  72. if(self.component_id === toReloadId){
  73. self.updateProjects();
  74. self.$nextTick(function() {
  75. self.$emit('restartRefreshingState');
  76. });
  77. }
  78. },
  79. updateProjects: function(){
  80. if (this.searchEnabled === false) {
  81. return;
  82. }
  83. var self = this;
  84. self.loading = true;
  85. var resp = self.$parent.$root.$options.methods.vloadData(
  86. {
  87. loadData : self.component_id,
  88. namespace : self.component_namespace,
  89. index: self.component_index,
  90. iDisplayLength : self.length,
  91. iDisplayStart : self.dataShowing,
  92. sSearch : (self.sSearch !== false ? self.sSearch : ''),
  93. iSortCol_0 : self.iSortCol_0,
  94. sSortDir_0 : self.sSortDir_0,
  95. filters: self.getFilters()
  96. });
  97. resp.done(function(data){
  98. if (data.data.status === 'error') {
  99. self.noData = true;
  100. mgPageControler.vueLoader.handleErrorMessage(data.data);
  101. } else {
  102. var actionData = data.data.rawData;
  103. data = data.data.rawData.recordsSet;
  104. if( typeof data.records == "undefined"){
  105. data.records =[];
  106. }
  107. if (data.records.length === 0 && self.dataShowing > 0) {
  108. self.dataShowing = 0;
  109. return self.updateProjects();
  110. }
  111. self.dataRows = data.records;
  112. self.runCalbacks(actionData);
  113. mgEventHandler.runCallback('DatatableDataLoaded', self.component_id, {data: data.records, datatable: self});
  114. self.dataShowing = data.offset;
  115. self.dataTo = data.records.length + data.offset;
  116. self.dataFrom = data.fullDataLenght;
  117. self.addTimeout = false;
  118. if(self.addTimeout === true){
  119. setTimeout(self.updateProjects, 60000);
  120. self.addTimeout = false;
  121. }
  122. self.noData = data.records.length > 0 ? false : true;
  123. }
  124. self.updatePagination();
  125. self.loading = false;
  126. }).fail(function(jqXHR, textStatus, errorThrown) {
  127. self.loading = false;
  128. self.dataRows = [];
  129. self.noData = true;
  130. mgEventHandler.runCallback('DatatableDataLoadingFailed', self.component_id, {jqXHR: jqXHR, textStatus: textStatus, errorThrown: errorThrown});
  131. mgPageControler.vueLoader.handleServerError(jqXHR, textStatus, errorThrown);
  132. });
  133. uncheckSelectAllCheck(self.tableWrapperId);
  134. },
  135. runCalbacks: function(data) {
  136. var self = this;
  137. if (typeof data.recordsSet !== 'undefined' && typeof data.recordsSet.records !== 'undefined' && data.recordsSet.records.length > 0)
  138. {
  139. $('#loadedTemplates').append(data.template);
  140. self.$nextTick(function() {
  141. for (var key in data.registrations) {
  142. mgJsComponentHandler.extendRegisterByDefaultTemplate(key.toLowerCase(), data.registrations[key]);
  143. }
  144. });
  145. }
  146. },
  147. updateLength: function(event){
  148. var self = this;
  149. var btnTarget = (typeof $(event.target).attr('data-length') === 'undefined') ? $(event.target).parent() : $(event.target);
  150. self.length = $(btnTarget).attr('data-length');
  151. self.dataShowing = 0;
  152. $(btnTarget).parent().children('.active').removeClass('active');
  153. $(btnTarget).addClass('active');
  154. self.updateProjects();
  155. },
  156. updateSorting: function(event){
  157. var self = this;
  158. var sortTarget = $(event.target)[0].tagName === 'TH' ? $(event.target) : $(event.target).parents('th').first();
  159. self.iSortCol_0 = $(sortTarget).attr('name');
  160. self.dataShowing = 0;
  161. var currentDir = self.getSortDir($(sortTarget), true);
  162. $(event.target).parents('tr').first().children('.sorting_asc, .sorting_desc').addClass('sorting').removeClass('sorting_asc').removeClass('sorting_desc');
  163. $(sortTarget).removeClass('sorting').removeClass('sorting_asc').removeClass('sorting_desc').addClass(self.reverseSort(currentDir));
  164. self.sSortDir_0 = self.getSortDir($(sortTarget), false);
  165. self.updateProjects();
  166. },
  167. reverseSort: function(sort){
  168. var sortingType = 'sorting_asc';
  169. if(sort === 'sorting_asc'){
  170. sortingType = 'sorting_desc';
  171. }
  172. return sortingType;
  173. },
  174. getSortDir: function(elem, rawClass){
  175. var sorts = ['sorting_asc', 'sorting_desc', 'sorting'];
  176. var sorting = '';
  177. $.each(sorts, function(key, sort) {
  178. if($(elem).hasClass(sort) === true) {
  179. sorting = rawClass ? sort : sort.replace('sorting_', '').replace('sorting', '');
  180. return sorting;
  181. }
  182. });
  183. return sorting;
  184. },
  185. searchDataEnter: function(event){
  186. event.preventDefault();
  187. this.searchData(event);
  188. },
  189. searchData: function(event){
  190. var self = this;
  191. if (typeof event == 'object') {
  192. self.sSearch = $(event.target).val() === '' ? false : $(event.target).val();
  193. if (self.sSearch !== false) {
  194. if (self.sSearchPrevious !== false && self.sSearchPrevious !== self.sSearch) {
  195. self.dataShowing = 0;
  196. }
  197. self.sSearchPrevious = self.sSearch;
  198. } else {
  199. self.sSearchPrevious = false;
  200. }
  201. }
  202. self.updateProjects();
  203. },
  204. updatePagination: function(){
  205. var self = this;
  206. self.curPage = (parseInt(self.dataShowing) / parseInt(self.length)) + 1;
  207. var tempPages = parseInt(parseInt(self.dataFrom) / parseInt(self.length));
  208. self.allPages = parseInt(tempPages + ((parseInt(self.length) * tempPages) < parseInt(self.dataFrom) ? 1 : 0));
  209. self.updatePagesMap();
  210. },
  211. updatePagesMap: function(){
  212. var self = this;
  213. if (self.allPages === 1) {
  214. self.pagesMap = [1];
  215. return;
  216. }
  217. self.pagesMap = [
  218. self.curPage -5,
  219. self.curPage -4,
  220. self.curPage -3,
  221. self.curPage -2,
  222. self.curPage -1,
  223. self.curPage,
  224. self.curPage +1,
  225. self.curPage +2,
  226. self.curPage +3,
  227. self.curPage +4,
  228. self.curPage +5
  229. ];
  230. for(i=0; i< self.pagesMap.length; i++){
  231. if(self.pagesMap[i] < 0 || self.pagesMap[i] > self.allPages){
  232. self.pagesMap[i] = null;
  233. }
  234. }
  235. if(self.pagesMap.indexOf(self.allPages) === -1) {
  236. self.pagesMap[self.pagesMap.length-1] = self.allPages;
  237. }
  238. if(self.pagesMap.indexOf(1) === -1) {
  239. self.pagesMap[0] = 1;
  240. }
  241. if(self.allPages > 7 && self.curPage > 4) {
  242. self.pagesMap[self.pagesMap.indexOf(Math.min(
  243. self.curPage-1 > 1 ? self.curPage-1 : self.curPage,
  244. self.curPage-2 > 1 ? self.curPage-2 : self.curPage,
  245. self.curPage-3 > 1 ? self.curPage-3 : self.curPage,
  246. self.curPage-4 > 1 ? self.curPage-4 : self.curPage
  247. ))] = '...';
  248. }
  249. for(i=self.pagesMap.length-1; i > self.pagesMap.indexOf(self.curPage); i--){
  250. if(i === 8 && self.pagesMap[i] === self.curPage + 3 && self.pagesMap[i] !== self.allPages) {
  251. self.pagesMap[i] = null;
  252. }
  253. }
  254. if(self.allPages > 7 && (4 <= self.allPages - self.curPage)) {
  255. self.pagesMap[self.pagesMap.indexOf(self.allPages) - 1] = '...';
  256. }
  257. },
  258. changePage: function(event) {
  259. var self = this;
  260. if($(event.target).parent().hasClass('disabled') === false && $(event.target).hasClass('disabled') === false){
  261. var newPageNumber = $(event.target).attr('data-dt-idx');
  262. self.dataShowing = ((newPageNumber < 1) ? 0 : newPageNumber -1) * parseInt(self.length);
  263. self.updateProjects();
  264. }
  265. },
  266. rowDrow : function(name, DataRow, customFunctionName) {
  267. if(window[customFunctionName] === undefined) {
  268. return DataRow[name];
  269. } else {
  270. return window[customFunctionName](name, DataRow);
  271. }
  272. },
  273. loadModal: function(event, targetId, namespace, index, params, addSpinner){
  274. mgPageControler.vueLoader.loadModal(event, targetId,
  275. typeof namespace !== 'undefined' ? namespace : getItemNamespace(targetId),
  276. typeof index !== 'undefined' ? index : getItemIndex(targetId), params, addSpinner);
  277. },
  278. onOffSwitch: function(event, targetId){
  279. var switchPostData = $(event.target).is(':checked') ? {'value' : 'on'} : {'value' : 'off'};
  280. mgPageControler.vueLoader.ajaxAction(event, targetId, getItemNamespace(targetId), getItemIndex(targetId), switchPostData);
  281. },
  282. redirect : function (event, params, targetBlank) {
  283. mgPageControler.vueLoader.redirect(event, params, targetBlank);
  284. },
  285. getFilters: function () {
  286. return this.$store.getters.getComponentData(this.component_id, 'filters');
  287. }
  288. }
  289. });