app.ts 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. ///<reference path="headers/common.d.ts" />
  2. ///<amd-dependency path="bootstrap" />
  3. ///<amd-dependency path="angular-strap" />
  4. ///<amd-dependency path="angular-route" />
  5. ///<amd-dependency path="angular-sanitize" />
  6. ///<amd-dependency path="angular-dragdrop" />
  7. ///<amd-dependency path="angular-bindonce" />
  8. ///<amd-dependency path="angular-ui" />
  9. ///<amd-dependency path="app/core/core" />
  10. import 'es6-shim';
  11. import 'es6-promise';
  12. import _ = require('lodash');
  13. import $ = require('jquery');
  14. import bootstrap = require('bootstrap');
  15. import kbn = require('app/core/utils/kbn');
  16. import angular = require('angular');
  17. import config = require('app/core/config');
  18. class GrafanaApp {
  19. registerFunctions: any;
  20. ngModuleDependencies: any[];
  21. preBootModules: any[];
  22. useModule(module) {
  23. if (this.preBootModules) {
  24. this.preBootModules.push(module);
  25. } else {
  26. _.extend(module, this.registerFunctions);
  27. }
  28. this.ngModuleDependencies.push(module.name);
  29. return module;
  30. }
  31. init() {
  32. this.registerFunctions = {};
  33. this.preBootModules = [];
  34. var app = angular.module('grafana', []);
  35. app.constant('grafanaVersion', "@grafanaVersion@");
  36. app.config(($locationProvider, $controllerProvider, $compileProvider, $filterProvider, $provide) => {
  37. console.log('app config');
  38. this.registerFunctions.controller = $controllerProvider.register;
  39. this.registerFunctions.directive = $compileProvider.directive;
  40. this.registerFunctions.factory = $provide.factory;
  41. this.registerFunctions.service = $provide.service;
  42. this.registerFunctions.filter = $filterProvider.register;
  43. });
  44. this.ngModuleDependencies = [
  45. 'grafana.core',
  46. 'ngRoute',
  47. 'ngSanitize',
  48. '$strap.directives',
  49. 'ang-drag-drop',
  50. 'grafana',
  51. 'pasvaz.bindonce',
  52. 'ui.bootstrap.tabs',
  53. ];
  54. var module_types = ['controllers', 'directives', 'factories', 'services', 'filters', 'routes'];
  55. _.each(module_types, type => {
  56. var moduleName = 'grafana.' + type;
  57. this.useModule(angular.module(moduleName, []));
  58. });
  59. var preBootRequires = [System.import('app/features/all')];
  60. var pluginModules = config.bootData.pluginModules || [];
  61. // add plugin modules
  62. for (var i = 0; i < pluginModules.length; i++) {
  63. preBootRequires.push(System.import(pluginModules[i]));
  64. }
  65. Promise.all(preBootRequires).then(() => {
  66. // disable tool tip animation
  67. $.fn.tooltip.defaults.animation = false;
  68. // bootstrap the app
  69. angular.bootstrap(document, this.ngModuleDependencies).invoke(() => {
  70. _.each(this.preBootModules, module => {
  71. _.extend(module, this.registerFunctions);
  72. });
  73. this.preBootModules = null;
  74. });
  75. }).catch(function(err) {
  76. console.log('Application boot failed: ' + err);
  77. });
  78. }
  79. }
  80. var grafanaApp = new GrafanaApp();
  81. export = {
  82. init: function() {
  83. grafanaApp.init();
  84. },
  85. useModule: function(m) {
  86. grafanaApp.useModule(m);
  87. }
  88. };