@angular-generic-table/core
Version:
A generic table component for Angular
113 lines (112 loc) • 12.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { Pipe } from '@angular/core';
// unsupported: template constraints.
/**
* @template R
*/
export class GtSearchPipe {
constructor() {
/**
* Return property
*/
this.getProperty = function (array, key) {
for (let /** @type {?} */ i = 0; i < array.length; i++) {
if (array[i].objectKey === key) {
return array[i];
}
}
};
}
/**
* @param {?} allRows
* @param {?} searchTerms
* @param {?} gtInfo
* @param {?} settings
* @param {?} fields
* @param {?} refreshData
* @return {?}
*/
transform(allRows, searchTerms, gtInfo, settings, fields, refreshData) {
// if no search terms are defined...
if (!searchTerms || searchTerms.replace(/"/g, '').length === 0) {
// ...return all rows
const /** @type {?} */ length = allRows === null ? 0 : allRows.length;
gtInfo.recordsAfterSearch = length;
return allRows;
}
const /** @type {?} */ searchFunction = {};
const /** @type {?} */ fieldsTemp = [];
for (let /** @type {?} */ k = 0; k < fields.length; k++) {
const /** @type {?} */ field = fields[k];
// check if field should be included in global search
const /** @type {?} */ include = this.getProperty(settings, field.objectKey).search === false
? false
: true;
// if include...
if (include) {
// ...and if search function is defined...
if (typeof field.search === 'function') {
// ...add it as search function for field
searchFunction[field.objectKey] = field.search;
}
else if (typeof field.value === 'function') {
// ...add it as search function for field
searchFunction[field.objectKey] = field.value;
}
// ...push it to our fields array
fieldsTemp.push(field);
}
}
const /** @type {?} */ filteredRows = [];
searchTerms = typeof searchTerms === 'undefined' ? '' : searchTerms;
const /** @type {?} */ searchTermsArray = searchTerms.toLowerCase().match(/(".*"|[^\s]+)/g);
for (let /** @type {?} */ i = 0; i < allRows.length; i++) {
const /** @type {?} */ row = allRows[i];
let /** @type {?} */ string = '';
for (let /** @type {?} */ j = 0; j < fieldsTemp.length; j++) {
const /** @type {?} */ separator = j === 0 ? '' : ' & ';
string += searchFunction[fieldsTemp[j].objectKey]
? separator + searchFunction[fieldsTemp[j].objectKey](row, j)
: separator + row[fieldsTemp[j].objectKey];
}
string = string.toLowerCase();
let /** @type {?} */ match = true;
for (let /** @type {?} */ k = 0; k < searchTermsArray.length; k++) {
const /** @type {?} */ term = searchTermsArray[k].replace(/"/g, '');
match = string.indexOf(term) !== -1;
if (!match) {
break;
}
}
if (match) {
filteredRows.push(row);
}
}
gtInfo.recordsAfterSearch = filteredRows.length;
// gtInfo.refresh(filteredRows.length,gt);
return filteredRows;
}
}
GtSearchPipe.decorators = [
{ type: Pipe, args: [{
name: 'gtSearch'
},] },
];
function GtSearchPipe_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
GtSearchPipe.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
GtSearchPipe.ctorParameters;
/**
* Return property
* @type {?}
*/
GtSearchPipe.prototype.getProperty;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gt-search.pipe.js","sourceRoot":"ng://@angular-generic-table/core/","sources":["pipes/gt-search.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { GtConfigField } from '../interfaces/gt-config-field';\nimport { GtRow } from '../interfaces/gt-row';\nimport { GtConfigSetting } from '../interfaces/gt-config-setting';\nimport { GtInformation } from '../interfaces/gt-information';\n\n@Pipe({\n\tname: 'gtSearch'\n})\nexport class GtSearchPipe<R extends GtRow> implements PipeTransform {\n\t/** Return property */\n\tprivate getProperty = function(array: Array<any>, key: string) {\n\t\tfor (let i = 0; i < array.length; i++) {\n\t\t\tif (array[i].objectKey === key) {\n\t\t\t\treturn array[i];\n\t\t\t}\n\t\t}\n\t};\n\n\ttransform(\n\t\tallRows: any,\n\t\tsearchTerms: string,\n\t\tgtInfo: GtInformation,\n\t\tsettings: Array<GtConfigSetting>,\n\t\tfields: Array<GtConfigField<R, any>>,\n\t\trefreshData: number\n\t): any {\n\t\t//  if no search terms are defined...\n\t\tif (!searchTerms || searchTerms.replace(/\"/g, '').length === 0) {\n\t\t\t// ...return all rows\n\t\t\tconst length = allRows === null ? 0 : allRows.length;\n\t\t\tgtInfo.recordsAfterSearch = length;\n\t\t\treturn allRows;\n\t\t}\n\n\t\tconst searchFunction: any = {};\n\t\tconst fieldsTemp: Array<any> = [];\n\n\t\tfor (let k = 0; k < fields.length; k++) {\n\t\t\tconst field = fields[k];\n\n\t\t\t// check if field should be included in global search\n\t\t\tconst include =\n\t\t\t\tthis.getProperty(settings, field.objectKey).search === false\n\t\t\t\t\t? false\n\t\t\t\t\t: true;\n\n\t\t\t// if include...\n\t\t\tif (include) {\n\t\t\t\t// ...and if search function is defined...\n\t\t\t\tif (typeof field.search === 'function') {\n\t\t\t\t\t// ...add it as search function for field\n\t\t\t\t\tsearchFunction[field.objectKey] = field.search;\n\t\t\t\t}\n\t\t\t\t// ...if no search function is defined but value function is defined...\n\t\t\t\telse if (typeof field.value === 'function') {\n\t\t\t\t\t// ...add it as search function for field\n\t\t\t\t\tsearchFunction[field.objectKey] = field.value;\n\t\t\t\t}\n\n\t\t\t\t// ...push it to our fields array\n\t\t\t\tfieldsTemp.push(field);\n\t\t\t}\n\t\t}\n\n\t\tconst filteredRows: Array<any> = [];\n\t\tsearchTerms = typeof searchTerms === 'undefined' ? '' : searchTerms;\n\t\tconst searchTermsArray = searchTerms.toLowerCase().match(/(\".*\"|[^\\s]+)/g);\n\n\t\tfor (let i = 0; i < allRows.length; i++) {\n\t\t\tconst row = allRows[i];\n\t\t\tlet string = '';\n\n\t\t\tfor (let j = 0; j < fieldsTemp.length; j++) {\n\t\t\t\tconst separator = j === 0 ? '' : ' & ';\n\t\t\t\tstring += searchFunction[fieldsTemp[j].objectKey]\n\t\t\t\t\t? separator + searchFunction[fieldsTemp[j].objectKey](row, j)\n\t\t\t\t\t: separator + row[fieldsTemp[j].objectKey];\n\t\t\t}\n\t\t\tstring = string.toLowerCase();\n\t\t\tlet match: Boolean = true;\n\n\t\t\tfor (let k = 0; k < searchTermsArray.length; k++) {\n\t\t\t\tconst term = searchTermsArray[k].replace(/\"/g, '');\n\t\t\t\tmatch = string.indexOf(term) !== -1;\n\n\t\t\t\tif (!match) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (match) {\n\t\t\t\tfilteredRows.push(row);\n\t\t\t}\n\t\t}\n\t\tgtInfo.recordsAfterSearch = filteredRows.length;\n\t\t// gtInfo.refresh(filteredRows.length,gt);\n\t\treturn filteredRows;\n\t}\n}\n"]}