@smarterplan/ngx-smarterplan-locations 0.4.7 → 0.4.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/locations/map/map-popup/map-popup.component.mjs +11 -9
- package/esm2022/lib/components/locations/map/map.component.mjs +60 -39
- package/fesm2022/smarterplan-ngx-smarterplan-locations.mjs +69 -46
- package/fesm2022/smarterplan-ngx-smarterplan-locations.mjs.map +1 -1
- package/lib/components/locations/map/map.component.d.ts +7 -4
- package/package.json +2 -2
|
@@ -27,12 +27,14 @@ export class MapPopupComponent {
|
|
|
27
27
|
this.marker.openPopup();
|
|
28
28
|
this.isOnPopup = false;
|
|
29
29
|
this.popuparea = document.querySelector(".leaflet-popup");
|
|
30
|
-
this.popuparea
|
|
31
|
-
this.
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
this.
|
|
35
|
-
|
|
30
|
+
if (this.popuparea) {
|
|
31
|
+
this.popuparea.addEventListener("mouseleave", () => {
|
|
32
|
+
this.closePopup();
|
|
33
|
+
});
|
|
34
|
+
this.popuparea.addEventListener("mouseover", () => {
|
|
35
|
+
this.isOnPopup = true;
|
|
36
|
+
});
|
|
37
|
+
}
|
|
36
38
|
this.marker.on("mouseout", () => {
|
|
37
39
|
this.closePopup();
|
|
38
40
|
});
|
|
@@ -62,10 +64,10 @@ export class MapPopupComponent {
|
|
|
62
64
|
});
|
|
63
65
|
}
|
|
64
66
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapPopupComponent, deps: [{ token: i1.Router }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
65
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapPopupComponent, selector: "lib-map-popup", ngImport: i0, template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [".map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
67
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapPopupComponent, selector: "lib-map-popup", ngImport: i0, template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [":host{display:none!important}:host-context(.leaflet-popup-content){display:block!important}.map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
66
68
|
}
|
|
67
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapPopupComponent, decorators: [{
|
|
68
70
|
type: Component,
|
|
69
|
-
args: [{ selector: 'lib-map-popup', template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [".map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"] }]
|
|
71
|
+
args: [{ selector: 'lib-map-popup', template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [":host{display:none!important}:host-context(.leaflet-popup-content){display:block!important}.map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"] }]
|
|
70
72
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i0.NgZone }] });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwLXBvcHVwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1sb2NhdGlvbnMvc3JjL2xpYi9jb21wb25lbnRzL2xvY2F0aW9ucy9tYXAvbWFwLXBvcHVwL21hcC1wb3B1cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc21hcnRlcnBsYW4tbG9jYXRpb25zL3NyYy9saWIvY29tcG9uZW50cy9sb2NhdGlvbnMvbWFwL21hcC1wb3B1cC9tYXAtcG9wdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBa0IsTUFBTSxlQUFlLENBQUM7Ozs7QUFVMUQsTUFBTSxPQUFPLGlCQUFpQjtJQVlOO0lBQXdCO0lBVjVDLEtBQUssQ0FBUTtJQUViLE1BQU0sQ0FBUztJQUVmLFNBQVMsQ0FBYztJQUV2QixTQUFTLEdBQUcsS0FBSyxDQUFDO0lBRWxCLFlBQVksR0FBRyxJQUFJLENBQUM7SUFFcEIsWUFBb0IsTUFBYyxFQUFVLE1BQWM7UUFBdEMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUFVLFdBQU0sR0FBTixNQUFNLENBQVE7SUFBSSxDQUFDO0lBRS9ELFFBQVE7UUFDSixJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUMsQ0FBQztRQUV4RCxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxXQUFXLEVBQUUsR0FBRyxFQUFFO1lBQzdCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUM7Z0JBQzdCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNyQixDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsU0FBUztRQUNMLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFnQixDQUFDO1FBRXpFLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxFQUFFLEdBQUcsRUFBRTtnQkFDL0MsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3RCLENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxXQUFXLEVBQUUsR0FBRyxFQUFFO2dCQUM5QyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztZQUMxQixDQUFDLENBQUMsQ0FBQztRQUNQLENBQUM7UUFDRCxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxVQUFVLEVBQUUsR0FBRyxFQUFFO1lBQzVCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxVQUFVO1FBQ04sSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDdkIsc0NBQXNDO1FBQ3RDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDWixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUNsQixJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQzdCLENBQUM7UUFDTCxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDWixDQUFDO0lBRUQsaUJBQWlCO1FBQ2IsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDakMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7YUFBTSxDQUFDO1lBQ0osSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzVDLENBQUM7SUFDTCxDQUFDO0lBRUQsS0FBSyxDQUFDLFlBQVksQ0FBQyxLQUFZO1FBQzNCLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRTtZQUNqQixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxFQUFFO2dCQUMzQyxXQUFXLEVBQUUsRUFBRSxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU8sRUFBRTthQUMxQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7d0dBcEVRLGlCQUFpQjs0RkFBakIsaUJBQWlCLHFEQ1Y5QixpbkJBV0E7OzRGRERhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDRSxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBOZ1pvbmUsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBNYXJrZXIgfSBmcm9tICdsZWFmbGV0JztcclxuaW1wb3J0IHsgU3BhY2UsIFZpc2l0IH0gZnJvbSAnQHNtYXJ0ZXJwbGFuL25neC1zbWFydGVycGxhbi1jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLW1hcC1wb3B1cCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL21hcC1wb3B1cC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbWFwLXBvcHVwLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIE1hcFBvcHVwQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgICBzcGFjZTogU3BhY2U7XHJcblxyXG4gICAgbWFya2VyOiBNYXJrZXI7XHJcblxyXG4gICAgcG9wdXBhcmVhOiBIVE1MRWxlbWVudDtcclxuXHJcbiAgICBpc09uUG9wdXAgPSBmYWxzZTtcclxuXHJcbiAgICBpc011c2V1bVVzZXIgPSB0cnVlO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcm91dGVyOiBSb3V0ZXIsIHByaXZhdGUgbmdab25lOiBOZ1pvbmUpIHsgfVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIHRoaXMubWFya2VyLm9uKFwiY2xpY2tcIiwgKCkgPT4gdGhpcy5vbkNsaWNrVmlzaXRGaXJzdCgpKTtcclxuXHJcbiAgICAgICAgdGhpcy5tYXJrZXIub24oXCJtb3VzZW92ZXJcIiwgKCkgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLmlzT25Qb3B1cCA9IHRydWU7XHJcbiAgICAgICAgICAgIGlmICghdGhpcy5tYXJrZXIuaXNQb3B1cE9wZW4oKSkge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5vcGVuUG9wdXAoKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIG9wZW5Qb3B1cCgpIHtcclxuICAgICAgICB0aGlzLm1hcmtlci5vcGVuUG9wdXAoKTtcclxuXHJcbiAgICAgICAgdGhpcy5pc09uUG9wdXAgPSBmYWxzZTtcclxuICAgICAgICB0aGlzLnBvcHVwYXJlYSA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoXCIubGVhZmxldC1wb3B1cFwiKSBhcyBIVE1MRWxlbWVudDtcclxuXHJcbiAgICAgICAgaWYgKHRoaXMucG9wdXBhcmVhKSB7XHJcbiAgICAgICAgICAgIHRoaXMucG9wdXBhcmVhLmFkZEV2ZW50TGlzdGVuZXIoXCJtb3VzZWxlYXZlXCIsICgpID0+IHtcclxuICAgICAgICAgICAgICAgIHRoaXMuY2xvc2VQb3B1cCgpO1xyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgdGhpcy5wb3B1cGFyZWEuYWRkRXZlbnRMaXN0ZW5lcihcIm1vdXNlb3ZlclwiLCAoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmlzT25Qb3B1cCA9IHRydWU7XHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH1cclxuICAgICAgICB0aGlzLm1hcmtlci5vbihcIm1vdXNlb3V0XCIsICgpID0+IHtcclxuICAgICAgICAgICAgdGhpcy5jbG9zZVBvcHVwKCk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgY2xvc2VQb3B1cCgpIHtcclxuICAgICAgICB0aGlzLmlzT25Qb3B1cCA9IGZhbHNlO1xyXG4gICAgICAgIC8qKiBXZSB3YW50IHRvIHdhaXQgdG8gYXZvaWQgZ2xpdGNoICovXHJcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgICAgIGlmICghdGhpcy5pc09uUG9wdXApIHtcclxuICAgICAgICAgICAgICAgIHRoaXMubWFya2VyLmNsb3NlUG9wdXAoKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0sIDEwMCk7XHJcbiAgICB9XHJcblxyXG4gICAgb25DbGlja1Zpc2l0Rmlyc3QoKSB7XHJcbiAgICAgICAgaWYgKHRoaXMuc3BhY2UudmlzaXRzLmxlbmd0aCA9PT0gMCkge1xyXG4gICAgICAgICAgICBjb25zb2xlLmxvZyhcIk5vIHNwYWNlIHRvIHZpc2l0ICFcIik7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgdGhpcy5vblZpc2l0Q2xpY2sodGhpcy5zcGFjZS52aXNpdHNbMF0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBhc3luYyBvblZpc2l0Q2xpY2sodmlzaXQ6IFZpc2l0KSB7XHJcbiAgICAgICAgdGhpcy5uZ1pvbmUucnVuKCgpID0+IHtcclxuICAgICAgICAgICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoW1widmlzaXRcIiwgdGhpcy5zcGFjZS5pZF0sIHtcclxuICAgICAgICAgICAgICAgIHF1ZXJ5UGFyYW1zOiB7IG1vZGVsM0Q6IHZpc2l0Lm1vZGVsM2QgfSxcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG59XHJcbiIsIjxkaXYgaWQ9XCJtYXAtcG9wdXBcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJtYXAtcG9wdXAtaGVhZGVyXCIgKGNsaWNrKT1cIm9uQ2xpY2tWaXNpdEZpcnN0KClcIiBbc3R5bGUuY3Vyc29yXT1cIidwb2ludGVyJ1wiPlxyXG4gICAgICAgIDxpbWcgW3NyY109XCJzcGFjZS5hbm5leGVzXCIgLz5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cIm1hcC1wb3B1cC1kZXRhaWxzXCI+XHJcbiAgICA8aDEgKGNsaWNrKT1cIm9uQ2xpY2tWaXNpdEZpcnN0KClcIiBbc3R5bGUuY3Vyc29yXT1cIidwb2ludGVyJ1wiPnt7c3BhY2UubmFtZX19PC9oMT5cclxuICAgIDxzcGFuIGNsYXNzPVwibWFwLXBvcHVwLWFkZHJlc3NcIj57e3NwYWNlLmFkZHJlc3Nlc319PC9zcGFuPlxyXG4gICAgPHNwYW4gKm5nRm9yPVwibGV0IHZpc2l0IG9mIHNwYWNlLnZpc2l0c1wiIGNsYXNzPVwibWFwLXBvcHVwLXZpc2l0XCIgKGNsaWNrKT1cIm9uVmlzaXRDbGljayh2aXNpdClcIlxyXG4gICAgICAgICAgICAgICAgICBbc3R5bGUuY3Vyc29yXT1cIidwb2ludGVyJ1wiPuKepCB7eyB2aXNpdC5uYW1lID8gdmlzaXQubmFtZSA6IHNwYWNlLm5hbWV9fTwvc3Bhbj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
1
|
+
import { Component, Input, ViewContainerRef, ViewChild } from '@angular/core';
|
|
2
2
|
import { latLng, marker, tileLayer, latLngBounds, point, Marker, icon, } from "leaflet";
|
|
3
3
|
import { MapPopupComponent } from './map-popup/map-popup.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -18,11 +18,9 @@ const iconDefault = icon({
|
|
|
18
18
|
});
|
|
19
19
|
Marker.prototype.options.icon = iconDefault;
|
|
20
20
|
export class MapComponent {
|
|
21
|
-
|
|
22
|
-
constructor(viewContainerRef) {
|
|
23
|
-
this.viewContainerRef = viewContainerRef;
|
|
24
|
-
}
|
|
21
|
+
constructor() { }
|
|
25
22
|
spaces;
|
|
23
|
+
popupContainer;
|
|
26
24
|
options = {
|
|
27
25
|
layers: [
|
|
28
26
|
tileLayer("http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png", {
|
|
@@ -35,57 +33,80 @@ export class MapComponent {
|
|
|
35
33
|
};
|
|
36
34
|
layers = [];
|
|
37
35
|
map;
|
|
36
|
+
isViewInitialized = false;
|
|
38
37
|
ngOnChanges(changes) {
|
|
39
38
|
if (changes.spaces) {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
if (!changes.spaces.currentValue) {
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
// Filtering out spaces without lat/longitudes
|
|
46
|
-
for (const s of changes.spaces.currentValue) {
|
|
47
|
-
if (s.latitude === null || s.longitude === null) {
|
|
48
|
-
console.log(`${s.name} has not coordinates for ${s.addresses}`);
|
|
49
|
-
continue;
|
|
50
|
-
}
|
|
51
|
-
// We use the popup system from leaflet, as it packs a few improvements
|
|
52
|
-
// on using bootstrap: autoclose other popups, closing option.
|
|
53
|
-
const m = marker([s.latitude, s.longitude]);
|
|
54
|
-
m.bindPopup(this.createPopupComponent(s, m));
|
|
55
|
-
nm.push(m);
|
|
56
|
-
bd.push(latLng(s.latitude, s.longitude));
|
|
39
|
+
if (this.isViewInitialized) {
|
|
40
|
+
this.rebuildLayers();
|
|
57
41
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
ngAfterViewInit() {
|
|
45
|
+
this.isViewInitialized = true;
|
|
46
|
+
this.rebuildLayers();
|
|
47
|
+
}
|
|
48
|
+
rebuildLayers() {
|
|
49
|
+
if (!this.spaces) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const nm = [];
|
|
53
|
+
const bd = [];
|
|
54
|
+
// Clear previous components to avoid leakage.
|
|
55
|
+
// this.viewContainerRef.clear(); // Removed as we use the dedicated container
|
|
56
|
+
if (this.popupContainer) {
|
|
57
|
+
this.popupContainer.clear();
|
|
58
|
+
}
|
|
59
|
+
// Filtering out spaces without lat/longitudes
|
|
60
|
+
for (const s of this.spaces) {
|
|
61
|
+
if (s.latitude === null || s.longitude === null) {
|
|
62
|
+
console.log(`${s.name} has not coordinates for ${s.addresses}`);
|
|
63
|
+
continue;
|
|
69
64
|
}
|
|
65
|
+
// We use the popup system from leaflet, as it packs a few improvements
|
|
66
|
+
// on using bootstrap: autoclose other popups, closing option.
|
|
67
|
+
const m = marker([s.latitude, s.longitude]);
|
|
68
|
+
m.bindPopup(this.createPopupComponent(s, m));
|
|
69
|
+
nm.push(m);
|
|
70
|
+
bd.push(latLng(s.latitude, s.longitude));
|
|
71
|
+
}
|
|
72
|
+
// Note how we set the layers in one assignment, in order to have leaflet
|
|
73
|
+
// detects the change correctly
|
|
74
|
+
// We also set the bounds afterward, for the map to be properly zoomed and
|
|
75
|
+
// centered
|
|
76
|
+
this.layers = nm;
|
|
77
|
+
if (this.map && bd.length > 0) {
|
|
78
|
+
this.map.fitBounds(latLngBounds(bd), {
|
|
79
|
+
padding: point(48, 48),
|
|
80
|
+
maxZoom: 12,
|
|
81
|
+
animate: true,
|
|
82
|
+
});
|
|
70
83
|
}
|
|
71
84
|
}
|
|
85
|
+
// Previous ngOnChanges logic was moved to rebuildLayers()
|
|
72
86
|
onMapReady(map) {
|
|
73
87
|
this.map = map;
|
|
74
88
|
}
|
|
75
89
|
createPopupComponent(space, marker) {
|
|
76
|
-
|
|
90
|
+
if (!this.popupContainer) {
|
|
91
|
+
console.warn("Popup container not ready yet");
|
|
92
|
+
return "";
|
|
93
|
+
}
|
|
94
|
+
const comp = this.popupContainer.createComponent(MapPopupComponent);
|
|
77
95
|
comp.instance.space = space;
|
|
78
96
|
comp.instance.marker = marker;
|
|
79
97
|
comp.changeDetectorRef.detectChanges();
|
|
80
98
|
return comp.location.nativeElement;
|
|
81
99
|
}
|
|
82
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapComponent, deps: [
|
|
83
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapComponent, selector: "lib-map", inputs: { spaces: "spaces" }, usesOnChanges: true, ngImport: i0, template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\
|
|
100
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapComponent, selector: "lib-map", inputs: { spaces: "spaces" }, viewQueries: [{ propertyName: "popupContainer", first: true, predicate: ["popupContainer"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, ngImport: i0, template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\n style=\"height: 500px; margin-top: 30px; z-index: 195\"></div>\n\n<!-- Hidden container for popup components to avoid display leakage and manage lifecycle -->\n<div style=\"display: none\">\n <div #popupContainer></div>\n</div>", styles: [":host ::ng-deep lib-map-popup{display:none!important}:host ::ng-deep .leaflet-popup-content lib-map-popup{display:block!important}\n"], dependencies: [{ kind: "directive", type: i1.LeafletDirective, selector: "[leaflet]", inputs: ["leafletFitBoundsOptions", "leafletPanOptions", "leafletZoomOptions", "leafletZoomPanOptions", "leafletOptions", "leafletZoom", "leafletCenter", "leafletFitBounds", "leafletMaxBounds", "leafletMinZoom", "leafletMaxZoom"], outputs: ["leafletMapReady", "leafletZoomChange", "leafletCenterChange", "leafletClick", "leafletDoubleClick", "leafletMouseDown", "leafletMouseUp", "leafletMouseMove", "leafletMouseOver", "leafletMouseOut", "leafletMapMove", "leafletMapMoveStart", "leafletMapMoveEnd", "leafletMapZoom", "leafletMapZoomStart", "leafletMapZoomEnd"] }, { kind: "directive", type: i1.LeafletLayersDirective, selector: "[leafletLayers]", inputs: ["leafletLayers"] }] });
|
|
84
102
|
}
|
|
85
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapComponent, decorators: [{
|
|
86
104
|
type: Component,
|
|
87
|
-
args: [{ selector: 'lib-map', template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\
|
|
88
|
-
}], ctorParameters: () => [
|
|
105
|
+
args: [{ selector: 'lib-map', template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\n style=\"height: 500px; margin-top: 30px; z-index: 195\"></div>\n\n<!-- Hidden container for popup components to avoid display leakage and manage lifecycle -->\n<div style=\"display: none\">\n <div #popupContainer></div>\n</div>", styles: [":host ::ng-deep lib-map-popup{display:none!important}:host ::ng-deep .leaflet-popup-content lib-map-popup{display:block!important}\n"] }]
|
|
106
|
+
}], ctorParameters: () => [], propDecorators: { spaces: [{
|
|
89
107
|
type: Input
|
|
108
|
+
}], popupContainer: [{
|
|
109
|
+
type: ViewChild,
|
|
110
|
+
args: ['popupContainer', { read: ViewContainerRef, static: true }]
|
|
90
111
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-smarterplan-locations/src/lib/components/locations/map/map.component.ts","../../../../../../../projects/ngx-smarterplan-locations/src/lib/components/locations/map/map.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, NgZone, OnChanges, SimpleChanges, ViewContainerRef } from '@angular/core';\r\nimport { Space } from '@smarterplan/ngx-smarterplan-core';\r\nimport {\r\n    latLng,\r\n    marker,\r\n    tileLayer,\r\n    Map,\r\n    latLngBounds,\r\n    point,\r\n    Marker,\r\n    icon,\r\n} from \"leaflet\";\r\nimport { MapPopupComponent } from './map-popup/map-popup.component';\r\nimport { Router } from '@angular/router';\r\n\r\n\r\nconst iconRetinaUrl = \"assets/marker-icon-2x.png\";\r\nconst iconUrl = \"assets/marker-icon.png\";\r\nconst shadowUrl = \"assets/marker-shadow.png\";\r\nconst iconDefault = icon({\r\n    iconRetinaUrl,\r\n    iconUrl,\r\n    shadowUrl,\r\n    iconSize: [25, 41],\r\n    iconAnchor: [12, 41],\r\n    popupAnchor: [1, -34],\r\n    tooltipAnchor: [16, -28],\r\n    shadowSize: [41, 41],\r\n});\r\nMarker.prototype.options.icon = iconDefault;\r\n@Component({\r\n    selector: 'lib-map',\r\n    templateUrl: './map.component.html',\r\n    styleUrls: ['./map.component.scss']\r\n})\r\nexport class MapComponent implements OnChanges {\r\n\r\n    constructor(private viewContainerRef: ViewContainerRef) { }\r\n\r\n    @Input() spaces: Space[];\r\n\r\n    options = {\r\n        layers: [\r\n            tileLayer(\"http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\", {\r\n                maxZoom: 18,\r\n                attribution: \"...\",\r\n            }),\r\n        ],\r\n        zoom: 5.5,\r\n        center: latLng(47.06394, 2.77736),\r\n    };\r\n\r\n    layers: any[] = [];\r\n\r\n    map: any;\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.spaces) {\r\n            const nm = [];\r\n            const bd = [];\r\n            if (!changes.spaces.currentValue) {\r\n                return;\r\n            }\r\n            // Filtering out spaces without lat/longitudes\r\n            for (const s of changes.spaces.currentValue as Space[]) {\r\n                if (s.latitude === null || s.longitude === null) {\r\n                    console.log(\r\n                        `${s.name} has not coordinates for ${s.addresses}`,\r\n                    );\r\n                    continue;\r\n                }\r\n                // We use the popup system from leaflet, as it packs a few improvements\r\n                // on using bootstrap: autoclose other popups, closing option.\r\n                const m = marker([s.latitude, s.longitude]);\r\n\r\n                m.bindPopup(this.createPopupComponent(s, m));\r\n\r\n                nm.push(m);\r\n                bd.push(latLng(s.latitude, s.longitude));\r\n            }\r\n            // Note how we set the layers in one assignment, in order to have leaflet\r\n            // detects the change correctly\r\n            // We also set the bounds afterward, for the map to be properly zoomed and\r\n            // centered\r\n            this.layers = nm;\r\n            if (this.map && bd.length > 0) {\r\n                this.map.fitBounds(latLngBounds(bd), {\r\n                    padding: point(48, 48),\r\n                    maxZoom: 12,\r\n                    animate: true,\r\n                });\r\n            }\r\n        }\r\n    }\r\n\r\n    onMapReady(map: Map) {\r\n        this.map = map;\r\n    }\r\n\r\n    createPopupComponent(space: Space, marker: Marker) {\r\n        const comp = this.viewContainerRef.createComponent(MapPopupComponent);\r\n        comp.instance.space = space;\r\n        comp.instance.marker = marker;\r\n        comp.changeDetectorRef.detectChanges();\r\n        return comp.location.nativeElement;\r\n    }\r\n\r\n}\r\n","<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\r\n    style=\"height: 500px; margin-top: 30px; z-index: 195\"></div>"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-smarterplan-locations/src/lib/components/locations/map/map.component.ts","../../../../../../../projects/ngx-smarterplan-locations/src/lib/components/locations/map/map.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAY,KAAK,EAAoC,gBAAgB,EAAE,SAAS,EAAiB,MAAM,eAAe,CAAC;AAEzI,OAAO,EACH,MAAM,EACN,MAAM,EACN,SAAS,EAET,YAAY,EACZ,KAAK,EACL,MAAM,EACN,IAAI,GACP,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;;;AAIpE,MAAM,aAAa,GAAG,2BAA2B,CAAC;AAClD,MAAM,OAAO,GAAG,wBAAwB,CAAC;AACzC,MAAM,SAAS,GAAG,0BAA0B,CAAC;AAC7C,MAAM,WAAW,GAAG,IAAI,CAAC;IACrB,aAAa;IACb,OAAO;IACP,SAAS;IACT,QAAQ,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;IAClB,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;IACpB,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;IACrB,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC;IACxB,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;CACvB,CAAC,CAAC;AACH,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,GAAG,WAAW,CAAC;AAM5C,MAAM,OAAO,YAAY;IAErB,gBAAgB,CAAC;IAER,MAAM,CAAU;IAC8C,cAAc,CAAmB;IAExG,OAAO,GAAG;QACN,MAAM,EAAE;YACJ,SAAS,CAAC,mDAAmD,EAAE;gBAC3D,OAAO,EAAE,EAAE;gBACX,WAAW,EAAE,KAAK;aACrB,CAAC;SACL;QACD,IAAI,EAAE,GAAG;QACT,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC;KACpC,CAAC;IAEF,MAAM,GAAU,EAAE,CAAC;IAEnB,GAAG,CAAM;IACD,iBAAiB,GAAG,KAAK,CAAC;IAElC,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACjB,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACzB,IAAI,CAAC,aAAa,EAAE,CAAC;YACzB,CAAC;QACL,CAAC;IACL,CAAC;IAED,eAAe;QACX,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACf,OAAO;QACX,CAAC;QAED,MAAM,EAAE,GAAG,EAAE,CAAC;QACd,MAAM,EAAE,GAAG,EAAE,CAAC;QAEd,+CAA+C;QAC/C,8EAA8E;QAC9E,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAChC,CAAC;QAED,8CAA8C;QAC9C,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAC1B,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,IAAI,CAAC,CAAC,SAAS,KAAK,IAAI,EAAE,CAAC;gBAC9C,OAAO,CAAC,GAAG,CACP,GAAG,CAAC,CAAC,IAAI,4BAA4B,CAAC,CAAC,SAAS,EAAE,CACrD,CAAC;gBACF,SAAS;YACb,CAAC;YACD,uEAAuE;YACvE,8DAA8D;YAC9D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;YAE5C,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAE7C,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACX,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC7C,CAAC;QACD,yEAAyE;QACzE,+BAA+B;QAC/B,0EAA0E;QAC1E,WAAW;QACX,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,EAAE;gBACjC,OAAO,EAAE,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC;gBACtB,OAAO,EAAE,EAAE;gBACX,OAAO,EAAE,IAAI;aAChB,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAED,0DAA0D;IAE1D,UAAU,CAAC,GAAQ;QACf,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACnB,CAAC;IAED,oBAAoB,CAAC,KAAY,EAAE,MAAc;QAC7C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACvB,OAAO,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;YAC9C,OAAO,EAAE,CAAC;QACd,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,MAAM,CAAC;QAC9B,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;QACvC,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;IACvC,CAAC;wGAjGQ,YAAY;4FAAZ,YAAY,0KAKgB,gBAAgB,gECxCzD,4WAMM;;4FD6BO,YAAY;kBALxB,SAAS;+BACI,SAAS;wDAQV,MAAM;sBAAd,KAAK;gBACiE,cAAc;sBAApF,SAAS;uBAAC,gBAAgB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Component, Injector, Input, NgZone, OnChanges, SimpleChanges, ViewContainerRef, ViewChild, AfterViewInit } from '@angular/core';\r\nimport { Space } from '@smarterplan/ngx-smarterplan-core';\r\nimport {\r\n    latLng,\r\n    marker,\r\n    tileLayer,\r\n    Map,\r\n    latLngBounds,\r\n    point,\r\n    Marker,\r\n    icon,\r\n} from \"leaflet\";\r\nimport { MapPopupComponent } from './map-popup/map-popup.component';\r\nimport { Router } from '@angular/router';\r\n\r\n\r\nconst iconRetinaUrl = \"assets/marker-icon-2x.png\";\r\nconst iconUrl = \"assets/marker-icon.png\";\r\nconst shadowUrl = \"assets/marker-shadow.png\";\r\nconst iconDefault = icon({\r\n    iconRetinaUrl,\r\n    iconUrl,\r\n    shadowUrl,\r\n    iconSize: [25, 41],\r\n    iconAnchor: [12, 41],\r\n    popupAnchor: [1, -34],\r\n    tooltipAnchor: [16, -28],\r\n    shadowSize: [41, 41],\r\n});\r\nMarker.prototype.options.icon = iconDefault;\r\n@Component({\r\n    selector: 'lib-map',\r\n    templateUrl: './map.component.html',\r\n    styleUrls: ['./map.component.scss']\r\n})\r\nexport class MapComponent implements OnChanges, AfterViewInit {\r\n\r\n    constructor() { }\r\n\r\n    @Input() spaces: Space[];\r\n    @ViewChild('popupContainer', { read: ViewContainerRef, static: true }) popupContainer: ViewContainerRef;\r\n\r\n    options = {\r\n        layers: [\r\n            tileLayer(\"http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\", {\r\n                maxZoom: 18,\r\n                attribution: \"...\",\r\n            }),\r\n        ],\r\n        zoom: 5.5,\r\n        center: latLng(47.06394, 2.77736),\r\n    };\r\n\r\n    layers: any[] = [];\r\n\r\n    map: any;\r\n    private isViewInitialized = false;\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.spaces) {\r\n            if (this.isViewInitialized) {\r\n                this.rebuildLayers();\r\n            }\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this.isViewInitialized = true;\r\n        this.rebuildLayers();\r\n    }\r\n\r\n    private rebuildLayers() {\r\n        if (!this.spaces) {\r\n            return;\r\n        }\r\n\r\n        const nm = [];\r\n        const bd = [];\r\n\r\n        // Clear previous components to avoid leakage. \r\n        // this.viewContainerRef.clear(); // Removed as we use the dedicated container\r\n        if (this.popupContainer) {\r\n            this.popupContainer.clear();\r\n        }\r\n\r\n        // Filtering out spaces without lat/longitudes\r\n        for (const s of this.spaces) {\r\n            if (s.latitude === null || s.longitude === null) {\r\n                console.log(\r\n                    `${s.name} has not coordinates for ${s.addresses}`,\r\n                );\r\n                continue;\r\n            }\r\n            // We use the popup system from leaflet, as it packs a few improvements\r\n            // on using bootstrap: autoclose other popups, closing option.\r\n            const m = marker([s.latitude, s.longitude]);\r\n\r\n            m.bindPopup(this.createPopupComponent(s, m));\r\n\r\n            nm.push(m);\r\n            bd.push(latLng(s.latitude, s.longitude));\r\n        }\r\n        // Note how we set the layers in one assignment, in order to have leaflet\r\n        // detects the change correctly\r\n        // We also set the bounds afterward, for the map to be properly zoomed and\r\n        // centered\r\n        this.layers = nm;\r\n        if (this.map && bd.length > 0) {\r\n            this.map.fitBounds(latLngBounds(bd), {\r\n                padding: point(48, 48),\r\n                maxZoom: 12,\r\n                animate: true,\r\n            });\r\n        }\r\n    }\r\n\r\n    // Previous ngOnChanges logic was moved to rebuildLayers()\r\n\r\n    onMapReady(map: Map) {\r\n        this.map = map;\r\n    }\r\n\r\n    createPopupComponent(space: Space, marker: Marker) {\r\n        if (!this.popupContainer) {\r\n            console.warn(\"Popup container not ready yet\");\r\n            return \"\";\r\n        }\r\n        const comp = this.popupContainer.createComponent(MapPopupComponent);\r\n        comp.instance.space = space;\r\n        comp.instance.marker = marker;\r\n        comp.changeDetectorRef.detectChanges();\r\n        return comp.location.nativeElement;\r\n    }\r\n\r\n}\r\n","<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\n    style=\"height: 500px; margin-top: 30px; z-index: 195\"></div>\n\n<!-- Hidden container for popup components to avoid display leakage and manage lifecycle -->\n<div style=\"display: none\">\n    <div #popupContainer></div>\n</div>"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, EventEmitter, Input, Output, Component, ViewChild, Pipe, HostListener, NgModule } from '@angular/core';
|
|
2
|
+
import { Injectable, EventEmitter, Input, Output, Component, ViewContainerRef, ViewChild, Pipe, HostListener, NgModule } from '@angular/core';
|
|
3
3
|
import * as i2 from '@smarterplan/ngx-smarterplan-core';
|
|
4
4
|
import { enumToArray, LevelStatus, textValidator, noEmptyValidator, floatValidator, uploadFileToS3, deleteFromS3, PropertyType, getSignedImageUrlForSpace, SearchObjectType, SpaceStatus, getMetaForImage, getSignedFile, downloadFileAsObject, downloadBlob, CaptureViewer, showScanPointsOnPlanInDiv, getCoefficientsForImage, CommentType, SpModule, wait, InventoryStatus, NgxSmarterplanCoreModule } from '@smarterplan/ngx-smarterplan-core';
|
|
5
5
|
import * as i1 from '@angular/router';
|
|
@@ -96,12 +96,14 @@ class MapPopupComponent {
|
|
|
96
96
|
this.marker.openPopup();
|
|
97
97
|
this.isOnPopup = false;
|
|
98
98
|
this.popuparea = document.querySelector(".leaflet-popup");
|
|
99
|
-
this.popuparea
|
|
100
|
-
this.
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
this.
|
|
104
|
-
|
|
99
|
+
if (this.popuparea) {
|
|
100
|
+
this.popuparea.addEventListener("mouseleave", () => {
|
|
101
|
+
this.closePopup();
|
|
102
|
+
});
|
|
103
|
+
this.popuparea.addEventListener("mouseover", () => {
|
|
104
|
+
this.isOnPopup = true;
|
|
105
|
+
});
|
|
106
|
+
}
|
|
105
107
|
this.marker.on("mouseout", () => {
|
|
106
108
|
this.closePopup();
|
|
107
109
|
});
|
|
@@ -131,11 +133,11 @@ class MapPopupComponent {
|
|
|
131
133
|
});
|
|
132
134
|
}
|
|
133
135
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapPopupComponent, deps: [{ token: i1.Router }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
134
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapPopupComponent, selector: "lib-map-popup", ngImport: i0, template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [".map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
136
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapPopupComponent, selector: "lib-map-popup", ngImport: i0, template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [":host{display:none!important}:host-context(.leaflet-popup-content){display:block!important}.map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
135
137
|
}
|
|
136
138
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapPopupComponent, decorators: [{
|
|
137
139
|
type: Component,
|
|
138
|
-
args: [{ selector: 'lib-map-popup', template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [".map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"] }]
|
|
140
|
+
args: [{ selector: 'lib-map-popup', template: "<div id=\"map-popup\">\r\n <div class=\"map-popup-header\" (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">\r\n <img [src]=\"space.annexes\" />\r\n </div>\r\n <div class=\"map-popup-details\">\r\n <h1 (click)=\"onClickVisitFirst()\" [style.cursor]=\"'pointer'\">{{space.name}}</h1>\r\n <span class=\"map-popup-address\">{{space.addresses}}</span>\r\n <span *ngFor=\"let visit of space.visits\" class=\"map-popup-visit\" (click)=\"onVisitClick(visit)\"\r\n [style.cursor]=\"'pointer'\">\u27A4 {{ visit.name ? visit.name : space.name}}</span>\r\n </div>\r\n</div>\r\n", styles: [":host{display:none!important}:host-context(.leaflet-popup-content){display:block!important}.map-popup-header{height:120px;overflow:hidden;border-top-right-radius:20px;border-top-left-radius:20px}.map-popup-header img{width:100%;position:relative;top:50%;transform:translateY(-50%)}.map-popup-details{padding:5px 10px 10px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;background-color:#fff;color:#000}.map-popup-details{display:flex;flex-direction:column}.map-popup-details h1{font-size:1.5rem;font-weight:700;margin-bottom:0;color:var(--smarterplan-primary)}.map-popup-address{align-self:flex-end;margin-bottom:10px}.map-popup-visit{color:var(--smarterplan-primary);font-size:1.15rem}.map-popup-visit:hover{color:var(--smarterplan-primary)}\n"] }]
|
|
139
141
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i0.NgZone }] });
|
|
140
142
|
|
|
141
143
|
const iconRetinaUrl = "assets/marker-icon-2x.png";
|
|
@@ -153,11 +155,9 @@ const iconDefault = icon({
|
|
|
153
155
|
});
|
|
154
156
|
Marker.prototype.options.icon = iconDefault;
|
|
155
157
|
class MapComponent {
|
|
156
|
-
|
|
157
|
-
constructor(viewContainerRef) {
|
|
158
|
-
this.viewContainerRef = viewContainerRef;
|
|
159
|
-
}
|
|
158
|
+
constructor() { }
|
|
160
159
|
spaces;
|
|
160
|
+
popupContainer;
|
|
161
161
|
options = {
|
|
162
162
|
layers: [
|
|
163
163
|
tileLayer("http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png", {
|
|
@@ -170,58 +170,81 @@ class MapComponent {
|
|
|
170
170
|
};
|
|
171
171
|
layers = [];
|
|
172
172
|
map;
|
|
173
|
+
isViewInitialized = false;
|
|
173
174
|
ngOnChanges(changes) {
|
|
174
175
|
if (changes.spaces) {
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
if (!changes.spaces.currentValue) {
|
|
178
|
-
return;
|
|
176
|
+
if (this.isViewInitialized) {
|
|
177
|
+
this.rebuildLayers();
|
|
179
178
|
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
animate: true,
|
|
203
|
-
});
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
ngAfterViewInit() {
|
|
182
|
+
this.isViewInitialized = true;
|
|
183
|
+
this.rebuildLayers();
|
|
184
|
+
}
|
|
185
|
+
rebuildLayers() {
|
|
186
|
+
if (!this.spaces) {
|
|
187
|
+
return;
|
|
188
|
+
}
|
|
189
|
+
const nm = [];
|
|
190
|
+
const bd = [];
|
|
191
|
+
// Clear previous components to avoid leakage.
|
|
192
|
+
// this.viewContainerRef.clear(); // Removed as we use the dedicated container
|
|
193
|
+
if (this.popupContainer) {
|
|
194
|
+
this.popupContainer.clear();
|
|
195
|
+
}
|
|
196
|
+
// Filtering out spaces without lat/longitudes
|
|
197
|
+
for (const s of this.spaces) {
|
|
198
|
+
if (s.latitude === null || s.longitude === null) {
|
|
199
|
+
console.log(`${s.name} has not coordinates for ${s.addresses}`);
|
|
200
|
+
continue;
|
|
204
201
|
}
|
|
202
|
+
// We use the popup system from leaflet, as it packs a few improvements
|
|
203
|
+
// on using bootstrap: autoclose other popups, closing option.
|
|
204
|
+
const m = marker([s.latitude, s.longitude]);
|
|
205
|
+
m.bindPopup(this.createPopupComponent(s, m));
|
|
206
|
+
nm.push(m);
|
|
207
|
+
bd.push(latLng(s.latitude, s.longitude));
|
|
208
|
+
}
|
|
209
|
+
// Note how we set the layers in one assignment, in order to have leaflet
|
|
210
|
+
// detects the change correctly
|
|
211
|
+
// We also set the bounds afterward, for the map to be properly zoomed and
|
|
212
|
+
// centered
|
|
213
|
+
this.layers = nm;
|
|
214
|
+
if (this.map && bd.length > 0) {
|
|
215
|
+
this.map.fitBounds(latLngBounds(bd), {
|
|
216
|
+
padding: point(48, 48),
|
|
217
|
+
maxZoom: 12,
|
|
218
|
+
animate: true,
|
|
219
|
+
});
|
|
205
220
|
}
|
|
206
221
|
}
|
|
222
|
+
// Previous ngOnChanges logic was moved to rebuildLayers()
|
|
207
223
|
onMapReady(map) {
|
|
208
224
|
this.map = map;
|
|
209
225
|
}
|
|
210
226
|
createPopupComponent(space, marker) {
|
|
211
|
-
|
|
227
|
+
if (!this.popupContainer) {
|
|
228
|
+
console.warn("Popup container not ready yet");
|
|
229
|
+
return "";
|
|
230
|
+
}
|
|
231
|
+
const comp = this.popupContainer.createComponent(MapPopupComponent);
|
|
212
232
|
comp.instance.space = space;
|
|
213
233
|
comp.instance.marker = marker;
|
|
214
234
|
comp.changeDetectorRef.detectChanges();
|
|
215
235
|
return comp.location.nativeElement;
|
|
216
236
|
}
|
|
217
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapComponent, deps: [
|
|
218
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapComponent, selector: "lib-map", inputs: { spaces: "spaces" }, usesOnChanges: true, ngImport: i0, template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\
|
|
237
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
238
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MapComponent, selector: "lib-map", inputs: { spaces: "spaces" }, viewQueries: [{ propertyName: "popupContainer", first: true, predicate: ["popupContainer"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, ngImport: i0, template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\n style=\"height: 500px; margin-top: 30px; z-index: 195\"></div>\n\n<!-- Hidden container for popup components to avoid display leakage and manage lifecycle -->\n<div style=\"display: none\">\n <div #popupContainer></div>\n</div>", styles: [":host ::ng-deep lib-map-popup{display:none!important}:host ::ng-deep .leaflet-popup-content lib-map-popup{display:block!important}\n"], dependencies: [{ kind: "directive", type: i1$1.LeafletDirective, selector: "[leaflet]", inputs: ["leafletFitBoundsOptions", "leafletPanOptions", "leafletZoomOptions", "leafletZoomPanOptions", "leafletOptions", "leafletZoom", "leafletCenter", "leafletFitBounds", "leafletMaxBounds", "leafletMinZoom", "leafletMaxZoom"], outputs: ["leafletMapReady", "leafletZoomChange", "leafletCenterChange", "leafletClick", "leafletDoubleClick", "leafletMouseDown", "leafletMouseUp", "leafletMouseMove", "leafletMouseOver", "leafletMouseOut", "leafletMapMove", "leafletMapMoveStart", "leafletMapMoveEnd", "leafletMapZoom", "leafletMapZoomStart", "leafletMapZoomEnd"] }, { kind: "directive", type: i1$1.LeafletLayersDirective, selector: "[leafletLayers]", inputs: ["leafletLayers"] }] });
|
|
219
239
|
}
|
|
220
240
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapComponent, decorators: [{
|
|
221
241
|
type: Component,
|
|
222
|
-
args: [{ selector: 'lib-map', template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\
|
|
223
|
-
}], ctorParameters: () => [
|
|
242
|
+
args: [{ selector: 'lib-map', template: "<div [leafletLayers]=\"layers\" [leafletOptions]=\"options\" (leafletMapReady)=\"onMapReady($any($event))\" id=\"map\" leaflet\n style=\"height: 500px; margin-top: 30px; z-index: 195\"></div>\n\n<!-- Hidden container for popup components to avoid display leakage and manage lifecycle -->\n<div style=\"display: none\">\n <div #popupContainer></div>\n</div>", styles: [":host ::ng-deep lib-map-popup{display:none!important}:host ::ng-deep .leaflet-popup-content lib-map-popup{display:block!important}\n"] }]
|
|
243
|
+
}], ctorParameters: () => [], propDecorators: { spaces: [{
|
|
224
244
|
type: Input
|
|
245
|
+
}], popupContainer: [{
|
|
246
|
+
type: ViewChild,
|
|
247
|
+
args: ['popupContainer', { read: ViewContainerRef, static: true }]
|
|
225
248
|
}] } });
|
|
226
249
|
|
|
227
250
|
class FormLocationComponent {
|