Няма описание
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.

app-access-permission.js 7.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. /**
  2. * App user list (js)
  3. */
  4. 'use strict';
  5. document.addEventListener('DOMContentLoaded', function (e) {
  6. const dataTablePermissions = document.querySelector('.datatables-permissions'),
  7. userList = baseUrl + 'app/user/list';
  8. let dt_permission;
  9. // Users List datatable
  10. if (dataTablePermissions) {
  11. dt_permission = new DataTable(dataTablePermissions, {
  12. ajax: assetsPath + 'json/permissions-list.json', // JSON file to add data
  13. columns: [
  14. // columns according to JSON
  15. { data: 'id' },
  16. { data: 'id' },
  17. { data: 'name' },
  18. { data: 'assigned_to' },
  19. { data: 'created_date' },
  20. { data: 'id' }
  21. ],
  22. columnDefs: [
  23. {
  24. // For Responsive
  25. className: 'control',
  26. orderable: false,
  27. searchable: false,
  28. responsivePriority: 2,
  29. targets: 0,
  30. render: function (data, type, full, meta) {
  31. return '';
  32. }
  33. },
  34. {
  35. targets: 1,
  36. searchable: false,
  37. visible: false
  38. },
  39. {
  40. // Name
  41. targets: 2,
  42. render: function (data, type, full, meta) {
  43. let name = full['name'];
  44. return '<span class="text-nowrap text-heading">' + name + '</span>';
  45. }
  46. },
  47. {
  48. // User Role
  49. targets: 3,
  50. orderable: false,
  51. render: function (data, type, full, meta) {
  52. const assignedTo = full['assigned_to'];
  53. let output = '';
  54. const roleBadgeObj = {
  55. Admin: `<a href="${userList}"><span class="badge bg-label-primary me-4">Administrator</span></a>`,
  56. Manager: `<a href="${userList}"><span class="badge bg-label-warning me-4">Manager</span></a>`,
  57. Users: `<a href="${userList}"><span class="badge bg-label-success me-4">Users</span></a>`,
  58. Support: `<a href="${userList}"><span class="badge bg-label-info me-4">Support</span></a>`,
  59. Restricted: `<a href="${userList}"><span class="badge bg-label-danger me-4">Restricted User</span></a>`
  60. };
  61. assignedTo.forEach(role => {
  62. output += roleBadgeObj[role] || '';
  63. });
  64. return `<span class="text-nowrap">${output}</span>`;
  65. }
  66. },
  67. {
  68. // remove ordering from Name
  69. targets: 4,
  70. orderable: false,
  71. render: function (data, type, full, meta) {
  72. let date = full['created_date'];
  73. return '<span class="text-nowrap">' + date + '</span>';
  74. }
  75. },
  76. {
  77. // Actions
  78. targets: -1,
  79. searchable: false,
  80. title: 'Actions',
  81. orderable: false,
  82. render: function (data, type, full, meta) {
  83. return `
  84. <div class="d-flex align-items-center">
  85. <span class="text-nowrap">
  86. <button class="btn btn-icon me-1" data-bs-target="#editPermissionModal" data-bs-toggle="modal" data-bs-dismiss="modal">
  87. <i class="icon-base bx bx-edit icon-md"></i>
  88. </button>
  89. <a href="javascript:;" class="btn btn-icon dropdown-toggle hide-arrow" data-bs-toggle="dropdown">
  90. <i class="icon-base bx bx-dots-vertical-rounded icon-md"></i>
  91. </a>
  92. <div class="dropdown-menu dropdown-menu-end m-0">
  93. <a href="javascript:;" class="dropdown-item">Edit</a>
  94. <a href="javascript:;" class="dropdown-item">Suspend</a>
  95. </div>
  96. </span>
  97. </div>
  98. `;
  99. }
  100. }
  101. ],
  102. order: [[1, 'asc']],
  103. layout: {
  104. topStart: {
  105. rowClass: 'row m-3 my-0 justify-content-between',
  106. features: [
  107. {
  108. pageLength: {
  109. menu: [10, 25, 50, 100],
  110. text: 'Show_MENU_'
  111. }
  112. }
  113. ]
  114. },
  115. topEnd: {
  116. features: [
  117. {
  118. search: {
  119. placeholder: 'Search Permission',
  120. text: '_INPUT_'
  121. }
  122. },
  123. {
  124. buttons: [
  125. {
  126. text: `<i class="icon-base bx bx-plus icon-xs me-0 me-sm-2"></i><span class="d-none d-sm-inline-block">Add Permission</span>`,
  127. className: 'add-new btn btn-primary',
  128. attr: {
  129. 'data-bs-toggle': 'modal',
  130. 'data-bs-target': '#addPermissionModal'
  131. }
  132. }
  133. ]
  134. }
  135. ]
  136. },
  137. bottomStart: {
  138. rowClass: 'row mx-3 justify-content-between',
  139. features: ['info']
  140. },
  141. bottomEnd: 'paging'
  142. },
  143. language: {
  144. paginate: {
  145. next: '<i class="icon-base bx bx-chevron-right scaleX-n1-rtl icon-18px"></i>',
  146. previous: '<i class="icon-base bx bx-chevron-left scaleX-n1-rtl icon-18px"></i>',
  147. first: '<i class="icon-base bx bx-chevrons-left scaleX-n1-rtl icon-18px"></i>',
  148. last: '<i class="icon-base bx bx-chevrons-right scaleX-n1-rtl icon-18px"></i>'
  149. }
  150. },
  151. responsive: {
  152. details: {
  153. display: DataTable.Responsive.display.modal({
  154. header: function (row) {
  155. const data = row.data();
  156. return 'Details of ' + data['name'];
  157. }
  158. }),
  159. type: 'column',
  160. renderer: function (api, rowIdx, columns) {
  161. const data = columns
  162. .map(function (col) {
  163. return col.title !== '' //? Do not show row in modal popup if title is blank (for check box)
  164. ? `<tr data-dt-row="${col.rowIndex}" data-dt-column="${col.columnIndex}">
  165. <td>${col.title}:</td>
  166. <td>${col.data}</td>
  167. </tr>`
  168. : '';
  169. })
  170. .join('');
  171. if (data) {
  172. const div = document.createElement('div');
  173. div.classList.add('table-responsive');
  174. const table = document.createElement('table');
  175. div.appendChild(table);
  176. table.classList.add('table');
  177. const tbody = document.createElement('tbody');
  178. tbody.innerHTML = data;
  179. table.appendChild(tbody);
  180. return div;
  181. }
  182. return false;
  183. }
  184. }
  185. }
  186. });
  187. }
  188. // Filter form control to default size
  189. // ? setTimeout used for multilingual table initialization
  190. setTimeout(() => {
  191. const elementsToModify = [
  192. { selector: '.dt-buttons .btn', classToRemove: 'btn-secondary' },
  193. { selector: '.dt-search', classToAdd: 'me-4' },
  194. { selector: '.dt-search .form-control', classToRemove: 'form-control-sm' },
  195. { selector: '.dt-length', classToAdd: 'mb-0 mb-md-5' },
  196. { selector: '.dt-length .form-select', classToRemove: 'form-select-sm' },
  197. { selector: '.dt-buttons', classToAdd: 'mb-0 w-auto' },
  198. { selector: '.dt-layout-start', classToAdd: 'mt-0 px-5' },
  199. {
  200. selector: '.dt-layout-end',
  201. classToAdd: 'justify-content-md-between justify-content-center d-flex',
  202. classToRemove: 'justify-content-between d-md-flex'
  203. },
  204. { selector: '.dt-layout-table', classToRemove: 'row mt-2' },
  205. { selector: '.dt-layout-full', classToRemove: 'col-md col-12', classToAdd: 'table-responsive' }
  206. ];
  207. // Delete record
  208. elementsToModify.forEach(({ selector, classToRemove, classToAdd }) => {
  209. document.querySelectorAll(selector).forEach(element => {
  210. if (classToRemove) {
  211. classToRemove.split(' ').forEach(className => element.classList.remove(className));
  212. }
  213. if (classToAdd) {
  214. classToAdd.split(' ').forEach(className => element.classList.add(className));
  215. }
  216. });
  217. });
  218. }, 100);
  219. });