Fix zoom issue
This commit is contained in:
		| @@ -128,29 +128,24 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | |||||||
|     this.store.dispatch(new mapActions.Init());    |     this.store.dispatch(new mapActions.Init());    | ||||||
|     this.selectedFeatures$.next({x:0,y:0,features:[]}); |     this.selectedFeatures$.next({x:0,y:0,features:[]}); | ||||||
|     this.selectedFeatures$.next(null); |     this.selectedFeatures$.next(null); | ||||||
|     this.query$.pipe(withLatestFrom(this.mapState$),withLatestFrom(this.setStateCount$)).subscribe((state) => { |     this.query$.pipe(withLatestFrom(this.mapState$),withLatestFrom(this.setStateCount$)).subscribe(([[queryState,mapState],setStateCount]) =>{ | ||||||
|       let queryState = state[0][0]; |       if(setStateCount>0) { | ||||||
|       let mapState = state[0][1];       |         console.debug("Querystate:replace url"); | ||||||
|       let urlparts=[]; |         this.replaceUrl(mapState,queryState,false); | ||||||
|  |  | ||||||
|       // TODO: fix this properly move the action to a separte column in itemtypes |  | ||||||
|       if(queryState.itemType && queryState.itemCode) { |  | ||||||
|         let itemType = this.itemTypeService.itemTypes[queryState.itemType]; |  | ||||||
|         if (itemType.viewer == "edit_in_editor" && itemType.editor) { |  | ||||||
|           urlparts.push('/editor'); |  | ||||||
|           urlparts.push(itemType.editor); |  | ||||||
|           urlparts.push('item'); |  | ||||||
|           urlparts.push(queryState.itemCode);                |  | ||||||
|         }        |  | ||||||
|       }    |  | ||||||
|       if(state[1]>0) { |  | ||||||
|         if(urlparts.length>0) { |  | ||||||
|            this.router.navigate(urlparts);    |  | ||||||
|         } else { |  | ||||||
|            this.replaceUrl(mapState, queryState,false);  |  | ||||||
|         }  |  | ||||||
|       } |       } | ||||||
|     });    |     });    | ||||||
|  |     this.mapState$.pipe(withLatestFrom(this.queryState$),withLatestFrom(this.setStateCount$)).subscribe(([[mapState,queryState],setStateCount]) =>{ | ||||||
|  |       if(setStateCount>0) { | ||||||
|  |         console.debug("Mapstate:replace url"); | ||||||
|  |         this.replaceUrl(mapState,queryState,true); | ||||||
|  |       } | ||||||
|  |     });     | ||||||
|  |     this.queryState$.pipe(withLatestFrom(this.mapState$),withLatestFrom(this.setStateCount$)).subscribe(([[queryState,mapState],setStateCount]) =>{ | ||||||
|  |       if(setStateCount>0) { | ||||||
|  |         console.debug("Querystate:replace url"); | ||||||
|  |         this.replaceUrl(mapState,queryState,true); | ||||||
|  |       } | ||||||
|  |     })  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   initCustomStyles() { |   initCustomStyles() { | ||||||
| @@ -278,10 +273,10 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | |||||||
|       let mapState: IMapState = { xCenter: center[0], yCenter: center[1], zoom: zoom, rotation: rotation, baseLayerCode: null }; |       let mapState: IMapState = { xCenter: center[0], yCenter: center[1], zoom: zoom, rotation: rotation, baseLayerCode: null }; | ||||||
|       let state = { mapState: mapState, extent: extent }; |       let state = { mapState: mapState, extent: extent }; | ||||||
|       let source = from([state]); |       let source = from([state]); | ||||||
|       source.pipe(withLatestFrom(this.selectedBaseLayer$), withLatestFrom(this.queryState$)).subscribe(([[state, baselayer], queryState]) => { |       source.pipe(withLatestFrom(this.selectedBaseLayer$)).subscribe(([state, baselayer]) => { | ||||||
|         if (mapState && baselayer && queryState) { |         if (mapState && baselayer) { | ||||||
|           let newMapState = tassign(state.mapState, { baseLayerCode: baselayer.item.code }); |           let newMapState = tassign(state.mapState, { baseLayerCode: baselayer.item.code }); | ||||||
|           this.replaceUrl(newMapState, tassign(queryState, { bbox: queryState.bboxFilter ? state.extent : queryState.bbox })); |           this.store.dispatch(new mapActions.SetMapState(newMapState)); | ||||||
|           this.store.dispatch(new mapActions.SetViewExtent(state.extent)); |           this.store.dispatch(new mapActions.SetViewExtent(state.extent)); | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|   | |||||||
| @@ -26,6 +26,10 @@ import {FeatureIconService} from '../services/feature-icon.service'; | |||||||
|  |  | ||||||
| import * as style from 'ol/style'; | import * as style from 'ol/style'; | ||||||
|  |  | ||||||
|  | import { ItemTypeService } from '@farmmaps/common'; | ||||||
|  | import { Router } from '@angular/router'; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @Injectable() | @Injectable() | ||||||
| export class MapEffects { | export class MapEffects { | ||||||
| @@ -252,7 +256,22 @@ export class MapEffects { | |||||||
|     switchMap((action: mapActions.SetQueryState) => { |     switchMap((action: mapActions.SetQueryState) => { | ||||||
|         var newAction:Action; |         var newAction:Action; | ||||||
|         if (action.queryState.itemCode && action.queryState.itemCode != "") { |         if (action.queryState.itemCode && action.queryState.itemCode != "") { | ||||||
|  |           let urlparts=[]; | ||||||
|  |           if(action.queryState.itemType && action.queryState.itemType!= "") { | ||||||
|  |             let itemType = this.itemTypeService$.itemTypes[action.queryState.itemType]; | ||||||
|  |             if (itemType.viewer == "edit_in_editor" && itemType.editor) { | ||||||
|  |               urlparts.push('/editor'); | ||||||
|  |               urlparts.push(itemType.editor); | ||||||
|  |               urlparts.push('item'); | ||||||
|  |               urlparts.push(action.queryState.itemCode);                | ||||||
|  |             }     | ||||||
|  |           } | ||||||
|  |           if(urlparts.length==0 ) { | ||||||
|             newAction= new mapActions.SelectItem(action.queryState.itemCode); |             newAction= new mapActions.SelectItem(action.queryState.itemCode); | ||||||
|  |           } else { | ||||||
|  |             this.router$.navigate(urlparts); | ||||||
|  |             return []; | ||||||
|  |           } | ||||||
|         } else { |         } else { | ||||||
|           newAction= new mapActions.StartSearch(action.queryState); |           newAction= new mapActions.StartSearch(action.queryState); | ||||||
|         } |         } | ||||||
| @@ -272,7 +291,7 @@ export class MapEffects { | |||||||
|       return of(newAction); |       return of(newAction); | ||||||
|     })); |     })); | ||||||
|  |  | ||||||
|   constructor(private actions$: Actions, private store$: Store<mapReducers.State>, private folderService$: FolderService, private itemService$: ItemService,private featureIconService$:FeatureIconService) { |     constructor(private actions$: Actions, private store$: Store<mapReducers.State>, private folderService$: FolderService, private itemService$: ItemService,private featureIconService$:FeatureIconService,private itemTypeService$:ItemTypeService,private router$:Router) { | ||||||
|     this._geojsonFormat = new GeoJSON(); |     this._geojsonFormat = new GeoJSON(); | ||||||
|     this._wktFormat = new WKT(); |     this._wktFormat = new WKT(); | ||||||
|   } |   } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user