Renamed prefixes in angular.json
All checks were successful
FarmMaps.Develop/FarmMapsLib/develop This commit looks good
All checks were successful
FarmMaps.Develop/FarmMapsLib/develop This commit looks good
This commit is contained in:
@@ -0,0 +1,29 @@
|
||||
<div class="layerlist" *ngIf="itemLayers.length > 0;else noLayers">
|
||||
<div class="list-group">
|
||||
<div *ngFor="let itemLayer of itemLayers" class="list-group-item list-group-item-action p-2 text-truncate" [ngClass]="{'active' : selectedLayer==itemLayer}">
|
||||
<div (click)="handleSelectLayer($event,itemLayer)" [title]="itemLayer.item.name">{{itemLayer.item.name}}</div>
|
||||
<div class="mt-1" *ngIf="selectedLayer==itemLayer && !baseLayers">
|
||||
<span class="btn-group">
|
||||
<a title="Toggle visibility"href="#" class="btn btn-light btn-sm" (click)="handleToggleVisibility($event,itemLayer)"><i class="fa" aria-hidden="true" [ngClass]="{'fa-eye':!itemLayer.visible,'fa-eye-slash':itemLayer.visible}"></i></a>
|
||||
<a title="Transparency 25%" *ngIf="itemLayer.visible" href="#" class="btn btn-light btn-sm" (click)="handleSetOpacity($event,itemLayer,0.25)">25%</a>
|
||||
<a title="Transparency 50%" *ngIf="itemLayer.visible" href="#" class="btn btn-light btn-sm" (click)="handleSetOpacity($event,itemLayer,0.5)">50%</a>
|
||||
<a title="Transparency 75%" *ngIf="itemLayer.visible" href="#" class="btn btn-light btn-sm" (click)="handleSetOpacity($event,itemLayer,0.75)">75%</a>
|
||||
<a title="No transparency" *ngIf="itemLayer.visible" href="#" class="btn btn-light btn-sm" (click)="handleSetOpacity($event,itemLayer,1)">100%</a>
|
||||
</span>
|
||||
<a href="#" title="Zoom to extent" class="btn btn-light btn-sm" (click)="handleZoomToExtent($event,itemLayer)"><i class="fa fa-search-plus" aria-hidden="true"></i></a>
|
||||
<span *ngIf="firstLayer(itemLayer)"><a href="#" title="Toggle legend" class="btn btn-light btn-sm" (click)="itemLayer.legendVisible=toggleLegend($event,itemLayer.legendVisible)"><i class="fa fa-bar-chart" aria-hidden="true"></i></a></span>
|
||||
<span class="float-right"><a href="#" title="Remove overlay" class="btn btn-light btn-sm" (click)="handleDelete($event,itemLayer)"><i class="fa fa-minus" aria-hidden="true"></i></a></span>
|
||||
</div>
|
||||
<div *ngIf="itemLayer.legendVisible">
|
||||
<div class="card legend">
|
||||
<fm-map-layer-legend [layer]="firstLayer(itemLayer)" (click)="handleLegendClick($event,itemLayer);"></fm-map-layer-legend>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<ng-template #noLayers>
|
||||
<div class="list-group">
|
||||
<div class="list-group-item" i18n>No layers</div>
|
||||
</div>
|
||||
</ng-template>
|
@@ -0,0 +1,18 @@
|
||||
.layerlist ul {
|
||||
list-style:none;
|
||||
padding:0;
|
||||
}
|
||||
|
||||
.active span.btn.btn-lnk.p-0.border-0 {
|
||||
color:white;
|
||||
}
|
||||
|
||||
.btn-sm {
|
||||
padding:0.25rem 0.3rem;
|
||||
}
|
||||
|
||||
.legend {
|
||||
margin-top:0.5rem;
|
||||
color:black;
|
||||
padding:0.25rem;
|
||||
}
|
@@ -0,0 +1,64 @@
|
||||
import { Component,Input,Output,EventEmitter } from '@angular/core';
|
||||
import { IItemLayer } from '../../../models';
|
||||
|
||||
@Component({
|
||||
selector: 'fm-map-layer-list',
|
||||
templateUrl: './layer-list.component.html',
|
||||
styleUrls: ['./layer-list.component.scss']
|
||||
})
|
||||
|
||||
export class LayerListComponent {
|
||||
@Input() itemLayers: IItemLayer[];
|
||||
@Input() baseLayers: boolean = false;
|
||||
@Output() onToggleVisibility = new EventEmitter<IItemLayer>();
|
||||
@Output() onSetOpacity = new EventEmitter<{layer: IItemLayer,opacity:number }>();
|
||||
@Output() onDelete = new EventEmitter<IItemLayer>();
|
||||
@Output() onZoomToExtent = new EventEmitter<IItemLayer>();
|
||||
@Output() onSelectLayer = new EventEmitter<IItemLayer>();
|
||||
@Input() selectedLayer: IItemLayer;
|
||||
|
||||
constructor( ) {
|
||||
}
|
||||
|
||||
handleDelete(event:MouseEvent, item:IItemLayer) {
|
||||
this.onDelete.emit(item);
|
||||
event.preventDefault();
|
||||
}
|
||||
|
||||
handleToggleVisibility(event:MouseEvent, item: IItemLayer) {
|
||||
this.onToggleVisibility.emit(item);
|
||||
item.legendVisible = item.visible && item.legendVisible;
|
||||
event.preventDefault();
|
||||
}
|
||||
|
||||
handleSetOpacity(event: MouseEvent, layer: IItemLayer,opacity:number) {
|
||||
this.onSetOpacity.emit({ layer,opacity });
|
||||
event.preventDefault();
|
||||
}
|
||||
|
||||
handleZoomToExtent(event: MouseEvent, item: IItemLayer) {
|
||||
this.onZoomToExtent.emit(item);
|
||||
event.preventDefault();
|
||||
}
|
||||
|
||||
handleSelectLayer(event: MouseEvent, item: IItemLayer) {
|
||||
this.onSelectLayer.emit(item);
|
||||
event.preventDefault();
|
||||
}
|
||||
|
||||
firstLayer(item: IItemLayer): any {
|
||||
if (item && item.item && item.item.data && item.item.data.layers && item.item.data.layers.length > 0) return item.item.data.layers[0];
|
||||
return null;
|
||||
}
|
||||
|
||||
toggleLegend(event: MouseEvent, lg: boolean) {
|
||||
event.preventDefault();
|
||||
return !lg;
|
||||
}
|
||||
|
||||
handleLegendClick(event: MouseEvent, item: IItemLayer) {
|
||||
this.onSelectLayer.emit(item);
|
||||
this.onZoomToExtent.emit(item);
|
||||
event.preventDefault();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user