"use strict"; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } // DataTables Demo // ============================================================= var InvoicesListDemo = /*#__PURE__*/function () { function InvoicesListDemo() { _classCallCheck(this, InvoicesListDemo); this.init(); } _createClass(InvoicesListDemo, [{ key: "init", value: function init() { // event handlers this.table = this.table(); this.searchRecords(); this.selecter(); this.clearSelected(); } }, { key: "table", value: function table() { // register to support date sorting $.fn.dataTable.moment('DD/MM/YYYY'); return $('#invoicesTable').DataTable({ dom: "<'table-responsive'tr>\n <'mt-4'p>", language: { paginate: { previous: '', next: '' } }, autoWidth: false, ajax: 'assets/data/invoices-list.json', deferRender: true, order: [3, 'dec'], columns: [{ data: 'number', className: 'col-checker align-middle', orderable: false, searchable: false }, { data: 'number', className: 'align-middle' }, { data: 'client', className: 'align-middle' }, { data: 'duedate', className: 'align-middle' }, { data: 'status', className: 'align-middle' }, { data: 'amount', className: 'align-middle' }, { data: 'paid', className: 'align-middle' }, { data: 'balance', className: 'align-middle' }, { data: 'actions', className: 'align-middle text-right', orderable: false, searchable: false }], columnDefs: [{ targets: 0, render: function render(data, type, row, meta) { return "
\n \n \n
"); } }, { targets: 1, render: function render(data, type, row, meta) { return "".concat(row.number, ""); } }, { targets: 4, render: function render(data, type, row, meta) { return "").concat(row.status, ""); } }, { targets: 5, render: function render(data, type, row, meta) { return "
".concat(row.amount, "
"); } }, { targets: 6, render: function render(data, type, row, meta) { return "
".concat(row.paid, "
"); } }, { targets: 8, render: function render(data, type, row, meta) { return "
\n \n
\n
\n View\n Edit\n Send reminder\n
\n Download pdf\n Share to...\n
\n Delete\n
\n
"); } }] }); } }, { key: "searchRecords", value: function searchRecords() { var self = this; $('#table-search, #filterBy').on('keyup change focus', function (e) { var filterBy = $('#filterBy').val(); var hasFilter = filterBy !== ''; // reset search term self.table.column(4).search('').draw(); if (hasFilter) { self.table.column(4).search(filterBy).draw(); } else { self.table.draw(); } }); } }, { key: "getSelectedInfo", value: function getSelectedInfo() { var $selectedRow = $('input[name="selectedRow[]"]:checked').length; var $info = $('.thead-btn'); var $badge = $('').addClass('selected-row-info text-muted pl-1').text("".concat($selectedRow, " selected")); // remove existing info $('.selected-row-info').remove(); // add current info if ($selectedRow) { $info.prepend($badge); } } }, { key: "selecter", value: function selecter() { var self = this; $(document).on('change', '#check-handle', function () { var isChecked = $(this).prop('checked'); $('input[name="selectedRow[]"]').prop('checked', isChecked); // get info self.getSelectedInfo(); }).on('change', 'input[name="selectedRow[]"]', function () { var $selectors = $('input[name="selectedRow[]"]'); var $selectedRow = $('input[name="selectedRow[]"]:checked').length; var prop = $selectedRow === $selectors.length ? 'checked' : 'indeterminate'; // reset props $('#check-handle').prop('indeterminate', false).prop('checked', false); if ($selectedRow) { $('#check-handle').prop(prop, true); } // get info self.getSelectedInfo(); }); } }, { key: "clearSelected", value: function clearSelected() { var self = this; // clear selected rows $('#invoicesTable').on('page.dt', function () { self.clearSelectedRows(); }); $('#clear-search').on('click', function () { self.clearSelectedRows(); }); } }, { key: "clearSelectedRows", value: function clearSelectedRows() { $('#check-handle').prop('indeterminate', false).prop('checked', false).trigger('change'); } }]); return InvoicesListDemo; }(); /** * Keep in mind that your scripts may not always be executed after the theme is completely ready, * you might need to observe the `theme:load` event to make sure your scripts are executed after the theme is ready. */ $(document).on('theme:init', function () { new InvoicesListDemo(); });