diff --git a/x-pack/plugins/monitoring/public/angular/helpers/routes.ts b/x-pack/plugins/monitoring/public/angular/helpers/routes.ts index 176b7f154d253..b9307e8594a7a 100644 --- a/x-pack/plugins/monitoring/public/angular/helpers/routes.ts +++ b/x-pack/plugins/monitoring/public/angular/helpers/routes.ts @@ -11,7 +11,7 @@ interface Redirect { class Routes { private routes: RouteObject[] = []; - private redirect?: Redirect; + public redirect?: Redirect = { redirectTo: '/no-data' }; public when = (...args: RouteObject) => { const [, routeOptions] = args; diff --git a/x-pack/plugins/monitoring/public/angular/index.ts b/x-pack/plugins/monitoring/public/angular/index.ts index 6aba3339db95f..b371503fdb7c9 100644 --- a/x-pack/plugins/monitoring/public/angular/index.ts +++ b/x-pack/plugins/monitoring/public/angular/index.ts @@ -12,7 +12,7 @@ import { localAppModule, appModuleName } from './app_modules'; import { MonitoringPluginDependencies } from '../types'; -const SAFARI_FIX = 'kbnLocalApplicationWrapper'; +const APP_WRAPPER_CLASS = 'monitoringApplicationWrapper'; export class AngularApp { private injector?: angular.auto.IInjectorService; @@ -41,11 +41,10 @@ export class AngularApp { configureAppAngularModule(app, np, true); const appElement = document.createElement('div'); appElement.setAttribute('style', 'height: 100%'); - appElement.setAttribute('class', SAFARI_FIX); - appElement.innerHTML = `
`; + appElement.innerHTML = ''; - if (!element.classList.contains(SAFARI_FIX)) { - element.classList.add(SAFARI_FIX); + if (!element.classList.contains(APP_WRAPPER_CLASS)) { + element.classList.add(APP_WRAPPER_CLASS); } angular.bootstrap(appElement, [appModuleName]); @@ -57,4 +56,13 @@ export class AngularApp { this.injector.get('$rootScope').$destroy(); } }; + + public applyScope = () => { + if (!this.injector) { + return; + } + + const rootScope = this.injector.get('$rootScope'); + rootScope.$applyAsync(); + }; } diff --git a/x-pack/plugins/monitoring/public/index.scss b/x-pack/plugins/monitoring/public/index.scss index af1f1c92240ac..4dda80ee7454b 100644 --- a/x-pack/plugins/monitoring/public/index.scss +++ b/x-pack/plugins/monitoring/public/index.scss @@ -21,4 +21,10 @@ @import 'components/logstash/pipeline_viewer/views/index'; @import 'components/elasticsearch/shard_allocation/index'; @import 'components/setup_mode/index'; -@import 'components/elasticsearch/ccr/index' +@import 'components/elasticsearch/ccr/index'; + +.monitoringApplicationWrapper { + display: flex; + flex-direction: column; + flex-grow: 1; +} diff --git a/x-pack/plugins/monitoring/public/plugin.ts b/x-pack/plugins/monitoring/public/plugin.ts index 14f3253d51155..6c50c6ae8b639 100644 --- a/x-pack/plugins/monitoring/public/plugin.ts +++ b/x-pack/plugins/monitoring/public/plugin.ts @@ -8,7 +8,6 @@ import './views/all'; import { i18n } from '@kbn/i18n'; import { App, - AppMountContext, AppMountParameters, CoreSetup, CoreStart, @@ -22,11 +21,11 @@ import { import { initAngularBootstrap } from '../../../../src/plugins/kibana_legacy/public'; import { DEFAULT_APP_CATEGORIES } from '../../../../src/core/utils'; import { MonitoringPluginDependencies, MonitoringConfig } from './types'; - import { MONITORING_CONFIG_ALERTING_EMAIL_ADDRESS, KIBANA_ALERTING_ENABLED, } from '../common/constants'; +import { uiRoutes } from './angular/helpers/routes'; export class MonitoringPlugin implements Plugin