Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- "use strict";
- var KTDatatablesExtensionButtons = function() {
- let datatables = function() {
- // begin first table
- var table = $('#kt_datatable1').DataTable({
- responsive: true,
- // Pagination settings
- dom: `<'row'<'col-sm-6 text-left'f><'col-sm-6 text-right'B>>
- <'row'<'col-sm-12'tr>>
- <'row'<'col-sm-12 col-md-5'i><'col-sm-12 col-md-7 dataTables_pager'lp>>`,
- buttons: [
- 'print',
- 'copyHtml5',
- 'excelHtml5',
- 'csvHtml5',
- 'pdfHtml5',
- ],
- // Order settings
- order: [[1, 'desc']],
- headerCallback: function(thead, data, start, end, display) {
- thead.getElementsByTagName('th')[0].innerHTML = `
- <label class="checkbox checkbox-single">
- <input type="checkbox" value="" class="group-checkable"/>
- <span></span>
- </label>`;
- },
- columnDefs: [
- {
- targets: 0,
- width: '30px',
- className: 'dt-left',
- orderable: false,
- render: function (data, type, full, meta) {
- return '<label class="checkbox checkbox-single"> <input type="checkbox" value="' + data +'" class="checkable"/><span></span></label>';
- },
- },
- {
- targets: 3,
- width: '75px',
- render: function(data, type, full, meta) {
- var status = {
- 0: {'title': 'Inactive', 'class': ' label-light-danger'},
- 1: {'title': 'Active', 'class': ' label-light-primary'},
- };
- if (typeof status[data] === 'undefined') {
- return data;
- }
- return '<span class="label label-lg font-weight-bold' + status[data].class + ' label-inline">' + status[data].title + '</span>';
- },
- },
- {
- targets: -1,
- title: 'Actions',
- orderable: false,
- width: '125px',
- render: function(data, type, full, meta) {
- return '\
- <div class="dropdown dropdown-inline">\
- <a href="javascript:;" class="btn btn-sm btn-clean btn-icon mr-2" data-toggle="dropdown">\
- <span class="svg-icon svg-icon-md">\
- <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24px" height="24px" viewBox="0 0 24 24" version="1.1">\
- <g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\
- <rect x="0" y="0" width="24" height="24"/>\
- <path d="M5,8.6862915 L5,5 L8.6862915,5 L11.5857864,2.10050506 L14.4852814,5 L19,5 L19,9.51471863 L21.4852814,12 L19,14.4852814 L19,19 L14.4852814,19 L11.5857864,21.8994949 L8.6862915,19 L5,19 L5,15.3137085 L1.6862915,12 L5,8.6862915 Z M12,15 C13.6568542,15 15,13.6568542 15,12 C15,10.3431458 13.6568542,9 12,9 C10.3431458,9 9,10.3431458 9,12 C9,13.6568542 10.3431458,15 12,15 Z" fill="#000000"/>\
- </g>\
- </svg>\
- </span>\
- </a>\
- <div class="dropdown-menu dropdown-menu-sm dropdown-menu-right">\
- <ul class="navi flex-column navi-hover py-2">\
- <li class="navi-header font-weight-bolder text-uppercase font-size-xs text-primary pb-2">\
- Choose an action:\
- </li>\
- <li class="navi-item">\
- <a href="#" class="navi-link">\
- <span class="navi-icon"><i class="la la-print"></i></span>\
- <span class="navi-text">Print</span>\
- </a>\
- </li>\
- <li class="navi-item">\
- <a href="#" class="navi-link">\
- <span class="navi-icon"><i class="la la-copy"></i></span>\
- <span class="navi-text">Copy</span>\
- </a>\
- </li>\
- <li class="navi-item">\
- <a href="#" class="navi-link">\
- <span class="navi-icon"><i class="la la-file-excel-o"></i></span>\
- <span class="navi-text">Excel</span>\
- </a>\
- </li>\
- <li class="navi-item">\
- <a href="#" class="navi-link">\
- <span class="navi-icon"><i class="la la-file-text-o"></i></span>\
- <span class="navi-text">CSV</span>\
- </a>\
- </li>\
- <li class="navi-item">\
- <a href="#" class="navi-link">\
- <span class="navi-icon"><i class="la la-file-pdf-o"></i></span>\
- <span class="navi-text">PDF</span>\
- </a>\
- </li>\
- </ul>\
- </div>\
- </div>\
- <a href="javascript:;" class="btn btn-sm btn-clean btn-icon mr-2 edit-record" title="Edit details">\
- <span class="svg-icon svg-icon-md">\
- <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24px" height="24px" viewBox="0 0 24 24" version="1.1">\
- <g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\
- <rect x="0" y="0" width="24" height="24"/>\
- <path d="M8,17.9148182 L8,5.96685884 C8,5.56391781 8.16211443,5.17792052 8.44982609,4.89581508 L10.965708,2.42895648 C11.5426798,1.86322723 12.4640974,1.85620921 13.0496196,2.41308426 L15.5337377,4.77566479 C15.8314604,5.0588212 16,5.45170806 16,5.86258077 L16,17.9148182 C16,18.7432453 15.3284271,19.4148182 14.5,19.4148182 L9.5,19.4148182 C8.67157288,19.4148182 8,18.7432453 8,17.9148182 Z" fill="#000000" fill-rule="nonzero"\ transform="translate(12.000000, 10.707409) rotate(-135.000000) translate(-12.000000, -10.707409) "/>\
- <rect fill="#000000" opacity="0.3" x="5" y="20" width="15" height="2" rx="1"/>\
- </g>\
- </svg>\
- </span>\
- </a>\
- <a href="javascript:;" class="btn btn-sm btn-clean btn-icon" title="Delete">\
- <span class="svg-icon svg-icon-md">\
- <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24px" height="24px" viewBox="0 0 24 24" version="1.1">\
- <g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\
- <rect x="0" y="0" width="24" height="24"/>\
- <path d="M6,8 L6,20.5 C6,21.3284271 6.67157288,22 7.5,22 L16.5,22 C17.3284271,22 18,21.3284271 18,20.5 L18,8 L6,8 Z" fill="#000000" fill-rule="nonzero"/>\
- <path d="M14,4.5 L14,4 C14,3.44771525 13.5522847,3 13,3 L11,3 C10.4477153,3 10,3.44771525 10,4 L10,4.5 L5.5,4.5 C5.22385763,4.5 5,4.72385763 5,5 L5,5.5 C5,5.77614237 5.22385763,6 5.5,6 L18.5,6 C18.7761424,6 19,5.77614237 19,5.5 L19,5 C19,4.72385763 18.7761424,4.5 18.5,4.5 L14,4.5 Z" fill="#000000" opacity="0.3"/>\
- </g>\
- </svg>\
- </span>\
- </a>\
- ';
- },
- },
- ],
- });
- table.on('change', '.group-checkable', function() {
- var set = $(this).closest('table').find('td:first-child .checkable');
- var checked = $(this).is(':checked');
- $(set).each(function() {
- if (checked) {
- $(this).prop('checked', true);
- $(this).closest('tr').addClass('active');
- }
- else {
- $(this).prop('checked', false);
- $(this).closest('tr').removeClass('active');
- }
- });
- });
- table.on('change', 'tbody tr .checkbox', function() {
- $(this).parents('tr').toggleClass('active');
- });
- $('.edit-record').click(function (e) {
- e.preventDefault();
- let $id = $(this).closest('tr').data('id');
- alert($id)
- })
- };
- let crud = function () {
- const form = document.getElementById('add_form');
- const fv = FormValidation.formValidation(
- document.getElementById('add_form'),
- {
- fields: {
- name: {
- validators: {
- notEmpty: {
- message: 'Website URL is required'
- },
- }
- },
- email: {
- validators: {
- notEmpty: {
- message: 'Email is required'
- },
- emailAddress: {
- message: 'The value is not a valid email address'
- },
- remote: {
- data: function() {
- return {
- user_id: form.querySelector('[name="id"]').value,
- };
- },
- message: 'Email already registered',
- method: 'POST',
- url: '/admin/users/check-email',
- }
- }
- },
- role: {
- validators: {
- notEmpty: {
- message: 'Please select an option'
- }
- }
- },
- password: {
- validators: {
- stringLength: {
- min:12,
- message: 'Password must have at least 12 character'
- },
- callback: {
- message: 'Please specific the framework',
- callback: function(input) {
- const id = form.querySelector('[name="id"]');
- const user_id = id.value ? id.value : '';
- return (user_id !== '')
- // The field is valid if user picks
- // a given framework from the list
- ? true
- // Otherwise, the field value is required
- : (input.value !== '');
- }
- }
- }
- },
- password_confirmation: {
- validators: {
- identical: {
- compare: function() {
- return form.querySelector('[name="password"]').value;
- },
- message: 'The password and its confirm are not the same'
- }
- }
- },
- },
- plugins: {
- trigger: new FormValidation.plugins.Trigger(),
- bootstrap: new FormValidation.plugins.Bootstrap(),
- submitButton: new FormValidation.plugins.SubmitButton(),
- excluded: new FormValidation.plugins.Excluded({
- excluded: function(field, ele, eles) {
- const id = form.querySelector('[name="id"]');
- const password = form.querySelector('[name="password"]');
- const password_value = password.value ? password.value : '';
- const user_id = id.value ? id.value : '';
- return (field === 'password' && user_id !== '') ;
- },
- }),
- }
- }
- )
- // Revalidate the confirmation password when changing the password
- form.querySelector('[name="password"]').addEventListener('input', function() {
- fv.revalidateField('password_confirmation');
- });
- }
- return {
- //main function to initiate the module
- init: function() {
- datatables();
- crud();
- },
- };
- }();
- jQuery(document).ready(function() {
- KTDatatablesExtensionButtons.init();
- });
Add Comment
Please, Sign In to add comment