AngularLoader.ts 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import angular from 'angular';
  2. import coreModule from 'app/core/core_module';
  3. import _ from 'lodash';
  4. export interface AngularComponent {
  5. destroy();
  6. digest();
  7. getScope();
  8. }
  9. export class AngularLoader {
  10. /** @ngInject */
  11. constructor(private $compile, private $rootScope) {}
  12. load(elem, scopeProps, template): AngularComponent {
  13. const scope = this.$rootScope.$new();
  14. _.assign(scope, scopeProps);
  15. const compiledElem = this.$compile(template)(scope);
  16. const rootNode = angular.element(elem);
  17. rootNode.append(compiledElem);
  18. return {
  19. destroy: () => {
  20. scope.$destroy();
  21. compiledElem.remove();
  22. },
  23. digest: () => {
  24. if (!scope.$$phase) {
  25. scope.$digest();
  26. }
  27. },
  28. getScope: () => {
  29. return scope;
  30. },
  31. };
  32. }
  33. }
  34. coreModule.service('angularLoader', AngularLoader);
  35. let angularLoaderInstance: AngularLoader;
  36. export function setAngularLoader(pl: AngularLoader) {
  37. angularLoaderInstance = pl;
  38. }
  39. // away to access it from react
  40. export function getAngularLoader(): AngularLoader {
  41. return angularLoaderInstance;
  42. }