forked from MapComplete/MapComplete
		
	Refactoring: add current view button
This commit is contained in:
		
							parent
							
								
									dec4296204
								
							
						
					
					
						commit
						2149fc1a1d
					
				
					 3 changed files with 266 additions and 256 deletions
				
			
		|  | @ -1,27 +1,23 @@ | |||
| import LayoutConfig from "./ThemeConfig/LayoutConfig" | ||||
| import { SpecialVisualizationState } from "../UI/SpecialVisualization" | ||||
| import { Changes } from "../Logic/Osm/Changes" | ||||
| import { ImmutableStore, Store, UIEventSource } from "../Logic/UIEventSource" | ||||
| import { | ||||
|     FeatureSource, | ||||
|     IndexedFeatureSource, | ||||
|     WritableFeatureSource, | ||||
| } from "../Logic/FeatureSource/FeatureSource" | ||||
| import { OsmConnection } from "../Logic/Osm/OsmConnection" | ||||
| import { ExportableMap, MapProperties } from "./MapProperties" | ||||
| import {SpecialVisualizationState} from "../UI/SpecialVisualization" | ||||
| import {Changes} from "../Logic/Osm/Changes" | ||||
| import {ImmutableStore, Store, UIEventSource} from "../Logic/UIEventSource" | ||||
| import {FeatureSource, IndexedFeatureSource, WritableFeatureSource,} from "../Logic/FeatureSource/FeatureSource" | ||||
| import {OsmConnection} from "../Logic/Osm/OsmConnection" | ||||
| import {ExportableMap, MapProperties} from "./MapProperties" | ||||
| import LayerState from "../Logic/State/LayerState" | ||||
| import { Feature, Point } from "geojson" | ||||
| import {Feature, Point, Polygon} from "geojson" | ||||
| import FullNodeDatabaseSource from "../Logic/FeatureSource/TiledFeatureSource/FullNodeDatabaseSource" | ||||
| import { Map as MlMap } from "maplibre-gl" | ||||
| import {Map as MlMap} from "maplibre-gl" | ||||
| import InitialMapPositioning from "../Logic/Actors/InitialMapPositioning" | ||||
| import { MapLibreAdaptor } from "../UI/Map/MapLibreAdaptor" | ||||
| import { GeoLocationState } from "../Logic/State/GeoLocationState" | ||||
| import {MapLibreAdaptor} from "../UI/Map/MapLibreAdaptor" | ||||
| import {GeoLocationState} from "../Logic/State/GeoLocationState" | ||||
| import FeatureSwitchState from "../Logic/State/FeatureSwitchState" | ||||
| import { QueryParameters } from "../Logic/Web/QueryParameters" | ||||
| import {QueryParameters} from "../Logic/Web/QueryParameters" | ||||
| import UserRelatedState from "../Logic/State/UserRelatedState" | ||||
| import LayerConfig from "./ThemeConfig/LayerConfig" | ||||
| import GeoLocationHandler from "../Logic/Actors/GeoLocationHandler" | ||||
| import { AvailableRasterLayers, RasterLayerPolygon, RasterLayerUtils } from "./RasterLayers" | ||||
| import {AvailableRasterLayers, RasterLayerPolygon, RasterLayerUtils} from "./RasterLayers" | ||||
| import LayoutSource from "../Logic/FeatureSource/Sources/LayoutSource" | ||||
| import StaticFeatureSource from "../Logic/FeatureSource/Sources/StaticFeatureSource" | ||||
| import FeaturePropertiesStore from "../Logic/FeatureSource/Actors/FeaturePropertiesStore" | ||||
|  | @ -32,20 +28,20 @@ import TitleHandler from "../Logic/Actors/TitleHandler" | |||
| import ChangeToElementsActor from "../Logic/Actors/ChangeToElementsActor" | ||||
| import PendingChangesUploader from "../Logic/Actors/PendingChangesUploader" | ||||
| import SelectedElementTagsUpdater from "../Logic/Actors/SelectedElementTagsUpdater" | ||||
| import { BBox } from "../Logic/BBox" | ||||
| import {BBox} from "../Logic/BBox" | ||||
| import Constants from "./Constants" | ||||
| import Hotkeys from "../UI/Base/Hotkeys" | ||||
| import Translations from "../UI/i18n/Translations" | ||||
| import { GeoIndexedStoreForLayer } from "../Logic/FeatureSource/Actors/GeoIndexedStore" | ||||
| import { LastClickFeatureSource } from "../Logic/FeatureSource/Sources/LastClickFeatureSource" | ||||
| import { MenuState } from "./MenuState" | ||||
| import {GeoIndexedStoreForLayer} from "../Logic/FeatureSource/Actors/GeoIndexedStore" | ||||
| import {LastClickFeatureSource} from "../Logic/FeatureSource/Sources/LastClickFeatureSource" | ||||
| import {MenuState} from "./MenuState" | ||||
| import MetaTagging from "../Logic/MetaTagging" | ||||
| import ChangeGeometryApplicator from "../Logic/FeatureSource/Sources/ChangeGeometryApplicator" | ||||
| import { NewGeometryFromChangesFeatureSource } from "../Logic/FeatureSource/Sources/NewGeometryFromChangesFeatureSource" | ||||
| import {NewGeometryFromChangesFeatureSource} from "../Logic/FeatureSource/Sources/NewGeometryFromChangesFeatureSource" | ||||
| import OsmObjectDownloader from "../Logic/Osm/OsmObjectDownloader" | ||||
| import ShowOverlayRasterLayer from "../UI/Map/ShowOverlayRasterLayer" | ||||
| import { Utils } from "../Utils" | ||||
| import { EliCategory } from "./RasterLayerProperties" | ||||
| import {Utils} from "../Utils" | ||||
| import {EliCategory} from "./RasterLayerProperties" | ||||
| import BackgroundLayerResetter from "../Logic/Actors/BackgroundLayerResetter" | ||||
| import SaveFeatureSourceToLocalStorage from "../Logic/FeatureSource/Actors/SaveFeatureSourceToLocalStorage" | ||||
| import Hash from "../Logic/Web/Hash" | ||||
|  | @ -80,6 +76,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
| 
 | ||||
