diff --git a/x-pack/legacy/plugins/maps/public/angular/get_initial_layers.test.js b/x-pack/legacy/plugins/maps/public/angular/get_initial_layers.test.js index b15b94a49cebc..5dc08751347e4 100644 --- a/x-pack/legacy/plugins/maps/public/angular/get_initial_layers.test.js +++ b/x-pack/legacy/plugins/maps/public/angular/get_initial_layers.test.js @@ -44,7 +44,6 @@ describe('kibana.yml configured with map.tilemap.url', () => { expect(layers).toEqual([{ alpha: 1, __dataRequests: [], - __injectedData: null, id: layers[0].id, applyGlobalQuery: true, label: null, @@ -87,7 +86,6 @@ describe('EMS is enabled', () => { expect(layers).toEqual([{ alpha: 1, __dataRequests: [], - __injectedData: null, id: layers[0].id, applyGlobalQuery: true, label: null, diff --git a/x-pack/legacy/plugins/maps/public/layers/layer.js b/x-pack/legacy/plugins/maps/public/layers/layer.js index c8187fd83ee4d..45854b7b729f5 100644 --- a/x-pack/legacy/plugins/maps/public/layers/layer.js +++ b/x-pack/legacy/plugins/maps/public/layers/layer.js @@ -9,7 +9,6 @@ import { EuiIcon, EuiLoadingSpinner } from '@elastic/eui'; import turf from 'turf'; import turfBooleanContains from '@turf/boolean-contains'; import { DataRequest } from './util/data_request'; -import { InjectedData } from './util/injected_data'; import { MB_SOURCE_ID_LAYER_ID_PREFIX_DELIMITER, SOURCE_DATA_ID_ORIGIN @@ -32,11 +31,6 @@ export class AbstractLayer { } else { this._dataRequests = []; } - if (this._descriptor.__injectedData) { - this._injectedData = new InjectedData(this._descriptor.__injectedData); - } else { - this._injectedData = null; - } } static getBoundDataForSource(mbMap, sourceId) { @@ -48,7 +42,6 @@ export class AbstractLayer { const layerDescriptor = { ...options }; layerDescriptor.__dataRequests = _.get(options, '__dataRequests', []); - layerDescriptor.__injectedData = _.get(options, '__injectedData', null); layerDescriptor.id = _.get(options, 'id', uuid()); layerDescriptor.label = options.label && options.label.length > 0 ? options.label : null; layerDescriptor.minZoom = _.get(options, 'minZoom', 0); @@ -287,10 +280,6 @@ export class AbstractLayer { return this._dataRequests.find(dataRequest => dataRequest.getDataId() === id); } - getInjectedData() { - return this._injectedData ? this._injectedData.getData() : null; - } - isLayerLoading() { return this._dataRequests.some(dataRequest => dataRequest.isLoading()); } diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/client_file_source/geojson_file_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/client_file_source/geojson_file_source.js index cf876a59d0be4..59cfc7b486bdd 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/client_file_source/geojson_file_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/client_file_source/geojson_file_source.js @@ -35,9 +35,32 @@ export class GeojsonFileSource extends AbstractVectorSource { applyGlobalQuery: DEFAULT_APPLY_GLOBAL_QUERY } - static createDescriptor(name) { + static createDescriptor(geoJson, name) { + // Wrap feature as feature collection if needed + let featureCollection; + + if (!geoJson) { + featureCollection = { + type: 'FeatureCollection', + features: [] + }; + } else if (geoJson.type === 'FeatureCollection') { + featureCollection = geoJson; + } else if (geoJson.type === 'Feature') { + featureCollection = { + type: 'FeatureCollection', + features: [geoJson] + }; + } else { // Missing or incorrect type + featureCollection = { + type: 'FeatureCollection', + features: [] + }; + } + return { type: GeojsonFileSource.type, + __featureCollection: featureCollection, name }; } @@ -85,16 +108,9 @@ export class GeojsonFileSource extends AbstractVectorSource { onPreviewSource(null); return; } - const sourceDescriptor = GeojsonFileSource.createDescriptor(name); + const sourceDescriptor = GeojsonFileSource.createDescriptor(geojsonFile, name); const source = new GeojsonFileSource(sourceDescriptor, inspectorAdapters); - const featureCollection = (geojsonFile.type === 'Feature') - ? { - type: 'FeatureCollection', - features: [{ ...geojsonFile }] - } - : geojsonFile; - - onPreviewSource(source, { __injectedData: featureCollection }); + onPreviewSource(source); }; }; @@ -125,6 +141,22 @@ export class GeojsonFileSource extends AbstractVectorSource { ); } + async getGeoJsonWithMeta() { + const copiedPropsFeatures = this._descriptor.__featureCollection.features + .map(feature => ({ + type: 'Feature', + geometry: feature.geometry, + properties: feature.properties ? { ...feature.properties } : {} + })); + return { + data: { + type: 'FeatureCollection', + features: copiedPropsFeatures + }, + meta: {} + }; + } + async getDisplayName() { return this._descriptor.name; } @@ -136,8 +168,4 @@ export class GeojsonFileSource extends AbstractVectorSource { shouldBeIndexed() { return GeojsonFileSource.isIndexingSource; } - - isInjectedData() { - return true; - } } diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/source.js b/x-pack/legacy/plugins/maps/public/layers/sources/source.js index f96fc42f02178..3bee49cff6d18 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/source.js @@ -115,10 +115,6 @@ export class AbstractSource { return AbstractSource.isIndexingSource; } - isInjectedData() { - return false; - } - supportsElasticsearchFilters() { return false; } diff --git a/x-pack/legacy/plugins/maps/public/layers/util/injected_data.js b/x-pack/legacy/plugins/maps/public/layers/util/injected_data.js deleted file mode 100644 index 8c18819e9f8b5..0000000000000 --- a/x-pack/legacy/plugins/maps/public/layers/util/injected_data.js +++ /dev/null @@ -1,21 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ -export class InjectedData { - - constructor(data) { - this._descriptor = { data }; - } - - getData() { - return this._descriptor.data; - } - - hasData() { - return !!this._descriptor.data; - } - -} - diff --git a/x-pack/legacy/plugins/maps/public/layers/vector_layer.js b/x-pack/legacy/plugins/maps/public/layers/vector_layer.js index 81f4f3b388d56..7372b549f6423 100644 --- a/x-pack/legacy/plugins/maps/public/layers/vector_layer.js +++ b/x-pack/legacy/plugins/maps/public/layers/vector_layer.js @@ -132,18 +132,6 @@ export class VectorLayer extends AbstractLayer { return true; } - getInjectedData() { - const featureCollection = super.getInjectedData(); - if (!featureCollection) { - return null; - } - // Set default visible property on data - featureCollection.features.forEach( - feature => _.set(feature, `properties.${FEATURE_VISIBLE_PROPERTY_NAME}`, true) - ); - return featureCollection; - } - getCustomIconAndTooltipContent() { const featureCollection = this._getSourceFeatureCollection(); @@ -510,16 +498,7 @@ export class VectorLayer extends AbstractLayer { startLoading, stopLoading, onLoadError, registerCancelCallback, dataFilters }) { - if (this._source.isInjectedData()) { - const featureCollection = this.getInjectedData(); - return { - refreshed: false, - featureCollection - }; - } - const requestToken = Symbol(`layer-source-refresh:${ this.getId()} - source`); - const searchFilters = this._getSearchFilters(dataFilters); const canSkip = await this._canSkipSourceUpdate(this._source, SOURCE_DATA_ID_ORIGIN, searchFilters); if (canSkip) { @@ -594,12 +573,8 @@ export class VectorLayer extends AbstractLayer { } _getSourceFeatureCollection() { - if (this._source.isInjectedData()) { - return this.getInjectedData(); - } else { - const sourceDataRequest = this.getSourceDataRequest(); - return sourceDataRequest ? sourceDataRequest.getData() : null; - } + const sourceDataRequest = this.getSourceDataRequest(); + return sourceDataRequest ? sourceDataRequest.getData() : null; } _syncFeatureCollectionWithMb(mbMap) {