rb-data-table
Version:
Angular Smart Table
64 lines • 3.42 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, ViewChild, ViewContainerRef, } from '@angular/core';
import { EditCellDefault } from './edit-cell-default';
var CustomEditComponent = /** @class */ (function (_super) {
__extends(CustomEditComponent, _super);
function CustomEditComponent(resolver) {
var _this = _super.call(this) || this;
_this.resolver = resolver;
return _this;
}
CustomEditComponent.prototype.ngOnChanges = function (changes) {
var _this = this;
if (this.cell && !this.customComponent) {
var componentFactory = this.resolver.resolveComponentFactory(this.cell.getColumn().editor.component);
this.customComponent = this.dynamicTarget.createComponent(componentFactory);
// set @Inputs and @Outputs of custom component
this.customComponent.instance.cell = this.cell;
this.customComponent.instance.inputClass = this.inputClass;
this.customComponent.instance.onStopEditing.subscribe(function () { return _this.onStopEditing(); });
this.customComponent.instance.onEdited.subscribe(function (event) { return _this.onEdited(event); });
this.customComponent.instance.onClick.subscribe(function (event) { return _this.onClick(event); });
}
};
CustomEditComponent.prototype.ngOnDestroy = function () {
if (this.customComponent) {
this.customComponent.destroy();
}
};
__decorate([
ViewChild('dynamicTarget', { read: ViewContainerRef }),
__metadata("design:type", Object)
], CustomEditComponent.prototype, "dynamicTarget", void 0);
CustomEditComponent = __decorate([
Component({
selector: 'table-cell-custom-editor',
template: "\n <ng-template #dynamicTarget></ng-template>\n ",
}),
__metadata("design:paramtypes", [ComponentFactoryResolver])
], CustomEditComponent);
return CustomEditComponent;
}(EditCellDefault));
export { CustomEditComponent };
//# sourceMappingURL=custom-edit.component.js.map