forked from MapComplete/MapComplete
		
	Chore: housekeeping
This commit is contained in:
		
							parent
							
								
									18e3e6f806
								
							
						
					
					
						commit
						a3a7e74f56
					
				
					 94 changed files with 1273 additions and 1080 deletions
				
			
		|  | @ -2,7 +2,11 @@ import LayoutConfig from "./ThemeConfig/LayoutConfig" | |||
| import { SpecialVisualizationState } from "../UI/SpecialVisualization" | ||||
| import { Changes } from "../Logic/Osm/Changes" | ||||
| import { Store, UIEventSource } from "../Logic/UIEventSource" | ||||
| import { FeatureSource, IndexedFeatureSource, WritableFeatureSource } from "../Logic/FeatureSource/FeatureSource" | ||||
| 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" | ||||
|  | @ -46,7 +50,9 @@ import BackgroundLayerResetter from "../Logic/Actors/BackgroundLayerResetter" | |||
| import SaveFeatureSourceToLocalStorage from "../Logic/FeatureSource/Actors/SaveFeatureSourceToLocalStorage" | ||||
| import BBoxFeatureSource from "../Logic/FeatureSource/Sources/TouchesBboxFeatureSource" | ||||
| import ThemeViewStateHashActor from "../Logic/Web/ThemeViewStateHashActor" | ||||
| import NoElementsInViewDetector, { FeatureViewState } from "../Logic/Actors/NoElementsInViewDetector" | ||||
| import NoElementsInViewDetector, { | ||||
|     FeatureViewState, | ||||
| } from "../Logic/Actors/NoElementsInViewDetector" | ||||
| import FilteredLayer from "./FilteredLayer" | ||||
| import { PreferredRasterLayerSelector } from "../Logic/Actors/PreferredRasterLayerSelector" | ||||
| import { ImageUploadManager } from "../Logic/ImageProviders/ImageUploadManager" | ||||
|  | @ -152,7 +158,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|         this.featureSwitches = new FeatureSwitchState(layout) | ||||
|         this.guistate = new MenuState( | ||||
|             this.featureSwitches.featureSwitchWelcomeMessage.data, | ||||
|             layout.id, | ||||
|             layout.id | ||||
|         ) | ||||
|         this.map = new UIEventSource<MlMap>(undefined) | ||||
|         const geolocationState = new GeoLocationState() | ||||
|  | @ -168,14 +174,14 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             oauth_token: QueryParameters.GetQueryParameter( | ||||
|                 "oauth_token", | ||||
|                 undefined, | ||||
|                 "Used to complete the login", | ||||
|                 "Used to complete the login" | ||||
|             ), | ||||
|         }) | ||||
|         this.userRelatedState = new UserRelatedState( | ||||
|             this.osmConnection, | ||||
|             layout, | ||||
|             this.featureSwitches, | ||||
|             this.mapProperties, | ||||
|             this.mapProperties | ||||
|         ) | ||||
|         this.userRelatedState.fixateNorth.addCallbackAndRunD((fixated) => { | ||||
|             this.mapProperties.allowRotating.setData(fixated !== "yes") | ||||
|  | @ -186,13 +192,13 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             geolocationState, | ||||
|             this.selectedElement, | ||||
|             this.mapProperties, | ||||
|             this.userRelatedState.gpsLocationHistoryRetentionTime, | ||||
|             this.userRelatedState.gpsLocationHistoryRetentionTime | ||||
|         ) | ||||
|         this.geolocationControl = new GeolocationControlState(this.geolocation, this.mapProperties) | ||||
| 
 | ||||
|         this.availableLayers = AvailableRasterLayers.layersAvailableAt( | ||||
|             this.mapProperties.location, | ||||
|             this.osmConnection.isLoggedIn, | ||||
|             this.osmConnection.isLoggedIn | ||||
|         ) | ||||
| 
 | ||||
|         const self = this | ||||
|  | @ -204,7 +210,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 const isDisplayed = QueryParameters.GetBooleanQueryParameter( | ||||
|                     "overlay-" + rasterInfo.id, | ||||
|                     rasterInfo.defaultState ?? true, | ||||
|                     "Wether or not overlayer layer " + rasterInfo.id + " is shown", | ||||
|                     "Wether or not overlayer layer " + rasterInfo.id + " is shown" | ||||
|                 ) | ||||
|                 const state = { isDisplayed } | ||||
|                 overlayLayerStates.set(rasterInfo.id, state) | ||||
|  | @ -229,7 +235,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 this.osmConnection.Backend(), | ||||
|                 (id) => self.layerState.filteredLayers.get(id).isDisplayed, | ||||
|                 mvtAvailableLayers, | ||||
|                 this.fullNodeDatabase, | ||||
|                 this.fullNodeDatabase | ||||
|             ) | ||||
| 
 | ||||
