@ngx-performance-ui/core
Version:
Ngx Performance UI - Core
241 lines • 18.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Directive, Input, IterableDiffers, TemplateRef, ViewContainerRef, } from '@angular/core';
import { NgForOfContext } from '@angular/common';
import compare from 'just-compare';
/**
* @template T
*/
var /**
* @template T
*/
RecordViewTuple = /** @class */ (function () {
function RecordViewTuple(record, view) {
this.record = record;
this.view = view;
}
return RecordViewTuple;
}());
if (false) {
/** @type {?} */
RecordViewTuple.prototype.record;
/** @type {?} */
RecordViewTuple.prototype.view;
}
var ForDirective = /** @class */ (function () {
function ForDirective(iterable, tempRef, vcRef) {
this.iterable = iterable;
this.tempRef = tempRef;
this.vcRef = vcRef;
}
Object.defineProperty(ForDirective.prototype, "compareFn", {
get: /**
* @return {?}
*/
function () {
return this.compareBy || compare;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ForDirective.prototype, "containCompareFn", {
get: /**
* @return {?}
*/
function () {
return (this.containCompareBy ||
((/**
* @param {?} value
* @param {?} comparision
* @return {?}
*/
function (value, comparision) { return value.toLocaleLowerCase().indexOf(comparision.toLocaleLowerCase()) > -1; })));
},
enumerable: true,
configurable: true
});
Object.defineProperty(ForDirective.prototype, "trackByFn", {
get: /**
* @return {?}
*/
function () {
return this.trackBy || ((/**
* @param {?} index
* @param {?=} item
* @return {?}
*/
function (index, item) {
if (item === void 0) { item = {}; }
return item.id || index;
}));
},
enumerable: true,
configurable: true
});
/**
* @private
* @param {?} changes
* @param {?} items
* @return {?}
*/
ForDirective.prototype.applyChanges = /**
* @private
* @param {?} changes
* @param {?} items
* @return {?}
*/
function (changes, items) {
var _this = this;
/** @type {?} */
var insertTuples = [];
changes.forEachOperation((/**
* @param {?} item
* @param {?} adjustedPreviousIndex
* @param {?} currentIndex
* @return {?}
*/
function (item, adjustedPreviousIndex, currentIndex) {
if (item.previousIndex == null) {
/** @type {?} */
var view = _this.vcRef.createEmbeddedView(_this.tempRef, new NgForOfContext((/** @type {?} */ (null)), items, -1, -1), currentIndex);
/** @type {?} */
var tuple = new RecordViewTuple(item, view);
insertTuples.push(tuple);
}
else if (currentIndex == null) {
_this.vcRef.remove(adjustedPreviousIndex);
}
else {
/** @type {?} */
var view = (/** @type {?} */ (_this.vcRef.get(adjustedPreviousIndex)));
_this.vcRef.move(view, currentIndex);
/** @type {?} */
var tuple = new RecordViewTuple(item, (/** @type {?} */ (view)));
insertTuples.push(tuple);
}
}));
for (var i = 0; i < insertTuples.length; i++) {
insertTuples[i].view.context.$implicit = insertTuples[i].record.item;
}
for (var i = 0, ilen = this.vcRef.length; i < ilen; i++) {
/** @type {?} */
var viewRef = (/** @type {?} */ (this.vcRef.get(i)));
viewRef.context.index = i;
viewRef.context.count = ilen;
viewRef.context.ngForOf = items;
}
changes.forEachIdentityChange((/**
* @param {?} record
* @return {?}
*/
function (record) {
/** @type {?} */
var viewRef = (/** @type {?} */ (_this.vcRef.get(record.currentIndex)));
viewRef.context.$implicit = record.item;
}));
};
/**
* @return {?}
*/
ForDirective.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
var _this = this;
if (!Array.isArray(this.items))
throw 'pForOf must be an array!';
/** @type {?} */
var items = [];
if (this.filterValue !== undefined) {
/** @type {?} */
var compareFn_1;
if (this.filterContain) {
if (typeof this.filterValue !== 'string') {
throw 'filterValue must be a string when filterContain is true';
}
compareFn_1 = this.containCompareFn;
}
else {
compareFn_1 = this.compareFn;
}
items = this.items.filter((/**
* @param {?} item
* @return {?}
*/
function (item) { return compareFn_1(_this.filterKey ? item[_this.filterKey] : item, _this.filterValue); }));
}
else {
items = this.items;
}
if (!this.iterableDiffer && items) {
this.iterableDiffer = this.iterable.find(items).create(this.trackByFn);
}
if (this.iterableDiffer) {
/** @type {?} */
var changes = this.iterableDiffer.diff(items);
if (changes)
this.applyChanges(changes, items);
}
};
ForDirective.decorators = [
{ type: Directive, args: [{
selector: '[pFor]',
},] }
];
/** @nocollapse */
ForDirective.ctorParameters = function () { return [
{ type: IterableDiffers },
{ type: TemplateRef },
{ type: ViewContainerRef }
]; };
ForDirective.propDecorators = {
items: [{ type: Input, args: ['pForOf',] }],
trackBy: [{ type: Input, args: ['pForTrackBy',] }],
filterKey: [{ type: Input, args: ['pForFilterKey',] }],
filterValue: [{ type: Input, args: ['pForFilterValue',] }],
filterContain: [{ type: Input, args: ['pForFilterContain',] }],
compareBy: [{ type: Input, args: ['pForCompareBy',] }],
containCompareBy: [{ type: Input, args: ['pForContainCompareBy',] }]
};
return ForDirective;
}());
export { ForDirective };
if (false) {
/** @type {?} */
ForDirective.prototype.items;
/** @type {?} */
ForDirective.prototype.trackBy;
/** @type {?} */
ForDirective.prototype.filterKey;
/** @type {?} */
ForDirective.prototype.filterValue;
/** @type {?} */
ForDirective.prototype.filterContain;
/** @type {?} */
ForDirective.prototype.compareBy;
/** @type {?} */
ForDirective.prototype.containCompareBy;
/**
* @type {?}
* @private
*/
ForDirective.prototype.iterableDiffer;
/**
* @type {?}
* @private
*/
ForDirective.prototype.iterable;
/**
* @type {?}
* @private
*/
ForDirective.prototype.tempRef;
/**
* @type {?}
* @private
*/
ForDirective.prototype.vcRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"for.directive.js","sourceRoot":"ng://@ngx-performance-ui/core/","sources":["lib/directives/for.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  EmbeddedViewRef,\n  Input,\n  IterableChangeRecord,\n  IterableDiffer,\n  IterableDiffers,\n  TemplateRef,\n  TrackByFunction,\n  ViewContainerRef,\n  IterableChanges,\n} from '@angular/core';\nimport { NgForOfContext } from '@angular/common';\nimport compare from 'just-compare';\n\nexport type CompareFn<T = any> = (value: T, comparison: T) => boolean;\n\nclass RecordViewTuple<T> {\n  constructor(public record: any, public view: EmbeddedViewRef<NgForOfContext<T>>) {}\n}\n\n@Directive({\n  selector: '[pFor]',\n})\nexport class ForDirective {\n  @Input('pForOf')\n  items: any[];\n\n  @Input('pForTrackBy')\n  trackBy: TrackByFunction<any>;\n\n  @Input('pForFilterKey')\n  filterKey: string;\n\n  @Input('pForFilterValue')\n  filterValue: any;\n\n  @Input('pForFilterContain')\n  filterContain: boolean;\n\n  @Input('pForCompareBy')\n  compareBy: CompareFn;\n\n  @Input('pForContainCompareBy')\n  containCompareBy: CompareFn;\n\n  get compareFn(): CompareFn {\n    return this.compareBy || compare;\n  }\n\n  get containCompareFn(): CompareFn {\n    return (\n      this.containCompareBy ||\n      ((value, comparision) => value.toLocaleLowerCase().indexOf(comparision.toLocaleLowerCase()) > -1)\n    );\n  }\n\n  get trackByFn(): TrackByFunction<any> {\n    return this.trackBy || ((index, item = {}) => item.id || index);\n  }\n\n  private iterableDiffer: IterableDiffer<any>;\n\n  constructor(private iterable: IterableDiffers, private tempRef: TemplateRef<any>, private vcRef: ViewContainerRef) {}\n\n  private applyChanges(changes: IterableChanges<any>, items: any[]) {\n    const insertTuples: RecordViewTuple<any>[] = [];\n    changes.forEachOperation((item: IterableChangeRecord<any>, adjustedPreviousIndex: number, currentIndex: number) => {\n      if (item.previousIndex == null) {\n        const view = this.vcRef.createEmbeddedView(\n          this.tempRef,\n          new NgForOfContext<any>(null!, items, -1, -1),\n          currentIndex,\n        );\n        const tuple = new RecordViewTuple<any>(item, view);\n        insertTuples.push(tuple);\n      } else if (currentIndex == null) {\n        this.vcRef.remove(adjustedPreviousIndex);\n      } else {\n        const view = this.vcRef.get(adjustedPreviousIndex)!;\n        this.vcRef.move(view, currentIndex);\n        const tuple = new RecordViewTuple(item, <EmbeddedViewRef<NgForOfContext<any>>>view);\n        insertTuples.push(tuple);\n      }\n    });\n\n    for (let i = 0; i < insertTuples.length; i++) {\n      insertTuples[i].view.context.$implicit = insertTuples[i].record.item;\n    }\n\n    for (let i = 0, ilen = this.vcRef.length; i < ilen; i++) {\n      const viewRef = <EmbeddedViewRef<NgForOfContext<any>>>this.vcRef.get(i);\n      viewRef.context.index = i;\n      viewRef.context.count = ilen;\n      viewRef.context.ngForOf = items;\n    }\n\n    changes.forEachIdentityChange((record: any) => {\n      const viewRef = <EmbeddedViewRef<NgForOfContext<any>>>this.vcRef.get(record.currentIndex);\n      viewRef.context.$implicit = record.item;\n    });\n  }\n\n  ngOnChanges() {\n    if (!Array.isArray(this.items)) throw 'pForOf must be an array!';\n\n    let items = [];\n    if (this.filterValue !== undefined) {\n      let compareFn: CompareFn;\n      if (this.filterContain) {\n        if (typeof this.filterValue !== 'string') {\n          throw 'filterValue must be a string when filterContain is true';\n        }\n\n        compareFn = this.containCompareFn;\n      } else {\n        compareFn = this.compareFn;\n      }\n\n      items = this.items.filter(item => compareFn(this.filterKey ? item[this.filterKey] : item, this.filterValue));\n    } else {\n      items = this.items;\n    }\n\n    if (!this.iterableDiffer && items) {\n      this.iterableDiffer = this.iterable.find(items).create(this.trackByFn);\n    }\n    if (this.iterableDiffer) {\n      const changes = this.iterableDiffer.diff(items);\n      if (changes) this.applyChanges(changes, items);\n    }\n  }\n}\n"]}