plugin_loader.ts 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. import System from 'systemjs/dist/system.js';
  2. import _ from 'lodash';
  3. import * as sdk from 'app/plugins/sdk';
  4. import kbn from 'app/core/utils/kbn';
  5. import moment from 'moment';
  6. import angular from 'angular';
  7. import jquery from 'jquery';
  8. import config from 'app/core/config';
  9. import TimeSeries from 'app/core/time_series2';
  10. import * as graphitePlugin from 'app/plugins/datasource/graphite/module';
  11. import * as cloudwatchPlugin from 'app/plugins/datasource/cloudwatch/module';
  12. import * as elasticsearchPlugin from 'app/plugins/datasource/elasticsearch/module';
  13. import * as opentsdbPlugin from 'app/plugins/datasource/opentsdb/module';
  14. import * as grafanaPlugin from 'app/plugins/datasource/grafana/module';
  15. import * as influxdbPlugin from 'app/plugins/datasource/influxdb/module';
  16. import * as mixedPlugin from 'app/plugins/datasource/mixed/module';
  17. import * as mysqlPlugin from 'app/plugins/datasource/mysql/module';
  18. import * as prometheusPlugin from 'app/plugins/datasource/prometheus/module';
  19. import * as textPanel from 'app/plugins/panel/text/module';
  20. import * as graphPanel from 'app/plugins/panel/graph/module';
  21. import * as dashListPanel from 'app/plugins/panel/dashlist/module';
  22. import * as pluginsListPanel from 'app/plugins/panel/pluginlist/module';
  23. import * as alertListPanel from 'app/plugins/panel/alertlist/module';
  24. import * as heatmapPanel from 'app/plugins/panel/heatmap/module';
  25. import * as tablePanel from 'app/plugins/panel/table/module';
  26. import * as singlestatPanel from 'app/plugins/panel/singlestat/module';
  27. import * as gettingStartedPanel from 'app/plugins/panel/gettingstarted/module';
  28. import * as testDataAppPlugin from 'app/plugins/app/testdata/module';
  29. import * as testDataDSPlugin from 'app/plugins/app/testdata/datasource/module';
  30. let builtInPlugins = {
  31. "app/plugins/datasource/graphite/module": graphitePlugin,
  32. "app/plugins/datasource/cloudwatch/module": cloudwatchPlugin,
  33. "app/plugins/datasource/elasticsearch/module": elasticsearchPlugin,
  34. "app/plugins/datasource/opentsdb/module": opentsdbPlugin,
  35. "app/plugins/datasource/grafana/module": grafanaPlugin,
  36. "app/plugins/datasource/influxdb/module": influxdbPlugin,
  37. "app/plugins/datasource/mixed/module": mixedPlugin,
  38. "app/plugins/datasource/mysql/module": mysqlPlugin,
  39. "app/plugins/datasource/prometheus/module": prometheusPlugin,
  40. "app/plugins/app/testdata/module": testDataAppPlugin,
  41. "app/plugins/app/testdata/datasource/module": testDataDSPlugin,
  42. "app/plugins/panel/text/module": textPanel,
  43. "app/plugins/panel/graph/module": graphPanel,
  44. "app/plugins/panel/dashlist/module": dashListPanel,
  45. "app/plugins/panel/pluginlist/module": pluginsListPanel,
  46. "app/plugins/panel/alertlist/module": alertListPanel,
  47. "app/plugins/panel/heatmap/module": heatmapPanel,
  48. "app/plugins/panel/table/module": tablePanel,
  49. "app/plugins/panel/singlestat/module": singlestatPanel,
  50. "app/plugins/panel/gettingstarted/module": gettingStartedPanel,
  51. };
  52. System.config({
  53. baseURL: 'public',
  54. defaultExtension: 'js',
  55. packages: {
  56. 'plugins': {
  57. defaultExtension: 'js'
  58. }
  59. },
  60. map: {
  61. text: 'vendor/plugin-text/text.js',
  62. css: 'vendor/plugin-css/css.js'
  63. },
  64. });
  65. // add cache busting
  66. var systemLocate = System.locate;
  67. System.cacheBust = '?bust=' + Date.now();
  68. System.locate = function(load) {
  69. var System = this;
  70. return Promise.resolve(systemLocate.call(this, load)).then(function(address) {
  71. return address + System.cacheBust;
  72. });
  73. };
  74. System.registerDynamic('lodash', [], true, function(require, exports, module) { module.exports = _; });
  75. System.registerDynamic('moment', [], true, function(require, exports, module) { module.exports = moment; });
  76. System.registerDynamic('jquery', [], true, function(require, exports, module) { module.exports = jquery; });
  77. System.registerDynamic('angular', [], true, function(require, exports, module) { module.exports = angular; });
  78. System.registerDynamic('app/plugins/sdk', [], true, function(require, exports, module) { module.exports = sdk; });
  79. System.registerDynamic('app/core/utils/kbn', [], true, function(require, exports, module) { module.exports = kbn; });
  80. System.registerDynamic('app/core/config', [], true, function(require, exports, module) { module.exports = config; });
  81. System.registerDynamic('app/core/time_series', [], true, function(require, exports, module) { module.exports = TimeSeries; });
  82. System.registerDynamic('app/core/time_series2', [], true, function(require, exports, module) { module.exports = TimeSeries; });
  83. import 'vendor/flot/jquery.flot';
  84. import 'vendor/flot/jquery.flot.selection';
  85. import 'vendor/flot/jquery.flot.time';
  86. import 'vendor/flot/jquery.flot.stack';
  87. import 'vendor/flot/jquery.flot.pie';
  88. import 'vendor/flot/jquery.flot.stackpercent';
  89. import 'vendor/flot/jquery.flot.fillbelow';
  90. import 'vendor/flot/jquery.flot.crosshair';
  91. import 'vendor/flot/jquery.flot.dashes';
  92. for (let flotDep of ['jquery.flot', 'jquery.flot.pie', 'jquery.flot.time']) {
  93. System.registerDynamic(flotDep, [], true, function(require, exports, module) { module.exports = {fakeDep: 1}; });
  94. }
  95. export function importPluginModule(path: string): Promise<any> {
  96. let builtIn = builtInPlugins[path];
  97. if (builtIn) {
  98. return Promise.resolve(builtIn);
  99. }
  100. return System.import(path);
  101. }
  102. export function loadPluginCss(options) {
  103. if (config.bootData.user.lightTheme) {
  104. System.import(options.light + '!css');
  105. } else {
  106. System.import(options.dark + '!css');
  107. }
  108. }