UNPKG

@ngx-performance-ui/core

Version:
241 lines 18.4 kB
/** * @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"]}