Compare commits
	
		
			8 Commits
		
	
	
		
			d9848a8ba3
			...
			914e272fc2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 914e272fc2 | |||
|  | b182b7fda6 | ||
|  | 22040b43b3 | ||
|  | 50170cf599 | ||
|  | 2deff46a7e | ||
|  | e939a787ba | ||
|  | 4ae9562ce1 | ||
|  | 288e507e6c | 
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "farmmaps-lib-app", | ||||
|   "version": "3.3.0", | ||||
|   "version": "3.4.0", | ||||
|   "scripts": { | ||||
|     "ng": "ng", | ||||
|     "start": "ng serve", | ||||
|   | ||||
| @@ -5,7 +5,7 @@ import { IItemLayer } from '../models/item.layer'; | ||||
| import { ILayervalue } from '../models/layer.value'; | ||||
| import { IQueryState } from '@farmmaps/common'; | ||||
| import { IItem } from '@farmmaps/common'; | ||||
| import { Feature } from 'ol'; | ||||
| import { Feature, Observable } from 'ol'; | ||||
| import { Style } from 'ol/style'; | ||||
| import { Geometry } from 'ol/geom'; | ||||
| import { IPeriodState } from '../models/period.state'; | ||||
| @@ -56,7 +56,7 @@ export const GETLAYERVALUE = '[Map] GetLayerValue' | ||||
| export const GETLAYERVALUESUCCESS = '[Map] GetLayerValueSuccess' | ||||
| export const TOGGLESHOWDATALAYERSLIDE = '[Map] ToggleShowDataLayerSlide' | ||||
| export const SETVIEWSTATE = '[Map] SetViewState' | ||||
|  | ||||
| export const SETCODELIST = '[Map] SetCodeList' | ||||
|  | ||||
| export class Clear implements Action { | ||||
|   readonly type = CLEAR; | ||||
| @@ -329,6 +329,12 @@ export class SetViewState implements Action { | ||||
|   constructor(public enabled:boolean) {} | ||||
| } | ||||
|  | ||||
| export class SetCodeList implements Action { | ||||
|   readonly type = SETCODELIST; | ||||
|  | ||||
|   constructor(public itemType:string, public values: IItem[]) { } | ||||
| } | ||||
|  | ||||
| export type Actions = SetMapState | ||||
|   | Init | ||||
|   | Clear | ||||
| @@ -374,5 +380,6 @@ export type Actions = SetMapState | ||||
|   | GetLayerValue | ||||
|   | SetPeriod | ||||
|   | ToggleShowDataLayerSlide | ||||
|   | SetViewState; | ||||
|   | SetViewState | ||||
|   | SetCodeList; | ||||
|  | ||||
|   | ||||
| @@ -250,8 +250,8 @@ export class ItemLayersComponent extends LayerGroupComponent implements OnChange | ||||
|             return new style.Style( | ||||
|               {                | ||||
|                 stroke: new style.Stroke({ | ||||
|                   color: 'red', | ||||
|                   width: 2 | ||||
|                   color: '#0d6efd', | ||||
|                   width: 3 | ||||
|                 }) | ||||
|               } | ||||
|             ); | ||||
|   | ||||
| @@ -36,6 +36,7 @@ import {Extent,createEmpty,extend } from 'ol/extent'; | ||||
| import {transform} from 'ol/proj'; | ||||
| import { tassign } from 'tassign'; | ||||
| import * as style from 'ol/style'; | ||||
| import { ICodeLists } from '../../models/codelist.cache'; | ||||
|  | ||||
|  | ||||
| @Component({ | ||||
| @@ -85,6 +86,8 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | ||||
|   public overlayLayersCollapsed = true; | ||||
|   public extent$: Observable<Extent> = this.store.select(mapReducers.selectGetExtent); | ||||
|   public styles$:Observable<IStyles> = this.store.select(mapReducers.selectGetStyles); | ||||
|   public codeLists$: Observable<ICodeLists> = this.store.select(mapReducers.selectGetCodeLists); | ||||
|   public codeList$ = (id: string) => this.store.select(mapReducers.selectGetCodeList(id)); | ||||
|   public fullscreen$: Observable<boolean> = this.store.select(commonReducers.selectGetFullScreen); | ||||
|   private lastUrl = ""; | ||||
|   private initialized = false; | ||||
|   | ||||
| @@ -5,7 +5,7 @@ import { ROUTER_NAVIGATED, RouterReducerState } from '@ngrx/router-store'; | ||||
| import * as fromRouter from '@ngrx/router-store'; | ||||
| import { createEffect, Actions, ofType } from '@ngrx/effects'; | ||||
|  | ||||
| import { EMPTY, Observable, of } from 'rxjs'; | ||||
| import { EMPTY, Observable, of, forkJoin } from 'rxjs'; | ||||
| import { withLatestFrom, switchMap, map, catchError, mergeMap } from 'rxjs/operators'; | ||||
|  | ||||
| import { GeoJSON, WKT } from 'ol/format'; | ||||
| @@ -99,6 +99,65 @@ export class MapEffects { | ||||
|           color: 'rgba(0, 0, 0, 0)' | ||||
|         }) | ||||
|       }))); | ||||
|       // cache code lists | ||||
|       forkJoin([ | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl017'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl018'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl020'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl022'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl104'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl127'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl232'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl251'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl256'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl259'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl263'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl264'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl290'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl291'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl293'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl405'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl411'), | ||||
|         this.itemService$.getItemList('vnd.farmmaps.itemtype.codelist.cl421'), | ||||
|       ]).subscribe(([ | ||||
|         cl017, | ||||
|         cl018, | ||||
|         cl020, | ||||
|         cl022, | ||||
|         cl104, | ||||
|         cl127, | ||||
|         cl232, | ||||
|         cl251, | ||||
|         cl256, | ||||
|         cl259, | ||||
|         cl263, | ||||
|         cl264, | ||||
|         cl290, | ||||
|         cl291, | ||||
|         cl293, | ||||
|         cl405, | ||||
|         cl411, | ||||
|         cl421, | ||||
|       ]) => { | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl017', cl017)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl018', cl018)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl020', cl020)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl020', cl020)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl104', cl104)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl127', cl127)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl232', cl232)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl251', cl251)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl256', cl256)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl259', cl259)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl263', cl263)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl264', cl264)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl290', cl290)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl291', cl291)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl293', cl293)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl405', cl405)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl411', cl411)); | ||||
|         actions.push(new mapActions.SetCodeList('vnd.farmmaps.itemtype.codelist.cl421', cl421)); | ||||
|       }); | ||||
|  | ||||
|       return actions; | ||||
|     } | ||||
|   | ||||
							
								
								
									
										5
									
								
								projects/common-map/src/fm-map/models/codelist.cache.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								projects/common-map/src/fm-map/models/codelist.cache.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| import { IItem } from '@farmmaps/common'; | ||||
