ng8 можно получить аннотации для компонента (свойства annotations, prop__metadata, __parameters__) в АОТ в декораторе?
пример декоратора ()
export function MyDecorator(value): Function {
return function decorate(){
const patchMethods = ['ngOnInit', 'ngOnChanges', 'ngAfterContentInit', 'ngAfterViewInit', 'ngOnDestroy'];
const Decorated = function ZoneDecoratedComponent(...args) {
return Original.apply(this, args);
};
// копируем конструктор, instanceof работает
Decorated.prototype = Original.prototype;
// копируем статические методы
Object.keys(Original).forEach((name: string) => {
Decorated[name] = (<any>Original)[name];
});
// патчим lifecycle hooks
patchMethods.forEach(method => {
const temp = Decorated.prototype[method];
if (temp) {
Decorated.prototype[method] = function(...args) {
return temp.apply(this, args);
};
}
});
// забираем зависимости конструктора, от которого наследуемся
const dependencies = Reflect.getOwnMetadata('design:paramtypes', Original);
Reflect.defineMetadata('design:paramtypes', dependencies, Decorated);
// копируем информацию об Input и Viewchild
//Работает только в JIT
Decorated.__prop__metadata__ = Original.__prop__metadata__;
return Decorated as any;
};
}
пример использования
@Component({ ... })
@MyDecorator('bla')
так вот, внутри декоратора хочу обернуть все методы (конструктор и lifecycle) компонента. при этом возвращаю новый конструктор. аннотации доступны только в JIT
Раньше так понимаю было что-то типа Reflect.getOwnMetadata('annotations'), но ng team отказались от reflect api, и теперь чуда не случается. Кто-нибудь сталкивался?
Если используется Ivy, то в декоратор приходит ComponentDef — там есть все, что необходимо. Для доступа к Injector используйте inject из @angular/core.
Обсуждают сегодня