grafana/public/app/angular/services/dynamic_directive_srv.ts
Josh Hunt 3c6e0e8ef8
Chore: ESlint import order (#44959)
* Add and configure eslint-plugin-import

* Fix the lint:ts npm command

* Autofix + prettier all the files

* Manually fix remaining files

* Move jquery code in jest-setup to external file to safely reorder imports

* Resolve issue caused by circular dependencies within Prometheus

* Update .betterer.results

* Fix missing // @ts-ignore

* ignore iconBundle.ts

* Fix missing // @ts-ignore
2022-04-22 14:33:13 +01:00

57 lines
1.5 KiB
TypeScript

import angular from 'angular';
import coreModule from '../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);