UNPKG

angular-bootstrap-italia

Version:

<p align="center"> <h1 align="center">Bootstrap Italia + Angular 9</h1>

210 lines 26.3 kB
import { __decorate, __values } 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'; var LeafletMapComponent = /** @class */ (function () { function LeafletMapComponent() { 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 } }; } LeafletMapComponent.prototype.ngOnInit = function () { var _this = this; 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: '&copy; <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) { var drawControl = new L.Control.Draw(this.options); this.map.addControl(drawControl); } this.map.on(L.Draw.Event.CREATED, function (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, function (e) { e.layers.eachLayer(function (layer) { var _a, _b; var lyIndex = -1; _this.drawnLayers.forEach(function (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 var fullLayer = L.geoJSON(this.geoJsonFeatureList); var layers = fullLayer.getLayers(); layers.forEach(function (layer) { _this.drawnLayers.push({ layer: layer, type: 'Feature' }); _this.editableLayers.addLayer(layer); }); this.map.fitBounds(fullLayer.getBounds()); }; LeafletMapComponent.prototype.ngOnChanges = function (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)) { var 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(); }; LeafletMapComponent.prototype.getBoundBoxFromPolygon = function (coordinates) { var e_1, _a; var lats = []; var lngs = []; try { for (var _b = __values(coordinates[0]), _c = _b.next(); !_c.done; _c = _b.next()) { var coordinate = _c.value; lats.push(coordinate[1]); lngs.push(coordinate[0]); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } // calc the min and max lng and lat var minlat = Math.min.apply(null, lats); var maxlat = Math.max.apply(null, lats); var minlng = Math.min.apply(null, lngs); var maxlng = Math.max.apply(null, lngs); // create a bounding rectangle that can be used in leaflet return [[minlat, minlng], [maxlat, maxlng]]; }; LeafletMapComponent.prototype.layerToGeoJson = function (layer, layerType) { var geoJson = layer.toGeoJSON(); if (layerType === 'circle') { var radius = layer.getRadius(); geoJson.properties.radius = radius; } return geoJson; }; LeafletMapComponent.prototype.updateMapGeoJson = function () { var _this = this; var drawnLayersGeoJson = []; if (this.drawnLayers) { this.drawnLayers.forEach(function (e) { var 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); return 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"]}