dataTable.js 13 KB

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