UNPKG

ag-grid

Version:

Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components

225 lines (224 loc) 10.9 kB
/** * ag-grid - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components * @version v18.1.2 * @link http://www.ag-grid.com/ * @license MIT */ "use strict"; var __extends = (this && this.__extends) || (function () { var extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; Object.defineProperty(exports, "__esModule", { value: true }); var utils_1 = require("../utils"); var baseFilter_1 = require("./baseFilter"); var componentAnnotations_1 = require("../widgets/componentAnnotations"); var TextFilter = (function (_super) { __extends(TextFilter, _super); function TextFilter() { return _super !== null && _super.apply(this, arguments) || this; } TextFilter.prototype.getDefaultType = function () { return baseFilter_1.BaseFilter.CONTAINS; }; TextFilter.prototype.customInit = function () { this.comparator = this.filterParams.textCustomComparator ? this.filterParams.textCustomComparator : TextFilter.DEFAULT_COMPARATOR; this.formatter = this.filterParams.textFormatter ? this.filterParams.textFormatter : this.filterParams.caseSensitive == true ? TextFilter.DEFAULT_FORMATTER : TextFilter.DEFAULT_LOWERCASE_FORMATTER; _super.prototype.customInit.call(this); }; TextFilter.prototype.modelFromFloatingFilter = function (from) { return { type: this.filter, filter: from, filterType: 'text' }; }; TextFilter.prototype.getApplicableFilterTypes = function () { return [baseFilter_1.BaseFilter.EQUALS, baseFilter_1.BaseFilter.NOT_EQUAL, baseFilter_1.BaseFilter.STARTS_WITH, baseFilter_1.BaseFilter.ENDS_WITH, baseFilter_1.BaseFilter.CONTAINS, baseFilter_1.BaseFilter.NOT_CONTAINS]; }; TextFilter.prototype.bodyTemplate = function (type) { var translate = this.translate.bind(this); var fieldId = type == baseFilter_1.FilterConditionType.MAIN ? "filterText" : "filterConditionText"; return "<div class=\"ag-filter-body\">\n <input class=\"ag-filter-filter\" id=" + fieldId + " type=\"text\" placeholder=\"" + translate('filterOoo', 'Filter...') + "\"/>\n </div>"; }; TextFilter.prototype.initialiseFilterBodyUi = function (type) { _super.prototype.initialiseFilterBodyUi.call(this, type); this.addFilterChangedListener(type); this.setFilter(this.filterConditionText, baseFilter_1.FilterConditionType.CONDITION); this.setFilterType(this.filterCondition, baseFilter_1.FilterConditionType.CONDITION); }; TextFilter.prototype.addFilterChangedListener = function (type) { var _this = this; var eElement = type === baseFilter_1.FilterConditionType.MAIN ? this.eFilterTextField : this.eFilterConditionTextField; var debounceMs = this.getDebounceMs(this.filterParams); var toDebounce = utils_1.Utils.debounce(function () { return _this.onFilterTextFieldChanged(type); }, debounceMs); this.addDestroyableEventListener(eElement, 'input', toDebounce); }; TextFilter.prototype.refreshFilterBodyUi = function (type) { if (this.eFilterConditionTextField) { this.addFilterChangedListener(baseFilter_1.FilterConditionType.CONDITION); } }; TextFilter.prototype.afterGuiAttached = function () { this.eFilterTextField.focus(); }; TextFilter.prototype.filterValues = function (type) { return type === baseFilter_1.FilterConditionType.MAIN ? this.filterText : this.filterConditionText; }; TextFilter.prototype.individualFilterPasses = function (params, type) { var filterText = type == baseFilter_1.FilterConditionType.MAIN ? this.filterText : this.filterConditionText; var filter = type == baseFilter_1.FilterConditionType.MAIN ? this.filter : this.filterCondition; if (!filterText) { return type === baseFilter_1.FilterConditionType.MAIN ? true : this.conditionValue === 'AND'; } else { return this.checkIndividualFilter(params, filter, filterText); } }; TextFilter.prototype.checkIndividualFilter = function (params, filterType, filterText) { var value = this.filterParams.valueGetter(params.node); if (value == null || value === undefined) { return filterType === baseFilter_1.BaseFilter.NOT_EQUAL || filterType === baseFilter_1.BaseFilter.NOT_CONTAINS; } var valueFormatted = this.formatter(value); return this.comparator(filterType, valueFormatted, filterText); }; TextFilter.prototype.onFilterTextFieldChanged = function (type) { var value = type === baseFilter_1.FilterConditionType.MAIN ? this.eFilterTextField.value : this.eFilterConditionTextField.value; var current = type === baseFilter_1.FilterConditionType.MAIN ? this.filterText : this.filterConditionText; var filterText = utils_1.Utils.makeNull(value); if (filterText && filterText.trim() === '') { filterText = null; } if (current !== filterText) { var newLowerCase = filterText && this.filterParams.caseSensitive != true ? filterText.toLowerCase() : filterText; var previousLowerCase = current && this.filterParams.caseSensitive != true ? current.toLowerCase() : current; if (type === baseFilter_1.FilterConditionType.MAIN) { this.filterText = this.formatter(filterText); } else { this.filterConditionText = this.formatter(filterText); } if (previousLowerCase !== newLowerCase) { this.onFilterChanged(); } } }; TextFilter.prototype.setFilter = function (filter, type) { filter = utils_1.Utils.makeNull(filter); if (type === baseFilter_1.FilterConditionType.MAIN) { if (filter) { this.filterText = this.formatter(filter); if (!this.eFilterTextField) return; this.eFilterTextField.value = filter; } else { this.filterText = null; if (!this.eFilterTextField) return; this.eFilterTextField.value = null; } } else { if (filter) { this.filterConditionText = this.formatter(filter); if (!this.eFilterConditionTextField) return; this.eFilterConditionTextField.value = filter; } else { this.filterConditionText = null; if (!this.eFilterConditionTextField) return; this.eFilterConditionTextField.value = null; } } }; TextFilter.prototype.getFilter = function () { return this.filterText; }; TextFilter.prototype.resetState = function () { this.setFilter(null, baseFilter_1.FilterConditionType.MAIN); this.setFilterType(this.defaultFilter, baseFilter_1.FilterConditionType.MAIN); this.setFilter(null, baseFilter_1.FilterConditionType.CONDITION); this.setFilterType(this.defaultFilter, baseFilter_1.FilterConditionType.CONDITION); }; TextFilter.prototype.serialize = function (type) { var filter = type === baseFilter_1.FilterConditionType.MAIN ? this.filter : this.filterCondition; var filterText = type === baseFilter_1.FilterConditionType.MAIN ? this.filterText : this.filterConditionText; return { type: filter ? filter : this.defaultFilter, filter: filterText, filterType: 'text' }; }; TextFilter.prototype.parse = function (model, type) { this.setFilterType(model.type, type); this.setFilter(model.filter, type); }; TextFilter.prototype.setType = function (filterType, type) { this.setFilterType(filterType, type); }; TextFilter.DEFAULT_FORMATTER = function (from) { return from; }; TextFilter.DEFAULT_LOWERCASE_FORMATTER = function (from) { if (from == null) { return null; } return from.toString().toLowerCase(); }; TextFilter.DEFAULT_COMPARATOR = function (filter, value, filterText) { switch (filter) { case TextFilter.CONTAINS: return value.indexOf(filterText) >= 0; case TextFilter.NOT_CONTAINS: return value.indexOf(filterText) === -1; case TextFilter.EQUALS: return value === filterText; case TextFilter.NOT_EQUAL: return value != filterText; case TextFilter.STARTS_WITH: return value.indexOf(filterText) === 0; case TextFilter.ENDS_WITH: var index = value.lastIndexOf(filterText); return index >= 0 && index === (value.length - filterText.length); default: // should never happen console.warn('invalid filter type ' + filter); return false; } }; __decorate([ componentAnnotations_1.QuerySelector('#filterText'), __metadata("design:type", HTMLInputElement) ], TextFilter.prototype, "eFilterTextField", void 0); __decorate([ componentAnnotations_1.QuerySelector('#filterConditionText'), __metadata("design:type", HTMLInputElement) ], TextFilter.prototype, "eFilterConditionTextField", void 0); return TextFilter; }(baseFilter_1.ComparableBaseFilter)); exports.TextFilter = TextFilter;