|             let currentViewIndex = 0 | ||||
|  | @ -247,7 +253,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                             id: "current_view_" + currentViewIndex, | ||||
|                         }), | ||||
|                     ] | ||||
|                 }), | ||||
|                 }) | ||||
|             ) | ||||
|             this.featuresInView = new BBoxFeatureSource(layoutSource, this.mapProperties.bounds) | ||||
| 
 | ||||
|  | @ -265,19 +271,19 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     featureSwitches: this.featureSwitches, | ||||
|                 }, | ||||
|                 layout?.isLeftRightSensitive() ?? false, | ||||
|                 e => this.reportError(e), | ||||
|                 (e) => this.reportError(e) | ||||
|             ) | ||||
|             this.historicalUserLocations = this.geolocation.historicalUserLocations | ||||
|             this.newFeatures = new NewGeometryFromChangesFeatureSource( | ||||
|                 this.changes, | ||||
|                 layoutSource, | ||||
|                 this.featureProperties, | ||||
|                 this.featureProperties | ||||
|             ) | ||||
|             layoutSource.addSource(this.newFeatures) | ||||
| 
 | ||||
|             const perLayer = new PerLayerFeatureSourceSplitter( | ||||
|                 Array.from(this.layerState.filteredLayers.values()).filter( | ||||
|                     (l) => l.layerDef?.source !== null, | ||||
|                     (l) => l.layerDef?.source !== null | ||||
|                 ), | ||||
|                 new ChangeGeometryApplicator(this.indexedFeatures, this.changes), | ||||
|                 { | ||||
|  | @ -288,10 +294,10 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                             "Got ", | ||||
|                             features.length, | ||||
|                             "leftover features, such as", | ||||
|                             features[0].properties, | ||||
|                             features[0].properties | ||||
|                         ) | ||||
|                     }, | ||||
|                 }, | ||||
|                 } | ||||
|             ) | ||||
|             this.perLayer = perLayer.perLayer | ||||
|         } | ||||
|  | @ -336,7 +342,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
| 
 | ||||
|         this.osmObjectDownloader = new OsmObjectDownloader( | ||||
|             this.osmConnection.Backend(), | ||||
|             this.changes, | ||||
|             this.changes | ||||
|         ) | ||||
| 
 | ||||
|         this.perLayerFiltered = this.showNormalDataOn(this.map) | ||||
|  | @ -347,7 +353,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 currentZoom: this.mapProperties.zoom, | ||||
|                 layerState: this.layerState, | ||||
|                 bounds: this.visualFeedbackViewportBounds, | ||||
|             }, | ||||
|             } | ||||
|         ) | ||||
|         this.hasDataInView = new NoElementsInViewDetector(this).hasFeatureInView | ||||
|         this.imageUploadManager = new ImageUploadManager( | ||||
|  | @ -355,7 +361,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             Imgur.singleton, | ||||
|             this.featureProperties, | ||||
|             this.osmConnection, | ||||
|             this.changes, | ||||
|             this.changes | ||||
|         ) | ||||
|         this.favourites = new FavouritesFeatureSource(this) | ||||
| 
 | ||||
|  | @ -398,7 +404,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 LayoutSource.fromCacheZoomLevel, | ||||
|                 fs, | ||||
|                 this.featureProperties, | ||||
|                 fs.layer.layerDef.maxAgeOfCache, | ||||
|                 fs.layer.layerDef.maxAgeOfCache | ||||
|             ) | ||||
|             toLocalStorage.set(layerId, storage) | ||||
|         }) | ||||
|  | @ -411,7 +417,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             const doShowLayer = this.mapProperties.zoom.map( | ||||
|                 (z) => | ||||
|                     (fs.layer.isDisplayed?.data ?? true) && z >= (fs.layer.layerDef?.minzoom ?? 0), | ||||
|                 [fs.layer.isDisplayed], | ||||
|                 [fs.layer.isDisplayed] | ||||
|             ) | ||||
| 
 | ||||
|             if (!doShowLayer.data && this.featureSwitches.featureSwitchFilter.data === false) { | ||||
|  | @ -428,7 +434,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 fs.layer, | ||||
|                 fs, | ||||
|                 (id) => this.featureProperties.getStore(id), | ||||
|                 this.layerState.globalFilters, | ||||
|                 this.layerState.globalFilters | ||||
|             ) | ||||
|             filteringFeatureSource.set(layerName, filtered) | ||||
| 
 | ||||
