From 0ae98564e2cdce26794a46ef6e858ae1f73bede6 Mon Sep 17 00:00:00 2001 From: Faris Ansari Date: Sat, 7 Oct 2017 15:43:56 +0530 Subject: [PATCH] Add checkbox option, store options in this.options --- index.html | 3 +- lib/ReGrid.js | 135 ++++++++++++++++++++++++++++++++++++---------- lib/ReGrid.js.map | 2 +- src/regrid.js | 124 +++++++++++++++++++++++++++++++++--------- src/style.scss | 8 ++- 5 files changed, 215 insertions(+), 57 deletions(-) diff --git a/index.html b/index.html index e937bd9..ce4878f 100644 --- a/index.html +++ b/index.html @@ -503,8 +503,7 @@ console.log('No of Rows:', data.rows.length) performance.mark("ReGrid-start"); - var grid = new ReGrid({ - wrapper: document.querySelector('section'), + var grid = new ReGrid(document.querySelector('section'), { addSerialNoColumn: true, enableClusterize: true, data diff --git a/lib/ReGrid.js b/lib/ReGrid.js index 8d940ba..222e496 100644 --- a/lib/ReGrid.js +++ b/lib/ReGrid.js @@ -106,8 +106,6 @@ Object.defineProperty(exports, "__esModule", { var _createClass = 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); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); /* globals $, Clusterize */ -// import $ from 'jQuery'; -// import Clusterize from 'clusterize.js'; var _utils = __webpack_require__(2); @@ -115,16 +113,21 @@ __webpack_require__(3); function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -var ReGrid = function () { - function ReGrid(_ref) { - var wrapper = _ref.wrapper, - events = _ref.events, - data = _ref.data, - editing = _ref.editing, - addSerialNoColumn = _ref.addSerialNoColumn, - enableClusterize = _ref.enableClusterize, - enableLogs = _ref.enableLogs; +var DEFAULT_OPTIONS = { + events: null, + data: { + columns: [], + rows: [] + }, + editing: null, + addSerialNoColumn: true, + enableClusterize: true, + enableLogs: false, + addCheckbox: true +}; +var ReGrid = function () { + function ReGrid(wrapper, options) { _classCallCheck(this, ReGrid); this.wrapper = $(wrapper); @@ -132,14 +135,11 @@ var ReGrid = function () { throw new Error('Invalid argument given for `wrapper`'); } - this.events = (0, _utils.getDefault)(events, {}); - this.addSerialNoColumn = (0, _utils.getDefault)(addSerialNoColumn, false); - this.enableClusterize = (0, _utils.getDefault)(enableClusterize, false); - this.enableLogs = (0, _utils.getDefault)(enableLogs, true); - this.editing = (0, _utils.getDefault)(editing, null); + this.options = Object.assign({}, DEFAULT_OPTIONS, options); + this.events = this.options.events; - if (data) { - this.refresh(data); + if (this.options.data) { + this.refresh(this.options.data); } } @@ -181,7 +181,7 @@ var ReGrid = function () { }, { key: 'renderBody', value: function renderBody() { - if (this.enableClusterize) { + if (this.options.enableClusterize) { this.renderBodyWithClusterize(); } else { this.renderBodyHTML(); @@ -295,13 +295,13 @@ var ReGrid = function () { rows = data.rows; - if (this.addSerialNoColumn) { + if (this.options.addSerialNoColumn) { var serialNoColumn = { content: 'Sr. No', resizable: false }; - columns = [serialNoColumn].concat(columns); + columns.unshift(serialNoColumn); rows = rows.map(function (row, i) { var val = i + 1 + ''; @@ -310,6 +310,24 @@ var ReGrid = function () { }); } + if (this.options.addCheckbox) { + var addCheckboxColumn = { + content: '', + resizable: false, + sortable: false, + editable: false + }; + + columns.unshift(addCheckboxColumn); + + rows = rows.map(function (row, i) { + // make copy of object, else it will be mutated + var val = Object.assign({}, addCheckboxColumn); + + return [val].concat(row); + }); + } + var _columns = (0, _utils.prepareRowHeader)(columns); var _rows = (0, _utils.prepareRows)(rows); @@ -325,6 +343,7 @@ var ReGrid = function () { this.bindEditCell(); this.bindResizeColumn(); this.bindSortColumn(); + this.bindCheckbox(); } }, { key: 'setDimensions', @@ -386,6 +405,13 @@ var ReGrid = function () { this.bodyScrollable.on('click', '.data-table-col', function () { var $cell = $(this); + var _self$getCellAttr2 = self.getCellAttr($cell), + colIndex = _self$getCellAttr2.colIndex; + + if (self.options.addCheckbox && colIndex === 0) { + return; + } + self.$focusedCell = $cell; self.bodyScrollable.find('.data-table-col').removeClass('selected'); $cell.addClass('selected'); @@ -434,6 +460,12 @@ var ReGrid = function () { rowIndex = _getCellAttr.rowIndex, colIndex = _getCellAttr.colIndex; + var col = this.getColumn(colIndex); + + if (col && col.editable === false) { + return; + } + if (this.$editingCell) { var _getCellAttr2 = this.getCellAttr(this.$editingCell), _rowIndex = _getCellAttr2._rowIndex, @@ -460,8 +492,8 @@ var ReGrid = function () { }, { key: 'getEditingObject', value: function getEditingObject(colIndex, rowIndex, value, parent) { - if (this.editing) { - return this.editing(colIndex, rowIndex, value, parent); + if (this.options.editing) { + return this.options.editing(colIndex, rowIndex, value, parent); } // editing fallback @@ -569,6 +601,11 @@ var ReGrid = function () { var $cell = $(this).closest('.data-table-col'); var sortAction = (0, _utils.getDefault)($cell.attr('data-sort-action'), 'none'); var colIndex = $cell.attr('data-col-index'); + var col = self.getColumn(colIndex); + + if (col && col.sortable === false) { + return; + } // reset sort indicator self.header.find('.sort-indicator').text(''); @@ -588,7 +625,7 @@ var ReGrid = function () { // sortWith this action var sortWith = $cell.attr('data-sort-action'); - if (self.events.onSort) { + if (self.events && self.events.onSort) { self.events.onSort(colIndex, sortWith); } else { self.sortRows(colIndex, sortWith); @@ -623,6 +660,50 @@ var ReGrid = function () { return 0; }); } + }, { + key: 'bindCheckbox', + value: function bindCheckbox() { + if (!this.options.addCheckbox) return; + var self = this; + + this.wrapper.on('click', '.data-table-col[data-col-index="0"] [type="checkbox"]', function () { + var $checkbox = $(this); + var $cell = $checkbox.closest('.data-table-col'); + + var _self$getCellAttr3 = self.getCellAttr($cell), + rowIndex = _self$getCellAttr3.rowIndex, + isHeader = _self$getCellAttr3.isHeader; + + var checked = $checkbox.is(':checked'); + + if (isHeader) { + self.highlightAll(checked); + } else { + self.highlightRow(rowIndex, checked); + } + }); + } + }, { + key: 'highlightAll', + value: function highlightAll() { + var toggle = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; + + this.bodyScrollable.find('.data-table-col[data-col-index="0"] [type="checkbox"]').prop('checked', toggle); + this.bodyScrollable.find('.data-table-row').toggleClass('row-highlight', toggle); + } + }, { + key: 'highlightRow', + value: function highlightRow(rowIndex) { + var toggle = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + + var $row = this.bodyScrollable.find('.data-table-row[data-row-index="' + rowIndex + '"]'); + + if (toggle) { + $row.addClass('row-highlight'); + } else { + $row.removeClass('row-highlight'); + } + } }, { key: 'setColumnWidth', value: function setColumnWidth(colIndex, width) { @@ -675,7 +756,7 @@ var ReGrid = function () { var width = _this4.getColumnHeaderElement(col.colIndex).width(); var finalWidth = width + deltaWidth - 16; - if (_this4.addSerialNoColumn && col.colIndex === 0) { + if (_this4.options.addSerialNoColumn && col.colIndex === 0) { return; } @@ -748,7 +829,7 @@ var ReGrid = function () { }, { key: 'log', value: function log() { - if (this.enableLogs) { + if (this.options.enableLogs) { console.log.apply(console, arguments); } } @@ -1002,7 +1083,7 @@ exports = module.exports = __webpack_require__(5)(undefined); // module -exports.push([module.i, ".table {\n width: 100%;\n max-width: 100%;\n margin-bottom: 1rem;\n background-color: transparent; }\n .table th,\n .table td {\n padding: 0.75rem;\n vertical-align: top;\n border-top: 1px solid #e9ecef; }\n .table thead th {\n vertical-align: bottom;\n border-bottom: 2px solid #e9ecef; }\n .table tbody + tbody {\n border-top: 2px solid #e9ecef; }\n .table .table {\n background-color: #fff; }\n\n.table-sm th,\n.table-sm td {\n padding: 0.3rem; }\n\n.table-bordered {\n border: 1px solid #e9ecef; }\n .table-bordered th,\n .table-bordered td {\n border: 1px solid #e9ecef; }\n .table-bordered thead th,\n .table-bordered thead td {\n border-bottom-width: 2px; }\n\n.table-striped tbody tr:nth-of-type(odd) {\n background-color: rgba(0, 0, 0, 0.05); }\n\n.table-hover tbody tr:hover {\n background-color: rgba(0, 0, 0, 0.075); }\n\n.table-primary,\n.table-primary > th,\n.table-primary > td {\n background-color: #b8daff; }\n\n.table-hover .table-primary:hover {\n background-color: #9fcdff; }\n .table-hover .table-primary:hover > td,\n .table-hover .table-primary:hover > th {\n background-color: #9fcdff; }\n\n.table-secondary,\n.table-secondary > th,\n.table-secondary > td {\n background-color: #dddfe2; }\n\n.table-hover .table-secondary:hover {\n background-color: #cfd2d6; }\n .table-hover .table-secondary:hover > td,\n .table-hover .table-secondary:hover > th {\n background-color: #cfd2d6; }\n\n.table-success,\n.table-success > th,\n.table-success > td {\n background-color: #c3e6cb; }\n\n.table-hover .table-success:hover {\n background-color: #b1dfbb; }\n .table-hover .table-success:hover > td,\n .table-hover .table-success:hover > th {\n background-color: #b1dfbb; }\n\n.table-info,\n.table-info > th,\n.table-info > td {\n background-color: #bee5eb; }\n\n.table-hover .table-info:hover {\n background-color: #abdde5; }\n .table-hover .table-info:hover > td,\n .table-hover .table-info:hover > th {\n background-color: #abdde5; }\n\n.table-warning,\n.table-warning > th,\n.table-warning > td {\n background-color: #ffeeba; }\n\n.table-hover .table-warning:hover {\n background-color: #ffe8a1; }\n .table-hover .table-warning:hover > td,\n .table-hover .table-warning:hover > th {\n background-color: #ffe8a1; }\n\n.table-danger,\n.table-danger > th,\n.table-danger > td {\n background-color: #f5c6cb; }\n\n.table-hover .table-danger:hover {\n background-color: #f1b0b7; }\n .table-hover .table-danger:hover > td,\n .table-hover .table-danger:hover > th {\n background-color: #f1b0b7; }\n\n.table-light,\n.table-light > th,\n.table-light > td {\n background-color: #fdfdfe; }\n\n.table-hover .table-light:hover {\n background-color: #ececf6; }\n .table-hover .table-light:hover > td,\n .table-hover .table-light:hover > th {\n background-color: #ececf6; }\n\n.table-dark,\n.table-dark > th,\n.table-dark > td {\n background-color: #c6c8ca; }\n\n.table-hover .table-dark:hover {\n background-color: #b9bbbe; }\n .table-hover .table-dark:hover > td,\n .table-hover .table-dark:hover > th {\n background-color: #b9bbbe; }\n\n.table-active,\n.table-active > th,\n.table-active > td {\n background-color: rgba(0, 0, 0, 0.075); }\n\n.table-hover .table-active:hover {\n background-color: rgba(0, 0, 0, 0.075); }\n .table-hover .table-active:hover > td,\n .table-hover .table-active:hover > th {\n background-color: rgba(0, 0, 0, 0.075); }\n\n.thead-inverse th {\n color: #fff;\n background-color: #212529; }\n\n.thead-default th {\n color: #495057;\n background-color: #e9ecef; }\n\n.table-inverse {\n color: #fff;\n background-color: #212529; }\n .table-inverse th,\n .table-inverse td,\n .table-inverse thead th {\n border-color: #32383e; }\n .table-inverse.table-bordered {\n border: 0; }\n .table-inverse.table-striped tbody tr:nth-of-type(odd) {\n background-color: rgba(255, 255, 255, 0.05); }\n .table-inverse.table-hover tbody tr:hover {\n background-color: rgba(255, 255, 255, 0.075); }\n\n@media (max-width: 991px) {\n .table-responsive {\n display: block;\n width: 100%;\n overflow-x: auto;\n -ms-overflow-style: -ms-autohiding-scrollbar; }\n .table-responsive.table-bordered {\n border: 0; } }\n\n.data-table {\n width: 100%;\n position: relative;\n overflow: auto; }\n .data-table .table {\n border-collapse: collapse; }\n .data-table .table > thead > tr > td, .data-table .table > tbody > tr > td {\n padding: 0; }\n\n.body-scrollable {\n max-height: 500px;\n overflow: auto;\n border-bottom: 1px solid #e9ecef; }\n\n.data-table-header {\n position: absolute;\n top: 0;\n left: 0;\n background-color: white;\n font-weight: bold;\n cursor: col-resize; }\n .data-table-header .content span {\n cursor: pointer; }\n .data-table-header .sort-indicator {\n position: absolute;\n right: 8px;\n top: 9px; }\n\n.data-table-col {\n position: relative; }\n .data-table-col .content {\n padding: 8px;\n border: 1px solid white; }\n .data-table-col.selected .content {\n border: 1px solid #007bff; }\n .data-table-col .content.ellipsis {\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden; }\n\n.edit-cell {\n position: absolute;\n top: -1px;\n left: -1px;\n background: white;\n z-index: 1; }\n .edit-cell input {\n outline: none;\n padding: 8px;\n font-size: inherit;\n font-family: inherit;\n width: inherit;\n height: inherit;\n border: 2px solid #007bff; }\n\n.noselect {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -khtml-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n", ""]); +exports.push([module.i, ".table {\n width: 100%;\n max-width: 100%;\n margin-bottom: 1rem;\n background-color: transparent; }\n .table th,\n .table td {\n padding: 0.75rem;\n vertical-align: top;\n border-top: 1px solid #e9ecef; }\n .table thead th {\n vertical-align: bottom;\n border-bottom: 2px solid #e9ecef; }\n .table tbody + tbody {\n border-top: 2px solid #e9ecef; }\n .table .table {\n background-color: #fff; }\n\n.table-sm th,\n.table-sm td {\n padding: 0.3rem; }\n\n.table-bordered {\n border: 1px solid #e9ecef; }\n .table-bordered th,\n .table-bordered td {\n border: 1px solid #e9ecef; }\n .table-bordered thead th,\n .table-bordered thead td {\n border-bottom-width: 2px; }\n\n.table-striped tbody tr:nth-of-type(odd) {\n background-color: rgba(0, 0, 0, 0.05); }\n\n.table-hover tbody tr:hover {\n background-color: rgba(0, 0, 0, 0.075); }\n\n.table-primary,\n.table-primary > th,\n.table-primary > td {\n background-color: #b8daff; }\n\n.table-hover .table-primary:hover {\n background-color: #9fcdff; }\n .table-hover .table-primary:hover > td,\n .table-hover .table-primary:hover > th {\n background-color: #9fcdff; }\n\n.table-secondary,\n.table-secondary > th,\n.table-secondary > td {\n background-color: #dddfe2; }\n\n.table-hover .table-secondary:hover {\n background-color: #cfd2d6; }\n .table-hover .table-secondary:hover > td,\n .table-hover .table-secondary:hover > th {\n background-color: #cfd2d6; }\n\n.table-success,\n.table-success > th,\n.table-success > td {\n background-color: #c3e6cb; }\n\n.table-hover .table-success:hover {\n background-color: #b1dfbb; }\n .table-hover .table-success:hover > td,\n .table-hover .table-success:hover > th {\n background-color: #b1dfbb; }\n\n.table-info,\n.table-info > th,\n.table-info > td {\n background-color: #bee5eb; }\n\n.table-hover .table-info:hover {\n background-color: #abdde5; }\n .table-hover .table-info:hover > td,\n .table-hover .table-info:hover > th {\n background-color: #abdde5; }\n\n.table-warning,\n.table-warning > th,\n.table-warning > td {\n background-color: #ffeeba; }\n\n.table-hover .table-warning:hover {\n background-color: #ffe8a1; }\n .table-hover .table-warning:hover > td,\n .table-hover .table-warning:hover > th {\n background-color: #ffe8a1; }\n\n.table-danger,\n.table-danger > th,\n.table-danger > td {\n background-color: #f5c6cb; }\n\n.table-hover .table-danger:hover {\n background-color: #f1b0b7; }\n .table-hover .table-danger:hover > td,\n .table-hover .table-danger:hover > th {\n background-color: #f1b0b7; }\n\n.table-light,\n.table-light > th,\n.table-light > td {\n background-color: #fdfdfe; }\n\n.table-hover .table-light:hover {\n background-color: #ececf6; }\n .table-hover .table-light:hover > td,\n .table-hover .table-light:hover > th {\n background-color: #ececf6; }\n\n.table-dark,\n.table-dark > th,\n.table-dark > td {\n background-color: #c6c8ca; }\n\n.table-hover .table-dark:hover {\n background-color: #b9bbbe; }\n .table-hover .table-dark:hover > td,\n .table-hover .table-dark:hover > th {\n background-color: #b9bbbe; }\n\n.table-active,\n.table-active > th,\n.table-active > td {\n background-color: rgba(0, 0, 0, 0.075); }\n\n.table-hover .table-active:hover {\n background-color: rgba(0, 0, 0, 0.075); }\n .table-hover .table-active:hover > td,\n .table-hover .table-active:hover > th {\n background-color: rgba(0, 0, 0, 0.075); }\n\n.thead-inverse th {\n color: #fff;\n background-color: #212529; }\n\n.thead-default th {\n color: #495057;\n background-color: #e9ecef; }\n\n.table-inverse {\n color: #fff;\n background-color: #212529; }\n .table-inverse th,\n .table-inverse td,\n .table-inverse thead th {\n border-color: #32383e; }\n .table-inverse.table-bordered {\n border: 0; }\n .table-inverse.table-striped tbody tr:nth-of-type(odd) {\n background-color: rgba(255, 255, 255, 0.05); }\n .table-inverse.table-hover tbody tr:hover {\n background-color: rgba(255, 255, 255, 0.075); }\n\n@media (max-width: 991px) {\n .table-responsive {\n display: block;\n width: 100%;\n overflow-x: auto;\n -ms-overflow-style: -ms-autohiding-scrollbar; }\n .table-responsive.table-bordered {\n border: 0; } }\n\n.data-table {\n width: 100%;\n position: relative;\n overflow: auto; }\n .data-table .table {\n border-collapse: collapse; }\n .data-table .table > thead > tr > td, .data-table .table > tbody > tr > td {\n padding: 0; }\n\n.body-scrollable {\n max-height: 500px;\n overflow: auto;\n border-bottom: 1px solid #e9ecef; }\n\n.data-table-header {\n position: absolute;\n top: 0;\n left: 0;\n background-color: white;\n font-weight: bold;\n cursor: col-resize; }\n .data-table-header .content span {\n cursor: pointer; }\n .data-table-header .sort-indicator {\n position: absolute;\n right: 8px;\n top: 9px; }\n\n.data-table-col {\n position: relative; }\n .data-table-col .content {\n padding: 8px;\n border: 1px solid transparent; }\n .data-table-col.selected .content {\n border: 1px solid #007bff; }\n .data-table-col .content.ellipsis {\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden; }\n\n.data-table-row.row-highlight {\n background-color: #f8f9fa; }\n\n.edit-cell {\n position: absolute;\n top: -1px;\n left: -1px;\n background: white;\n z-index: 1; }\n .edit-cell input {\n outline: none;\n padding: 8px;\n font-size: inherit;\n font-family: inherit;\n width: inherit;\n height: inherit;\n border: 2px solid #007bff; }\n\n.noselect {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -khtml-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n", ""]); // exports diff --git a/lib/ReGrid.js.map b/lib/ReGrid.js.map index 4645ea6..90ea5fa 100644 --- a/lib/ReGrid.js.map +++ b/lib/ReGrid.js.map @@ -1 +1 @@ -{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap f79f55de7cb9ee5f816c","webpack:///./src/index.js","webpack:///./src/regrid.js","webpack:///./src/utils.js","webpack:///./src/style.scss?3ec1","webpack:///./src/style.scss","webpack:///./node_modules/css-loader/lib/css-base.js","webpack:///./node_modules/style-loader/lib/addStyles.js","webpack:///./node_modules/style-loader/lib/urls.js"],"names":["ReGrid","wrapper","events","data","editing","addSerialNoColumn","enableClusterize","enableLogs","$","length","Error","refresh","html","header","find","bodyScrollable","footer","prepareData","render","makeDom","makeStyle","bindEvents","renderHeader","renderBody","setDimensions","columns","renderBodyWithClusterize","renderBodyHTML","rows","start","pageLength","end","initialData","getDataForClusterize","slice","clusterize","Clusterize","scrollElem","get","contentElem","log","appendRemainingData","dataAppended","promises","push","appendNextPagePromise","reduce","prev","cur","then","Promise","resolve","setTimeout","append","map","row","rowIndex","colIndex","value","cell","getCell","content","refreshCell","selector","$cell","$newCell","replaceWith","_data","serialNoColumn","resizable","concat","i","val","_columns","_rows","bindFocusCell","bindEditCell","bindResizeColumn","bindSortColumn","self","css","width","margin","minWidthMap","each","col","parseInt","attr","height","getCellAttr","setColumnWidth","setDefaultCellHeight","setBodyWidth","setStyle","display","$focusedCell","on","removeClass","addClass","$editingCell","activateEditing","document","body","e","which","stopImmediatePropagation","submitEditing","target","is","hide","_rowIndex","_colIndex","$editCell","empty","getEditingObject","currentCellEditing","initValue","show","parent","$input","getValue","setValue","done","updateCell","isDragging","$currCell","startWidth","startX","getColumn","pageX","finalWidth","getColumnMinWidth","setColumnHeaderWidth","closest","sortAction","text","sortWith","onSort","sortRows","refreshRows","sort","a","b","_aIndex","_bIndex","_a","_b","availableWidth","headerWidth","deltaWidth","getColumnHeaderElement","rule","styleMap","styles","$style","prependTo","console","apply","arguments","camelCaseToDash","str","replace","g","toLowerCase","makeDataAttributeString","props","keys","Object","key","_key","undefined","join","trim","getEditCellHTML","getColumnHTML","column","isHeader","dataAttr","editCellHTML","format","getRowHTML","getHeaderHTML","$header","getBodyHTML","prepareColumn","assign","prepareColumns","prepareRowHeader","prepareRow","prepareRows","getDefault","escapeRegExp","getCSSString","style","prop","hasOwnProperty","getCSSRuleBlock","namespaceSelector","buildCSSRule","cssRulesString","rulePatternStr","rulePattern","RegExp","match","property","propPattern","propertyStr","valueStr","replacer"],"mappings":"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AC3EA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;AACD;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,sBAAsB;AACvC;;AAEA;AACA,mBAAmB,2BAA2B;;AAE9C;AACA;AACA;AACA;AACA;;AAEA;AACA,gBAAgB,mBAAmB;AACnC;AACA;;AAEA;AACA;;AAEA,iBAAiB,2BAA2B;AAC5C;AACA;;AAEA,QAAQ,uBAAuB;AAC/B;AACA;AACA,GAAG;AACH;;AAEA,iBAAiB,uBAAuB;AACxC;AACA;;AAEA,2BAA2B;AAC3B;AACA;AACA;;AAEA;AACA;AACA;;AAEA,gBAAgB,iBAAiB;AACjC;AACA;AACA;AACA;AACA;AACA,cAAc;;AAEd,kDAAkD,sBAAsB;AACxE;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;AACA,EAAE;AACF;AACA,EAAE;AACF;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA,EAAE;AACF;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,EAAE;AACF;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,uDAAuD;AACvD;;AAEA,6BAA6B,mBAAmB;;AAEhD;;AAEA;;AAEA;AACA;;;;;;;;AC/VA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,WAAW,EAAE;AACrD,wCAAwC,WAAW,EAAE;;AAErD;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA,sCAAsC;AACtC,GAAG;AACH;AACA,8DAA8D;AAC9D;;AAEA;AACA;AACA,EAAE;;AAEF;AACA;AACA","file":"regrid.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"ReGrid\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ReGrid\"] = factory();\n\telse\n\t\troot[\"ReGrid\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap f79f55de7cb9ee5f816c","import ReGrid from './regrid.js';\nexport default ReGrid;\n\n\n\n// WEBPACK FOOTER //\n// ./src/index.js","/* globals $, Clusterize */\nimport {\n getHeaderHTML,\n getBodyHTML,\n getRowHTML,\n getColumnHTML,\n prepareRowHeader,\n buildCSSRule,\n prepareRows,\n getDefault\n} from './utils.js';\n// import $ from 'jQuery';\n// import Clusterize from 'clusterize.js';\n\nimport './style.scss';\n\nexport default class ReGrid {\n constructor({\n wrapper,\n events,\n data,\n editing,\n addSerialNoColumn,\n enableClusterize,\n enableLogs\n }) {\n this.wrapper = $(wrapper);\n if (this.wrapper.length === 0) {\n throw new Error('Invalid argument given for `wrapper`');\n }\n\n this.events = getDefault(events, {});\n this.addSerialNoColumn = getDefault(addSerialNoColumn, false);\n this.enableClusterize = getDefault(enableClusterize, false);\n this.enableLogs = getDefault(enableLogs, true);\n this.editing = getDefault(editing, null);\n\n if (data) {\n this.refresh(data);\n }\n }\n\n makeDom() {\n this.wrapper.html(`\n
\n \n
\n
\n
\n
\n
\n
\n
\n
\n
\n `);\n\n this.header = this.wrapper.find('.data-table-header');\n this.bodyScrollable = this.wrapper.find('.body-scrollable');\n // this.body = this.wrapper.find('.data-table-body');\n this.footer = this.wrapper.find('.data-table-footer');\n }\n\n refresh(data) {\n this.data = this.prepareData(data);\n this.render();\n }\n\n render() {\n if (this.wrapper.find('.data-table').length === 0) {\n this.makeDom();\n this.makeStyle();\n this.bindEvents();\n }\n\n this.renderHeader();\n this.renderBody();\n this.setDimensions();\n }\n\n renderHeader() {\n // fixed header\n this.header.html(getHeaderHTML(this.data.columns));\n }\n\n renderBody() {\n if (this.enableClusterize) {\n this.renderBodyWithClusterize();\n } else {\n this.renderBodyHTML();\n }\n }\n\n renderBodyHTML() {\n // scrollable body\n this.bodyScrollable.html(`\n \n ${getBodyHTML(this.data.rows)}\n
\n `);\n }\n\n renderBodyWithClusterize() {\n // empty body\n this.bodyScrollable.html(`\n \n ${getBodyHTML([])}\n
\n `);\n\n this.start = 0;\n this.pageLength = 1000;\n this.end = this.start + this.pageLength;\n\n const initialData = this.getDataForClusterize(\n // only append ${this.pageLength} rows in the beginning\n // defer remaining rows\n this.data.rows.slice(this.start, this.end)\n );\n\n this.clusterize = new Clusterize({\n rows: initialData,\n scrollElem: this.bodyScrollable.get(0),\n contentElem: this.bodyScrollable.find('tbody').get(0)\n });\n this.log('dataAppended', this.pageLength);\n this.appendRemainingData();\n }\n\n appendRemainingData() {\n let dataAppended = this.pageLength;\n const promises = [];\n\n while (dataAppended + this.pageLength < this.data.rows.length) {\n this.start = this.end;\n this.end = this.start + this.pageLength;\n promises.push(this.appendNextPagePromise(this.start, this.end));\n dataAppended += this.pageLength;\n }\n\n if (this.data.rows.length % this.pageLength > 0) {\n // last page\n this.start = this.end;\n this.end = this.start + this.pageLength;\n promises.push(this.appendNextPagePromise(this.start, this.end));\n }\n\n return promises.reduce(\n (prev, cur) => prev.then(cur), Promise.resolve()\n );\n }\n\n appendNextPagePromise(start, end) {\n return new Promise(resolve => {\n setTimeout(() => {\n const rows = this.data.rows.slice(start, end);\n const data = this.getDataForClusterize(rows);\n\n this.clusterize.append(data);\n this.log('dataAppended', rows.length);\n resolve();\n }, 0);\n });\n }\n\n getDataForClusterize(rows) {\n return rows.map((row) => getRowHTML(row, { rowIndex: row[0].rowIndex }));\n }\n\n updateCell(rowIndex, colIndex, value) {\n const cell = this.getCell(rowIndex, colIndex);\n\n cell.content = value;\n this.refreshCell(cell);\n }\n\n refreshRows() {\n this.renderBody();\n this.setDimensions();\n }\n\n refreshCell(cell) {\n const selector = `.data-table-col[data-row-index=\"${cell.rowIndex}\"][data-col-index=\"${cell.colIndex}\"]`;\n const $cell = this.bodyScrollable.find(selector);\n const $newCell = $(getColumnHTML(cell));\n\n $cell.replaceWith($newCell);\n }\n\n prepareData(data) {\n // cache original data passed\n this._data = data;\n let { columns, rows } = data;\n\n if (this.addSerialNoColumn) {\n const serialNoColumn = {\n content: 'Sr. No',\n resizable: false\n };\n\n columns = [serialNoColumn].concat(columns);\n\n rows = rows.map((row, i) => {\n const val = (i + 1) + '';\n\n return [val].concat(row);\n });\n }\n\n const _columns = prepareRowHeader(columns);\n const _rows = prepareRows(rows);\n\n return {\n columns: _columns,\n rows: _rows\n };\n }\n\n bindEvents() {\n this.bindFocusCell();\n this.bindEditCell();\n this.bindResizeColumn();\n this.bindSortColumn();\n }\n\n setDimensions() {\n const self = this;\n\n // setting width as 0 will ensure that the\n // header doesn't take the available space\n this.header.css({\n width: 0,\n margin: 0\n });\n\n // cache minWidth for each column\n this.minWidthMap = getDefault(this.minWidthMap, []);\n this.header.find('.data-table-col').each(function () {\n const col = $(this);\n const width = parseInt(col.find('.content').css('width'), 10);\n const colIndex = col.attr('data-col-index');\n\n if (!self.minWidthMap[colIndex]) {\n // only set this once\n self.minWidthMap[colIndex] = width;\n }\n });\n\n // set initial width as naturally calculated by table's first row\n this.bodyScrollable.find('.data-table-row[data-row-index=\"0\"] .data-table-col').each(function () {\n const $cell = $(this);\n const width = parseInt($cell.find('.content').css('width'), 10);\n const height = parseInt($cell.find('.content').css('height'), 10);\n const { colIndex } = self.getCellAttr($cell);\n\n self.setColumnWidth(colIndex, width);\n self.setDefaultCellHeight(height);\n });\n\n this.setBodyWidth();\n\n this.setStyle('.data-table .body-scrollable', {\n 'margin-top': (this.header.height() + 1) + 'px'\n });\n\n // hide edit cells by default\n this.setStyle('.data-table .body-scrollable .edit-cell', {\n display: 'none'\n });\n\n this.bodyScrollable.find('.table').css('margin', 0);\n }\n\n bindFocusCell() {\n const self = this;\n\n this.$focusedCell = null;\n this.bodyScrollable.on('click', '.data-table-col', function () {\n const $cell = $(this);\n\n self.$focusedCell = $cell;\n self.bodyScrollable.find('.data-table-col').removeClass('selected');\n $cell.addClass('selected');\n });\n }\n\n bindEditCell() {\n const self = this;\n\n this.$editingCell = null;\n this.bodyScrollable.on('dblclick', '.data-table-col', function () {\n self.activateEditing($(this));\n });\n\n $(document.body).on('keypress', (e) => {\n // enter keypress on focused cell\n if (e.which === 13 && this.$focusedCell && !this.$editingCell) {\n this.log('editingCell');\n this.activateEditing(this.$focusedCell);\n e.stopImmediatePropagation();\n }\n });\n\n $(document.body).on('keypress', (e) => {\n // enter keypress on editing cell\n if (e.which === 13 && this.$editingCell) {\n this.log('submitCell');\n this.submitEditing(this.$editingCell);\n e.stopImmediatePropagation();\n }\n });\n\n $(document.body).on('click', e => {\n if ($(e.target).is('.edit-cell, .edit-cell *')) return;\n self.bodyScrollable.find('.edit-cell').hide();\n this.$editingCell = null;\n });\n }\n\n activateEditing($cell) {\n const { rowIndex, colIndex } = this.getCellAttr($cell);\n\n if (this.$editingCell) {\n const { _rowIndex, _colIndex } = this.getCellAttr(this.$editingCell);\n\n if (rowIndex === _rowIndex && colIndex === _colIndex) {\n // editing the same cell\n return;\n }\n }\n\n this.$editingCell = $cell;\n const $editCell = $cell.find('.edit-cell').empty();\n const cell = this.getCell(rowIndex, colIndex);\n const editing = this.getEditingObject(colIndex, rowIndex, cell.content, $editCell);\n\n if (editing) {\n this.currentCellEditing = editing;\n // initialize editing input with cell value\n editing.initValue(cell.content);\n $editCell.show();\n }\n }\n\n getEditingObject(colIndex, rowIndex, value, parent) {\n if (this.editing) {\n return this.editing(colIndex, rowIndex, value, parent);\n }\n\n // editing fallback\n const $input = $('');\n\n parent.append($input);\n\n return {\n initValue(value) {\n return $input.val(value);\n },\n getValue() {\n return $input.val();\n },\n setValue(value) {\n return $input.val(value);\n }\n };\n }\n\n submitEditing($cell) {\n const { rowIndex, colIndex } = this.getCellAttr($cell);\n\n if ($cell) {\n const editing = this.currentCellEditing;\n\n if (editing) {\n const value = editing.getValue();\n const done = editing.setValue(value);\n\n if (done && done.then) {\n // wait for promise then update internal state\n done.then(\n () => this.updateCell(rowIndex, colIndex, value)\n );\n } else {\n this.updateCell(rowIndex, colIndex, value);\n }\n }\n }\n\n this.currentCellEditing = null;\n }\n\n bindResizeColumn() {\n const self = this;\n let isDragging = false;\n let $currCell, startWidth, startX;\n\n this.header.on('mousedown', '.data-table-col', function (e) {\n $currCell = $(this);\n const colIndex = $currCell.attr('data-col-index');\n const col = self.getColumn(colIndex);\n\n if (col && col.resizable === false) {\n return;\n }\n\n isDragging = true;\n startWidth = $currCell.find('.content').width();\n startX = e.pageX;\n });\n\n $('body').on('mouseup', function (e) {\n if (!$currCell) return;\n isDragging = false;\n const colIndex = $currCell.attr('data-col-index');\n\n if ($currCell) {\n const width = parseInt($currCell.find('.content').css('width'), 10);\n\n self.setColumnWidth(colIndex, width);\n self.setBodyWidth();\n $currCell = null;\n }\n });\n\n $('body').on('mousemove', function (e) {\n if (!isDragging) return;\n const finalWidth = startWidth + (e.pageX - startX);\n const colIndex = $currCell.attr('data-col-index');\n\n if (self.getColumnMinWidth(colIndex) > finalWidth) {\n // don't resize past minWidth\n return;\n }\n\n self.setColumnHeaderWidth(colIndex, finalWidth);\n });\n }\n\n bindSortColumn() {\n const self = this;\n\n this.header.on('click', '.data-table-col .content span', function () {\n const $cell = $(this).closest('.data-table-col');\n const sortAction = getDefault($cell.attr('data-sort-action'), 'none');\n const colIndex = $cell.attr('data-col-index');\n\n // reset sort indicator\n self.header.find('.sort-indicator').text('');\n self.header.find('.data-table-col').attr('data-sort-action', 'none');\n\n if (sortAction === 'none') {\n $cell.attr('data-sort-action', 'asc');\n $cell.find('.sort-indicator').text('▲');\n } else if (sortAction === 'asc') {\n $cell.attr('data-sort-action', 'desc');\n $cell.find('.sort-indicator').text('▼');\n } else if (sortAction === 'desc') {\n $cell.attr('data-sort-action', 'none');\n $cell.find('.sort-indicator').text('');\n }\n\n // sortWith this action\n const sortWith = $cell.attr('data-sort-action');\n\n if (self.events.onSort) {\n self.events.onSort(colIndex, sortWith);\n } else {\n self.sortRows(colIndex, sortWith);\n self.refreshRows();\n }\n });\n }\n\n sortRows(colIndex, sortAction = 'none') {\n colIndex = +colIndex;\n\n this.data.rows.sort((a, b) => {\n const _aIndex = a[0].rowIndex;\n const _bIndex = b[0].rowIndex;\n const _a = a[colIndex].content;\n const _b = b[colIndex].content;\n\n if (sortAction === 'none') {\n return _aIndex - _bIndex;\n } else if (sortAction === 'asc') {\n if (_a < _b) return -1;\n if (_a > _b) return 1;\n if (_a === _b) return 0;\n } else if (sortAction === 'desc') {\n if (_a < _b) return 1;\n if (_a > _b) return -1;\n if (_a === _b) return 0;\n }\n return 0;\n });\n }\n\n setColumnWidth(colIndex, width) {\n // set width for content\n this.setStyle(`[data-col-index=\"${colIndex}\"] .content`, {\n width: width + 'px'\n });\n // set width for edit cell\n this.setStyle(`[data-col-index=\"${colIndex}\"] .edit-cell`, {\n width: width + 'px'\n });\n }\n\n setColumnHeaderWidth(colIndex, width) {\n this.setStyle(`[data-col-index=\"${colIndex}\"][data-is-header] .content`, {\n width: width + 'px'\n });\n }\n\n setDefaultCellHeight(height) {\n this.setStyle('.data-table-col .content', {\n height: height + 'px'\n });\n }\n\n setRowHeight(rowIndex, height) {\n this.setStyle(`[data-row-index=\"${rowIndex}\"] .content`, {\n height: height + 'px'\n });\n }\n\n setColumnWidths() {\n const availableWidth = this.wrapper.width();\n const headerWidth = this.header.width();\n\n if (headerWidth > availableWidth) {\n // don't resize, horizontal scroll takes place\n return;\n }\n\n const deltaWidth = (availableWidth - headerWidth) / this.data.columns.length;\n\n this.data.columns.map(col => {\n const width = this.getColumnHeaderElement(col.colIndex).width();\n let finalWidth = width + deltaWidth - 16;\n\n if (this.addSerialNoColumn && col.colIndex === 0) {\n return;\n }\n\n this.setColumnHeaderWidth(col.colIndex, finalWidth);\n this.setColumnWidth(col.colIndex, finalWidth);\n });\n this.setBodyWidth();\n }\n\n setBodyWidth() {\n this.bodyScrollable.css(\n 'width',\n parseInt(this.header.css('width'), 10) + 1\n );\n }\n\n setStyle(rule, styleMap) {\n let styles = this.$style.text();\n\n styles = buildCSSRule(rule, styleMap, styles);\n this.$style.html(styles);\n }\n\n makeStyle() {\n this.$style = $('')\n .prependTo(this.wrapper);\n }\n\n getColumn(colIndex) {\n colIndex = +colIndex;\n return this.data.columns.find(col => col.colIndex === colIndex);\n }\n\n getRow(rowIndex) {\n rowIndex = +rowIndex;\n return this.data.rows.find(row => row[0].rowIndex === rowIndex);\n }\n\n getCell(rowIndex, colIndex) {\n rowIndex = +rowIndex;\n colIndex = +colIndex;\n return this.data.rows.find(row => row[0].rowIndex === rowIndex)[colIndex];\n }\n\n getColumnHeaderElement(colIndex) {\n colIndex = +colIndex;\n if (colIndex < 0) return null;\n return this.wrapper.find(\n `.data-table-col[data-is-header][data-col-index=\"${colIndex}\"]`\n );\n }\n\n getColumnMinWidth(colIndex) {\n colIndex = +colIndex;\n return this.minWidthMap && this.minWidthMap[colIndex];\n }\n\n getCellAttr($cell) {\n return $cell.data();\n }\n\n log() {\n if (this.enableLogs) {\n console.log.apply(console, arguments);\n }\n }\n}\n\n\n\n\n// WEBPACK FOOTER //\n// ./src/regrid.js","function camelCaseToDash(str) {\n return str.replace(/([A-Z])/g, (g) => `-${g[0].toLowerCase()}`);\n}\n\nfunction makeDataAttributeString(props) {\n const keys = Object.keys(props);\n\n return keys\n .map((key) => {\n const _key = camelCaseToDash(key);\n const val = props[key];\n\n if (val === undefined) return '';\n return `data-${_key}=\"${val}\" `;\n })\n .join('')\n .trim();\n}\n\nfunction getEditCellHTML() {\n return `\n
\n `;\n}\n\nfunction getColumnHTML(column) {\n const { rowIndex, colIndex, isHeader } = column;\n const dataAttr = makeDataAttributeString({\n rowIndex,\n colIndex,\n isHeader\n });\n\n const editCellHTML = isHeader ? '' : getEditCellHTML();\n\n return `\n \n
\n ${column.format ? column.format(column.content) : column.content}\n \n
\n ${editCellHTML}\n \n `;\n}\n\nfunction getRowHTML(columns, props) {\n const dataAttr = makeDataAttributeString(props);\n\n return `\n \n ${columns.map(getColumnHTML).join('')}\n \n `;\n}\n\nfunction getHeaderHTML(columns) {\n const $header = `\n \n ${getRowHTML(columns, { isHeader: 1, rowIndex: -1 })}\n \n `;\n\n // columns.map(col => {\n // if (!col.width) return;\n // const $cellContent = $header.find(\n // `.data-table-col[data-col-index=\"${col.colIndex}\"] .content`\n // );\n\n // $cellContent.width(col.width);\n // });\n\n return $header;\n}\n\nfunction getBodyHTML(rows) {\n return `\n \n ${rows.map(row => getRowHTML(row, { rowIndex: row[0].rowIndex })).join('')}\n \n `;\n}\n\nfunction prepareColumn(col, i) {\n if (typeof col === 'string') {\n col = {\n content: col\n };\n }\n return Object.assign(col, {\n colIndex: i\n });\n}\n\nfunction prepareColumns(columns, props = {}) {\n const _columns = columns.map(prepareColumn);\n\n return _columns.map(col => Object.assign(col, props));\n}\n\nfunction prepareRowHeader(columns) {\n return prepareColumns(columns, {\n rowIndex: -1,\n isHeader: 1,\n format: (content) => `${content}`\n });\n}\n\nfunction prepareRow(row, i) {\n return prepareColumns(row, {\n rowIndex: i\n });\n}\n\nfunction prepareRows(rows) {\n return rows.map(prepareRow);\n}\n\nfunction getDefault(a, b) {\n return a !== undefined ? a : b;\n}\n\nfunction escapeRegExp(str) {\n // https://stackoverflow.com/a/6969486\n return str.replace(/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g, '\\\\$&');\n}\n\nfunction getCSSString(styleMap) {\n let style = '';\n\n for (const prop in styleMap) {\n if (styleMap.hasOwnProperty(prop)) {\n style += `${prop}: ${styleMap[prop]}; `;\n }\n }\n\n return style.trim();\n}\n\nfunction getCSSRuleBlock(rule, styleMap) {\n return `${rule} { ${getCSSString(styleMap)} }`;\n}\n\nfunction namespaceSelector(selector) {\n return '.data-table ' + selector;\n}\n\nfunction buildCSSRule(rule, styleMap, cssRulesString = '') {\n // build css rules efficiently,\n // append new rule if doesnt exist,\n // update existing ones\n\n const rulePatternStr = `${escapeRegExp(rule)} {([^}]*)}`;\n const rulePattern = new RegExp(rulePatternStr, 'g');\n\n if (cssRulesString && cssRulesString.match(rulePattern)) {\n for (const property in styleMap) {\n const value = styleMap[property];\n const propPattern = new RegExp(`${escapeRegExp(property)}:([^;]*);`);\n\n cssRulesString = cssRulesString.replace(rulePattern, function (match, propertyStr) {\n if (propertyStr.match(propPattern)) {\n // property exists, replace value with new value\n propertyStr = propertyStr.replace(propPattern, (match, valueStr) => {\n return `${property}: ${value};`;\n });\n }\n propertyStr = propertyStr.trim();\n\n const replacer =\n `${rule} { ${propertyStr} }`;\n\n return replacer;\n });\n }\n\n return cssRulesString;\n }\n // no match, append new rule block\n return `${cssRulesString}${getCSSRuleBlock(rule, styleMap)}`;\n}\n\nexport default {\n getHeaderHTML,\n getBodyHTML,\n getRowHTML,\n getColumnHTML,\n getEditCellHTML,\n prepareRowHeader,\n prepareRows,\n namespaceSelector,\n getCSSString,\n buildCSSRule,\n makeDataAttributeString,\n getDefault,\n escapeRegExp\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/utils.js","// style-loader: Adds some css to the DOM by adding a ')\n .prependTo(this.wrapper);\n }\n\n getColumn(colIndex) {\n colIndex = +colIndex;\n return this.data.columns.find(col => col.colIndex === colIndex);\n }\n\n getRow(rowIndex) {\n rowIndex = +rowIndex;\n return this.data.rows.find(row => row[0].rowIndex === rowIndex);\n }\n\n getCell(rowIndex, colIndex) {\n rowIndex = +rowIndex;\n colIndex = +colIndex;\n return this.data.rows.find(row => row[0].rowIndex === rowIndex)[colIndex];\n }\n\n getColumnHeaderElement(colIndex) {\n colIndex = +colIndex;\n if (colIndex < 0) return null;\n return this.wrapper.find(\n `.data-table-col[data-is-header][data-col-index=\"${colIndex}\"]`\n );\n }\n\n getColumnMinWidth(colIndex) {\n colIndex = +colIndex;\n return this.minWidthMap && this.minWidthMap[colIndex];\n }\n\n getCellAttr($cell) {\n return $cell.data();\n }\n\n log() {\n if (this.options.enableLogs) {\n console.log.apply(console, arguments);\n }\n }\n}\n\n\n\n\n// WEBPACK FOOTER //\n// ./src/regrid.js","function camelCaseToDash(str) {\n return str.replace(/([A-Z])/g, (g) => `-${g[0].toLowerCase()}`);\n}\n\nfunction makeDataAttributeString(props) {\n const keys = Object.keys(props);\n\n return keys\n .map((key) => {\n const _key = camelCaseToDash(key);\n const val = props[key];\n\n if (val === undefined) return '';\n return `data-${_key}=\"${val}\" `;\n })\n .join('')\n .trim();\n}\n\nfunction getEditCellHTML() {\n return `\n
\n `;\n}\n\nfunction getColumnHTML(column) {\n const { rowIndex, colIndex, isHeader } = column;\n const dataAttr = makeDataAttributeString({\n rowIndex,\n colIndex,\n isHeader\n });\n\n const editCellHTML = isHeader ? '' : getEditCellHTML();\n\n return `\n \n
\n ${column.format ? column.format(column.content) : column.content}\n \n
\n ${editCellHTML}\n \n `;\n}\n\nfunction getRowHTML(columns, props) {\n const dataAttr = makeDataAttributeString(props);\n\n return `\n \n ${columns.map(getColumnHTML).join('')}\n \n `;\n}\n\nfunction getHeaderHTML(columns) {\n const $header = `\n \n ${getRowHTML(columns, { isHeader: 1, rowIndex: -1 })}\n \n `;\n\n // columns.map(col => {\n // if (!col.width) return;\n // const $cellContent = $header.find(\n // `.data-table-col[data-col-index=\"${col.colIndex}\"] .content`\n // );\n\n // $cellContent.width(col.width);\n // });\n\n return $header;\n}\n\nfunction getBodyHTML(rows) {\n return `\n \n ${rows.map(row => getRowHTML(row, { rowIndex: row[0].rowIndex })).join('')}\n \n `;\n}\n\nfunction prepareColumn(col, i) {\n if (typeof col === 'string') {\n col = {\n content: col\n };\n }\n return Object.assign(col, {\n colIndex: i\n });\n}\n\nfunction prepareColumns(columns, props = {}) {\n const _columns = columns.map(prepareColumn);\n\n return _columns.map(col => Object.assign(col, props));\n}\n\nfunction prepareRowHeader(columns) {\n return prepareColumns(columns, {\n rowIndex: -1,\n isHeader: 1,\n format: (content) => `${content}`\n });\n}\n\nfunction prepareRow(row, i) {\n return prepareColumns(row, {\n rowIndex: i\n });\n}\n\nfunction prepareRows(rows) {\n return rows.map(prepareRow);\n}\n\nfunction getDefault(a, b) {\n return a !== undefined ? a : b;\n}\n\nfunction escapeRegExp(str) {\n // https://stackoverflow.com/a/6969486\n return str.replace(/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g, '\\\\$&');\n}\n\nfunction getCSSString(styleMap) {\n let style = '';\n\n for (const prop in styleMap) {\n if (styleMap.hasOwnProperty(prop)) {\n style += `${prop}: ${styleMap[prop]}; `;\n }\n }\n\n return style.trim();\n}\n\nfunction getCSSRuleBlock(rule, styleMap) {\n return `${rule} { ${getCSSString(styleMap)} }`;\n}\n\nfunction namespaceSelector(selector) {\n return '.data-table ' + selector;\n}\n\nfunction buildCSSRule(rule, styleMap, cssRulesString = '') {\n // build css rules efficiently,\n // append new rule if doesnt exist,\n // update existing ones\n\n const rulePatternStr = `${escapeRegExp(rule)} {([^}]*)}`;\n const rulePattern = new RegExp(rulePatternStr, 'g');\n\n if (cssRulesString && cssRulesString.match(rulePattern)) {\n for (const property in styleMap) {\n const value = styleMap[property];\n const propPattern = new RegExp(`${escapeRegExp(property)}:([^;]*);`);\n\n cssRulesString = cssRulesString.replace(rulePattern, function (match, propertyStr) {\n if (propertyStr.match(propPattern)) {\n // property exists, replace value with new value\n propertyStr = propertyStr.replace(propPattern, (match, valueStr) => {\n return `${property}: ${value};`;\n });\n }\n propertyStr = propertyStr.trim();\n\n const replacer =\n `${rule} { ${propertyStr} }`;\n\n return replacer;\n });\n }\n\n return cssRulesString;\n }\n // no match, append new rule block\n return `${cssRulesString}${getCSSRuleBlock(rule, styleMap)}`;\n}\n\nexport default {\n getHeaderHTML,\n getBodyHTML,\n getRowHTML,\n getColumnHTML,\n getEditCellHTML,\n prepareRowHeader,\n prepareRows,\n namespaceSelector,\n getCSSString,\n buildCSSRule,\n makeDataAttributeString,\n getDefault,\n escapeRegExp\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/utils.js","// style-loader: Adds some css to the DOM by adding a