UNPKG

@angular-generic-table/core

Version:
173 lines (172 loc) 17.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Pipe } from '@angular/core'; import { DomSanitizer } from '@angular/platform-browser'; import { GtHighlightPipe } from './gt-highlight.pipe'; // unsupported: template constraints. /** * @template R */ export class GtRenderPipe { /** * @param {?} sanitizer * @param {?} gtHighlightPipe */ constructor(sanitizer, gtHighlightPipe) { this.sanitizer = sanitizer; this.gtHighlightPipe = gtHighlightPipe; /** * Sort by column order */ this.getColumnOrder = function (a, b) { if (a.columnOrder < b.columnOrder) { return -1; } if (a.columnOrder > b.columnOrder || typeof a.columnOrder === 'undefined') { return 1; } return 0; }; /** * Sort by length */ this.getOrderByLength = function (a, b) { return b.length - a.length; }; /** * 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 {?} row * @param {?} settings * @param {?} fields * @param {?} updated * @param {?} loading * @param {?=} highlight * @param {?=} searchString * @return {?} */ transform(row, settings, fields, updated, loading, highlight = false, searchString) { // let arr = [{"temp":123,"name":"happy"},{"temp":456,"name":"dfgdfg"},{"temp":789,"name":"asdasd"}]; // console.log(arr,arr.map(function(item){return item.temp})); // console.log(settings.map('objectKey')); // console.log('render'); const /** @type {?} */ columns = []; for (let /** @type {?} */ i = 0; i < settings.length; i++) { if (settings[i].visible !== false && settings[i].enabled !== false) { columns.push(settings[i].objectKey); } } for (let /** @type {?} */ i = 0; i < fields.length; i++) { // console.log(!row[fields[i].objectKey]); if (fields[i].value && typeof fields[i].value === 'function' && !row.hasOwnProperty(fields[i].objectKey)) { row[fields[i].objectKey] = loading ? '' : fields[i].value(row); } } // console.log(row); const /** @type {?} */ keys = []; for (const /** @type {?} */ key in row) { // console.log(key); if (columns.indexOf(key) !== -1) { let /** @type {?} */ fieldSetting; for (let /** @type {?} */ i = 0; i < fields.length; i++) { if (fields[i].objectKey === key) { fieldSetting = fields[i]; // console.log(fieldSetting); } } const /** @type {?} */ columnObject = { objectKey: key, sortValue: row[key] }; // add component if defined if (fieldSetting.columnComponent) { columnObject.columnComponent = fieldSetting.columnComponent; } if (loading) { columnObject.renderValue = row[key] !== null ? row[key] : ''; } else if (highlight && searchString && this.getProperty(settings, key).search !== false) { columnObject.renderValue = fieldSetting.render && typeof fieldSetting.render === 'function' ? this.gtHighlightPipe.transform(fieldSetting.render(row), searchString) : this.gtHighlightPipe.transform(row[key] !== null ? row[key] : '', searchString); } else { columnObject.renderValue = fieldSetting.render && typeof fieldSetting.render === 'function' ? this.sanitizer.bypassSecurityTrustHtml(fieldSetting.render(row)) : row[key] !== null ? row[key] : ''; } if (fieldSetting.click && typeof fieldSetting.click === 'function') { columnObject.click = fieldSetting.click; } if (fieldSetting.expand) { columnObject.expand = fieldSetting.expand; } keys.push(columnObject); } } keys.sort(function (a, b) { return columns.indexOf(a.objectKey) < columns.indexOf(b.objectKey) ? -1 : 1; }); return keys; } } GtRenderPipe.decorators = [ { type: Pipe, args: [{ name: 'gtRender' },] }, ]; /** @nocollapse */ GtRenderPipe.ctorParameters = () => [ { type: DomSanitizer, }, { type: GtHighlightPipe, }, ]; function GtRenderPipe_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ GtRenderPipe.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ GtRenderPipe.ctorParameters; /** * Sort by column order * @type {?} */ GtRenderPipe.prototype.getColumnOrder; /** * Sort by length * @type {?} */ GtRenderPipe.prototype.getOrderByLength; /** * Return property * @type {?} */ GtRenderPipe.prototype.getProperty; /** @type {?} */ GtRenderPipe.prototype.sanitizer; /** @type {?} */ GtRenderPipe.prototype.gtHighlightPipe; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gt-render.pipe.js","sourceRoot":"ng://@angular-generic-table/core/","sources":["pipes/gt-render.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { GtConfigSetting } from '../interfaces/gt-config-setting';\nimport { GtConfigField } from '../interfaces/gt-config-field';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { GtRow } from '../interfaces/gt-row';\nimport { GtRenderField } from '../interfaces/gt-render-field';\nimport { GtHighlightPipe } from './gt-highlight.pipe';\n\n@Pipe({\n\tname: 'gtRender'\n})\nexport class GtRenderPipe<R extends GtRow> implements PipeTransform {\n\tconstructor(\n\t\tprivate sanitizer: DomSanitizer,\n\t\tprivate gtHighlightPipe: GtHighlightPipe\n\t) {}\n\n\t// TODO: move to helper functions\n\t/** Sort by column order */\n\tprivate getColumnOrder = function(a: GtConfigSetting, b: GtConfigSetting) {\n\t\tif (a.columnOrder < b.columnOrder) {\n\t\t\treturn -1;\n\t\t}\n\t\tif (a.columnOrder > b.columnOrder || typeof a.columnOrder === 'undefined') {\n\t\t\treturn 1;\n\t\t}\n\t\treturn 0;\n\t};\n\n\t/** Sort by length */\n\tprivate getOrderByLength = function(a: any, b: any) {\n\t\treturn b.length - a.length;\n\t};\n\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\trow: any,\n\t\tsettings: Array<GtConfigSetting>,\n\t\tfields: Array<GtConfigField<R, any>>,\n\t\tupdated: boolean,\n\t\tloading: boolean,\n\t\thighlight: boolean = false,\n\t\tsearchString?: string\n\t): Array<GtRenderField<R, any>> {\n\t\t// let arr = [{\"temp\":123,\"name\":\"happy\"},{\"temp\":456,\"name\":\"dfgdfg\"},{\"temp\":789,\"name\":\"asdasd\"}];\n\t\t// console.log(arr,arr.map(function(item){return item.temp}));\n\t\t// console.log(settings.map('objectKey'));\n\n\t\t// console.log('render');\n\t\tconst columns: Array<string> = [];\n\t\tfor (let i = 0; i < settings.length; i++) {\n\t\t\tif (settings[i].visible !== false && settings[i].enabled !== false) {\n\t\t\t\tcolumns.push(settings[i].objectKey);\n\t\t\t}\n\t\t}\n\n\t\tfor (let i = 0; i < fields.length; i++) {\n\t\t\t// console.log(!row[fields[i].objectKey]);\n\t\t\tif (\n\t\t\t\tfields[i].value &&\n\t\t\t\ttypeof fields[i].value === 'function' &&\n\t\t\t\t!row.hasOwnProperty(fields[i].objectKey)\n\t\t\t) {\n\t\t\t\trow[fields[i].objectKey] = loading ? '' : fields[i].value(row);\n\t\t\t}\n\t\t}\n\t\t// console.log(row);\n\t\tconst keys: Array<any> = [];\n\t\tfor (const key in row) {\n\t\t\t// console.log(key);\n\t\t\tif (columns.indexOf(key) !== -1) {\n\t\t\t\tlet fieldSetting;\n\t\t\t\tfor (let i = 0; i < fields.length; i++) {\n\t\t\t\t\tif (fields[i].objectKey === key) {\n\t\t\t\t\t\tfieldSetting = fields[i];\n\t\t\t\t\t\t// console.log(fieldSetting);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst columnObject: GtRenderField<R, any> = {\n\t\t\t\t\tobjectKey: key,\n\t\t\t\t\tsortValue: row[key]\n\t\t\t\t};\n\n\t\t\t\t// add component if defined\n\t\t\t\tif (fieldSetting.columnComponent) {\n\t\t\t\t\tcolumnObject.columnComponent = fieldSetting.columnComponent;\n\t\t\t\t}\n\n\t\t\t\tif (loading) {\n\t\t\t\t\tcolumnObject.renderValue = row[key] !== null ? row[key] : '';\n\t\t\t\t} else if (\n\t\t\t\t\thighlight &&\n\t\t\t\t\tsearchString &&\n\t\t\t\t\tthis.getProperty(settings, key).search !== false\n\t\t\t\t) {\n\t\t\t\t\tcolumnObject.renderValue =\n\t\t\t\t\t\tfieldSetting.render && typeof fieldSetting.render === 'function'\n\t\t\t\t\t\t\t? this.gtHighlightPipe.transform(\n\t\t\t\t\t\t\t\t\tfieldSetting.render(row),\n\t\t\t\t\t\t\t\t\tsearchString\n\t\t\t\t\t\t\t  )\n\t\t\t\t\t\t\t: this.gtHighlightPipe.transform(\n\t\t\t\t\t\t\t\t\trow[key] !== null ? row[key] : '',\n\t\t\t\t\t\t\t\t\tsearchString\n\t\t\t\t\t\t\t  );\n\t\t\t\t} else {\n\t\t\t\t\tcolumnObject.renderValue =\n\t\t\t\t\t\tfieldSetting.render && typeof fieldSetting.render === 'function'\n\t\t\t\t\t\t\t? this.sanitizer.bypassSecurityTrustHtml(fieldSetting.render(row))\n\t\t\t\t\t\t\t: row[key] !== null\n\t\t\t\t\t\t\t\t? row[key]\n\t\t\t\t\t\t\t\t: '';\n\t\t\t\t}\n\n\t\t\t\tif (fieldSetting.click && typeof fieldSetting.click === 'function') {\n\t\t\t\t\tcolumnObject.click = fieldSetting.click;\n\t\t\t\t}\n\t\t\t\tif (fieldSetting.expand) {\n\t\t\t\t\tcolumnObject.expand = fieldSetting.expand;\n\t\t\t\t}\n\n\t\t\t\tkeys.push(columnObject);\n\t\t\t}\n\t\t}\n\n\t\tkeys.sort(function(a: any, b: any) {\n\t\t\treturn columns.indexOf(a.objectKey) < columns.indexOf(b.objectKey)\n\t\t\t\t? -1\n\t\t\t\t: 1;\n\t\t});\n\t\treturn keys;\n\t}\n}\n"]}