diff --git a/src/core_plugins/region_map/public/region_map_controller.js b/src/core_plugins/region_map/public/region_map_controller.js index 42bd4df53447d..f0422f9000e51 100644 --- a/src/core_plugins/region_map/public/region_map_controller.js +++ b/src/core_plugins/region_map/public/region_map_controller.js @@ -9,11 +9,15 @@ import AggResponsePointSeriesTooltipFormatterProvider from './tooltip_formatter' import { ResizeCheckerProvider } from 'ui/resize_checker'; import 'ui/vis_maps/lib/service_settings'; - const module = uiModules.get('kibana/region_map', ['kibana']); module.controller('KbnRegionMapController', function ($scope, $element, Private, Notifier, getAppState, serviceSettings, config) { + const DEFAULT_ZOOM_SETTINGS = { + zoom: 2, + mapCenter: [0, 0] + }; + const tooltipFormatter = Private(AggResponsePointSeriesTooltipFormatterProvider); const ResizeChecker = Private(ResizeCheckerProvider); const notify = new Notifier({ location: 'Region map' }); @@ -90,10 +94,19 @@ module.controller('KbnRegionMapController', function ($scope, $element, Private, async function makeKibanaMap() { const tmsSettings = await serviceSettings.getTMSService(); const minMaxZoom = tmsSettings.getMinMaxZoom(false); - kibanaMap = new KibanaMap($element[0], minMaxZoom); - const url = tmsSettings.getUrl(); - const options = tmsSettings.getTMSOptions(); - kibanaMap.setBaseLayer({ baseLayerType: 'tms', options: { url, ...options } }); + + const options = { ...minMaxZoom }; + const uiState = $scope.vis.getUiState(); + const zoomFromUiState = parseInt(uiState.get('mapZoom')); + const centerFromUIState = uiState.get('mapCenter'); + options.zoom = !isNaN(zoomFromUiState) ? zoomFromUiState : DEFAULT_ZOOM_SETTINGS.zoom; + options.center = centerFromUIState ? centerFromUIState : DEFAULT_ZOOM_SETTINGS.mapCenter; + kibanaMap = new KibanaMap($element[0], options); + + + const tmsUrl = tmsSettings.getUrl(); + const tmsOptions = tmsSettings.getTMSOptions(); + kibanaMap.setBaseLayer({ baseLayerType: 'tms', options: { tmsUrl, ...tmsOptions } }); kibanaMap.addLegendControl(); kibanaMap.addFitControl(); kibanaMap.persistUiStateForVisualization($scope.vis);