|  | ||||
| export interface ICodeLists { | ||||
|   [id: string]: IItem[]; | ||||
| } | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { tassign } from 'tassign'; | ||||
| import { IItem,Item } from '@farmmaps/common'; | ||||
| import { IItem } from '@farmmaps/common'; | ||||
| import { IItemLayer,ItemLayer,ITemporalItemLayer,TemporalItemLayer} from '../models/item.layer'; | ||||
| import { IMapState} from '../models/map.state'; | ||||
| import { IQueryState} from '@farmmaps/common'; | ||||
| @@ -17,6 +17,7 @@ import {Geometry} from 'ol/geom'; | ||||
| import { ROUTER_NAVIGATION, RouterNavigationAction } from '@ngrx/router-store'; | ||||
|  | ||||
| import { MODULE_NAME } from '../module-name'; | ||||
| import { ICodeLists } from '../models/codelist.cache'; | ||||
|  | ||||
| const startDate:Date = new Date(new Date(Date.now()).getFullYear(), new Date(Date.now()).getMonth() - 3, 1); | ||||
| const endDate:Date = new Date(Date.now()); | ||||
| @@ -72,7 +73,8 @@ export interface State { | ||||
|   layerValuesEnabled:boolean, | ||||
|   layerValues: Array<ILayervalue> | ||||
|   showDataLayerSlide:boolean, | ||||
|   viewEnabled:boolean | ||||
|   viewEnabled: boolean, | ||||
|   codeLists:ICodeLists, | ||||
| } | ||||
|  | ||||
| export const initialState: State = { | ||||
| @@ -117,7 +119,8 @@ export const initialState: State = { | ||||
|   layerValuesEnabled:false, | ||||
|   layerValues:[], | ||||
|   showDataLayerSlide:false, | ||||
|   viewEnabled:true | ||||
|   viewEnabled: true, | ||||
|   codeLists: {} | ||||
| } | ||||
|  | ||||
| export function reducer(state = initialState, action: mapActions.Actions | commonActions.Actions | RouterNavigationAction): State { | ||||
| @@ -569,6 +572,12 @@ export function reducer(state = initialState, action: mapActions.Actions | commo | ||||
|       } | ||||
|       return state; | ||||
|     } | ||||
|     case mapActions.SETCODELIST:{ | ||||
|       const a = action as mapActions.SetCodeList; | ||||
|       const codeLists = tassign(state.codeLists); | ||||
|       codeLists[a.itemType] = a.values; | ||||
|       return tassign(state,{codeLists:codeLists}); | ||||
|     } | ||||
|     default: { | ||||
|       return state; | ||||
|     } | ||||
| @@ -588,6 +597,7 @@ export const getClearEnabled = (state: State) => state.clearEnabled; | ||||
| export const getSearchCollapsed = (state: State) => state.searchCollapsed; | ||||
| export const getSearchMinified = (state: State) => state.searchMinified; | ||||
| export const getExtent = (state: State) => state.extent; | ||||
| export const getViewExtent = (state: State) => state.viewExtent; | ||||
| export const getOverlayLayers = (state: State) => state.overlayLayers; | ||||
| export const getBaseLayers = (state: State) => state.baseLayers; | ||||
| export const getProjection = (state: State) => state.projection; | ||||
| @@ -606,7 +616,7 @@ export const getLayerValues = (state:State) => state.layerValues; | ||||
| export const getLayerValuesX = (state:State) => state.layerValuesX; | ||||
| export const getLayerValuesY = (state:State) => state.layerValuesY; | ||||
| export const getViewEnabled = (state:State) => state.viewEnabled; | ||||
|  | ||||
| export const getCodeLists = (state:State) => state.codeLists; | ||||
|  | ||||
| export const selectMapState = createFeatureSelector<State>(MODULE_NAME); | ||||
| export const selectGetMapState= createSelector(selectMapState, getMapState); | ||||
| @@ -622,6 +632,7 @@ export const selectGetClearEnabled = createSelector(selectMapState, getClearEnab | ||||
| export const selectGetSearchCollapsed = createSelector(selectMapState, getSearchCollapsed); | ||||
| export const selectGetSearchMinified = createSelector(selectMapState, getSearchMinified); | ||||
| export const selectGetExtent = createSelector(selectMapState, getExtent); | ||||
| export const selectGetViewExtent = createSelector(selectMapState, getViewExtent); | ||||
| export const selectGetOverlayLayers = createSelector(selectMapState, getOverlayLayers); | ||||
| export const selectGetBaseLayers = createSelector(selectMapState, getBaseLayers); | ||||
| export const selectGetProjection = createSelector(selectMapState, getProjection); | ||||
| @@ -640,5 +651,5 @@ export const selectGetLayerValues = createSelector(selectMapState,getLayerValues | ||||
| export const selectGetLayerValuesX = createSelector(selectMapState,getLayerValuesX); | ||||
| export const selectGetLayerValuesY = createSelector(selectMapState,getLayerValuesY); | ||||
| export const selectGetViewEnabled = createSelector(selectMapState,getViewEnabled); | ||||
|  | ||||
|  | ||||
| export const selectGetCodeLists = createSelector(selectMapState, getCodeLists); | ||||
| export const selectGetCodeList = (id: string) => createSelector(selectGetCodeLists, (codeLists) => codeLists[id]); | ||||
| @@ -73,7 +73,7 @@ export class ItemService { | ||||
|     return this.httpClient.get<IItem>(`${this.ApiEndpoint()}/api/v1/items/${code}/${itemType}`); | ||||
|   } | ||||
|  | ||||
|   getItemList(itemType?: string, dataFilter?: any, level?: number, atItemLocationItemCode?: string, indexed?: boolean, validToday?: boolean): Observable<IItem[]> { | ||||
|   getItemList(itemType?: string, dataFilter?: any, level?: number, atItemLocationItemCode?: string, indexed?: boolean, validToday?: boolean,tags?:string,crs?:string): Observable<IItem[]> { | ||||
|     let params = new HttpParams(); | ||||
|     if(itemType)  params = params.append("it", itemType); | ||||
|     if(dataFilter) params = params.append("df", JSON.stringify(dataFilter)); | ||||
| @@ -81,6 +81,8 @@ export class ItemService { | ||||
|     if(indexed) params = params.append("ind",indexed?"true":"false"); | ||||
|     if (level) params = params.append("lvl", level.toFixed()); | ||||
|     if (validToday) params = params.append("vt", validToday ? "true" : "false"); | ||||
|     if (tags) params = params.append("t", tags); | ||||
|     if (crs) params = params.append("crs", crs); | ||||
|     return this.httpClient.get<IItem[]>(`${this.ApiEndpoint()}/api/v1/items/`, { params: params }); | ||||
|   } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user