@angular-generic-table/core
Version:
A generic table component for Angular
173 lines (172 loc) • 17.6 kB
JavaScript
/**
* @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"]}