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.selectedFeatures$.next({x:0,y:0,features:[]}); | ||||
|     this.selectedFeatures$.next(null); | ||||
|     this.query$.pipe(withLatestFrom(this.mapState$),withLatestFrom(this.setStateCount$)).subscribe((state) => { | ||||
|       let queryState = state[0][0]; | ||||
|       let mapState = state[0][1];       | ||||
|       let urlparts=[]; | ||||
|  | ||||
|       // 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.query$.pipe(withLatestFrom(this.mapState$),withLatestFrom(this.setStateCount$)).subscribe(([[queryState,mapState],setStateCount]) =>{ | ||||
|       if(setStateCount>0) { | ||||
|         console.debug("Querystate:replace url"); | ||||
|         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() { | ||||
| @@ -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 state = { mapState: mapState, extent: extent }; | ||||
|       let source = from([state]); | ||||
|       source.pipe(withLatestFrom(this.selectedBaseLayer$), withLatestFrom(this.queryState$)).subscribe(([[state, baselayer], queryState]) => { | ||||
|         if (mapState && baselayer && queryState) { | ||||
|       source.pipe(withLatestFrom(this.selectedBaseLayer$)).subscribe(([state, baselayer]) => { | ||||
|         if (mapState && baselayer) { | ||||
|           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)); | ||||
|         } | ||||
|       }); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user