|  | @ -569,7 +575,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     return | ||||
|                 } | ||||
|                 this.selectClosestAtCenter(0) | ||||
|             }, | ||||
|             } | ||||
|         ) | ||||
| 
 | ||||
|         for (let i = 1; i < 9; i++) { | ||||
|  | @ -587,7 +593,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     onUp: true, | ||||
|                 }, | ||||
|                 doc, | ||||
|                 () => this.selectClosestAtCenter(i - 1), | ||||
|                 () => this.selectClosestAtCenter(i - 1) | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -604,7 +610,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     if (this.featureSwitches.featureSwitchBackgroundSelection.data) { | ||||
|                         this.guistate.backgroundLayerSelectionIsOpened.setData(true) | ||||
|                     } | ||||
|                 }, | ||||
|                 } | ||||
|             ) | ||||
|             Hotkeys.RegisterHotkey( | ||||
|                 { | ||||
|  | @ -616,14 +622,14 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     if (this.featureSwitches.featureSwitchFilter.data) { | ||||
|                         this.guistate.openFilterView() | ||||
|                     } | ||||
|                 }, | ||||
|                 } | ||||
|             ) | ||||
|             Hotkeys.RegisterHotkey( | ||||
|                 { shift: "O" }, | ||||
|                 Translations.t.hotkeyDocumentation.selectMapnik, | ||||
|                 () => { | ||||
|                     this.mapProperties.rasterLayer.setData(AvailableRasterLayers.osmCarto) | ||||
|                 }, | ||||
|                 } | ||||
|             ) | ||||
|             const setLayerCategory = (category: EliCategory) => { | ||||
|                 const available = this.availableLayers.data | ||||
|  | @ -631,7 +637,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 const best = RasterLayerUtils.SelectBestLayerAccordingTo( | ||||
|                     available, | ||||
|                     category, | ||||
|                     current.data, | ||||
|                     current.data | ||||
|                 ) | ||||
|                 console.log("Best layer for category", category, "is", best.properties.id) | ||||
|                 current.setData(best) | ||||
|  | @ -640,26 +646,26 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             Hotkeys.RegisterHotkey( | ||||
|                 { nomod: "O" }, | ||||
|                 Translations.t.hotkeyDocumentation.selectOsmbasedmap, | ||||
|                 () => setLayerCategory("osmbasedmap"), | ||||
|                 () => setLayerCategory("osmbasedmap") | ||||
|             ) | ||||
| 
 | ||||
|             Hotkeys.RegisterHotkey( | ||||
|                 { nomod: "M" }, | ||||
|                 Translations.t.hotkeyDocumentation.selectMap, | ||||
|                 () => setLayerCategory("map"), | ||||
|                 () => setLayerCategory("map") | ||||
|             ) | ||||
| 
 | ||||
|             Hotkeys.RegisterHotkey( | ||||
|                 { nomod: "P" }, | ||||
|                 Translations.t.hotkeyDocumentation.selectAerial, | ||||
|                 () => setLayerCategory("photo"), | ||||
|                 () => setLayerCategory("photo") | ||||
|             ) | ||||
|             Hotkeys.RegisterHotkey( | ||||
|                 { nomod: "L" }, | ||||
|                 Translations.t.hotkeyDocumentation.geolocate, | ||||
|                 () => { | ||||
|                     this.geolocationControl.handleClick() | ||||
|                 }, | ||||
|                 } | ||||
|             ) | ||||
|             return true | ||||
|         }) | ||||
|  | @ -671,7 +677,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             Translations.t.hotkeyDocumentation.translationMode, | ||||
|             () => { | ||||
|                 Locale.showLinkToWeblate.setData(!Locale.showLinkToWeblate.data) | ||||
|             }, | ||||
|             } | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -682,7 +688,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|         const normalLayers = this.layout.layers.filter( | ||||
|             (l) => | ||||
|                 Constants.priviliged_layers.indexOf(<any>l.id) < 0 && | ||||
|                 !l.id.startsWith("note_import"), | ||||
|                 !l.id.startsWith("note_import") | ||||
|         ) | ||||
|         const maxzoom = Math.min(...normalLayers.map((l) => l.minzoom)) | ||||
| 
 | ||||
