Add router-outlet to map component to make it more reusable
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				FarmMaps.Develop/FarmMapsLib/pipeline/head This commit looks good
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	FarmMaps.Develop/FarmMapsLib/pipeline/head This commit looks good
				
			This commit is contained in:
		| @@ -8,6 +8,10 @@ const routes = [ | ||||
|         path: '', | ||||
|         component: MapComponent    | ||||
|     }, | ||||
|     { | ||||
|         path: ':xCenter/:yCenter/:zoom/:rotation/:baseLayer', | ||||
|         component: MapComponent | ||||
|     }, | ||||
|     { | ||||
|        path: ':xCenter/:yCenter/:zoom/:rotation/:baseLayer/:queryState', | ||||
|        component: MapComponent | ||||
|   | ||||
| @@ -19,9 +19,10 @@ | ||||
|   period:period$|async, | ||||
|   compassHeading:compassHeading$|async, | ||||
|   styles:styles$|async, | ||||
|   selectedFeature:selectedFeature$|async | ||||
|   selectedFeature:selectedFeature$|async, | ||||
|   fullscreen:fullscreen$|async | ||||
| } as state"> | ||||
|   <aol-map #map (moveEnd)="handleOnMoveEnd($event)" (click)="handleOnMouseDown($event)" [ngClass]="{'panel-visible':state.panelVisible}" class="map"> | ||||
|   <aol-map #map (moveEnd)="handleOnMoveEnd($event)" (click)="handleOnMouseDown($event)" [ngClass]="{'panel-visible':state.panelVisible,'fullscreen':state.fullscreen}" class="map"> | ||||
|     <div> | ||||
|  | ||||
|     </div> | ||||
| @@ -46,9 +47,11 @@ | ||||
|     </div> | ||||
|     <fm-map-file-drop-target [parentCode]="state.parentCode" (onFileDropped)="handleFileDropped($event)"></fm-map-file-drop-target> | ||||
|   </aol-map> | ||||
|   <div *ngIf="noContent"> | ||||
|     <fm-map-map-search #mapSearch [openedModalName]="state.openedModalName" (onOpenModal)="handleOpenModal($event)" (onCloseModal)="handleCloseModal()" [ngClass]="{'menuVisible':state.menuVisible}" (onToggleMenu)="handleToggleMenu($event)" (onSearchCollapse)="handleSearchCollapse($event)" (onSearchExpand)="handleSearchExpand($event)" [collapsed]="state.searchCollapsed" [searchMinified]="state.searchMinified" (onSearch)="handleSearch($event)" (onClear)="handleClearSearch($event)" [filterOptions]="state.queryState" [clearEnabled]="state.clearEnabled" [period]="state.period"></fm-map-map-search> | ||||
|   <fm-side-panel [resizeable]="true" [visible]="state.panelVisible" [collapsed]="state.panelCollapsed" [collapsable]="false"> | ||||
|     <div class="panel-wrapper"> | ||||
|   </div> | ||||
|   <fm-side-panel [resizeable]="true" [visible]="state.panelVisible && noContent" [collapsed]="state.panelCollapsed" [collapsable]="false"> | ||||
|     <div class="panel-wrapper" *ngIf="noContent"> | ||||
|       <div class="panel-top bg-secondary" *ngIf="!(state.searchMinified)"> | ||||
|       </div> | ||||
|       <div class="panel-bottom"> | ||||
| @@ -67,6 +70,9 @@ | ||||
|       </div> | ||||
|     </div>   | ||||
|   </fm-side-panel> | ||||
|   <fm-side-panel [resizeable]="true" [visible]="!noContent"> | ||||
|     <router-outlet></router-outlet> | ||||
|   </fm-side-panel> | ||||
| </ng-container> | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -49,6 +49,10 @@ aol-map { position:absolute;width:100%;height:calc(100vh + 4rem);} | ||||
| .control-container { | ||||
|   position: absolute; | ||||
|   right: 1em; | ||||
|   bottom: 8.1em; | ||||
| } | ||||
|  | ||||
| .fullscreen .control-container { | ||||
|   bottom: 5em; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { Component, OnInit, OnDestroy, HostListener, ViewChild, AfterViewInit,NgZone } from '@angular/core'; | ||||
| import { Component, OnInit, OnDestroy, HostListener, ViewChild, AfterViewInit,NgZone,ElementRef } from '@angular/core'; | ||||
| import { Location } from '@angular/common'; | ||||
| import { Observable, Subject, Subscription, from,of ,EMPTY } from 'rxjs'; | ||||
| import { withLatestFrom, switchMap,skip  } from 'rxjs/operators'; | ||||
| @@ -79,10 +79,13 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | ||||
|   public overlayLayersCollapsed: boolean = true; | ||||
|   public extent$: Observable<Extent> = this.store.select(mapReducers.selectGetExtent); | ||||
|   public styles$:Observable<IStyles> = this.store.select(mapReducers.selectGetStyles); | ||||
|   public fullscreen$: Observable<boolean> = this.store.select(commonReducers.selectGetFullScreen); | ||||
|   private lastUrl = ""; | ||||
|   private initialized: boolean = false; | ||||
|   public noContent: boolean = false; | ||||
|  | ||||
|   @ViewChild('map') map; | ||||
|   @ViewChild('contentDiv') contentDiv: ElementRef; | ||||
|  | ||||
|   constructor(private store: Store<mapReducers.State | commonReducers.State>, | ||||
|     private route: ActivatedRoute, | ||||
| @@ -237,23 +240,27 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | ||||
|  | ||||
|   ngAfterViewInit() { | ||||
|     console.debug("View init"); | ||||
|     if(this.route.children.length == 0) { | ||||
|       this.noContent=true; | ||||
|     }  | ||||
|        | ||||
|     this.initCustomStyles(); | ||||
|  | ||||
|     // url to state | ||||
|  | ||||
|       let urlMapState = this.getMapStateFromUrl(this.route.snapshot.paramMap); | ||||
|       let urlQueryState = this.getQueryStateFromUrl(this.route.snapshot.paramMap); | ||||
|       if(urlQueryState && urlMapState) { | ||||
|       if(urlQueryState && urlMapState && this.noContent) { | ||||
|         this.store.dispatch(new mapActions.SetState(urlMapState,urlQueryState)); | ||||
|         window.localStorage.setItem("FarmMapsCommonMap_mapState",this.serializeMapState(urlMapState)); | ||||
|       } else if(urlQueryState) { | ||||
|       } else if(urlQueryState && this.noContent) { | ||||
|         this.store.dispatch(new mapActions.SetQueryState(urlQueryState)); | ||||
|       }  else { | ||||
|         this.store.dispatch(new mapActions.SetReplaceUrl(true)); | ||||
|       } | ||||
|  | ||||
|       this.paramSub = this.route.paramMap.pipe(withLatestFrom(this.state$),switchMap(([params,state]) => { | ||||
|          if(this.initialized) { | ||||
|          if(this.initialized && this.noContent) { | ||||
|           let urlQueryState = this.getQueryStateFromUrl(params); | ||||
|           if( this.serializeService.serialize(state.queryState) != this.serializeService.serialize(urlQueryState)) { | ||||
|             return of(new mapActions.SetState(state.mapState,urlQueryState)); | ||||
| @@ -318,7 +325,7 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | ||||
|   } | ||||
|  | ||||
|   replaceUrl(mapState: IMapState, queryState: IQueryState, replace: boolean = true) { | ||||
|       | ||||
|       if(this.noContent) { | ||||
|         let newMapState = this.serializeMapState(mapState); | ||||
|         let newQueryState = this.serializeService.serialize(queryState); | ||||
|         let currentMapState = this.serializeMapState(this.getMapStateFromUrl(this.route.snapshot.paramMap)); | ||||
| @@ -337,6 +344,7 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | ||||
|           this.router.navigate(parts, { replaceUrl: replace,relativeTo:this.route.parent }); | ||||
|         }   | ||||
|       }      | ||||
|   } | ||||
|  | ||||
|   handleOnMoveEnd(event) {     | ||||
|     if(this.initialized) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user