@smarterplan/ngx-smarterplan-core 1.2.10 → 1.2.12
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/README.md +24 -24
- package/esm2020/lib/components/csv-export/csv-export.component.mjs +3 -3
- package/esm2020/lib/components/loader/loader.component.mjs +3 -3
- package/esm2020/lib/components/menu-bar/avatar/avatar.component.mjs +1 -1
- package/esm2020/lib/components/menu-bar/menu-bar.component.mjs +3 -3
- package/esm2020/lib/components/menu-bar/navigation-bar/navigation-bar.component.mjs +3 -3
- package/esm2020/lib/components/menu-bar/range-date-picker/range-date-picker.component.mjs +1 -1
- package/esm2020/lib/components/modal-switch-visit/modal-switch-visit.component.mjs +3 -3
- package/esm2020/lib/components/search-bar/search-bar.component.mjs +3 -3
- package/esm2020/lib/components/support-modal/support-modal.component.mjs +3 -3
- package/esm2020/lib/config.mjs +1 -1
- package/esm2020/lib/helpers.service.mjs +1 -1
- package/esm2020/lib/matterport-extensions/nest-thermostat/CanvasImage.mjs +1 -1
- package/esm2020/lib/matterport-extensions/nest-thermostat/PlaneRenderer.mjs +1 -1
- package/esm2020/lib/matterport-extensions/scene-component/SceneComponent.mjs +1 -1
- package/esm2020/lib/matterport-extensions/tv-player/TvPlayer.mjs +1 -1
- package/esm2020/lib/mattertagData.mjs +1 -1
- package/esm2020/lib/ngx-smarterplan-core.module.mjs +1 -1
- package/esm2020/lib/ngx-smarterplan-core.service.mjs +1 -1
- package/esm2020/lib/pipes/duration-to-string.pipe.mjs +1 -1
- package/esm2020/lib/pipes/format-date-number-to-digits.pipe.mjs +1 -1
- package/esm2020/lib/pipes/hashtag-from-id.pipe.mjs +1 -1
- package/esm2020/lib/pipes/safe-url.pipe.mjs +1 -1
- package/esm2020/lib/pipes/time-date-to-local-string.pipe.mjs +1 -1
- package/esm2020/lib/pipes/username-from-id.pipe.mjs +1 -1
- package/esm2020/lib/services/amplify-cache.service.mjs +1 -1
- package/esm2020/lib/services/base-tab.service.mjs +1 -1
- package/esm2020/lib/services/baseVisibility.service.mjs +1 -1
- package/esm2020/lib/services/content.service.mjs +1 -1
- package/esm2020/lib/services/filter.service.mjs +1 -1
- package/esm2020/lib/services/intervention.service.mjs +1 -1
- package/esm2020/lib/services/locale.service.mjs +1 -1
- package/esm2020/lib/services/matterport-import.service.mjs +49 -41
- package/esm2020/lib/services/matterport.service.mjs +75 -1
- package/esm2020/lib/services/models/affectation.service.mjs +1 -1
- package/esm2020/lib/services/models/base-object.service.mjs +1 -1
- package/esm2020/lib/services/models/capture.service.mjs +1 -1
- package/esm2020/lib/services/models/comment.service.mjs +1 -1
- package/esm2020/lib/services/models/domain.service.mjs +1 -1
- package/esm2020/lib/services/models/equipment.service.mjs +1 -1
- package/esm2020/lib/services/models/event.service.mjs +1 -1
- package/esm2020/lib/services/models/feature.service.mjs +1 -1
- package/esm2020/lib/services/models/hashtag.service.mjs +1 -1
- package/esm2020/lib/services/models/layer.service.mjs +1 -1
- package/esm2020/lib/services/models/measurement.service.mjs +1 -1
- package/esm2020/lib/services/models/mission.service.mjs +1 -1
- package/esm2020/lib/services/models/navigation.service.mjs +1 -1
- package/esm2020/lib/services/models/node.service.mjs +1 -1
- package/esm2020/lib/services/models/object3D.service.mjs +1 -1
- package/esm2020/lib/services/models/operation.service.mjs +1 -1
- package/esm2020/lib/services/models/organisation.service.mjs +1 -1
- package/esm2020/lib/services/models/plan.service.mjs +1 -1
- package/esm2020/lib/services/models/poi.service.mjs +1 -1
- package/esm2020/lib/services/models/profile.service.mjs +1 -1
- package/esm2020/lib/services/models/property.service.mjs +1 -1
- package/esm2020/lib/services/models/space.service.mjs +1 -1
- package/esm2020/lib/services/models/template.service.mjs +1 -1
- package/esm2020/lib/services/models/ticket.service.mjs +1 -1
- package/esm2020/lib/services/models/visit.service.mjs +1 -1
- package/esm2020/lib/services/models/zone.service.mjs +1 -1
- package/esm2020/lib/services/navigator.service.mjs +1 -1
- package/esm2020/lib/services/s3.service.mjs +1 -1
- package/esm2020/lib/services/search.service.mjs +1 -1
- package/esm2020/lib/services/support.service.mjs +1 -1
- package/esm2020/lib/services/tag.service.mjs +18 -18
- package/esm2020/lib/services/user.service.mjs +1 -1
- package/esm2020/lib/services/validators.service.mjs +1 -1
- package/esm2020/lib/services/zone-drawer.service.mjs +1 -1
- package/esm2020/lib/services/zoneChange.service.mjs +1 -1
- package/esm2020/lib/validators/email.directive.mjs +1 -1
- package/esm2020/lib/validators/no-empty.directive.mjs +1 -1
- package/esm2020/lib/validators/number.directive.mjs +1 -1
- package/esm2020/lib/validators/text.directive.mjs +1 -1
- package/esm2020/public-api.mjs +1 -1
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs +156 -72
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs.map +1 -1
- package/fesm2020/smarterplan-ngx-smarterplan-core.mjs +153 -71
- package/fesm2020/smarterplan-ngx-smarterplan-core.mjs.map +1 -1
- package/lib/components/csv-export/csv-export.component.d.ts.map +1 -0
- package/lib/components/loader/loader.component.d.ts.map +1 -0
- package/lib/components/menu-bar/avatar/avatar.component.d.ts.map +1 -0
- package/lib/components/menu-bar/menu-bar.component.d.ts.map +1 -0
- package/lib/components/menu-bar/navigation-bar/navigation-bar.component.d.ts.map +1 -0
- package/lib/components/menu-bar/range-date-picker/range-date-picker.component.d.ts.map +1 -0
- package/lib/components/modal-switch-visit/modal-switch-visit.component.d.ts.map +1 -0
- package/lib/components/search-bar/search-bar.component.d.ts.map +1 -0
- package/lib/components/support-modal/support-modal.component.d.ts.map +1 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/helpers.service.d.ts.map +1 -0
- package/lib/matterport-extensions/hsl-loader/HlsLoader.d.ts.map +1 -0
- package/lib/matterport-extensions/nest-thermostat/CanvasImage.d.ts.map +1 -0
- package/lib/matterport-extensions/nest-thermostat/CanvasRenderer.d.ts.map +1 -0
- package/lib/matterport-extensions/nest-thermostat/NestThermostat.d.ts.map +1 -0
- package/lib/matterport-extensions/nest-thermostat/PlaneRenderer.d.ts.map +1 -0
- package/lib/matterport-extensions/scene-component/SceneComponent.d.ts.map +1 -0
- package/lib/matterport-extensions/security-camera/SecurityCamera.d.ts.map +1 -0
- package/lib/matterport-extensions/tv-player/TvPlayer.d.ts.map +1 -0
- package/lib/matterport-extensions/video-renderer/VideoRenderer.d.ts.map +1 -0
- package/lib/matterport-extensions/view-frustum-mesh/ViewFrustumMesh.d.ts.map +1 -0
- package/lib/mattertagData.d.ts.map +1 -0
- package/lib/ngx-smarterplan-core.module.d.ts.map +1 -0
- package/lib/ngx-smarterplan-core.service.d.ts.map +1 -0
- package/lib/pipes/duration-to-string.pipe.d.ts.map +1 -0
- package/lib/pipes/format-date-number-to-digits.pipe.d.ts.map +1 -0
- package/lib/pipes/hashtag-from-id.pipe.d.ts.map +1 -0
- package/lib/pipes/safe-url.pipe.d.ts.map +1 -0
- package/lib/pipes/time-date-to-local-string.pipe.d.ts.map +1 -0
- package/lib/pipes/username-from-id.pipe.d.ts.map +1 -0
- package/lib/services/amplify-cache.service.d.ts.map +1 -0
- package/lib/services/base-tab.service.d.ts.map +1 -0
- package/lib/services/baseVisibility.service.d.ts.map +1 -0
- package/lib/services/content.service.d.ts.map +1 -0
- package/lib/services/filter.service.d.ts.map +1 -0
- package/lib/services/intervention.service.d.ts.map +1 -0
- package/lib/services/locale.service.d.ts.map +1 -0
- package/lib/services/matterport-import.service.d.ts +7 -0
- package/lib/services/matterport-import.service.d.ts.map +1 -0
- package/lib/services/matterport.service.d.ts.map +1 -0
- package/lib/services/models/affectation.service.d.ts.map +1 -0
- package/lib/services/models/base-object.service.d.ts.map +1 -0
- package/lib/services/models/capture.service.d.ts.map +1 -0
- package/lib/services/models/comment.service.d.ts.map +1 -0
- package/lib/services/models/domain.service.d.ts.map +1 -0
- package/lib/services/models/equipment.service.d.ts.map +1 -0
- package/lib/services/models/event.service.d.ts.map +1 -0
- package/lib/services/models/feature.service.d.ts.map +1 -0
- package/lib/services/models/hashtag.service.d.ts.map +1 -0
- package/lib/services/models/layer.service.d.ts.map +1 -0
- package/lib/services/models/measurement.service.d.ts.map +1 -0
- package/lib/services/models/mission.service.d.ts.map +1 -0
- package/lib/services/models/navigation.service.d.ts.map +1 -0
- package/lib/services/models/node.service.d.ts.map +1 -0
- package/lib/services/models/object3D.service.d.ts.map +1 -0
- package/lib/services/models/operation.service.d.ts.map +1 -0
- package/lib/services/models/organisation.service.d.ts.map +1 -0
- package/lib/services/models/plan.service.d.ts.map +1 -0
- package/lib/services/models/poi.service.d.ts.map +1 -0
- package/lib/services/models/profile.service.d.ts.map +1 -0
- package/lib/services/models/property.service.d.ts.map +1 -0
- package/lib/services/models/space.service.d.ts.map +1 -0
- package/lib/services/models/template.service.d.ts.map +1 -0
- package/lib/services/models/ticket.service.d.ts.map +1 -0
- package/lib/services/models/visit.service.d.ts.map +1 -0
- package/lib/services/models/zone.service.d.ts.map +1 -0
- package/lib/services/navigator.service.d.ts.map +1 -0
- package/lib/services/s3.service.d.ts.map +1 -0
- package/lib/services/search.service.d.ts.map +1 -0
- package/lib/services/support.service.d.ts.map +1 -0
- package/lib/services/tag.service.d.ts.map +1 -0
- package/lib/services/user.service.d.ts.map +1 -0
- package/lib/services/validators.service.d.ts.map +1 -0
- package/lib/services/viewer.service.d.ts.map +1 -0
- package/lib/services/zone-drawer.service.d.ts.map +1 -0
- package/lib/services/zoneChange.service.d.ts.map +1 -0
- package/lib/types.service.d.ts.map +1 -0
- package/lib/validators/email.directive.d.ts.map +1 -0
- package/lib/validators/no-empty.directive.d.ts.map +1 -0
- package/lib/validators/number.directive.d.ts.map +1 -0
- package/lib/validators/text.directive.d.ts.map +1 -0
- package/package.json +1 -1
- package/public-api.d.ts.map +1 -0
- package/smarterplan-ngx-smarterplan-core.d.ts.map +1 -0
|
@@ -85,10 +85,10 @@ class CsvExportComponent {
|
|
|
85
85
|
}
|
|
86
86
|
}
|
|
87
87
|
CsvExportComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: CsvExportComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
-
CsvExportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: CsvExportComponent, selector: "lib-csv-export", inputs: { headers: "headers", rowsInput: "rowsInput", getRows: "getRows", title: "title", buttonLabel: "buttonLabel" }, ngImport: i0, template: "<span [style.cursor]=\"'pointer'\" (click)=\"onClickDownload()\" class=\"download-csv d-flex\">\
|
|
88
|
+
CsvExportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: CsvExportComponent, selector: "lib-csv-export", inputs: { headers: "headers", rowsInput: "rowsInput", getRows: "getRows", title: "title", buttonLabel: "buttonLabel" }, ngImport: i0, template: "<span [style.cursor]=\"'pointer'\" (click)=\"onClickDownload()\" class=\"download-csv d-flex\">\n <span class=\"iconify\" data-icon=\"mdi:file-download-outline\"></span>\n {{ buttonLabel | translate}}\n</span>\n", styles: [".download-csv{color:var(--smarterplan-primary)}\n"], pipes: { "translate": i1.TranslatePipe } });
|
|
89
89
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: CsvExportComponent, decorators: [{
|
|
90
90
|
type: Component,
|
|
91
|
-
args: [{ selector: 'lib-csv-export', template: "<span [style.cursor]=\"'pointer'\" (click)=\"onClickDownload()\" class=\"download-csv d-flex\">\
|
|
91
|
+
args: [{ selector: 'lib-csv-export', template: "<span [style.cursor]=\"'pointer'\" (click)=\"onClickDownload()\" class=\"download-csv d-flex\">\n <span class=\"iconify\" data-icon=\"mdi:file-download-outline\"></span>\n {{ buttonLabel | translate}}\n</span>\n", styles: [".download-csv{color:var(--smarterplan-primary)}\n"] }]
|
|
92
92
|
}], propDecorators: { headers: [{
|
|
93
93
|
type: Input
|
|
94
94
|
}], rowsInput: [{
|
|
@@ -2924,6 +2924,82 @@ class MatterportService {
|
|
|
2924
2924
|
// renderer.shadowMap.bias = 0.0001;
|
|
2925
2925
|
// renderer.shadowMap.type = three.PCFSoftShadowMap;
|
|
2926
2926
|
// });
|
|
2927
|
+
// Wait until Showcase is actually playing....
|
|
2928
|
+
this.sdk.Tag.data.subscribe({
|
|
2929
|
+
onAdded: function (index, item, collection) {
|
|
2930
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
2931
|
+
let thisOpacity = 0.2;
|
|
2932
|
+
this.sdk.Tag.editOpacity(index, thisOpacity);
|
|
2933
|
+
let source = null;
|
|
2934
|
+
try {
|
|
2935
|
+
source = yield Promise.all([
|
|
2936
|
+
this.sdk.Sensor.createSource(this.sdk.Sensor.SourceType.SPHERE, {
|
|
2937
|
+
origin: item.anchorPosition,
|
|
2938
|
+
radius: Number(3),
|
|
2939
|
+
userData: {
|
|
2940
|
+
id: index + '-sphere-source',
|
|
2941
|
+
},
|
|
2942
|
+
})
|
|
2943
|
+
]);
|
|
2944
|
+
}
|
|
2945
|
+
catch (e) {
|
|
2946
|
+
console.log('could not create Sphere sensor');
|
|
2947
|
+
console.error(e);
|
|
2948
|
+
}
|
|
2949
|
+
if (!source) {
|
|
2950
|
+
return;
|
|
2951
|
+
}
|
|
2952
|
+
let sensor = null;
|
|
2953
|
+
try {
|
|
2954
|
+
sensor = yield this.sdk.Sensor.createSensor(this.sdk.Sensor.SensorType.CAMERA);
|
|
2955
|
+
}
|
|
2956
|
+
catch (e) {
|
|
2957
|
+
console.log('could not create Camera sensor');
|
|
2958
|
+
console.error(e);
|
|
2959
|
+
}
|
|
2960
|
+
if (!sensor) {
|
|
2961
|
+
return;
|
|
2962
|
+
}
|
|
2963
|
+
sensor.addSource(...source);
|
|
2964
|
+
sensor.readings.subscribe({
|
|
2965
|
+
onUpdated(source, reading) {
|
|
2966
|
+
console.log(thisOpacity);
|
|
2967
|
+
let oldOpacity = thisOpacity;
|
|
2968
|
+
if (reading.inRange) {
|
|
2969
|
+
thisOpacity = 1;
|
|
2970
|
+
console.log(index + ' is inRange');
|
|
2971
|
+
}
|
|
2972
|
+
else if (reading.inView) {
|
|
2973
|
+
console.log(index + ' is inView but not inRange');
|
|
2974
|
+
thisOpacity = 0.5;
|
|
2975
|
+
}
|
|
2976
|
+
else {
|
|
2977
|
+
thisOpacity = 0.2;
|
|
2978
|
+
console.log(index + ' is not inView or inRange');
|
|
2979
|
+
}
|
|
2980
|
+
this.sdk.Tag.editOpacity(index, thisOpacity);
|
|
2981
|
+
/*
|
|
2982
|
+
let inc = 0.01;
|
|
2983
|
+
if (oldOpacity > thisOpacity) {
|
|
2984
|
+
inc = -0.01;
|
|
2985
|
+
}
|
|
2986
|
+
|
|
2987
|
+
for(var i = oldOpacity; i != thisOpacity; i=i+inc) {
|
|
2988
|
+
setTimeout(function() {
|
|
2989
|
+
mpSdk.Tag.editOpacity(index, i);
|
|
2990
|
+
console.log('Delay', i);
|
|
2991
|
+
},10);
|
|
2992
|
+
}
|
|
2993
|
+
*/
|
|
2994
|
+
}
|
|
2995
|
+
});
|
|
2996
|
+
//sensor.showDebug(true);
|
|
2997
|
+
});
|
|
2998
|
+
}.bind(this),
|
|
2999
|
+
onCollectionUpdated: function (collection) {
|
|
3000
|
+
console.log('Collection received. There are ', Object.keys(collection).length, ' Tags in the collection', collection);
|
|
3001
|
+
}
|
|
3002
|
+
});
|
|
2927
3003
|
resolve(true);
|
|
2928
3004
|
});
|
|
2929
3005
|
}.bind(this));
|
|
@@ -4476,10 +4552,10 @@ class ModalSwitchVisitComponent {
|
|
|
4476
4552
|
}
|
|
4477
4553
|
}
|
|
4478
4554
|
ModalSwitchVisitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ModalSwitchVisitComponent, deps: [{ token: i1$2.NgbActiveModal }, { token: i1$1.Router }, { token: ViewerService }], target: i0.ɵɵFactoryTarget.Component });
|
|
4479
|
-
ModalSwitchVisitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: ModalSwitchVisitComponent, selector: "lib-modal-switch-visit", inputs: { content: "content", model3D: "model3D", spaceID: "spaceID", dataToMove: "dataToMove" }, ngImport: i0, template: "<div class=\"modal-container\">\
|
|
4555
|
+
ModalSwitchVisitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: ModalSwitchVisitComponent, selector: "lib-modal-switch-visit", inputs: { content: "content", model3D: "model3D", spaceID: "spaceID", dataToMove: "dataToMove" }, ngImport: i0, template: "<div class=\"modal-container\">\n <p>{{content}}</p>\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"switchVisit()\">{{'Yes, switch visit' | translate }}</button>\n <button class=\"btn btn-outline-primary rounded-pill\"(click)=\"activeModal.close()\">{{'No, stay here' | translate }}</button>\n</div>\n", styles: [".modal-container{margin:10px}button{margin-right:8px}\n"], pipes: { "translate": i1.TranslatePipe } });
|
|
4480
4556
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: ModalSwitchVisitComponent, decorators: [{
|
|
4481
4557
|
type: Component,
|
|
4482
|
-
args: [{ selector: 'lib-modal-switch-visit', template: "<div class=\"modal-container\">\
|
|
4558
|
+
args: [{ selector: 'lib-modal-switch-visit', template: "<div class=\"modal-container\">\n <p>{{content}}</p>\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"switchVisit()\">{{'Yes, switch visit' | translate }}</button>\n <button class=\"btn btn-outline-primary rounded-pill\"(click)=\"activeModal.close()\">{{'No, stay here' | translate }}</button>\n</div>\n", styles: [".modal-container{margin:10px}button{margin-right:8px}\n"] }]
|
|
4483
4559
|
}], ctorParameters: function () { return [{ type: i1$2.NgbActiveModal }, { type: i1$1.Router }, { type: ViewerService }]; }, propDecorators: { content: [{
|
|
4484
4560
|
type: Input
|
|
4485
4561
|
}], model3D: [{
|
|
@@ -8211,10 +8287,10 @@ class SearchBarComponent {
|
|
|
8211
8287
|
}
|
|
8212
8288
|
}
|
|
8213
8289
|
SearchBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SearchBarComponent, deps: [{ token: SearchService }], target: i0.ɵɵFactoryTarget.Component });
|
|
8214
|
-
SearchBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SearchBarComponent, selector: "lib-search-bar", inputs: { searchable: "searchable", objectType: "objectType" }, outputs: { searchEvent: "searchEvent" }, ngImport: i0, template: "<div class=\"col-md-8 searchbar\">\
|
|
8290
|
+
SearchBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SearchBarComponent, selector: "lib-search-bar", inputs: { searchable: "searchable", objectType: "objectType" }, outputs: { searchEvent: "searchEvent" }, ngImport: i0, template: "<div class=\"col-md-8 searchbar\">\n <div class=\"row depend\">\n <div class=\"col-md-5\">\n <input id=\"searchbar\" type=\"text\" class=\"form-control\" placeholder=\"keyword\" />\n </div>\n <div class=\"col-md-5\">\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"onSubmit()\">{{ 'Search' |\n translate}}</button>\n </div>\n </div>\n</div>", styles: [".searchbar{margin-bottom:10px}\n"], pipes: { "translate": i1.TranslatePipe } });
|
|
8215
8291
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SearchBarComponent, decorators: [{
|
|
8216
8292
|
type: Component,
|
|
8217
|
-
args: [{ selector: 'lib-search-bar', template: "<div class=\"col-md-8 searchbar\">\
|
|
8293
|
+
args: [{ selector: 'lib-search-bar', template: "<div class=\"col-md-8 searchbar\">\n <div class=\"row depend\">\n <div class=\"col-md-5\">\n <input id=\"searchbar\" type=\"text\" class=\"form-control\" placeholder=\"keyword\" />\n </div>\n <div class=\"col-md-5\">\n <button class=\"btn btn-outline-primary rounded-pill\" (click)=\"onSubmit()\">{{ 'Search' |\n translate}}</button>\n </div>\n </div>\n</div>", styles: [".searchbar{margin-bottom:10px}\n"] }]
|
|
8218
8294
|
}], ctorParameters: function () { return [{ type: SearchService }]; }, propDecorators: { searchable: [{
|
|
8219
8295
|
type: Input
|
|
8220
8296
|
}], objectType: [{
|
|
@@ -8628,10 +8704,10 @@ class LoaderComponent {
|
|
|
8628
8704
|
}
|
|
8629
8705
|
}
|
|
8630
8706
|
LoaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: LoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8631
|
-
LoaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: LoaderComponent, selector: "lib-loader", inputs: { useLogo: "useLogo", color: "color" }, ngImport: i0, template: "<div class=\"sk-fading-circle\">\
|
|
8707
|
+
LoaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: LoaderComponent, selector: "lib-loader", inputs: { useLogo: "useLogo", color: "color" }, ngImport: i0, template: "<div class=\"sk-fading-circle\">\n <img *ngIf=\"useLogo\" src=\"../../../../assets/icons/smarterplan.svg\">\n <div class=\"sk-circle1 sk-circle\"></div>\n <div class=\"sk-circle2 sk-circle\"></div>\n <div class=\"sk-circle3 sk-circle\"></div>\n <div class=\"sk-circle4 sk-circle\"></div>\n <div class=\"sk-circle5 sk-circle\"></div>\n <div class=\"sk-circle6 sk-circle\"></div>\n <div class=\"sk-circle7 sk-circle\"></div>\n <div class=\"sk-circle8 sk-circle\"></div>\n <div class=\"sk-circle9 sk-circle\"></div>\n <div class=\"sk-circle10 sk-circle\"></div>\n <div class=\"sk-circle11 sk-circle\"></div>\n <div class=\"sk-circle12 sk-circle\"></div>\n</div>\n", styles: [".sk-fading-circle{width:88px;height:88px;position:relative}.sk-fading-circle img{width:2rem;position:absolute;left:calc(50% - 16px);top:calc(50% - 16px)}.sk-fading-circle .sk-circle{width:100%;height:100%;position:absolute;left:0;top:0}.sk-fading-circle .sk-circle:before{content:\"\";display:block;margin:0 auto;width:15%;height:15%;background-color:var(--color);border-radius:100%;animation:sk-circleFadeDelay 1.2s infinite ease-in-out both}.sk-fading-circle .sk-circle2{transform:rotate(30deg)}.sk-fading-circle .sk-circle3{transform:rotate(60deg)}.sk-fading-circle .sk-circle4{transform:rotate(90deg)}.sk-fading-circle .sk-circle5{transform:rotate(120deg)}.sk-fading-circle .sk-circle6{transform:rotate(150deg)}.sk-fading-circle .sk-circle7{transform:rotate(180deg)}.sk-fading-circle .sk-circle8{transform:rotate(210deg)}.sk-fading-circle .sk-circle9{transform:rotate(240deg)}.sk-fading-circle .sk-circle10{transform:rotate(270deg)}.sk-fading-circle .sk-circle11{transform:rotate(300deg)}.sk-fading-circle .sk-circle12{transform:rotate(330deg)}.sk-fading-circle .sk-circle2:before{animation-delay:-1.1s}.sk-fading-circle .sk-circle3:before{animation-delay:-1s}.sk-fading-circle .sk-circle4:before{animation-delay:-.9s}.sk-fading-circle .sk-circle5:before{animation-delay:-.8s}.sk-fading-circle .sk-circle6:before{animation-delay:-.7s}.sk-fading-circle .sk-circle7:before{animation-delay:-.6s}.sk-fading-circle .sk-circle8:before{animation-delay:-.5s}.sk-fading-circle .sk-circle9:before{animation-delay:-.4s}.sk-fading-circle .sk-circle10:before{animation-delay:-.3s}.sk-fading-circle .sk-circle11:before{animation-delay:-.2s}.sk-fading-circle .sk-circle12:before{animation-delay:-.1s}@keyframes sk-circleFadeDelay{0%,39%,to{opacity:0}40%{opacity:1}}\n"], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
8632
8708
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: LoaderComponent, decorators: [{
|
|
8633
8709
|
type: Component,
|
|
8634
|
-
args: [{ selector: 'lib-loader', template: "<div class=\"sk-fading-circle\">\
|
|
8710
|
+
args: [{ selector: 'lib-loader', template: "<div class=\"sk-fading-circle\">\n <img *ngIf=\"useLogo\" src=\"../../../../assets/icons/smarterplan.svg\">\n <div class=\"sk-circle1 sk-circle\"></div>\n <div class=\"sk-circle2 sk-circle\"></div>\n <div class=\"sk-circle3 sk-circle\"></div>\n <div class=\"sk-circle4 sk-circle\"></div>\n <div class=\"sk-circle5 sk-circle\"></div>\n <div class=\"sk-circle6 sk-circle\"></div>\n <div class=\"sk-circle7 sk-circle\"></div>\n <div class=\"sk-circle8 sk-circle\"></div>\n <div class=\"sk-circle9 sk-circle\"></div>\n <div class=\"sk-circle10 sk-circle\"></div>\n <div class=\"sk-circle11 sk-circle\"></div>\n <div class=\"sk-circle12 sk-circle\"></div>\n</div>\n", styles: [".sk-fading-circle{width:88px;height:88px;position:relative}.sk-fading-circle img{width:2rem;position:absolute;left:calc(50% - 16px);top:calc(50% - 16px)}.sk-fading-circle .sk-circle{width:100%;height:100%;position:absolute;left:0;top:0}.sk-fading-circle .sk-circle:before{content:\"\";display:block;margin:0 auto;width:15%;height:15%;background-color:var(--color);border-radius:100%;animation:sk-circleFadeDelay 1.2s infinite ease-in-out both}.sk-fading-circle .sk-circle2{transform:rotate(30deg)}.sk-fading-circle .sk-circle3{transform:rotate(60deg)}.sk-fading-circle .sk-circle4{transform:rotate(90deg)}.sk-fading-circle .sk-circle5{transform:rotate(120deg)}.sk-fading-circle .sk-circle6{transform:rotate(150deg)}.sk-fading-circle .sk-circle7{transform:rotate(180deg)}.sk-fading-circle .sk-circle8{transform:rotate(210deg)}.sk-fading-circle .sk-circle9{transform:rotate(240deg)}.sk-fading-circle .sk-circle10{transform:rotate(270deg)}.sk-fading-circle .sk-circle11{transform:rotate(300deg)}.sk-fading-circle .sk-circle12{transform:rotate(330deg)}.sk-fading-circle .sk-circle2:before{animation-delay:-1.1s}.sk-fading-circle .sk-circle3:before{animation-delay:-1s}.sk-fading-circle .sk-circle4:before{animation-delay:-.9s}.sk-fading-circle .sk-circle5:before{animation-delay:-.8s}.sk-fading-circle .sk-circle6:before{animation-delay:-.7s}.sk-fading-circle .sk-circle7:before{animation-delay:-.6s}.sk-fading-circle .sk-circle8:before{animation-delay:-.5s}.sk-fading-circle .sk-circle9:before{animation-delay:-.4s}.sk-fading-circle .sk-circle10:before{animation-delay:-.3s}.sk-fading-circle .sk-circle11:before{animation-delay:-.2s}.sk-fading-circle .sk-circle12:before{animation-delay:-.1s}@keyframes sk-circleFadeDelay{0%,39%,to{opacity:0}40%{opacity:1}}\n"] }]
|
|
8635
8711
|
}], ctorParameters: function () { return []; }, propDecorators: { useLogo: [{
|
|
8636
8712
|
type: Input
|
|
8637
8713
|
}], color: [{
|
|
@@ -8689,10 +8765,10 @@ class SupportModalComponent {
|
|
|
8689
8765
|
}
|
|
8690
8766
|
}
|
|
8691
8767
|
SupportModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SupportModalComponent, deps: [{ token: SupportService }, { token: i1$2.NgbActiveModal }, { token: i3.FormBuilder }, { token: BaseUserService }, { token: ValidatorsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
8692
|
-
SupportModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SupportModalComponent, selector: "app-support-modal", ngImport: i0, template: "<div class=\"modal-header\">\
|
|
8768
|
+
SupportModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SupportModalComponent, selector: "app-support-modal", ngImport: i0, template: "<div class=\"modal-header\">\n <h5 class=\"modal-title\" translate=\"Help\"></h5>\n</div>\n<div class=\"modal-body\">\n <div class=\"support-loader-container\">\n <lib-loader *ngIf=\"loading\"></lib-loader>\n </div>\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"supportForm\" style=\"margin-top:1rem;\" *ngIf=\"!loading && status==='new'\">\n <div>\n <label>{{'Title' | translate}} *</label>\n <div>\n <input type=\"text\" class=\"form-control\" formControlName=\"title\" data-testid=\"new-support-title\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['title'])}\"\n maxlength=\"255\">\n </div>\n <div class=\"invalid-feedback\">\n <span data-testid=\"new-support-title-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['title'])\"\n *ngIf=\" validatorsService.isControlError(supportForm.controls['title'])\"></span>\n </div>\n </div>\n <div *ngIf=\"!currentUser\">\n <label>{{'Email' | translate}} *</label>\n <div>\n <input type=\"email\" class=\"form-control\" formControlName=\"email\" data-testid=\"new-support-email\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['email'])}\"\n maxlength=\"255\">\n </div>\n <div class=\"invalid-feedback\">\n <span data-testid=\"new-support-email-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['email'])\"\n *ngIf=\" validatorsService.isControlError(supportForm.controls['email'])\"></span>\n </div>\n </div>\n <div>\n <label>{{'Description' | translate}} *</label>\n <div>\n <textarea formControlName=\"description\" class=\"form-control\"\n data-testid=\"new-support-description\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['description'])}\"></textarea>\n </div>\n <div class=\"invalid-feedback\" >\n <span data-testid=\"new-support-description-invalid\" [translate]=\" validatorsService.getError(supportForm.controls['description'])\"\n *ngIf=\"validatorsService.isControlError(supportForm.controls['description'])\"></span>\n </div>\n </div>\n </form>\n\n <div *ngIf=\"status ==='send'\" translate=\"Your request has been registered\" data-testid=\"new-support-send-info\">\n </div>\n <div *ngIf=\"status ==='error'\" translate=\"An error has occurred, please renew your request\"\n data-testid=\"new-support-error-info\">\n\n </div>\n</div>\n<div class=\"modal-footer\">\n <button type=\"button\" class=\"btn rounded-pill btn-museum\" data-dismiss=\"modal\" translate=\"Close\" (click)=\"onClose()\"\n data-testid=\"new-support-close-btn\"></button>\n <button *ngIf=\"!loading && status==='new'\" type=\"button\" class=\"btn rounded-pill btn-museum\" translate=\"Submit\"\n (click)=\"onSubmit()\" [disabled]=\"!supportForm.valid\" data-testid=\"new-support-submit-btn\"></button>\n</div>", styles: [".support-loader-container{width:88px;margin:auto}.invalid-feedback{height:16px}\n"], components: [{ type: LoaderComponent, selector: "lib-loader", inputs: ["useLogo", "color"] }], directives: [{ type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
8693
8769
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SupportModalComponent, decorators: [{
|
|
8694
8770
|
type: Component,
|
|
8695
|
-
args: [{ selector: 'app-support-modal', template: "<div class=\"modal-header\">\
|
|
8771
|
+
args: [{ selector: 'app-support-modal', template: "<div class=\"modal-header\">\n <h5 class=\"modal-title\" translate=\"Help\"></h5>\n</div>\n<div class=\"modal-body\">\n <div class=\"support-loader-container\">\n <lib-loader *ngIf=\"loading\"></lib-loader>\n </div>\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"supportForm\" style=\"margin-top:1rem;\" *ngIf=\"!loading && status==='new'\">\n <div>\n <label>{{'Title' | translate}} *</label>\n <div>\n <input type=\"text\" class=\"form-control\" formControlName=\"title\" data-testid=\"new-support-title\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['title'])}\"\n maxlength=\"255\">\n </div>\n <div class=\"invalid-feedback\">\n <span data-testid=\"new-support-title-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['title'])\"\n *ngIf=\" validatorsService.isControlError(supportForm.controls['title'])\"></span>\n </div>\n </div>\n <div *ngIf=\"!currentUser\">\n <label>{{'Email' | translate}} *</label>\n <div>\n <input type=\"email\" class=\"form-control\" formControlName=\"email\" data-testid=\"new-support-email\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['email'])}\"\n maxlength=\"255\">\n </div>\n <div class=\"invalid-feedback\">\n <span data-testid=\"new-support-email-invalid\" [translate]=\"validatorsService.getError(supportForm.controls['email'])\"\n *ngIf=\" validatorsService.isControlError(supportForm.controls['email'])\"></span>\n </div>\n </div>\n <div>\n <label>{{'Description' | translate}} *</label>\n <div>\n <textarea formControlName=\"description\" class=\"form-control\"\n data-testid=\"new-support-description\"\n [ngClass]=\"{'is-invalid' : validatorsService.isControlError(supportForm.controls['description'])}\"></textarea>\n </div>\n <div class=\"invalid-feedback\" >\n <span data-testid=\"new-support-description-invalid\" [translate]=\" validatorsService.getError(supportForm.controls['description'])\"\n *ngIf=\"validatorsService.isControlError(supportForm.controls['description'])\"></span>\n </div>\n </div>\n </form>\n\n <div *ngIf=\"status ==='send'\" translate=\"Your request has been registered\" data-testid=\"new-support-send-info\">\n </div>\n <div *ngIf=\"status ==='error'\" translate=\"An error has occurred, please renew your request\"\n data-testid=\"new-support-error-info\">\n\n </div>\n</div>\n<div class=\"modal-footer\">\n <button type=\"button\" class=\"btn rounded-pill btn-museum\" data-dismiss=\"modal\" translate=\"Close\" (click)=\"onClose()\"\n data-testid=\"new-support-close-btn\"></button>\n <button *ngIf=\"!loading && status==='new'\" type=\"button\" class=\"btn rounded-pill btn-museum\" translate=\"Submit\"\n (click)=\"onSubmit()\" [disabled]=\"!supportForm.valid\" data-testid=\"new-support-submit-btn\"></button>\n</div>", styles: [".support-loader-container{width:88px;margin:auto}.invalid-feedback{height:16px}\n"] }]
|
|
8696
8772
|
}], ctorParameters: function () { return [{ type: SupportService }, { type: i1$2.NgbActiveModal }, { type: i3.FormBuilder }, { type: BaseUserService }, { type: ValidatorsService }]; } });
|
|
8697
8773
|
|
|
8698
8774
|
class LocaleService {
|
|
@@ -11562,10 +11638,10 @@ class NavigationBarComponent {
|
|
|
11562
11638
|
}
|
|
11563
11639
|
}
|
|
11564
11640
|
NavigationBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: NavigationBarComponent, deps: [{ token: 'currentAwsKinesisAnalyticsService' }, { token: i1$1.Router }, { token: SpaceService }, { token: BaseUserService }, { token: ZoneService }, { token: VisitService }, { token: ViewerService }, { token: NavigatorService }, { token: ZoneChangeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
11565
|
-
NavigationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: NavigationBarComponent, selector: "lib-navigation-bar", viewQueries: [{ propertyName: "navbarSelectMenu", first: true, predicate: ["navbarSelectMenu"], descendants: true }], ngImport: i0, template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\
|
|
11641
|
+
NavigationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: NavigationBarComponent, selector: "lib-navigation-bar", viewQueries: [{ propertyName: "navbarSelectMenu", first: true, predicate: ["navbarSelectMenu"], descendants: true }], ngImport: i0, template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\n <div class=\"d-flex col-12\">\n <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\n <div class=\"d-flex flex-column flex-md-row \">\n <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\n (ngModelChange)=\"onLocationClick()\">\n <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\n <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\n *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\n <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\n <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\n </option>\n </select>\n <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\n (ngModelChange)=\"onFloorClick()\">\n <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\n <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\n (ngModelChange)=\"onZoneClick()\">\n <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\n *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\n *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\n <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\n </select>\n <!-- <select class=\"form-control flex-fill\">\n <option i18n>{{'Favorites' | translate}}</option>\n </select> -->\n </div>\n <div class=\"row\" style=\"margin-left: 0;\">\n <div class=\"outer_circle\">\n <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\n (click)=\"goTo()\"></button>\n </div>\n <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\n [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\n </div>\n </div>\n\n <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\n {{ showLocation() }}\n </h4>\n </div>\n</nav>", styles: [":host{position:sticky;top:0;height:123px}.navbar{z-index:200;padding:.4rem 1rem}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0}.form-control{width:auto;min-width:80px;max-width:18%}.location{width:auto;max-width:35%}.floor,.zone{width:auto;max-width:30%}button{color:#fff;padding:5px 10px;font-size:1.1em}.btn-3d:active:hover:not([disabled]){color:var(--smarterplan-secondary)}.btn-3d[disabled]:hover{color:#fff}.navbar-toggler{margin-right:1em}.select-menu{max-width:inherit}#btn-icon{width:30px;height:30px;background:url(../../../../../assets/icons/goTo3d.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../../assets/icons/goTo3d-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../../assets/icons/goTo3d.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px}\n"], directives: [{ type: i1$2.NgbNavbar, selector: ".navbar" }, { type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
11566
11642
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: NavigationBarComponent, decorators: [{
|
|
11567
11643
|
type: Component,
|
|
11568
|
-
args: [{ selector: 'lib-navigation-bar', template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\
|
|
11644
|
+
args: [{ selector: 'lib-navigation-bar', template: "<nav class=\"navbar navbar-expand-md navbar-dark navbar-inverse second-nav\">\n <div class=\"d-flex col-12\">\n <div #navbarSelectMenu class=\"collapse navbar-collapse\" id=\"nav-item-container-blue\">\n <div class=\"d-flex flex-column flex-md-row \">\n <select class=\"form-control flex-fill location select-menu\" [(ngModel)]=\"selectedLocation\"\n (ngModelChange)=\"onLocationClick()\">\n <option [ngValue]=\"null\" selected>{{ 'Location' | translate }}</option>\n <option *ngFor=\"let loc of locations; index as index\" [ngValue]=\"loc\"> {{ loc.name }}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" (change)=\"onVisitClick($event)\"\n *ngIf=\"visitsPerSpace && visitsPerSpace.length > 1\">\n <option value=\"default\" selected disabled hidden>{{'Visit' | translate}}</option>\n <option *ngFor=\"let visit of visitsPerSpace; index as index\" value=\"{{index}}\">{{ visit.name}}\n </option>\n </select>\n <select class=\"form-control flex-fill floor select-menu\" [(ngModel)]=\"selectedFloor\"\n (ngModelChange)=\"onFloorClick()\">\n <option [ngValue]=\"null\" selected>{{'Floor' | translate}}</option>\n <option *ngFor=\"let floor of floorsPerSpace\" [ngValue]=\"floor\">{{ floor.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu zone\" [(ngModel)]=\"selectedZone\"\n (ngModelChange)=\"onZoneClick()\">\n <option [ngValue]=\"null\" selected>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of zonesPerFloor\" [ngValue]=\"zone\"><span\n *ngIf=\"zone.code_ref\">{{zone.code_ref}}_</span>{{zone.name}}</option>\n </select>\n <select class=\"form-control flex-fill select-menu\" [(ngModel)]=\"selectedChildZone\"\n *ngIf=\"childrenZones && childrenZones.length>0\" (ngModelChange)=\"onChildZoneClick()\">\n <option [ngValue]=\"null\" selected disabled>{{'Zone' | translate}}</option>\n <option *ngFor=\"let zone of childrenZones\" [ngValue]=\"zone\">{{ zone.name}}</option>\n </select>\n <!-- <select class=\"form-control flex-fill\">\n <option i18n>{{'Favorites' | translate}}</option>\n </select> -->\n </div>\n <div class=\"row\" style=\"margin-left: 0;\">\n <div class=\"outer_circle\">\n <button id='btn-icon' [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\"\n (click)=\"goTo()\"></button>\n </div>\n <button (click)=\"goTo()\" class=\"btn rounded-pill btn-3d\"\n [disabled]=\"!selectedLocation || !selectedModel3d || !canGo()\">{{'3D visit' | translate}}</button>\n </div>\n </div>\n\n <h4 style=\"line-height: 29px;margin: 0;\" *ngIf=\"showLocation()\">\n {{ showLocation() }}\n </h4>\n </div>\n</nav>", styles: [":host{position:sticky;top:0;height:123px}.navbar{z-index:200;padding:.4rem 1rem}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0}.form-control{width:auto;min-width:80px;max-width:18%}.location{width:auto;max-width:35%}.floor,.zone{width:auto;max-width:30%}button{color:#fff;padding:5px 10px;font-size:1.1em}.btn-3d:active:hover:not([disabled]){color:var(--smarterplan-secondary)}.btn-3d[disabled]:hover{color:#fff}.navbar-toggler{margin-right:1em}.select-menu{max-width:inherit}#btn-icon{width:30px;height:30px;background:url(../../../../../assets/icons/goTo3d.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../../assets/icons/goTo3d-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../../assets/icons/goTo3d.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px}\n"] }]
|
|
11569
11645
|
}], ctorParameters: function () {
|
|
11570
11646
|
return [{ type: undefined, decorators: [{
|
|
11571
11647
|
type: Inject,
|
|
@@ -11657,10 +11733,10 @@ class MenuBarComponent {
|
|
|
11657
11733
|
}
|
|
11658
11734
|
}
|
|
11659
11735
|
MenuBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MenuBarComponent, deps: [{ token: i1$1.Router }, { token: LocaleService }, { token: BaseUserService }, { token: NavigatorService }, { token: SupportService }, { token: BaseVisibilityService }], target: i0.ɵɵFactoryTarget.Component });
|
|
11660
|
-
MenuBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: MenuBarComponent, selector: "lib-menu-bar", ngImport: i0, template: "<div id=\"menu-bar\">\
|
|
11736
|
+
MenuBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: MenuBarComponent, selector: "lib-menu-bar", ngImport: i0, template: "<div id=\"menu-bar\">\n <div *ngIf=\"!isVisitor\">\n <nav class=\"navbar navbar-expand-md navbar-light p-0\">\n <div class=\"container-fluid\" *ngIf=\"isVisible\">\n <div class=\"navbar-brand\" [routerLink]=\"['/dashboard']\">\n <img alt=\"\" src=\"../assets/images/logos/logo-rvb-straight.png\">\n </div>\n <!-- <button class=\"navbar-toggler\" data-bs-target=\".navbar-collapse\" data-bs-toggle=\"collapse\" type=\"button\">\n <span class=\"navbar-toggler-icon\"></span>\n </button> -->\n <div class=\"collapse navbar-collapse\">\n <form class=\"form-inline ms-3\">\n <input class=\"form-control search-button\" placeholder=\"keyword\" id=\"mainSearchBar\" type=\"text\">\n <button class=\"btn btn-outline-primary rounded-pill me-2\" (click)=\"onSubmit()\">{{'Search' |\n translate}}</button>\n <lib-range-date-picker cacheName=\"mainDate\"></lib-range-date-picker>\n <div class=\"change-position-button\">\n <input type=\"checkbox\" class=\"btn-check\" id=\"btn-check-outlined\" autocomplete=\"off\">\n <label class=\"btn btn-outline-primary\" (click)=\"onChangePositionClick()\"\n for=\"btn-check-outlined\">{{\"Change position\" | translate}}</label>\n </div>\n </form>\n <div class=\"ms-auto nav-item dropdown\">\n <div class=\"profile_pic dropdown-toggle\" data-testid=\"dropdown-menu-button\" data-bs-toggle=\"dropdown\">\n <lib-avatar></lib-avatar>\n </div>\n <div class=\"dropdown-menu dropdown-menu-right\">\n <p *ngIf=\"user && mission\" class=\"p-2\">\n <span class=\"username\">{{ user.displayName }}</span><br />\n <span class=\"user-role\">{{ mission.role }}</span><br />\n <span class=\"org\">{{ mission.organisation ? mission.organisation.name : \"No organisation\" |\n translate}}</span>\n </p>\n <div class=\"dropdown-divider\"></div>\n <!-- <a class=\"dropdown-item\" routerLink=\"/debug\" *ngIf=\"isManager\">Debug</a> -->\n <a class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</a>\n <a class=\"dropdown-item\" routerLink=\"/dashboard\">{{'Data management' | translate}}</a>\n <a class=\"dropdown-item\" data-testid=\"user-management-btn\" routerLink=\"/admin\" *ngIf=\"isManager\">\n {{'Users management' | translate}}</a>\n <a class=\"dropdown-item\" routerLink=\"/profile\">\n {{'Profile' | translate}}</a>\n <div class=\"dropdown-divider\"></div>\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\n translate}}</button>\n </div>\n </div>\n </div>\n </div>\n </nav>\n <lib-navigation-bar *ngIf=\"isVisible && isChangePositionVisible\"></lib-navigation-bar>\n </div>\n <div *ngIf=\"isVisitor && isVisible\">\n <div class=\"visitor-div\">\n <div class=\"logo-container\" data-testid=\"dropdown-menu-button\">\n <img class=\"img-logo\" alt=\"SmarterPlanLogo\" src=\"../assets/images/logos/logo-reserve.png\">\n </div>\n <div class=\"avatar-container-menu\">\n <div class=\"profile_pic dropdown-toggle\" data-bs-toggle=\"dropdown\">\n <lib-avatar></lib-avatar>\n </div>\n <div class=\"dropdown-menu dropdown-menu-right\">\n <button class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</button>\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\n translate}}</button>\n </div>\n </div>\n </div>\n </div>\n</div>", styles: [":host{position:sticky;top:0;z-index:200}.navbar{z-index:200}.navbar-brand{padding-top:5px;padding-bottom:5px;cursor:pointer}.navbar-brand img{height:70px}.profile_pic{border-radius:50%;height:45px;width:45px;margin:8px;border:.2px solid #969696}.navbar-nav .profile-pic-container .dropdown-menu{position:absolute}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}.profile_pic.dropdown-toggle:after{display:none}.navbar-light{border-bottom:1px solid var(--smarterplan-primary);background-color:#fff}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0;width:auto}button{background-color:#fff;color:var(--smarterplan-primary);padding:5px 10px}button:disabled,button[disabled]{color:#c04f4f}.navbar-toggler{margin-right:1em}.icon{height:40px;width:40px;color:var(--smarterplan-primary)}.search-button{width:auto}.visitor-div{background-color:var(--smarterplan-primary);height:60px;display:flex;justify-content:space-between}.logo-container,.img-logo{height:100%}.change-position-button{margin-left:2rem}.change-position-button label,.change-position-button .btn-check:checked,.change-position-button .btn-check:focus,.change-position-button .btn-outline-primary,.change-position-button .btn{box-shadow:none!important;outline:0}.change-position-button label{border-radius:16px}.change-position-button .btn-check:checked+.btn{background-color:var(--smarterplan-primary);color:#fff!important}\n"], components: [{ type: RangeDatePickerComponent, selector: "lib-range-date-picker", inputs: ["cacheName"] }, { type: AvatarComponent, selector: "lib-avatar", inputs: ["size", "userID"] }, { type: NavigationBarComponent, selector: "lib-navigation-bar" }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1$2.NgbNavbar, selector: ".navbar" }, { type: i1$1.RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: ["queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }, { type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1$1.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
11661
11737
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: MenuBarComponent, decorators: [{
|
|
11662
11738
|
type: Component,
|
|
11663
|
-
args: [{ selector: 'lib-menu-bar', template: "<div id=\"menu-bar\">\
|
|
11739
|
+
args: [{ selector: 'lib-menu-bar', template: "<div id=\"menu-bar\">\n <div *ngIf=\"!isVisitor\">\n <nav class=\"navbar navbar-expand-md navbar-light p-0\">\n <div class=\"container-fluid\" *ngIf=\"isVisible\">\n <div class=\"navbar-brand\" [routerLink]=\"['/dashboard']\">\n <img alt=\"\" src=\"../assets/images/logos/logo-rvb-straight.png\">\n </div>\n <!-- <button class=\"navbar-toggler\" data-bs-target=\".navbar-collapse\" data-bs-toggle=\"collapse\" type=\"button\">\n <span class=\"navbar-toggler-icon\"></span>\n </button> -->\n <div class=\"collapse navbar-collapse\">\n <form class=\"form-inline ms-3\">\n <input class=\"form-control search-button\" placeholder=\"keyword\" id=\"mainSearchBar\" type=\"text\">\n <button class=\"btn btn-outline-primary rounded-pill me-2\" (click)=\"onSubmit()\">{{'Search' |\n translate}}</button>\n <lib-range-date-picker cacheName=\"mainDate\"></lib-range-date-picker>\n <div class=\"change-position-button\">\n <input type=\"checkbox\" class=\"btn-check\" id=\"btn-check-outlined\" autocomplete=\"off\">\n <label class=\"btn btn-outline-primary\" (click)=\"onChangePositionClick()\"\n for=\"btn-check-outlined\">{{\"Change position\" | translate}}</label>\n </div>\n </form>\n <div class=\"ms-auto nav-item dropdown\">\n <div class=\"profile_pic dropdown-toggle\" data-testid=\"dropdown-menu-button\" data-bs-toggle=\"dropdown\">\n <lib-avatar></lib-avatar>\n </div>\n <div class=\"dropdown-menu dropdown-menu-right\">\n <p *ngIf=\"user && mission\" class=\"p-2\">\n <span class=\"username\">{{ user.displayName }}</span><br />\n <span class=\"user-role\">{{ mission.role }}</span><br />\n <span class=\"org\">{{ mission.organisation ? mission.organisation.name : \"No organisation\" |\n translate}}</span>\n </p>\n <div class=\"dropdown-divider\"></div>\n <!-- <a class=\"dropdown-item\" routerLink=\"/debug\" *ngIf=\"isManager\">Debug</a> -->\n <a class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</a>\n <a class=\"dropdown-item\" routerLink=\"/dashboard\">{{'Data management' | translate}}</a>\n <a class=\"dropdown-item\" data-testid=\"user-management-btn\" routerLink=\"/admin\" *ngIf=\"isManager\">\n {{'Users management' | translate}}</a>\n <a class=\"dropdown-item\" routerLink=\"/profile\">\n {{'Profile' | translate}}</a>\n <div class=\"dropdown-divider\"></div>\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\n translate}}</button>\n </div>\n </div>\n </div>\n </div>\n </nav>\n <lib-navigation-bar *ngIf=\"isVisible && isChangePositionVisible\"></lib-navigation-bar>\n </div>\n <div *ngIf=\"isVisitor && isVisible\">\n <div class=\"visitor-div\">\n <div class=\"logo-container\" data-testid=\"dropdown-menu-button\">\n <img class=\"img-logo\" alt=\"SmarterPlanLogo\" src=\"../assets/images/logos/logo-reserve.png\">\n </div>\n <div class=\"avatar-container-menu\">\n <div class=\"profile_pic dropdown-toggle\" data-bs-toggle=\"dropdown\">\n <lib-avatar></lib-avatar>\n </div>\n <div class=\"dropdown-menu dropdown-menu-right\">\n <button class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</button>\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\n translate}}</button>\n </div>\n </div>\n </div>\n </div>\n</div>", styles: [":host{position:sticky;top:0;z-index:200}.navbar{z-index:200}.navbar-brand{padding-top:5px;padding-bottom:5px;cursor:pointer}.navbar-brand img{height:70px}.profile_pic{border-radius:50%;height:45px;width:45px;margin:8px;border:.2px solid #969696}.navbar-nav .profile-pic-container .dropdown-menu{position:absolute}.navbar.second-nav{z-index:199;background-color:var(--smarterplan-primary)}.profile_pic.dropdown-toggle:after{display:none}.navbar-light{border-bottom:1px solid var(--smarterplan-primary);background-color:#fff}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0;width:auto}button{background-color:#fff;color:var(--smarterplan-primary);padding:5px 10px}button:disabled,button[disabled]{color:#c04f4f}.navbar-toggler{margin-right:1em}.icon{height:40px;width:40px;color:var(--smarterplan-primary)}.search-button{width:auto}.visitor-div{background-color:var(--smarterplan-primary);height:60px;display:flex;justify-content:space-between}.logo-container,.img-logo{height:100%}.change-position-button{margin-left:2rem}.change-position-button label,.change-position-button .btn-check:checked,.change-position-button .btn-check:focus,.change-position-button .btn-outline-primary,.change-position-button .btn{box-shadow:none!important;outline:0}.change-position-button label{border-radius:16px}.change-position-button .btn-check:checked+.btn{background-color:var(--smarterplan-primary);color:#fff!important}\n"] }]
|
|
11664
11740
|
}], ctorParameters: function () { return [{ type: i1$1.Router }, { type: LocaleService }, { type: BaseUserService }, { type: NavigatorService }, { type: SupportService }, { type: BaseVisibilityService }]; } });
|
|
11665
11741
|
|
|
11666
11742
|
class NgxSmarterplanCoreModule {
|
|
@@ -11766,7 +11842,7 @@ class BaseTagService {
|
|
|
11766
11842
|
constructor() { }
|
|
11767
11843
|
getHtmlToInject(tagType, object) {
|
|
11768
11844
|
return __awaiter(this, void 0, void 0, function* () {
|
|
11769
|
-
throw new Error(`getHtmlToInject is not implemented in the base class.
|
|
11845
|
+
throw new Error(`getHtmlToInject is not implemented in the base class.
|
|
11770
11846
|
Please override this method in your extended class.`);
|
|
11771
11847
|
});
|
|
11772
11848
|
}
|
|
@@ -11793,37 +11869,37 @@ class BaseTagService {
|
|
|
11793
11869
|
}
|
|
11794
11870
|
prepareEquipmentHtml(equip) {
|
|
11795
11871
|
return __awaiter(this, void 0, void 0, function* () {
|
|
11796
|
-
throw new Error(`prepareEquipmentHtml is not implemented in the base class.
|
|
11872
|
+
throw new Error(`prepareEquipmentHtml is not implemented in the base class.
|
|
11797
11873
|
Please override this method in your extended class.`);
|
|
11798
11874
|
});
|
|
11799
11875
|
}
|
|
11800
11876
|
prepareTicketHtml(ticket) {
|
|
11801
11877
|
return __awaiter(this, void 0, void 0, function* () {
|
|
11802
|
-
throw new Error(`prepareTicketHtml is not implemented in the base class.
|
|
11878
|
+
throw new Error(`prepareTicketHtml is not implemented in the base class.
|
|
11803
11879
|
Please override this method in your extended class.`);
|
|
11804
11880
|
});
|
|
11805
11881
|
}
|
|
11806
11882
|
prepareFeatureHtml(feature) {
|
|
11807
11883
|
return __awaiter(this, void 0, void 0, function* () {
|
|
11808
|
-
throw new Error(`prepareFeatureHtml is not implemented in the base class.
|
|
11884
|
+
throw new Error(`prepareFeatureHtml is not implemented in the base class.
|
|
11809
11885
|
Please override this method in your extended class.`);
|
|
11810
11886
|
});
|
|
11811
11887
|
}
|
|
11812
11888
|
prepareMeasurementHtml(measure) {
|
|
11813
11889
|
return __awaiter(this, void 0, void 0, function* () {
|
|
11814
|
-
throw new Error(`prepareMeasurementHtml is not implemented in the base class.
|
|
11890
|
+
throw new Error(`prepareMeasurementHtml is not implemented in the base class.
|
|
11815
11891
|
Please override this method in your extended class.`);
|
|
11816
11892
|
});
|
|
11817
11893
|
}
|
|
11818
11894
|
prepareDeskHtml(feature) {
|
|
11819
11895
|
return __awaiter(this, void 0, void 0, function* () {
|
|
11820
|
-
throw new Error(`prepareDeskHtml is not implemented in the base class.
|
|
11896
|
+
throw new Error(`prepareDeskHtml is not implemented in the base class.
|
|
11821
11897
|
Please override this method in your extended class.`);
|
|
11822
11898
|
});
|
|
11823
11899
|
}
|
|
11824
11900
|
prepareIndicatorHtml(feature) {
|
|
11825
11901
|
return __awaiter(this, void 0, void 0, function* () {
|
|
11826
|
-
throw new Error(`prepareDeskHtml is not implemented in the base class.
|
|
11902
|
+
throw new Error(`prepareDeskHtml is not implemented in the base class.
|
|
11827
11903
|
Please override this method in your extended class.`);
|
|
11828
11904
|
});
|
|
11829
11905
|
}
|
|
@@ -11835,43 +11911,43 @@ class BaseTagService {
|
|
|
11835
11911
|
getIconTagImageForFeature(feature, poi) {
|
|
11836
11912
|
// const tagIcon = JSON.parse(poi.tagIcon);
|
|
11837
11913
|
// return tagIcon.src;
|
|
11838
|
-
throw new Error(`getIconTagImageForFeature is not implemented in the base class.
|
|
11914
|
+
throw new Error(`getIconTagImageForFeature is not implemented in the base class.
|
|
11839
11915
|
Please override this method in your extended class.`);
|
|
11840
11916
|
}
|
|
11841
11917
|
getScriptForTag(object, tagType) {
|
|
11842
|
-
throw new Error(`getScriptForTag is not implemented in the base class.
|
|
11918
|
+
throw new Error(`getScriptForTag is not implemented in the base class.
|
|
11843
11919
|
Please override this method in your extended class.`);
|
|
11844
11920
|
}
|
|
11845
11921
|
getAnnexeForCommentTypeInFeature(feature, commentType) {
|
|
11846
|
-
throw new Error(`getAnnexeForCommentTypeInFeature is not implemented in the base class.
|
|
11922
|
+
throw new Error(`getAnnexeForCommentTypeInFeature is not implemented in the base class.
|
|
11847
11923
|
Please override this method in your extended class.`);
|
|
11848
11924
|
}
|
|
11849
11925
|
getBillboardMediaToEmbed(object) {
|
|
11850
|
-
throw new Error(`getBillboardMediaToEmbed is not implemented in the base class.
|
|
11926
|
+
throw new Error(`getBillboardMediaToEmbed is not implemented in the base class.
|
|
11851
11927
|
Please override this method in your extended class.`);
|
|
11852
11928
|
}
|
|
11853
11929
|
onActionDetailClick(url) {
|
|
11854
|
-
throw new Error(`onActionDetailClick is not implemented in the base class.
|
|
11930
|
+
throw new Error(`onActionDetailClick is not implemented in the base class.
|
|
11855
11931
|
Please override this method in your extended class.`);
|
|
11856
11932
|
}
|
|
11857
11933
|
onActionAudioClick(audioCommentID) {
|
|
11858
|
-
throw new Error(`onActionDetailClick is not implemented in the base class.
|
|
11934
|
+
throw new Error(`onActionDetailClick is not implemented in the base class.
|
|
11859
11935
|
Please override this method in your extended class.`);
|
|
11860
11936
|
}
|
|
11861
11937
|
onActionVideoClick(url) {
|
|
11862
|
-
throw new Error(`onActionVideoClick is not implemented in the base class.
|
|
11938
|
+
throw new Error(`onActionVideoClick is not implemented in the base class.
|
|
11863
11939
|
Please override this method in your extended class.`);
|
|
11864
11940
|
}
|
|
11865
11941
|
onActionImageClick(imageCommentID) {
|
|
11866
|
-
throw new Error(`onActionImageClick is not implemented in the base class.
|
|
11942
|
+
throw new Error(`onActionImageClick is not implemented in the base class.
|
|
11867
11943
|
Please override this method in your extended class.`);
|
|
11868
11944
|
}
|
|
11869
11945
|
onActionDocClick(url) {
|
|
11870
|
-
throw new Error(`onActionDocClick is not implemented in the base class.
|
|
11946
|
+
throw new Error(`onActionDocClick is not implemented in the base class.
|
|
11871
11947
|
Please override this method in your extended class.`);
|
|
11872
11948
|
}
|
|
11873
11949
|
onActionYoutubeClick(url) {
|
|
11874
|
-
throw new Error(`onActionYoutubeClick is not implemented in the base class.
|
|
11950
|
+
throw new Error(`onActionYoutubeClick is not implemented in the base class.
|
|
11875
11951
|
Please override this method in your extended class.`);
|
|
11876
11952
|
}
|
|
11877
11953
|
}
|
|
@@ -11957,7 +12033,7 @@ class MatterportImportService {
|
|
|
11957
12033
|
this.importingImages = new Subject();
|
|
11958
12034
|
this.sweepProcessedCount = new Subject();
|
|
11959
12035
|
this.totalSweepsCount = new Subject();
|
|
11960
|
-
this.MAX_SCANS_RELOAD =
|
|
12036
|
+
this.MAX_SCANS_RELOAD = 5;
|
|
11961
12037
|
}
|
|
11962
12038
|
get spaceID() {
|
|
11963
12039
|
return this._spaceID;
|
|
@@ -11991,46 +12067,49 @@ class MatterportImportService {
|
|
|
11991
12067
|
const element = document.querySelector('#viewer-frame');
|
|
11992
12068
|
element.append(iframe);
|
|
11993
12069
|
this.currentFrame = iframe;
|
|
11994
|
-
|
|
11995
|
-
|
|
11996
|
-
|
|
11997
|
-
|
|
11998
|
-
|
|
11999
|
-
|
|
12000
|
-
|
|
12001
|
-
|
|
12002
|
-
|
|
12003
|
-
|
|
12004
|
-
|
|
12005
|
-
|
|
12006
|
-
|
|
12007
|
-
|
|
12008
|
-
|
|
12009
|
-
|
|
12010
|
-
|
|
12011
|
-
|
|
12012
|
-
|
|
12013
|
-
|
|
12014
|
-
|
|
12015
|
-
|
|
12016
|
-
|
|
12017
|
-
|
|
12018
|
-
|
|
12019
|
-
|
|
12020
|
-
|
|
12021
|
-
|
|
12022
|
-
|
|
12023
|
-
|
|
12024
|
-
|
|
12025
|
-
|
|
12026
|
-
|
|
12027
|
-
|
|
12028
|
-
|
|
12029
|
-
|
|
12030
|
-
|
|
12031
|
-
|
|
12032
|
-
|
|
12033
|
-
|
|
12070
|
+
return new Promise((res, rej) => {
|
|
12071
|
+
iframe.addEventListener('load', () => __awaiter(this, void 0, void 0, function* () {
|
|
12072
|
+
try {
|
|
12073
|
+
this.sdk = yield window.MP_SDK.connect(iframe, 'qn9wsasuy5h2fzrbrn1nzr0id', '3.11');
|
|
12074
|
+
// Subscribe to Floor data
|
|
12075
|
+
this.sdk.Floor.data.subscribe({
|
|
12076
|
+
onCollectionUpdated: function upd(collection) {
|
|
12077
|
+
// console.log("Floors", collection);
|
|
12078
|
+
this.floors = collection;
|
|
12079
|
+
}.bind(this),
|
|
12080
|
+
});
|
|
12081
|
+
// Subscribe to current Floor
|
|
12082
|
+
this.sdk.Floor.current.subscribe(function upd(currentFloor) {
|
|
12083
|
+
this.currentFloor = currentFloor;
|
|
12084
|
+
}.bind(this));
|
|
12085
|
+
// Subscribe to Sweep data
|
|
12086
|
+
this.sdk.Sweep.data.subscribe({
|
|
12087
|
+
onCollectionUpdated: function upd(collection) {
|
|
12088
|
+
console.log('the entire up-to-date collection', collection);
|
|
12089
|
+
this.sweeps = collection;
|
|
12090
|
+
}.bind(this),
|
|
12091
|
+
});
|
|
12092
|
+
// remove labels
|
|
12093
|
+
yield this.sdk.Settings.update('labels', false);
|
|
12094
|
+
let timeoutExpired = false;
|
|
12095
|
+
// start timeout
|
|
12096
|
+
setTimeout(() => (timeoutExpired = true), 7000);
|
|
12097
|
+
yield waitUntil(() => (this.sweeps !== undefined && this.floors !== undefined) ||
|
|
12098
|
+
timeoutExpired === true);
|
|
12099
|
+
if (timeoutExpired) {
|
|
12100
|
+
// we are likely in matterport error case (that we cannot catch!)
|
|
12101
|
+
console.log('timeout intitialising Matterport');
|
|
12102
|
+
return rej(new Error('error init Matterport'));
|
|
12103
|
+
}
|
|
12104
|
+
console.log('init done');
|
|
12105
|
+
return res(true);
|
|
12106
|
+
}
|
|
12107
|
+
catch (e) {
|
|
12108
|
+
console.error(e);
|
|
12109
|
+
rej(new Error('error init Matterport'));
|
|
12110
|
+
}
|
|
12111
|
+
}));
|
|
12112
|
+
});
|
|
12034
12113
|
});
|
|
12035
12114
|
}
|
|
12036
12115
|
importData(spaceID, surface, reloading = false, node = null) {
|
|
@@ -12145,6 +12224,11 @@ class MatterportImportService {
|
|
|
12145
12224
|
}
|
|
12146
12225
|
for (let index = indexScan; index < maxScan; index += 1) {
|
|
12147
12226
|
if (!this.stop) {
|
|
12227
|
+
yield new Promise((res) => {
|
|
12228
|
+
setTimeout(() => {
|
|
12229
|
+
res(null);
|
|
12230
|
+
}, 1000);
|
|
12231
|
+
});
|
|
12148
12232
|
yield this.sdk.Sweep.moveTo(scans[index].uuid);
|
|
12149
12233
|
yield this.sdk.Camera.setRotation({
|
|
12150
12234
|
x: 0,
|