grafana/public/app/angular/services/dynamic_directive_srv.ts
Torkel Ödegaard d07fa0ce5e
AngularJS: Move angular stuff into app/angular (#41415)
* Moving more angular parts

* Moving more angular stuff

* Moving components

* Move more things
2021-11-08 18:41:04 +01:00

56 lines
1.5 KiB
TypeScript

import angular from 'angular';
import coreModule from '../../core/core_module';
class DynamicDirectiveSrv {
/** @ngInject */
constructor(private $compile: angular.ICompileService) {}
addDirective(element: any, name: string, scope: any) {
const child = angular.element(document.createElement(name));
this.$compile(child)(scope);
element.empty();
element.append(child);
}
link(scope: any, elem: JQLite, attrs: any, options: any) {
const directiveInfo = options.directive(scope);
if (!directiveInfo || !directiveInfo.fn) {
elem.empty();
return;
}
if (!directiveInfo.fn.registered) {
coreModule.directive(attrs.$normalize(directiveInfo.name), directiveInfo.fn);
directiveInfo.fn.registered = true;
}
this.addDirective(elem, directiveInfo.name, scope);
}
create(options: any) {
const directiveDef = {
restrict: 'E',
scope: options.scope,
link: (scope: any, elem: JQLite, attrs: any) => {
if (options.watchPath) {
let childScope: any = null;
scope.$watch(options.watchPath, () => {
if (childScope) {
childScope.$destroy();
}
childScope = scope.$new();
this.link(childScope, elem, attrs, options);
});
} else {
this.link(scope, elem, attrs, options);
}
},
};
return directiveDef;
}
}
coreModule.service('dynamicDirectiveSrv', DynamicDirectiveSrv);