rb-data-table
Version:
Angular Smart Table
71 lines • 3.57 kB
JavaScript
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
import { Component, ComponentFactoryResolver, Input, ViewChild, ViewContainerRef } from '@angular/core';
import { FilterDefault } from './filter-default';
var CustomFilterComponent = /** @class */ (function (_super) {
__extends(CustomFilterComponent, _super);
function CustomFilterComponent(resolver) {
var _this = _super.call(this) || this;
_this.resolver = resolver;
return _this;
}
CustomFilterComponent.prototype.ngOnChanges = function (changes) {
var _this = this;
if (this.column && !this.customComponent) {
var componentFactory = this.resolver.resolveComponentFactory(this.column.filter.component);
this.customComponent = this.dynamicTarget.createComponent(componentFactory);
// set @Inputs and @Outputs of custom component
this.customComponent.instance.query = this.query;
this.customComponent.instance.column = this.column;
this.customComponent.instance.source = this.source;
this.customComponent.instance.inputClass = this.inputClass;
this.customComponent.instance.filter.subscribe(function (event) { return _this.onFilter(event); });
}
if (this.customComponent) {
this.customComponent.instance.ngOnChanges(changes);
}
};
CustomFilterComponent.prototype.ngOnDestroy = function () {
if (this.customComponent) {
this.customComponent.destroy();
}
};
__decorate([
Input(),
__metadata("design:type", String)
], CustomFilterComponent.prototype, "query", void 0);
__decorate([
ViewChild('dynamicTarget', { read: ViewContainerRef }),
__metadata("design:type", Object)
], CustomFilterComponent.prototype, "dynamicTarget", void 0);
CustomFilterComponent = __decorate([
Component({
selector: 'custom-table-filter',
template: "<ng-template #dynamicTarget></ng-template>",
}),
__metadata("design:paramtypes", [ComponentFactoryResolver])
], CustomFilterComponent);
return CustomFilterComponent;
}(FilterDefault));
export { CustomFilterComponent };
//# sourceMappingURL=custom-filter.component.js.map