angular-bootstrap-italia
Version:
<p align="center"> <h1 align="center">Bootstrap Italia + Angular 9</h1>
196 lines • 25.4 kB
JavaScript
import { __decorate } from "tslib";
import { Component, Input, Output, EventEmitter } from '@angular/core';
import * as L from 'leaflet';
// Leaflet Draw
import 'leaflet-draw';
import drawLocales from 'leaflet-draw-locales';
let LeafletMapComponent = class LeafletMapComponent {
constructor() {
this.geoJson = new EventEmitter();
this.editableLayers = new L.FeatureGroup();
this.options = {
position: 'topright',
draw: {
marker: {
icon: L.icon({
iconSize: [25, 41],
iconAnchor: [13, 41],
iconUrl: 'assets/marker-icon.png',
shadowUrl: 'assets/marker-shadow.png'
})
},
// rectangle: { showArea: false }, // disable showArea
rectangle: false,
polyline: false,
polygon: true,
circlemarker: false
},
edit: {
featureGroup: this.editableLayers,
remove: true
}
};
}
ngOnInit() {
this.drawnLayers = [];
// initialize Leaflet
this.map = L.map('mapid', {
center: [this.latitude, this.longitude],
zoom: 6,
scrollWheelZoom: true
});
// add the OpenStreetMap tiles
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
maxZoom: 19,
attribution: '© <a href="https://openstreetmap.org/copyright">OpenStreetMap</a> contributors',
}).addTo(this.map);
// Center Marker
// this.userCenterMarker = L.marker([this.latitude, this.longitude]).addTo(this.map);
// show the scale bar on the lower left corner
L.control.scale().addTo(this.map);
// Automatically defines Leaflet.draw to the specified language
drawLocales('it');
this.map.addLayer(this.editableLayers);
if (this.enableEdit) {
const drawControl = new L.Control.Draw(this.options);
this.map.addControl(drawControl);
}
this.map.on(L.Draw.Event.CREATED, (e) => {
this.drawnLayers.push({ layer: e.layer, type: e.layerType });
this.editableLayers.addLayer(e.layer);
// Output GeoJSON
this.updateMapGeoJson();
});
this.map.on(L.Draw.Event.DELETED, (e) => {
e.layers.eachLayer(layer => {
var _a, _b;
let lyIndex = -1;
this.drawnLayers.forEach((value, index) => {
if (value.layer._leaflet_id === layer._leaflet_id) {
lyIndex = index;
}
});
if (lyIndex > -1) {
this.drawnLayers.splice(lyIndex, 1);
}
if (((_a = this.locationBoundingBox) === null || _a === void 0 ? void 0 : _a._leaflet_id) === layer._leaflet_id) {
this.locationBoundingBox = null;
}
if (((_b = this.userCenterMarker) === null || _b === void 0 ? void 0 : _b._leaflet_id) === layer._leaflet_id) {
this.userCenterMarker = null;
}
});
this.updateMapGeoJson();
});
// Input GeoJson feature list
const fullLayer = L.geoJSON(this.geoJsonFeatureList);
const layers = fullLayer.getLayers();
layers.forEach(layer => {
this.drawnLayers.push({ layer, type: 'Feature' });
this.editableLayers.addLayer(layer);
});
this.map.fitBounds(fullLayer.getBounds());
}
ngOnChanges(changes) {
var _a, _b;
if (this.map && (changes.latitude || changes.longitude)) {
this.map.setView([this.latitude, this.longitude], 6);
if (this.userCenterMarker) {
this.map.removeLayer(this.userCenterMarker);
}
this.userCenterMarker = L.marker([this.latitude, this.longitude], {
icon: L.icon({
iconSize: [25, 41],
iconAnchor: [13, 41],
iconUrl: 'assets/marker-icon.png',
shadowUrl: 'assets/marker-shadow.png'
})
});
this.editableLayers.addLayer(this.userCenterMarker);
}
if (changes.bboxPolygon && ((_a = this.bboxPolygon) === null || _a === void 0 ? void 0 : _a.coordinates)) {
const bbox = this.getBoundBoxFromPolygon(this.bboxPolygon.coordinates);
if (this.locationBoundingBox) {
this.map.removeLayer(this.locationBoundingBox);
}
// add the bounding box to the map, and set the map extent to it
// this.locationBoundingBox = L.rectangle(bbox);
// this.editableLayers.addLayer(this.locationBoundingBox);
this.map.fitBounds(bbox);
}
if (changes.shapePolygon && ((_b = this.shapePolygon) === null || _b === void 0 ? void 0 : _b.coordinates)) {
this.locationBoundingBox = L.geoJSON(this.shapePolygon);
this.editableLayers.addLayer(this.locationBoundingBox);
}
this.updateMapGeoJson();
}
getBoundBoxFromPolygon(coordinates) {
const lats = [];
const lngs = [];
for (const coordinate of coordinates[0]) {
lats.push(coordinate[1]);
lngs.push(coordinate[0]);
}
// calc the min and max lng and lat
const minlat = Math.min.apply(null, lats);
const maxlat = Math.max.apply(null, lats);
const minlng = Math.min.apply(null, lngs);
const maxlng = Math.max.apply(null, lngs);
// create a bounding rectangle that can be used in leaflet
return [[minlat, minlng], [maxlat, maxlng]];
}
layerToGeoJson(layer, layerType) {
const geoJson = layer.toGeoJSON();
if (layerType === 'circle') {
const radius = layer.getRadius();
geoJson.properties.radius = radius;
}
return geoJson;
}
updateMapGeoJson() {
const drawnLayersGeoJson = [];
if (this.drawnLayers) {
this.drawnLayers.forEach(e => {
const geojson = this.layerToGeoJson(e.layer, e.type);
drawnLayersGeoJson.push(geojson);
});
}
if (this.userCenterMarker) {
drawnLayersGeoJson.push(this.userCenterMarker.toGeoJSON());
}
if (this.locationBoundingBox) {
drawnLayersGeoJson.push(this.locationBoundingBox.toGeoJSON());
}
this.geoJson.emit(drawnLayersGeoJson);
}
};
__decorate([
Input()
], LeafletMapComponent.prototype, "latitude", void 0);
__decorate([
Input()
], LeafletMapComponent.prototype, "longitude", void 0);
__decorate([
Input()
], LeafletMapComponent.prototype, "enableEdit", void 0);
__decorate([
Input()
], LeafletMapComponent.prototype, "bboxPolygon", void 0);
__decorate([
Input()
], LeafletMapComponent.prototype, "shapePolygon", void 0);
__decorate([
Input()
], LeafletMapComponent.prototype, "geoJsonFeatureList", void 0);
__decorate([
Output()
], LeafletMapComponent.prototype, "geoJson", void 0);
LeafletMapComponent = __decorate([
Component({
selector: 'lib-leaflet-map',
template: "<div id=\"mapid\"></div>\r\n",
styles: ["#mapid{height:500px}"]
})
], LeafletMapComponent);
export { LeafletMapComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaflet-map.component.js","sourceRoot":"ng://angular-bootstrap-italia/","sources":["lib/components/leaflet/leaflet-map/leaflet-map.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnChanges, Output, EventEmitter, SimpleChanges } from '@angular/core';\r\nimport * as L from 'leaflet';\r\n\r\n// Leaflet Draw\r\nimport 'leaflet-draw';\r\nimport drawLocales from 'leaflet-draw-locales';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-leaflet-map',\r\n  templateUrl: './leaflet-map.component.html',\r\n  styleUrls: ['./leaflet-map.component.scss']\r\n})\r\nexport class LeafletMapComponent implements OnInit, OnChanges {\r\n\r\n  // @Input() mapId: string;\r\n  @Input() latitude: number;\r\n  @Input() longitude: number;\r\n  @Input() enableEdit: boolean;\r\n  @Input() bboxPolygon: any;\r\n  @Input() shapePolygon: any;\r\n  @Input() geoJsonFeatureList: any[];\r\n\r\n  @Output() geoJson = new EventEmitter();\r\n\r\n  private map;\r\n  private userCenterMarker;\r\n\r\n  private drawnLayers: any[];\r\n  private locationBoundingBox;\r\n\r\n  private editableLayers = new L.FeatureGroup();\r\n  private options = {\r\n    position: 'topright',\r\n    draw: {\r\n      marker: {\r\n        icon: L.icon({\r\n          iconSize: [25, 41],\r\n          iconAnchor: [13, 41],\r\n          iconUrl: 'assets/marker-icon.png',\r\n          shadowUrl: 'assets/marker-shadow.png'\r\n        })\r\n      },\r\n      // rectangle: { showArea: false }, // disable showArea\r\n      rectangle: false,\r\n      polyline: false,\r\n      polygon: true,\r\n      circlemarker: false\r\n    },\r\n    edit: {\r\n      featureGroup: this.editableLayers, // REQUIRED!!\r\n      remove: true\r\n    }\r\n  };\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.drawnLayers = [];\r\n\r\n    // initialize Leaflet\r\n    this.map = L.map('mapid', {\r\n      center: [this.latitude, this.longitude],\r\n      zoom: 6,\r\n      scrollWheelZoom: true\r\n    });\r\n\r\n    // add the OpenStreetMap tiles\r\n    L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {\r\n      maxZoom: 19,\r\n      attribution: '&copy; <a href=\"https://openstreetmap.org/copyright\">OpenStreetMap</a> contributors',\r\n    }).addTo(this.map);\r\n\r\n    // Center Marker\r\n    // this.userCenterMarker = L.marker([this.latitude, this.longitude]).addTo(this.map);\r\n\r\n    // show the scale bar on the lower left corner\r\n    L.control.scale().addTo(this.map);\r\n\r\n    // Automatically defines Leaflet.draw to the specified language\r\n    drawLocales('it');\r\n\r\n    this.map.addLayer(this.editableLayers);\r\n\r\n    if (this.enableEdit) {\r\n      const drawControl = new L.Control.Draw(this.options);\r\n      this.map.addControl(drawControl);\r\n    }\r\n\r\n    this.map.on(L.Draw.Event.CREATED, (e) => {\r\n      this.drawnLayers.push({ layer: e.layer, type: e.layerType });\r\n\r\n      this.editableLayers.addLayer(e.layer);\r\n\r\n      // Output GeoJSON\r\n      this.updateMapGeoJson();\r\n    });\r\n\r\n    this.map.on(L.Draw.Event.DELETED, (e) => {\r\n      e.layers.eachLayer(layer => {\r\n        let lyIndex = -1;\r\n        this.drawnLayers.forEach((value, index) => {\r\n          if (value.layer._leaflet_id === layer._leaflet_id) {\r\n            lyIndex = index;\r\n          }\r\n        });\r\n\r\n        if (lyIndex > -1) {\r\n          this.drawnLayers.splice(lyIndex, 1);\r\n        }\r\n\r\n        if (this.locationBoundingBox?._leaflet_id === layer._leaflet_id) {\r\n          this.locationBoundingBox = null;\r\n        }\r\n\r\n        if (this.userCenterMarker?._leaflet_id === layer._leaflet_id) {\r\n          this.userCenterMarker = null;\r\n        }\r\n      });\r\n\r\n      this.updateMapGeoJson();\r\n    });\r\n\r\n    // Input GeoJson feature list\r\n    const fullLayer = L.geoJSON(this.geoJsonFeatureList);\r\n    const layers = fullLayer.getLayers();\r\n    layers.forEach(layer => {\r\n      this.drawnLayers.push({ layer, type: 'Feature' });\r\n      this.editableLayers.addLayer(layer);\r\n    });\r\n\r\n    this.map.fitBounds(fullLayer.getBounds());\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (this.map && (changes.latitude || changes.longitude)) {\r\n      this.map.setView([this.latitude, this.longitude], 6);\r\n\r\n      if (this.userCenterMarker) {\r\n        this.map.removeLayer(this.userCenterMarker);\r\n      }\r\n\r\n      this.userCenterMarker = L.marker(\r\n        [this.latitude, this.longitude],\r\n        {\r\n          icon: L.icon({\r\n            iconSize: [25, 41],\r\n            iconAnchor: [13, 41],\r\n            iconUrl: 'assets/marker-icon.png',\r\n            shadowUrl: 'assets/marker-shadow.png'\r\n          })\r\n        });\r\n\r\n      this.editableLayers.addLayer(this.userCenterMarker);\r\n    }\r\n\r\n    if (changes.bboxPolygon && this.bboxPolygon?.coordinates) {\r\n      const bbox = this.getBoundBoxFromPolygon(this.bboxPolygon.coordinates);\r\n\r\n      if (this.locationBoundingBox) {\r\n        this.map.removeLayer(this.locationBoundingBox);\r\n      }\r\n\r\n      // add the bounding box to the map, and set the map extent to it\r\n      // this.locationBoundingBox = L.rectangle(bbox);\r\n      // this.editableLayers.addLayer(this.locationBoundingBox);\r\n      this.map.fitBounds(bbox);\r\n    }\r\n\r\n    if (changes.shapePolygon && this.shapePolygon?.coordinates) {\r\n      this.locationBoundingBox = L.geoJSON(this.shapePolygon);\r\n      this.editableLayers.addLayer(this.locationBoundingBox);\r\n    }\r\n\r\n    this.updateMapGeoJson();\r\n  }\r\n\r\n  getBoundBoxFromPolygon(coordinates) {\r\n    const lats = [];\r\n    const lngs = [];\r\n\r\n    for (const coordinate of coordinates[0]) {\r\n      lats.push(coordinate[1]);\r\n      lngs.push(coordinate[0]);\r\n    }\r\n\r\n    // calc the min and max lng and lat\r\n    const minlat = Math.min.apply(null, lats);\r\n    const maxlat = Math.max.apply(null, lats);\r\n    const minlng = Math.min.apply(null, lngs);\r\n    const maxlng = Math.max.apply(null, lngs);\r\n\r\n    // create a bounding rectangle that can be used in leaflet\r\n    return [[minlat, minlng], [maxlat, maxlng]];\r\n  }\r\n\r\n  layerToGeoJson(layer: any, layerType: any) {\r\n    const geoJson = layer.toGeoJSON();\r\n    if (layerType === 'circle') {\r\n      const radius = layer.getRadius();\r\n      geoJson.properties.radius = radius;\r\n    }\r\n\r\n    return geoJson;\r\n  }\r\n\r\n  updateMapGeoJson() {\r\n    const drawnLayersGeoJson = [];\r\n\r\n    if (this.drawnLayers) {\r\n      this.drawnLayers.forEach(e => {\r\n        const geojson = this.layerToGeoJson(e.layer, e.type);\r\n        drawnLayersGeoJson.push(geojson);\r\n      });\r\n    }\r\n\r\n    if (this.userCenterMarker) {\r\n      drawnLayersGeoJson.push(this.userCenterMarker.toGeoJSON());\r\n    }\r\n\r\n    if (this.locationBoundingBox) {\r\n      drawnLayersGeoJson.push(this.locationBoundingBox.toGeoJSON());\r\n    }\r\n\r\n    this.geoJson.emit(drawnLayersGeoJson);\r\n  }\r\n}\r\n"]}