|     readonly historicalUserLocations: WritableFeatureSource<Feature<Point>> | ||||
|     readonly indexedFeatures: IndexedFeatureSource & LayoutSource | ||||
|     readonly currentView: FeatureSource<Feature<Polygon>> | ||||
|     readonly featuresInView: FeatureSource | ||||
|     readonly newFeatures: WritableFeatureSource | ||||
|     readonly layerState: LayerState | ||||
|  | @ -169,6 +166,12 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 (id) => self.layerState.filteredLayers.get(id).isDisplayed | ||||
|             ) | ||||
|             this.indexedFeatures = layoutSource | ||||
|             const empty = [] | ||||
|             this.currentView = new StaticFeatureSource( | ||||
|                 this.mapProperties.bounds.map((bbox) => | ||||
|                     bbox === undefined ? empty : <Feature[]>[bbox.asGeoJson({ id: "current_view" })] | ||||
|                 ) | ||||
|             ) | ||||
|             this.featuresInView = new BBoxFeatureSource(layoutSource, this.mapProperties.bounds) | ||||
|             this.dataIsLoading = layoutSource.isLoading | ||||
| 
 | ||||
|  | @ -447,11 +450,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     bbox === undefined ? empty : <Feature[]>[bbox.asGeoJson({ id: "range" })] | ||||
|                 ) | ||||
|             ), | ||||
|             current_view: new StaticFeatureSource( | ||||
|                 this.mapProperties.bounds.map((bbox) => | ||||
|                     bbox === undefined ? empty : <Feature[]>[bbox.asGeoJson({ id: "current_view" })] | ||||
|                 ) | ||||
|             ), | ||||
|             current_view: this.currentView | ||||
|         } | ||||
|         if (this.layout?.lockLocation) { | ||||
|             const bbox = new BBox(this.layout.lockLocation) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue