JAVASCRIPT   47

local-sort.js

Guest on 13th October 2021 05:10:25 PM

  1. "use strict";
  2. // Class definition
  3.  
  4. var KTDatatableLocalSortDemo = function() {
  5.     // Private functions
  6.  
  7.     // basic demo
  8.     var demo = function() {
  9.         var datatable = $('#kt_datatable').KTDatatable({
  10.             // datasource definition
  11.             data: {
  12.                 type: 'remote',
  13.                 source: {
  14.                     read: {
  15.                         url: HOST_URL + '/api/datatables/demos/default.php',
  16.                     },
  17.                 },
  18.                 pageSize: 10,
  19.                 serverPaging: false,
  20.                 serverFiltering: true,
  21.                 serverSorting: false,
  22.                 saveState: {
  23.                     cookie: true,
  24.                     webstorage: true,
  25.                 },
  26.             },
  27.  
  28.             // layout definition
  29.             layout: {
  30.                 scroll: false, // enable/disable datatable scroll both horizontal and vertical when needed.
  31.                 footer: false, // display/hide footer
  32.             },
  33.  
  34.             // column sorting
  35.             sortable: true,
  36.  
  37.             pagination: true,
  38.  
  39.             search: {
  40.                 input: $('#kt_datatable_search_query'),
  41.                 key: 'generalSearch'
  42.             },
  43.  
  44.             // columns definition
  45.             columns: [{
  46.                 field: 'RecordID',
  47.                 title: '#',
  48.                 sortable: 'asc',
  49.                 width: 30,
  50.                 type: 'number',
  51.                 selector: false,
  52.                 textAlign: 'center',
  53.             }, {
  54.                 field: 'OrderID',
  55.                 title: 'Order ID',
  56.             }, {
  57.                 field: 'Country',
  58.                 title: 'Country',
  59.                 template: function(row) {
  60.                     return row.Country + ' ' + row.ShipCountry;
  61.                 },
  62.             }, {
  63.                 field: 'ShipDate',
  64.                 title: 'Ship Date',
  65.                 type: 'date',
  66.                 format: 'MM/DD/YYYY',
  67.             }, {
  68.                 field: 'TotalPayment',
  69.                 title: 'Payment',
  70.                 type: 'number',
  71.                 // custom sort callback for number
  72.                 sortCallback: function(data, sort, column) {
  73.                     var field = column['field'];
  74.                     return $(data).sort(function(a, b) {
  75.                         var aField = a[field];
  76.                         var bField = b[field];
  77.                         if (isNaN(parseFloat(aField)) && aField != null) {
  78.                             aField = Number(aField.replace(/[^0-9\.-]+/g, ''));
  79.                         }
  80.                         if (isNaN(parseFloat(bField)) && aField != null) {
  81.                             bField = Number(bField.replace(/[^0-9\.-]+/g, ''));
  82.                         }
  83.                         aField = parseFloat(aField);
  84.                         bField = parseFloat(bField);
  85.                         if (sort === 'asc') {
  86.                             return aField > bField ? 1 : aField < bField ? -1 : 0;
  87.                         } else {
  88.                             return aField < bField ? 1 : aField > bField ? -1 : 0;
  89.                         }
  90.                     });
  91.                 },
  92.             }, {
  93.                 field: 'Status',
  94.                 title: 'Status',
  95.                 // callback function support for column rendering
  96.                 template: function(row) {
  97.                     var status = {
  98.                         1: {
  99.                             'title': 'Pending',
  100.                             'class': 'label-light-primary'
  101.                         },
  102.                         2: {
  103.                             'title': 'Delivered',
  104.                             'class': ' label-light-danger'
  105.                         },
  106.                         3: {
  107.                             'title': 'Canceled',
  108.                             'class': ' label-light-primary'
  109.                         },
  110.                         4: {
  111.                             'title': 'Success',
  112.                             'class': ' label-light-success'
  113.                         },
  114.                         5: {
  115.                             'title': 'Info',
  116.                             'class': ' label-light-info'
  117.                         },
  118.                         6: {
  119.                             'title': 'Danger',
  120.                             'class': ' label-light-danger'
  121.                         },
  122.                         7: {
  123.                             'title': 'Warning',
  124.                             'class': ' label-light-warning'
  125.                         },
  126.                     };
  127.                     return '<span class="label font-weight-bold label-lg ' + status[row.Status].class + ' label-inline label-bold">' + status[row.Status].title + '</span>';
  128.                 },
  129.             }, {
  130.                 field: 'Type',
  131.                 title: 'Type',
  132.                 autoHide: false,
  133.                 // callback function support for column rendering
  134.                 template: function(row) {
  135.                     var status = {
  136.                         1: {
  137.                             'title': 'Online',
  138.                             'state': 'danger'
  139.                         },
  140.                         2: {
  141.                             'title': 'Retail',
  142.                             'state': 'primary'
  143.                         },
  144.                         3: {
  145.                             'title': 'Direct',
  146.                             'state': 'success'
  147.                         },
  148.                     };
  149.                     return '<span class="label label-' + status[row.Type].state + ' label-dot mr-2"></span><span class="font-weight-bold text-' + status[row.Type].state + '">' +
  150.                         status[row.Type].title + '</span>';
  151.                 },
  152.             }, {
  153.                 field: 'Actions',
  154.                 title: 'Actions',
  155.                 sortable: false,
  156.                 width: 125,
  157.                 overflow: 'visible',
  158.                 autoHide: false,
  159.                 template: function() {
  160.                     return '\
  161.                        <div class="dropdown dropdown-inline">\
  162.                            <a href="javascript:;" class="btn btn-sm btn-light btn-text-primary btn-icon mr-2" data-toggle="dropdown">\
  163.                                <span class="svg-icon svg-icon-md">\
  164.                                    <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">\
  165.                                        <g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\
  166.                                            <rect x="0" y="0" width="24" height="24"/>\
  167.                                            <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"/>\
  168.                                        </g>\
  169.                                    </svg>\
  170.                                </span>\
  171.                            </a>\
  172.                            <div class="dropdown-menu dropdown-menu-sm dropdown-menu-right">\
  173.                                <ul class="navi flex-column navi-hover py-2">\
  174.                                    <li class="navi-header font-weight-bolder text-uppercase font-size-xs text-primary pb-2">\
  175.                                        Choose an action:\
  176.                                    </li>\
  177.                                    <li class="navi-item">\
  178.                                        <a href="#" class="navi-link">\
  179.                                            <span class="navi-icon"><i class="la la-print"></i></span>\
  180.                                            <span class="navi-text">Print</span>\
  181.                                        </a>\
  182.                                    </li>\
  183.                                    <li class="navi-item">\
  184.                                        <a href="#" class="navi-link">\
  185.                                            <span class="navi-icon"><i class="la la-copy"></i></span>\
  186.                                            <span class="navi-text">Copy</span>\
  187.                                        </a>\
  188.                                    </li>\
  189.                                    <li class="navi-item">\
  190.                                        <a href="#" class="navi-link">\
  191.                                            <span class="navi-icon"><i class="la la-file-excel-o"></i></span>\
  192.                                            <span class="navi-text">Excel</span>\
  193.                                        </a>\
  194.                                    </li>\
  195.                                    <li class="navi-item">\
  196.                                        <a href="#" class="navi-link">\
  197.                                            <span class="navi-icon"><i class="la la-file-text-o"></i></span>\
  198.                                            <span class="navi-text">CSV</span>\
  199.                                        </a>\
  200.                                    </li>\
  201.                                    <li class="navi-item">\
  202.                                        <a href="#" class="navi-link">\
  203.                                            <span class="navi-icon"><i class="la la-file-pdf-o"></i></span>\
  204.                                            <span class="navi-text">PDF</span>\
  205.                                        </a>\
  206.                                    </li>\
  207.                                </ul>\
  208.                            </div>\
  209.                        </div>\
  210.                        <a href="javascript:;" class="btn btn-sm btn-light btn-text-primary btn-icon mr-2" title="Edit details">\
  211.                            <span class="svg-icon svg-icon-md">\
  212.                                <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">\
  213.                                    <g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\
  214.                                        <rect x="0" y="0" width="24" height="24"/>\
  215.                                        <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) "/>\
  216.                                        <rect fill="#000000" opacity="0.3" x="5" y="20" width="15" height="2" rx="1"/>\
  217.                                    </g>\
  218.                                </svg>\
  219.                            </span>\
  220.                        </a>\
  221.                        <a href="javascript:;" class="btn btn-sm btn-light btn-text-primary btn-icon" title="Delete">\
  222.                            <span class="svg-icon svg-icon-md">\
  223.                                <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">\
  224.                                    <g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\
  225.                                        <rect x="0" y="0" width="24" height="24"/>\
  226.                                        <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"/>\
  227.                                        <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"/>\
  228.                                    </g>\
  229.                                </svg>\
  230.                            </span>\
  231.                        </a>\
  232.                    ';
  233.                 },
  234.             }],
  235.         });
  236.  
  237.         $('#kt_datatable_search_status').on('change', function() {
  238.             datatable.search($(this).val().toLowerCase(), 'Status');
  239.         });
  240.  
  241.         $('#kt_datatable_search_type').on('change', function() {
  242.             datatable.search($(this).val().toLowerCase(), 'Type');
  243.         });
  244.  
  245.         $('#kt_datatable_search_status, #kt_datatable_search_type').selectpicker();
  246.     };
  247.  
  248.     return {
  249.         // public functions
  250.         init: function() {
  251.             demo();
  252.         },
  253.     };
  254. }();
  255.  
  256. jQuery(document).ready(function() {
  257.     KTDatatableLocalSortDemo.init();
  258. });

Raw Paste


Login or Register to edit or fork this paste. It's free.