UNPKG

@angular-generic-table/core

Version:
113 lines (112 loc) 12.5 kB
/** * @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":";;;;AAAA,OAAO,EAAE,IAAI,EAAiB,MAAM,eAAe,CAAC;;;;;AASpD,MAAM;;;;;2BAEiB,UAAS,KAAiB,EAAE,GAAW;YAC5D,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBACvC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,KAAK,GAAG,CAAC,CAAC,CAAC;oBAChC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;iBAChB;aACD;SACD;;;;;;;;;;;IAED,SAAS,CACR,OAAY,EACZ,WAAmB,EACnB,MAAqB,EACrB,QAAgC,EAChC,MAAoC,EACpC,WAAmB;;QAGnB,EAAE,CAAC,CAAC,CAAC,WAAW,IAAI,WAAW,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;;YAEhE,uBAAM,MAAM,GAAG,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;YACrD,MAAM,CAAC,kBAAkB,GAAG,MAAM,CAAC;YACnC,MAAM,CAAC,OAAO,CAAC;SACf;QAED,uBAAM,cAAc,GAAQ,EAAE,CAAC;QAC/B,uBAAM,UAAU,GAAe,EAAE,CAAC;QAElC,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,uBAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;;YAGxB,uBAAM,OAAO,GACZ,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,KAAK,KAAK;gBAC3D,CAAC,CAAC,KAAK;gBACP,CAAC,CAAC,IAAI,CAAC;;YAGT,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;;gBAEb,EAAE,CAAC,CAAC,OAAO,KAAK,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC;;oBAExC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC;iBAC/C;gBAED,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,KAAK,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC;;oBAE5C,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC;iBAC9C;;gBAGD,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACvB;SACD;QAED,uBAAM,YAAY,GAAe,EAAE,CAAC;QACpC,WAAW,GAAG,OAAO,WAAW,KAAK,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC;QACpE,uBAAM,gBAAgB,GAAG,WAAW,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAE3E,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACzC,uBAAM,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YACvB,qBAAI,MAAM,GAAG,EAAE,CAAC;YAEhB,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC5C,uBAAM,SAAS,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;gBACvC,MAAM,IAAI,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;oBAChD,CAAC,CAAC,SAAS,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;oBAC7D,CAAC,CAAC,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;aAC5C;YACD,MAAM,GAAG,MAAM,CAAC,WAAW,EAAE,CAAC;YAC9B,qBAAI,KAAK,GAAY,IAAI,CAAC;YAE1B,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,gBAAgB,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAClD,uBAAM,IAAI,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBACnD,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;gBAEpC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;oBACZ,KAAK,CAAC;iBACN;aACD;YACD,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;gBACX,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aACvB;SACD;QACD,MAAM,CAAC,kBAAkB,GAAG,YAAY,CAAC,MAAM,CAAC;;QAEhD,MAAM,CAAC,YAAY,CAAC;KACpB;;;YA3FD,IAAI,SAAC;gBACL,IAAI,EAAE,UAAU;aAChB","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"]}