|  | @ -690,7 +696,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             (l) => | ||||
|                 Constants.priviliged_layers.indexOf(<any>l.id) < 0 && | ||||
|                 l.source.geojsonSource === undefined && | ||||
|                 l.doCount, | ||||
|                 l.doCount | ||||
|         ) | ||||
|         const summaryTileSource = new SummaryTileSource( | ||||
|             Constants.SummaryServer, | ||||
|  | @ -699,7 +705,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             this.mapProperties, | ||||
|             { | ||||
|                 isActive: this.mapProperties.zoom.map((z) => z <= maxzoom), | ||||
|             }, | ||||
|             } | ||||
|         ) | ||||
|         return new SummaryTileSourceRewriter(summaryTileSource, this.layerState.filteredLayers) | ||||
|     } | ||||
|  | @ -719,12 +725,12 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             gps_location_history: this.geolocation.historicalUserLocations, | ||||
|             gps_track: this.geolocation.historicalUserLocationsTrack, | ||||
|             selected_element: new StaticFeatureSource( | ||||
|                 this.selectedElement.map((f) => (f === undefined ? empty : [f])), | ||||
|                 this.selectedElement.map((f) => (f === undefined ? empty : [f])) | ||||
|             ), | ||||
|             range: new StaticFeatureSource( | ||||
|                 this.mapProperties.maxbounds.map((bbox) => | ||||
|                     bbox === undefined ? empty : <Feature[]>[bbox.asGeoJson({ id: "range" })], | ||||
|                 ), | ||||
|                     bbox === undefined ? empty : <Feature[]>[bbox.asGeoJson({ id: "range" })] | ||||
|                 ) | ||||
|             ), | ||||
|             current_view: this.currentView, | ||||
|             favourite: this.favourites, | ||||
|  | @ -739,7 +745,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             ShowDataLayer.showRange( | ||||
|                 this.map, | ||||
|                 new StaticFeatureSource([bbox.asGeoJson({ id: "range" })]), | ||||
|                 this.featureSwitches.featureSwitchIsTesting, | ||||
|                 this.featureSwitches.featureSwitchIsTesting | ||||
|             ) | ||||
|         } | ||||
|         const currentViewLayer = this.layout.layers.find((l) => l.id === "current_view") | ||||
|  | @ -753,7 +759,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     currentViewLayer, | ||||
|                     this.layout, | ||||
|                     this.osmObjectDownloader, | ||||
|                     this.featureProperties, | ||||
|                     this.featureProperties | ||||
|                 ) | ||||
|             }) | ||||
|         } | ||||
|  | @ -797,20 +803,20 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
| 
 | ||||
|         const lastClickLayerConfig = new LayerConfig( | ||||
|             <LayerConfigJson>last_click_layerconfig, | ||||
|             "last_click", | ||||
|             "last_click" | ||||
|         ) | ||||
|         const lastClickFiltered = | ||||
|             lastClickLayerConfig.isShown === undefined | ||||
|                 ? specialLayers.last_click | ||||
|                 : specialLayers.last_click.features.mapD((fs) => | ||||
|                     fs.filter((f) => { | ||||
|                         const matches = lastClickLayerConfig.isShown.matchesProperties( | ||||
|                             f.properties, | ||||
|                         ) | ||||
|                         console.log("LastClick ", f, "matches", matches) | ||||
|                         return matches | ||||
|                     }), | ||||
|                 ) | ||||
|                       fs.filter((f) => { | ||||
|                           const matches = lastClickLayerConfig.isShown.matchesProperties( | ||||
|                               f.properties | ||||
|                           ) | ||||
|                           console.log("LastClick ", f, "matches", matches) | ||||
|                           return matches | ||||
|                       }) | ||||
|                   ) | ||||
|         new ShowDataLayer(this.map, { | ||||
|             features: new StaticFeatureSource(lastClickFiltered), | ||||
|             layer: lastClickLayerConfig, | ||||
|  | @ -855,7 +861,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             this.mapProperties.rasterLayer, | ||||
|             this.availableLayers, | ||||
|             this.featureSwitches.backgroundLayerId, | ||||
|             this.userRelatedState.preferredBackgroundLayer, | ||||
|             this.userRelatedState.preferredBackgroundLayer | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -865,14 +871,14 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|     } | ||||
| 
 | ||||
|     public async reportError(message: string | Error) { | ||||
|         console.log(">>> Reporting error to",Constants.ErrorReportServer, message) | ||||
|         console.log(">>> Reporting error to", Constants.ErrorReportServer, message) | ||||
|         let stacktrace: string = new Error().stack | ||||
| 
 | ||||
|         await fetch(Constants.ErrorReportServer, { | ||||
|             method: "POST", | ||||
|             body: JSON.stringify({ | ||||
|                 stacktrace, | ||||
|                 message: ""+message, | ||||
|                 message: "" + message, | ||||
|                 layout: this.layout.id, | ||||
|                 version: Constants.vNumber, | ||||
|                 language: this.userRelatedState.language.data, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue