ag-grid
Version:
Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
225 lines (224 loc) • 10.9 kB
JavaScript
/**
* 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;