@smarterplan/ngx-smarterplan-core 1.3.4 → 1.4.0
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/csv-export/csv-export.component.mjs +58 -0
- package/esm2022/lib/components/loader/loader.component.mjs +23 -0
- package/esm2022/lib/components/menu-bar/avatar/avatar.component.mjs +86 -0
- package/esm2022/lib/components/menu-bar/menu-bar.component.mjs +261 -0
- package/esm2022/lib/components/menu-bar/navigation-bar/navigation-bar.component.mjs +408 -0
- package/esm2022/lib/components/modal-switch-visit/modal-switch-visit.component.mjs +48 -0
- package/esm2022/lib/components/search-bar/search-bar.component.mjs +68 -0
- package/esm2022/lib/components/support-modal/support-modal.component.mjs +74 -0
- package/esm2022/lib/config.mjs +5 -0
- package/{esm2020 → esm2022}/lib/helpers.service.mjs +469 -469
- package/esm2022/lib/matterport-extensions/hsl-loader/HlsLoader.mjs +66 -0
- package/esm2022/lib/matterport-extensions/nest-thermostat/CanvasImage.mjs +48 -0
- package/esm2022/lib/matterport-extensions/nest-thermostat/CanvasRenderer.mjs +60 -0
- package/esm2022/lib/matterport-extensions/nest-thermostat/NestThermostat.mjs +156 -0
- package/esm2022/lib/matterport-extensions/nest-thermostat/PlaneRenderer.mjs +84 -0
- package/esm2022/lib/matterport-extensions/scene-component/SceneComponent.mjs +139 -0
- package/esm2022/lib/matterport-extensions/security-camera/SecurityCamera.mjs +248 -0
- package/esm2022/lib/matterport-extensions/tv-player/TvPlayer.mjs +97 -0
- package/esm2022/lib/matterport-extensions/video-renderer/VideoRenderer.mjs +63 -0
- package/esm2022/lib/matterport-extensions/view-frustum-mesh/ViewFrustumMesh.mjs +219 -0
- package/esm2022/lib/mattertagData.mjs +171 -0
- package/esm2022/lib/ngx-smarterplan-core.module.mjs +118 -0
- package/esm2022/lib/ngx-smarterplan-core.service.mjs +15 -0
- package/esm2022/lib/pipes/duration-to-string.pipe.mjs +68 -0
- package/{esm2020 → esm2022}/lib/pipes/format-date-number-to-digits.pipe.mjs +32 -30
- package/esm2022/lib/pipes/hashtag-from-id.pipe.mjs +28 -0
- package/esm2022/lib/pipes/safe-url.pipe.mjs +22 -0
- package/esm2022/lib/pipes/time-date-to-local-string.pipe.mjs +106 -0
- package/esm2022/lib/pipes/username-from-id.pipe.mjs +31 -0
- package/esm2022/lib/services/amplify-cache.service.mjs +73 -0
- package/esm2022/lib/services/base-tab.service.mjs +24 -0
- package/esm2022/lib/services/baseVisibility.service.mjs +18 -0
- package/esm2022/lib/services/content.service.mjs +141 -0
- package/esm2022/lib/services/filter.service.mjs +608 -0
- package/esm2022/lib/services/intervention.service.mjs +239 -0
- package/esm2022/lib/services/locale.service.mjs +47 -0
- package/esm2022/lib/services/matterport-import.service.mjs +354 -0
- package/esm2022/lib/services/matterport.service.mjs +1701 -0
- package/esm2022/lib/services/models/affectation.service.mjs +62 -0
- package/esm2022/lib/services/models/base-object.service.mjs +73 -0
- package/esm2022/lib/services/models/capture.service.mjs +36 -0
- package/esm2022/lib/services/models/comment.service.mjs +101 -0
- package/esm2022/lib/services/models/domain.service.mjs +80 -0
- package/esm2022/lib/services/models/equipment.service.mjs +698 -0
- package/esm2022/lib/services/models/event.service.mjs +132 -0
- package/esm2022/lib/services/models/feature.service.mjs +390 -0
- package/esm2022/lib/services/models/hashtag.service.mjs +41 -0
- package/esm2022/lib/services/models/layer.service.mjs +35 -0
- package/esm2022/lib/services/models/measurement.service.mjs +220 -0
- package/esm2022/lib/services/models/mission.service.mjs +211 -0
- package/esm2022/lib/services/models/navigation.service.mjs +96 -0
- package/esm2022/lib/services/models/node.service.mjs +33 -0
- package/esm2022/lib/services/models/object3D.service.mjs +374 -0
- package/esm2022/lib/services/models/operation.service.mjs +61 -0
- package/esm2022/lib/services/models/organisation.service.mjs +75 -0
- package/esm2022/lib/services/models/plan.service.mjs +823 -0
- package/esm2022/lib/services/models/poi.service.mjs +110 -0
- package/esm2022/lib/services/models/profile.service.mjs +60 -0
- package/esm2022/lib/services/models/property.service.mjs +46 -0
- package/esm2022/lib/services/models/space.service.mjs +215 -0
- package/esm2022/lib/services/models/template.service.mjs +43 -0
- package/esm2022/lib/services/models/ticket.service.mjs +545 -0
- package/esm2022/lib/services/models/visit.service.mjs +138 -0
- package/esm2022/lib/services/models/zone.service.mjs +228 -0
- package/esm2022/lib/services/navigator.service.mjs +233 -0
- package/{esm2020 → esm2022}/lib/services/s3.service.mjs +136 -136
- package/esm2022/lib/services/search.service.mjs +127 -0
- package/esm2022/lib/services/support.service.mjs +45 -0
- package/esm2022/lib/services/tag.service.mjs +112 -0
- package/esm2022/lib/services/user.service.mjs +513 -0
- package/esm2022/lib/services/validators.service.mjs +51 -0
- package/esm2022/lib/services/viewer.service.mjs +397 -0
- package/{esm2020 → esm2022}/lib/services/zone-drawer.service.mjs +75 -75
- package/esm2022/lib/services/zoneChange.service.mjs +33 -0
- package/esm2022/lib/types.service.mjs +324 -0
- package/{esm2020 → esm2022}/lib/validators/email.directive.mjs +6 -6
- package/{esm2020 → esm2022}/lib/validators/no-empty.directive.mjs +11 -11
- package/{esm2020 → esm2022}/lib/validators/number.directive.mjs +11 -11
- package/{esm2020 → esm2022}/lib/validators/text.directive.mjs +11 -11
- package/{esm2020 → esm2022}/public-api.mjs +71 -71
- package/{esm2020 → esm2022}/smarterplan-ngx-smarterplan-core.mjs +4 -4
- package/{fesm2020 → fesm2022}/smarterplan-ngx-smarterplan-core.mjs +12633 -12311
- package/fesm2022/smarterplan-ngx-smarterplan-core.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/components/csv-export/csv-export.component.d.ts +18 -18
- package/lib/components/loader/loader.component.d.ts +10 -10
- package/lib/components/menu-bar/avatar/avatar.component.d.ts +21 -21
- package/lib/components/menu-bar/menu-bar.component.d.ts +70 -70
- package/lib/components/menu-bar/navigation-bar/navigation-bar.component.d.ts +76 -76
- package/lib/components/modal-switch-visit/modal-switch-visit.component.d.ts +22 -22
- package/lib/components/search-bar/search-bar.component.d.ts +16 -16
- package/lib/components/support-modal/support-modal.component.d.ts +26 -26
- package/lib/config.d.ts +22 -22
- package/lib/helpers.service.d.ts +79 -79
- package/lib/matterport-extensions/hsl-loader/HlsLoader.d.ts +26 -26
- package/lib/matterport-extensions/nest-thermostat/CanvasImage.d.ts +31 -31
- package/lib/matterport-extensions/nest-thermostat/CanvasRenderer.d.ts +37 -37
- package/lib/matterport-extensions/nest-thermostat/NestThermostat.d.ts +42 -42
- package/lib/matterport-extensions/nest-thermostat/PlaneRenderer.d.ts +46 -46
- package/lib/matterport-extensions/scene-component/SceneComponent.d.ts +388 -388
- package/lib/matterport-extensions/security-camera/SecurityCamera.d.ts +47 -47
- package/lib/matterport-extensions/tv-player/TvPlayer.d.ts +26 -26
- package/lib/matterport-extensions/video-renderer/VideoRenderer.d.ts +26 -26
- package/lib/matterport-extensions/view-frustum-mesh/ViewFrustumMesh.d.ts +43 -43
- package/lib/mattertagData.d.ts +70 -70
- package/lib/ngx-smarterplan-core.module.d.ts +28 -28
- package/lib/ngx-smarterplan-core.service.d.ts +6 -6
- package/lib/pipes/duration-to-string.pipe.d.ts +12 -12
- package/lib/pipes/format-date-number-to-digits.pipe.d.ts +10 -10
- package/lib/pipes/hashtag-from-id.pipe.d.ts +10 -10
- package/lib/pipes/safe-url.pipe.d.ts +10 -10
- package/lib/pipes/time-date-to-local-string.pipe.d.ts +16 -16
- package/lib/pipes/username-from-id.pipe.d.ts +11 -11
- package/lib/services/amplify-cache.service.d.ts +37 -37
- package/lib/services/base-tab.service.d.ts +10 -10
- package/lib/services/baseVisibility.service.d.ts +9 -9
- package/lib/services/content.service.d.ts +28 -28
- package/lib/services/filter.service.d.ts +60 -60
- package/lib/services/intervention.service.d.ts +25 -25
- package/lib/services/locale.service.d.ts +23 -23
- package/lib/services/matterport-import.service.d.ts +53 -53
- package/lib/services/matterport.service.d.ts +336 -336
- package/lib/services/models/affectation.service.d.ts +14 -14
- package/lib/services/models/base-object.service.d.ts +20 -20
- package/lib/services/models/capture.service.d.ts +13 -13
- package/lib/services/models/comment.service.d.ts +26 -26
- package/lib/services/models/domain.service.d.ts +19 -19
- package/lib/services/models/equipment.service.d.ts +93 -93
- package/lib/services/models/event.service.d.ts +43 -43
- package/lib/services/models/feature.service.d.ts +75 -75
- package/lib/services/models/hashtag.service.d.ts +13 -13
- package/lib/services/models/layer.service.d.ts +11 -11
- package/lib/services/models/measurement.service.d.ts +51 -51
- package/lib/services/models/mission.service.d.ts +39 -39
- package/lib/services/models/navigation.service.d.ts +29 -29
- package/lib/services/models/node.service.d.ts +12 -12
- package/lib/services/models/object3D.service.d.ts +57 -57
- package/lib/services/models/operation.service.d.ts +15 -15
- package/lib/services/models/organisation.service.d.ts +19 -19
- package/lib/services/models/plan.service.d.ts +133 -133
- package/lib/services/models/poi.service.d.ts +25 -25
- package/lib/services/models/profile.service.d.ts +16 -16
- package/lib/services/models/property.service.d.ts +13 -13
- package/lib/services/models/space.service.d.ts +46 -46
- package/lib/services/models/template.service.d.ts +15 -15
- package/lib/services/models/ticket.service.d.ts +93 -93
- package/lib/services/models/visit.service.d.ts +24 -24
- package/lib/services/models/zone.service.d.ts +50 -50
- package/lib/services/navigator.service.d.ts +61 -61
- package/lib/services/s3.service.d.ts +14 -14
- package/lib/services/search.service.d.ts +20 -20
- package/lib/services/support.service.d.ts +17 -17
- package/lib/services/tag.service.d.ts +29 -29
- package/lib/services/user.service.d.ts +118 -118
- package/lib/services/validators.service.d.ts +18 -18
- package/lib/services/viewer.service.d.ts +111 -111
- package/lib/services/zone-drawer.service.d.ts +7 -7
- package/lib/services/zoneChange.service.d.ts +17 -17
- package/lib/types.service.d.ts +842 -842
- package/lib/validators/email.directive.d.ts +2 -2
- package/lib/validators/no-empty.directive.d.ts +2 -2
- package/lib/validators/number.directive.d.ts +2 -2
- package/lib/validators/text.directive.d.ts +2 -2
- package/package.json +8 -14
- package/public-api.d.ts +64 -64
- package/esm2020/lib/components/csv-export/csv-export.component.mjs +0 -59
- package/esm2020/lib/components/loader/loader.component.mjs +0 -23
- package/esm2020/lib/components/menu-bar/avatar/avatar.component.mjs +0 -79
- package/esm2020/lib/components/menu-bar/menu-bar.component.mjs +0 -238
- package/esm2020/lib/components/menu-bar/navigation-bar/navigation-bar.component.mjs +0 -389
- package/esm2020/lib/components/modal-switch-visit/modal-switch-visit.component.mjs +0 -40
- package/esm2020/lib/components/search-bar/search-bar.component.mjs +0 -63
- package/esm2020/lib/components/support-modal/support-modal.component.mjs +0 -66
- package/esm2020/lib/config.mjs +0 -4
- package/esm2020/lib/matterport-extensions/hsl-loader/HlsLoader.mjs +0 -69
- package/esm2020/lib/matterport-extensions/nest-thermostat/CanvasImage.mjs +0 -51
- package/esm2020/lib/matterport-extensions/nest-thermostat/CanvasRenderer.mjs +0 -61
- package/esm2020/lib/matterport-extensions/nest-thermostat/NestThermostat.mjs +0 -158
- package/esm2020/lib/matterport-extensions/nest-thermostat/PlaneRenderer.mjs +0 -85
- package/esm2020/lib/matterport-extensions/scene-component/SceneComponent.mjs +0 -128
- package/esm2020/lib/matterport-extensions/security-camera/SecurityCamera.mjs +0 -249
- package/esm2020/lib/matterport-extensions/tv-player/TvPlayer.mjs +0 -98
- package/esm2020/lib/matterport-extensions/video-renderer/VideoRenderer.mjs +0 -64
- package/esm2020/lib/matterport-extensions/view-frustum-mesh/ViewFrustumMesh.mjs +0 -221
- package/esm2020/lib/mattertagData.mjs +0 -165
- package/esm2020/lib/ngx-smarterplan-core.module.mjs +0 -117
- package/esm2020/lib/ngx-smarterplan-core.service.mjs +0 -14
- package/esm2020/lib/pipes/duration-to-string.pipe.mjs +0 -66
- package/esm2020/lib/pipes/hashtag-from-id.pipe.mjs +0 -26
- package/esm2020/lib/pipes/safe-url.pipe.mjs +0 -20
- package/esm2020/lib/pipes/time-date-to-local-string.pipe.mjs +0 -104
- package/esm2020/lib/pipes/username-from-id.pipe.mjs +0 -29
- package/esm2020/lib/services/amplify-cache.service.mjs +0 -72
- package/esm2020/lib/services/base-tab.service.mjs +0 -24
- package/esm2020/lib/services/baseVisibility.service.mjs +0 -18
- package/esm2020/lib/services/content.service.mjs +0 -135
- package/esm2020/lib/services/filter.service.mjs +0 -603
- package/esm2020/lib/services/intervention.service.mjs +0 -236
- package/esm2020/lib/services/locale.service.mjs +0 -45
- package/esm2020/lib/services/matterport-import.service.mjs +0 -340
- package/esm2020/lib/services/matterport.service.mjs +0 -1669
- package/esm2020/lib/services/models/affectation.service.mjs +0 -60
- package/esm2020/lib/services/models/base-object.service.mjs +0 -70
- package/esm2020/lib/services/models/capture.service.mjs +0 -34
- package/esm2020/lib/services/models/comment.service.mjs +0 -98
- package/esm2020/lib/services/models/domain.service.mjs +0 -78
- package/esm2020/lib/services/models/equipment.service.mjs +0 -683
- package/esm2020/lib/services/models/event.service.mjs +0 -128
- package/esm2020/lib/services/models/feature.service.mjs +0 -380
- package/esm2020/lib/services/models/hashtag.service.mjs +0 -38
- package/esm2020/lib/services/models/layer.service.mjs +0 -33
- package/esm2020/lib/services/models/measurement.service.mjs +0 -208
- package/esm2020/lib/services/models/mission.service.mjs +0 -206
- package/esm2020/lib/services/models/navigation.service.mjs +0 -92
- package/esm2020/lib/services/models/node.service.mjs +0 -31
- package/esm2020/lib/services/models/object3D.service.mjs +0 -364
- package/esm2020/lib/services/models/operation.service.mjs +0 -59
- package/esm2020/lib/services/models/organisation.service.mjs +0 -73
- package/esm2020/lib/services/models/plan.service.mjs +0 -799
- package/esm2020/lib/services/models/poi.service.mjs +0 -103
- package/esm2020/lib/services/models/profile.service.mjs +0 -58
- package/esm2020/lib/services/models/property.service.mjs +0 -44
- package/esm2020/lib/services/models/space.service.mjs +0 -204
- package/esm2020/lib/services/models/template.service.mjs +0 -41
- package/esm2020/lib/services/models/ticket.service.mjs +0 -526
- package/esm2020/lib/services/models/visit.service.mjs +0 -130
- package/esm2020/lib/services/models/zone.service.mjs +0 -225
- package/esm2020/lib/services/navigator.service.mjs +0 -212
- package/esm2020/lib/services/search.service.mjs +0 -124
- package/esm2020/lib/services/support.service.mjs +0 -42
- package/esm2020/lib/services/tag.service.mjs +0 -111
- package/esm2020/lib/services/user.service.mjs +0 -501
- package/esm2020/lib/services/validators.service.mjs +0 -50
- package/esm2020/lib/services/viewer.service.mjs +0 -390
- package/esm2020/lib/services/zoneChange.service.mjs +0 -30
- package/esm2020/lib/types.service.mjs +0 -311
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs +0 -13299
- package/fesm2015/smarterplan-ngx-smarterplan-core.mjs.map +0 -1
- package/fesm2020/smarterplan-ngx-smarterplan-core.mjs.map +0 -1
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@ngx-translate/core";
|
|
4
|
+
class CsvExportComponent {
|
|
5
|
+
/** Header of the CSV, titles for each columns */
|
|
6
|
+
headers = [];
|
|
7
|
+
/** Array of each rows (array of array of string), if it's not set, then the function getRows() will be used */
|
|
8
|
+
rowsInput = undefined;
|
|
9
|
+
/** Function used to get rows if rowsInput is not set, call each time the user click on the button to generate the CSV file */
|
|
10
|
+
getRows = undefined;
|
|
11
|
+
/** Title of the file to download */
|
|
12
|
+
title = "file";
|
|
13
|
+
/** Label for the button to click */
|
|
14
|
+
buttonLabel = "Export";
|
|
15
|
+
/** Delimiter for the CSV */
|
|
16
|
+
delimeter = ";";
|
|
17
|
+
async onClickDownload() {
|
|
18
|
+
let rows = this.rowsInput;
|
|
19
|
+
if (!rows) {
|
|
20
|
+
rows = await Promise.resolve(this.getRows());
|
|
21
|
+
}
|
|
22
|
+
const data = `data:text/csv;charset=utf-8,${this.headers.join(this.delimeter)}\n${rows
|
|
23
|
+
.map((row) =>
|
|
24
|
+
/** Clean each rows/cells */
|
|
25
|
+
row
|
|
26
|
+
.map((value) => value
|
|
27
|
+
.replace(this.delimeter, " ")
|
|
28
|
+
.replace("\n", " ")
|
|
29
|
+
.replace("\r", " "))
|
|
30
|
+
.join(this.delimeter))
|
|
31
|
+
.join("\n")}`;
|
|
32
|
+
/** Create a link to download the file */
|
|
33
|
+
const link = document.createElement("a");
|
|
34
|
+
link.setAttribute("href", encodeURI(data));
|
|
35
|
+
link.setAttribute("download", `${this.title}.csv`);
|
|
36
|
+
document.body.append(link);
|
|
37
|
+
link.click();
|
|
38
|
+
link.remove();
|
|
39
|
+
}
|
|
40
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsvExportComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
41
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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\">\r\n <span class=\"iconify\" data-icon=\"mdi:file-download-outline\"></span>\r\n {{ buttonLabel | translate}}\r\n</span>\r\n", styles: [".download-csv{color:var(--smarterplan-primary)}\n"], dependencies: [{ kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
|
|
42
|
+
}
|
|
43
|
+
export { CsvExportComponent };
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsvExportComponent, decorators: [{
|
|
45
|
+
type: Component,
|
|
46
|
+
args: [{ selector: 'lib-csv-export', template: "<span [style.cursor]=\"'pointer'\" (click)=\"onClickDownload()\" class=\"download-csv d-flex\">\r\n <span class=\"iconify\" data-icon=\"mdi:file-download-outline\"></span>\r\n {{ buttonLabel | translate}}\r\n</span>\r\n", styles: [".download-csv{color:var(--smarterplan-primary)}\n"] }]
|
|
47
|
+
}], propDecorators: { headers: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], rowsInput: [{
|
|
50
|
+
type: Input
|
|
51
|
+
}], getRows: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}], title: [{
|
|
54
|
+
type: Input
|
|
55
|
+
}], buttonLabel: [{
|
|
56
|
+
type: Input
|
|
57
|
+
}] } });
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3N2LWV4cG9ydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc21hcnRlcnBsYW4tY29yZS9zcmMvbGliL2NvbXBvbmVudHMvY3N2LWV4cG9ydC9jc3YtZXhwb3J0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1jb3JlL3NyYy9saWIvY29tcG9uZW50cy9jc3YtZXhwb3J0L2Nzdi1leHBvcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUVqRCxNQUthLGtCQUFrQjtJQUUzQixpREFBaUQ7SUFDeEMsT0FBTyxHQUFhLEVBQUUsQ0FBQztJQUVoQywrR0FBK0c7SUFDdEcsU0FBUyxHQUFlLFNBQVMsQ0FBQztJQUUzQyw4SEFBOEg7SUFDckgsT0FBTyxHQUFHLFNBQVMsQ0FBQztJQUU3QixvQ0FBb0M7SUFDM0IsS0FBSyxHQUFXLE1BQU0sQ0FBQztJQUVoQyxvQ0FBb0M7SUFDM0IsV0FBVyxHQUFXLFFBQVEsQ0FBQztJQUV4Qyw0QkFBNEI7SUFDNUIsU0FBUyxHQUFXLEdBQUcsQ0FBQztJQUV4QixLQUFLLENBQUMsZUFBZTtRQUNqQixJQUFJLElBQUksR0FBZSxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDUCxJQUFJLEdBQUcsTUFBTSxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1NBQ2hEO1FBQ0QsTUFBTSxJQUFJLEdBQUcsK0JBQStCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUN6RCxJQUFJLENBQUMsU0FBUyxDQUNqQixLQUFLLElBQUk7YUFDTCxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtRQUNULDRCQUE0QjtRQUM1QixHQUFHO2FBQ0UsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FDWCxLQUFLO2FBQ0EsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsR0FBRyxDQUFDO2FBQzVCLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDO2FBQ2xCLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQzFCO2FBQ0EsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FDNUI7YUFDQSxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUVsQix5Q0FBeUM7UUFDekMsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN6QyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLE1BQU0sQ0FBQyxDQUFDO1FBQ25ELFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzNCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNiLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNsQixDQUFDO3dHQWhEUSxrQkFBa0I7NEZBQWxCLGtCQUFrQiw4S0NQL0IsbU9BSUE7O1NER2Esa0JBQWtCOzRGQUFsQixrQkFBa0I7a0JBTDlCLFNBQVM7K0JBQ0UsZ0JBQWdCOzhCQU9mLE9BQU87c0JBQWYsS0FBSztnQkFHRyxTQUFTO3NCQUFqQixLQUFLO2dCQUdHLE9BQU87c0JBQWYsS0FBSztnQkFHRyxLQUFLO3NCQUFiLEtBQUs7Z0JBR0csV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWNzdi1leHBvcnQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jc3YtZXhwb3J0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jc3YtZXhwb3J0LmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIENzdkV4cG9ydENvbXBvbmVudCB7XHJcbiAgICBcclxuICAgIC8qKiBIZWFkZXIgb2YgdGhlIENTViwgdGl0bGVzIGZvciBlYWNoIGNvbHVtbnMgKi9cclxuICAgIEBJbnB1dCgpIGhlYWRlcnM6IHN0cmluZ1tdID0gW107XHJcblxyXG4gICAgLyoqIEFycmF5IG9mIGVhY2ggcm93cyAoYXJyYXkgb2YgYXJyYXkgb2Ygc3RyaW5nKSwgaWYgaXQncyBub3Qgc2V0LCB0aGVuIHRoZSBmdW5jdGlvbiBnZXRSb3dzKCkgd2lsbCBiZSB1c2VkICovXHJcbiAgICBASW5wdXQoKSByb3dzSW5wdXQ6IHN0cmluZ1tdW10gPSB1bmRlZmluZWQ7XHJcblxyXG4gICAgLyoqIEZ1bmN0aW9uIHVzZWQgdG8gZ2V0IHJvd3MgaWYgcm93c0lucHV0IGlzIG5vdCBzZXQsIGNhbGwgZWFjaCB0aW1lIHRoZSB1c2VyIGNsaWNrIG9uIHRoZSBidXR0b24gdG8gZ2VuZXJhdGUgdGhlIENTViBmaWxlICovXHJcbiAgICBASW5wdXQoKSBnZXRSb3dzID0gdW5kZWZpbmVkO1xyXG5cclxuICAgIC8qKiBUaXRsZSBvZiB0aGUgZmlsZSB0byBkb3dubG9hZCAqL1xyXG4gICAgQElucHV0KCkgdGl0bGU6IHN0cmluZyA9IFwiZmlsZVwiO1xyXG5cclxuICAgIC8qKiBMYWJlbCBmb3IgdGhlIGJ1dHRvbiB0byBjbGljayAqL1xyXG4gICAgQElucHV0KCkgYnV0dG9uTGFiZWw6IHN0cmluZyA9IFwiRXhwb3J0XCI7XHJcblxyXG4gICAgLyoqIERlbGltaXRlciBmb3IgdGhlIENTViAqL1xyXG4gICAgZGVsaW1ldGVyOiBzdHJpbmcgPSBcIjtcIjtcclxuXHJcbiAgICBhc3luYyBvbkNsaWNrRG93bmxvYWQoKSB7XHJcbiAgICAgICAgbGV0IHJvd3M6IHN0cmluZ1tdW10gPSB0aGlzLnJvd3NJbnB1dDtcclxuICAgICAgICBpZiAoIXJvd3MpIHtcclxuICAgICAgICAgICAgcm93cyA9IGF3YWl0IFByb21pc2UucmVzb2x2ZSh0aGlzLmdldFJvd3MoKSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGNvbnN0IGRhdGEgPSBgZGF0YTp0ZXh0L2NzdjtjaGFyc2V0PXV0Zi04LCR7dGhpcy5oZWFkZXJzLmpvaW4oXHJcbiAgICAgICAgICAgIHRoaXMuZGVsaW1ldGVyLFxyXG4gICAgICAgICl9XFxuJHtyb3dzXHJcbiAgICAgICAgICAgIC5tYXAoKHJvdykgPT5cclxuICAgICAgICAgICAgICAgIC8qKiBDbGVhbiBlYWNoIHJvd3MvY2VsbHMgKi9cclxuICAgICAgICAgICAgICAgIHJvd1xyXG4gICAgICAgICAgICAgICAgICAgIC5tYXAoKHZhbHVlKSA9PlxyXG4gICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgLnJlcGxhY2UodGhpcy5kZWxpbWV0ZXIsIFwiIFwiKVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgLnJlcGxhY2UoXCJcXG5cIiwgXCIgXCIpXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAucmVwbGFjZShcIlxcclwiLCBcIiBcIiksXHJcbiAgICAgICAgICAgICAgICAgICAgKVxyXG4gICAgICAgICAgICAgICAgICAgIC5qb2luKHRoaXMuZGVsaW1ldGVyKSxcclxuICAgICAgICAgICAgKVxyXG4gICAgICAgICAgICAuam9pbihcIlxcblwiKX1gO1xyXG5cclxuICAgICAgICAvKiogQ3JlYXRlIGEgbGluayB0byBkb3dubG9hZCB0aGUgZmlsZSAqL1xyXG4gICAgICAgIGNvbnN0IGxpbmsgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiYVwiKTtcclxuICAgICAgICBsaW5rLnNldEF0dHJpYnV0ZShcImhyZWZcIiwgZW5jb2RlVVJJKGRhdGEpKTtcclxuICAgICAgICBsaW5rLnNldEF0dHJpYnV0ZShcImRvd25sb2FkXCIsIGAke3RoaXMudGl0bGV9LmNzdmApO1xyXG4gICAgICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kKGxpbmspO1xyXG4gICAgICAgIGxpbmsuY2xpY2soKTtcclxuICAgICAgICBsaW5rLnJlbW92ZSgpO1xyXG4gICAgfVxyXG59XHJcbiIsIjxzcGFuIFtzdHlsZS5jdXJzb3JdPVwiJ3BvaW50ZXInXCIgKGNsaWNrKT1cIm9uQ2xpY2tEb3dubG9hZCgpXCIgY2xhc3M9XCJkb3dubG9hZC1jc3YgZC1mbGV4XCI+XHJcbiAgICA8c3BhbiBjbGFzcz1cImljb25pZnlcIiBkYXRhLWljb249XCJtZGk6ZmlsZS1kb3dubG9hZC1vdXRsaW5lXCI+PC9zcGFuPlxyXG4gICAge3sgYnV0dG9uTGFiZWwgfCB0cmFuc2xhdGV9fVxyXG48L3NwYW4+XHJcbiJdfQ==
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
class LoaderComponent {
|
|
5
|
+
useLogo = true;
|
|
6
|
+
color = "#53B6BB";
|
|
7
|
+
constructor() { }
|
|
8
|
+
ngOnInit() {
|
|
9
|
+
document.documentElement.style.setProperty('--color', this.color);
|
|
10
|
+
}
|
|
11
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: LoaderComponent, selector: "lib-loader", inputs: { useLogo: "useLogo", color: "color" }, ngImport: i0, template: "<div class=\"sk-fading-circle\">\r\n <img *ngIf=\"useLogo\" src=\"../../../../assets/icons/smarterplan.svg\">\r\n <div class=\"sk-circle1 sk-circle\"></div>\r\n <div class=\"sk-circle2 sk-circle\"></div>\r\n <div class=\"sk-circle3 sk-circle\"></div>\r\n <div class=\"sk-circle4 sk-circle\"></div>\r\n <div class=\"sk-circle5 sk-circle\"></div>\r\n <div class=\"sk-circle6 sk-circle\"></div>\r\n <div class=\"sk-circle7 sk-circle\"></div>\r\n <div class=\"sk-circle8 sk-circle\"></div>\r\n <div class=\"sk-circle9 sk-circle\"></div>\r\n <div class=\"sk-circle10 sk-circle\"></div>\r\n <div class=\"sk-circle11 sk-circle\"></div>\r\n <div class=\"sk-circle12 sk-circle\"></div>\r\n</div>\r\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"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
13
|
+
}
|
|
14
|
+
export { LoaderComponent };
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LoaderComponent, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{ selector: 'lib-loader', template: "<div class=\"sk-fading-circle\">\r\n <img *ngIf=\"useLogo\" src=\"../../../../assets/icons/smarterplan.svg\">\r\n <div class=\"sk-circle1 sk-circle\"></div>\r\n <div class=\"sk-circle2 sk-circle\"></div>\r\n <div class=\"sk-circle3 sk-circle\"></div>\r\n <div class=\"sk-circle4 sk-circle\"></div>\r\n <div class=\"sk-circle5 sk-circle\"></div>\r\n <div class=\"sk-circle6 sk-circle\"></div>\r\n <div class=\"sk-circle7 sk-circle\"></div>\r\n <div class=\"sk-circle8 sk-circle\"></div>\r\n <div class=\"sk-circle9 sk-circle\"></div>\r\n <div class=\"sk-circle10 sk-circle\"></div>\r\n <div class=\"sk-circle11 sk-circle\"></div>\r\n <div class=\"sk-circle12 sk-circle\"></div>\r\n</div>\r\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"] }]
|
|
18
|
+
}], ctorParameters: function () { return []; }, propDecorators: { useLogo: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}], color: [{
|
|
21
|
+
type: Input
|
|
22
|
+
}] } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1jb3JlL3NyYy9saWIvY29tcG9uZW50cy9sb2FkZXIvbG9hZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1jb3JlL3NyYy9saWIvY29tcG9uZW50cy9sb2FkZXIvbG9hZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7QUFFekQsTUFLYSxlQUFlO0lBQ2YsT0FBTyxHQUFZLElBQUksQ0FBQztJQUV4QixLQUFLLEdBQVcsU0FBUyxDQUFDO0lBQ25DLGdCQUFnQixDQUFDO0lBRWpCLFFBQVE7UUFDSixRQUFRLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN0RSxDQUFDO3dHQVJRLGVBQWU7NEZBQWYsZUFBZSxrR0NQNUIsMnRCQWVBOztTRFJhLGVBQWU7NEZBQWYsZUFBZTtrQkFMM0IsU0FBUzsrQkFDSSxZQUFZOzBFQUtiLE9BQU87c0JBQWYsS0FBSztnQkFFRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdsaWItbG9hZGVyJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9sb2FkZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vbG9hZGVyLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIExvYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgICBASW5wdXQoKSB1c2VMb2dvOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgICBASW5wdXQoKSBjb2xvcjogc3RyaW5nID0gXCIjNTNCNkJCXCI7XHJcbiAgICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zdHlsZS5zZXRQcm9wZXJ0eSgnLS1jb2xvcicsIHRoaXMuY29sb3IpO1xyXG4gICAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwic2stZmFkaW5nLWNpcmNsZVwiPlxyXG4gICAgPGltZyAqbmdJZj1cInVzZUxvZ29cIiBzcmM9XCIuLi8uLi8uLi8uLi9hc3NldHMvaWNvbnMvc21hcnRlcnBsYW4uc3ZnXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwic2stY2lyY2xlMSBzay1jaXJjbGVcIj48L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJzay1jaXJjbGUyIHNrLWNpcmNsZVwiPjwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cInNrLWNpcmNsZTMgc2stY2lyY2xlXCI+PC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwic2stY2lyY2xlNCBzay1jaXJjbGVcIj48L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJzay1jaXJjbGU1IHNrLWNpcmNsZVwiPjwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cInNrLWNpcmNsZTYgc2stY2lyY2xlXCI+PC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwic2stY2lyY2xlNyBzay1jaXJjbGVcIj48L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJzay1jaXJjbGU4IHNrLWNpcmNsZVwiPjwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cInNrLWNpcmNsZTkgc2stY2lyY2xlXCI+PC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwic2stY2lyY2xlMTAgc2stY2lyY2xlXCI+PC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwic2stY2lyY2xlMTEgc2stY2lyY2xlXCI+PC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwic2stY2lyY2xlMTIgc2stY2lyY2xlXCI+PC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { uploadFileToS3, getSignedImageUrlForProfile } from '../../../services/s3.service';
|
|
3
|
+
import { ProfileEntity } from '../../../types.service';
|
|
4
|
+
import * as CryptoJS from 'crypto-js';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../services/user.service";
|
|
7
|
+
import * as i2 from "../../../services/models/profile.service";
|
|
8
|
+
const cache = {};
|
|
9
|
+
class AvatarComponent {
|
|
10
|
+
userService;
|
|
11
|
+
profileService;
|
|
12
|
+
size = 45;
|
|
13
|
+
userID;
|
|
14
|
+
currentUser;
|
|
15
|
+
avatar;
|
|
16
|
+
userSub;
|
|
17
|
+
constructor(userService, profileService) {
|
|
18
|
+
this.userService = userService;
|
|
19
|
+
this.profileService = profileService;
|
|
20
|
+
this.userSub = this.userService.isChanged.subscribe((connected) => {
|
|
21
|
+
if (connected) {
|
|
22
|
+
this.currentUser = this.userService.cu;
|
|
23
|
+
this.setAvatar(this.currentUser);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
async ngOnInit() {
|
|
28
|
+
if (this.userID) {
|
|
29
|
+
const profile = await this.profileService.getProfile(this.userID);
|
|
30
|
+
if (profile) {
|
|
31
|
+
const user = new ProfileEntity(profile);
|
|
32
|
+
this.setAvatar(user);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this.currentUser = this.userService.cu;
|
|
37
|
+
this.setAvatar(this.currentUser);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
ngOnDestroy() {
|
|
41
|
+
if (this.userSub) {
|
|
42
|
+
this.userSub.unsubscribe();
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
async setAvatar(user) {
|
|
46
|
+
const { id, avatar, email } = user;
|
|
47
|
+
// If avatar is not cached, check first if we have an avatar URL to fetch
|
|
48
|
+
// from S3. If not, retrieve it from libravatar.
|
|
49
|
+
// TODO use in a Service to be able to change/upload freely.
|
|
50
|
+
if (!cache.hasOwnProperty(id)) {
|
|
51
|
+
if (!avatar && email) {
|
|
52
|
+
const md5hash = CryptoJS.MD5(email.trim().toLowerCase()).toString();
|
|
53
|
+
const avatar = `https://seccdn.libravatar.org/avatar/${md5hash}?s=${this.size}&default=identicon`;
|
|
54
|
+
const url = await fetch(avatar)
|
|
55
|
+
.then((res) => res.blob())
|
|
56
|
+
.then((blob) => {
|
|
57
|
+
const file = new File([blob], "avatar.jpeg", {
|
|
58
|
+
type: "image/jpeg",
|
|
59
|
+
});
|
|
60
|
+
return uploadFileToS3("avatars/", file, id);
|
|
61
|
+
});
|
|
62
|
+
await this.profileService.updateProfile({ id, avatar: url });
|
|
63
|
+
user.avatar = url;
|
|
64
|
+
cache[id] = avatar;
|
|
65
|
+
}
|
|
66
|
+
if (avatar) {
|
|
67
|
+
// TODO generating signed urls for avatar makes NO SENSE ($$$)
|
|
68
|
+
// Sorry got to copypaste that, but really need to get rid of
|
|
69
|
+
cache[id] = await getSignedImageUrlForProfile(user);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
this.avatar = cache[id];
|
|
73
|
+
}
|
|
74
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AvatarComponent, deps: [{ token: i1.BaseUserService }, { token: i2.ProfileService }], target: i0.ɵɵFactoryTarget.Component });
|
|
75
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AvatarComponent, selector: "lib-avatar", inputs: { size: "size", userID: "userID" }, ngImport: i0, template: `<img [src]="avatar" />`, isInline: true, styles: ["img{max-width:100%;max-height:100%;height:100%;width:100%;border-radius:50%}\n"] });
|
|
76
|
+
}
|
|
77
|
+
export { AvatarComponent };
|
|
78
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AvatarComponent, decorators: [{
|
|
79
|
+
type: Component,
|
|
80
|
+
args: [{ selector: 'lib-avatar', template: `<img [src]="avatar" />`, styles: ["img{max-width:100%;max-height:100%;height:100%;width:100%;border-radius:50%}\n"] }]
|
|
81
|
+
}], ctorParameters: function () { return [{ type: i1.BaseUserService }, { type: i2.ProfileService }]; }, propDecorators: { size: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], userID: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}] } });
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zbWFydGVycGxhbi1jb3JlL3NyYy9saWIvY29tcG9uZW50cy9tZW51LWJhci9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFM0YsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sS0FBSyxRQUFRLE1BQU0sV0FBVyxDQUFDOzs7O0FBR3RDLE1BQU0sS0FBSyxHQUFHLEVBQUUsQ0FBQztBQUNqQixNQUthLGVBQWU7SUFhWjtJQUNBO0lBWkgsSUFBSSxHQUFXLEVBQUUsQ0FBQztJQUVsQixNQUFNLENBQVM7SUFFeEIsV0FBVyxDQUFnQjtJQUUzQixNQUFNLENBQUM7SUFFUCxPQUFPLENBQWU7SUFFdEIsWUFDWSxXQUE0QixFQUM1QixjQUE4QjtRQUQ5QixnQkFBVyxHQUFYLFdBQVcsQ0FBaUI7UUFDNUIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBRXRDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7WUFDOUQsSUFBSSxTQUFTLEVBQUU7Z0JBQ1gsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztnQkFDdkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7YUFDcEM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxLQUFLLENBQUMsUUFBUTtRQUNWLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNiLE1BQU0sT0FBTyxHQUFHLE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ2xFLElBQUksT0FBTyxFQUFFO2dCQUNULE1BQU0sSUFBSSxHQUFHLElBQUksYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUN4QyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ3hCO1NBQ0o7YUFBTTtZQUNILElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFLENBQUM7WUFDdkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDcEM7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNkLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDOUI7SUFDTCxDQUFDO0lBRUQsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFtQjtRQUMvQixNQUFNLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFFbkMseUVBQXlFO1FBQ3pFLGdEQUFnRDtRQUNoRCw0REFBNEQ7UUFDNUQsSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDLEVBQUU7WUFDM0IsSUFBSSxDQUFDLE1BQU0sSUFBSSxLQUFLLEVBQUU7Z0JBQ2xCLE1BQU0sT0FBTyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBQ3BFLE1BQU0sTUFBTSxHQUFHLHdDQUF3QyxPQUFPLE1BQU0sSUFBSSxDQUFDLElBQUksb0JBQW9CLENBQUM7Z0JBQ2xHLE1BQU0sR0FBRyxHQUFHLE1BQU0sS0FBSyxDQUFDLE1BQU0sQ0FBQztxQkFDMUIsSUFBSSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUM7cUJBQ3pCLElBQUksQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO29CQUNYLE1BQU0sSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsYUFBYSxFQUFFO3dCQUN6QyxJQUFJLEVBQUUsWUFBWTtxQkFDckIsQ0FBQyxDQUFDO29CQUNILE9BQU8sY0FBYyxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQ2hELENBQUMsQ0FBQyxDQUFDO2dCQUNQLE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7Z0JBQzdELElBQUksQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDO2dCQUNsQixLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDO2FBQ3RCO1lBQ0QsSUFBSSxNQUFNLEVBQUU7Z0JBQ1IsOERBQThEO2dCQUM5RCw2REFBNkQ7Z0JBQzdELEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLDJCQUEyQixDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ3ZEO1NBQ0o7UUFDRCxJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUM1QixDQUFDO3dHQXhFUSxlQUFlOzRGQUFmLGVBQWUsOEZBSGQsd0JBQXdCOztTQUd6QixlQUFlOzRGQUFmLGVBQWU7a0JBTDNCLFNBQVM7K0JBQ0ksWUFBWSxZQUNaLHdCQUF3QjttSUFLekIsSUFBSTtzQkFBWixLQUFLO2dCQUVHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBQcm9maWxlU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL21vZGVscy9wcm9maWxlLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyB1cGxvYWRGaWxlVG9TMywgZ2V0U2lnbmVkSW1hZ2VVcmxGb3JQcm9maWxlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvczMuc2VydmljZSc7XHJcbmltcG9ydCB7IEJhc2VVc2VyU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL3VzZXIuc2VydmljZSc7XHJcbmltcG9ydCB7IFByb2ZpbGVFbnRpdHkgfSBmcm9tICcuLi8uLi8uLi90eXBlcy5zZXJ2aWNlJztcclxuaW1wb3J0ICogYXMgQ3J5cHRvSlMgZnJvbSAnY3J5cHRvLWpzJztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XHJcblxyXG5jb25zdCBjYWNoZSA9IHt9O1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnbGliLWF2YXRhcicsXHJcbiAgICB0ZW1wbGF0ZTogYDxpbWcgW3NyY109XCJhdmF0YXJcIiAvPmAsXHJcbiAgICBzdHlsZVVybHM6IFtcIi4vYXZhdGFyLmNvbXBvbmVudC5zY3NzXCJdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXZhdGFyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgICBASW5wdXQoKSBzaXplOiBudW1iZXIgPSA0NTtcclxuXHJcbiAgICBASW5wdXQoKSB1c2VySUQ6IHN0cmluZztcclxuXHJcbiAgICBjdXJyZW50VXNlcjogUHJvZmlsZUVudGl0eTtcclxuXHJcbiAgICBhdmF0YXI7XHJcblxyXG4gICAgdXNlclN1YjogU3Vic2NyaXB0aW9uO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgdXNlclNlcnZpY2U6IEJhc2VVc2VyU2VydmljZSxcclxuICAgICAgICBwcml2YXRlIHByb2ZpbGVTZXJ2aWNlOiBQcm9maWxlU2VydmljZSxcclxuICAgICkge1xyXG4gICAgICAgIHRoaXMudXNlclN1YiA9IHRoaXMudXNlclNlcnZpY2UuaXNDaGFuZ2VkLnN1YnNjcmliZSgoY29ubmVjdGVkKSA9PiB7XHJcbiAgICAgICAgICAgIGlmIChjb25uZWN0ZWQpIHtcclxuICAgICAgICAgICAgICAgIHRoaXMuY3VycmVudFVzZXIgPSB0aGlzLnVzZXJTZXJ2aWNlLmN1O1xyXG4gICAgICAgICAgICAgICAgdGhpcy5zZXRBdmF0YXIodGhpcy5jdXJyZW50VXNlcik7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBhc3luYyBuZ09uSW5pdCgpOiBQcm9taXNlPHZvaWQ+IHtcclxuICAgICAgICBpZiAodGhpcy51c2VySUQpIHtcclxuICAgICAgICAgICAgY29uc3QgcHJvZmlsZSA9IGF3YWl0IHRoaXMucHJvZmlsZVNlcnZpY2UuZ2V0UHJvZmlsZSh0aGlzLnVzZXJJRCk7XHJcbiAgICAgICAgICAgIGlmIChwcm9maWxlKSB7XHJcbiAgICAgICAgICAgICAgICBjb25zdCB1c2VyID0gbmV3IFByb2ZpbGVFbnRpdHkocHJvZmlsZSk7XHJcbiAgICAgICAgICAgICAgICB0aGlzLnNldEF2YXRhcih1c2VyKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIHRoaXMuY3VycmVudFVzZXIgPSB0aGlzLnVzZXJTZXJ2aWNlLmN1O1xyXG4gICAgICAgICAgICB0aGlzLnNldEF2YXRhcih0aGlzLmN1cnJlbnRVc2VyKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICAgICAgaWYgKHRoaXMudXNlclN1Yikge1xyXG4gICAgICAgICAgICB0aGlzLnVzZXJTdWIudW5zdWJzY3JpYmUoKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgYXN5bmMgc2V0QXZhdGFyKHVzZXI6IFByb2ZpbGVFbnRpdHkpIHtcclxuICAgICAgICBjb25zdCB7IGlkLCBhdmF0YXIsIGVtYWlsIH0gPSB1c2VyO1xyXG5cclxuICAgICAgICAvLyBJZiBhdmF0YXIgaXMgbm90IGNhY2hlZCwgY2hlY2sgZmlyc3QgaWYgd2UgaGF2ZSBhbiBhdmF0YXIgVVJMIHRvIGZldGNoXHJcbiAgICAgICAgLy8gZnJvbSBTMy4gSWYgbm90LCByZXRyaWV2ZSBpdCBmcm9tIGxpYnJhdmF0YXIuXHJcbiAgICAgICAgLy8gVE9ETyB1c2UgaW4gYSBTZXJ2aWNlIHRvIGJlIGFibGUgdG8gY2hhbmdlL3VwbG9hZCBmcmVlbHkuXHJcbiAgICAgICAgaWYgKCFjYWNoZS5oYXNPd25Qcm9wZXJ0eShpZCkpIHtcclxuICAgICAgICAgICAgaWYgKCFhdmF0YXIgJiYgZW1haWwpIHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IG1kNWhhc2ggPSBDcnlwdG9KUy5NRDUoZW1haWwudHJpbSgpLnRvTG93ZXJDYXNlKCkpLnRvU3RyaW5nKCk7XHJcbiAgICAgICAgICAgICAgICBjb25zdCBhdmF0YXIgPSBgaHR0cHM6Ly9zZWNjZG4ubGlicmF2YXRhci5vcmcvYXZhdGFyLyR7bWQ1aGFzaH0/cz0ke3RoaXMuc2l6ZX0mZGVmYXVsdD1pZGVudGljb25gO1xyXG4gICAgICAgICAgICAgICAgY29uc3QgdXJsID0gYXdhaXQgZmV0Y2goYXZhdGFyKVxyXG4gICAgICAgICAgICAgICAgICAgIC50aGVuKChyZXMpID0+IHJlcy5ibG9iKCkpXHJcbiAgICAgICAgICAgICAgICAgICAgLnRoZW4oKGJsb2IpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgZmlsZSA9IG5ldyBGaWxlKFtibG9iXSwgXCJhdmF0YXIuanBlZ1wiLCB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0eXBlOiBcImltYWdlL2pwZWdcIixcclxuICAgICAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiB1cGxvYWRGaWxlVG9TMyhcImF2YXRhcnMvXCIsIGZpbGUsIGlkKTtcclxuICAgICAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgIGF3YWl0IHRoaXMucHJvZmlsZVNlcnZpY2UudXBkYXRlUHJvZmlsZSh7IGlkLCBhdmF0YXI6IHVybCB9KTtcclxuICAgICAgICAgICAgICAgIHVzZXIuYXZhdGFyID0gdXJsO1xyXG4gICAgICAgICAgICAgICAgY2FjaGVbaWRdID0gYXZhdGFyO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGlmIChhdmF0YXIpIHtcclxuICAgICAgICAgICAgICAgIC8vIFRPRE8gZ2VuZXJhdGluZyBzaWduZWQgdXJscyBmb3IgYXZhdGFyIG1ha2VzIE5PIFNFTlNFICgkJCQpXHJcbiAgICAgICAgICAgICAgICAvLyBTb3JyeSBnb3QgdG8gY29weXBhc3RlIHRoYXQsIGJ1dCByZWFsbHkgbmVlZCB0byBnZXQgcmlkIG9mXHJcbiAgICAgICAgICAgICAgICBjYWNoZVtpZF0gPSBhd2FpdCBnZXRTaWduZWRJbWFnZVVybEZvclByb2ZpbGUodXNlcik7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgICAgdGhpcy5hdmF0YXIgPSBjYWNoZVtpZF07XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { SupportModalComponent } from '../support-modal/support-modal.component';
|
|
3
|
+
import { NgbDate, } from '@ng-bootstrap/ng-bootstrap';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/router";
|
|
6
|
+
import * as i2 from "../../services/locale.service";
|
|
7
|
+
import * as i3 from "../../services/user.service";
|
|
8
|
+
import * as i4 from "../../services/navigator.service";
|
|
9
|
+
import * as i5 from "../../services/support.service";
|
|
10
|
+
import * as i6 from "../../services/baseVisibility.service";
|
|
11
|
+
import * as i7 from "@ng-bootstrap/ng-bootstrap";
|
|
12
|
+
import * as i8 from "../../services/filter.service";
|
|
13
|
+
import * as i9 from "../../services/amplify-cache.service";
|
|
14
|
+
import * as i10 from "@angular/forms";
|
|
15
|
+
import * as i11 from "@angular/common";
|
|
16
|
+
import * as i12 from "./avatar/avatar.component";
|
|
17
|
+
import * as i13 from "./navigation-bar/navigation-bar.component";
|
|
18
|
+
import * as i14 from "@ngx-translate/core";
|
|
19
|
+
import * as i15 from "../../pipes/format-date-number-to-digits.pipe";
|
|
20
|
+
class MenuBarComponent {
|
|
21
|
+
router;
|
|
22
|
+
localeService;
|
|
23
|
+
userService;
|
|
24
|
+
navigatorService;
|
|
25
|
+
supportService;
|
|
26
|
+
baseVisibilityService;
|
|
27
|
+
calendar;
|
|
28
|
+
formatter;
|
|
29
|
+
filterService;
|
|
30
|
+
cacheService;
|
|
31
|
+
user;
|
|
32
|
+
mission;
|
|
33
|
+
isCollapsed = true;
|
|
34
|
+
isVisitor = true;
|
|
35
|
+
isVisible = false;
|
|
36
|
+
isChangePositionVisible = false;
|
|
37
|
+
isManager;
|
|
38
|
+
userSubscription;
|
|
39
|
+
navSubscription;
|
|
40
|
+
hoveredDate = null;
|
|
41
|
+
fromDate;
|
|
42
|
+
toDate;
|
|
43
|
+
cacheName;
|
|
44
|
+
cache;
|
|
45
|
+
isDateFilterApplied = false;
|
|
46
|
+
dateChanged = false;
|
|
47
|
+
changePositionSubscription;
|
|
48
|
+
searchInput;
|
|
49
|
+
filterSubscription;
|
|
50
|
+
constructor(router, localeService, userService, navigatorService, supportService, baseVisibilityService, calendar, formatter, filterService, cacheService) {
|
|
51
|
+
this.router = router;
|
|
52
|
+
this.localeService = localeService;
|
|
53
|
+
this.userService = userService;
|
|
54
|
+
this.navigatorService = navigatorService;
|
|
55
|
+
this.supportService = supportService;
|
|
56
|
+
this.baseVisibilityService = baseVisibilityService;
|
|
57
|
+
this.calendar = calendar;
|
|
58
|
+
this.formatter = formatter;
|
|
59
|
+
this.filterService = filterService;
|
|
60
|
+
this.cacheService = cacheService;
|
|
61
|
+
this.userSubscription = this.userService.isChanged.subscribe((isChanged) => {
|
|
62
|
+
if (isChanged) {
|
|
63
|
+
this.update();
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
this.navSubscription = this.navigatorService.isVisibleChanged.subscribe((data) => {
|
|
67
|
+
this.isVisible = data;
|
|
68
|
+
});
|
|
69
|
+
this.changePositionSubscription = this.baseVisibilityService.isChangePositionVisible.subscribe((data) => {
|
|
70
|
+
this.isChangePositionVisible = data;
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
ngOnInit() {
|
|
74
|
+
this.update();
|
|
75
|
+
if (this.cacheName) {
|
|
76
|
+
this.cache = this.cacheService.getFromCache(this.cacheName);
|
|
77
|
+
}
|
|
78
|
+
if (this.cache) {
|
|
79
|
+
this.isDateFilterApplied = true;
|
|
80
|
+
let { from, to } = this.cache;
|
|
81
|
+
this.toDate = this.getNgbDate(to);
|
|
82
|
+
this.fromDate = this.getNgbDate(from);
|
|
83
|
+
localStorage.setItem('startDate', from.toString());
|
|
84
|
+
localStorage.setItem('endDate', to.toString());
|
|
85
|
+
this.filterService.dateFilterUpdated([new Date(from), new Date(to)]);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
this.fromDate = null;
|
|
89
|
+
this.toDate = null;
|
|
90
|
+
localStorage.removeItem('startDate');
|
|
91
|
+
localStorage.removeItem('endDate');
|
|
92
|
+
this.filterService.dateFilterUpdated(null);
|
|
93
|
+
}
|
|
94
|
+
// This allows updating the inputs when measurement.service changes the date programmatically
|
|
95
|
+
this.filterSubscription = this.filterService.subscribeToDataFilterUpdate((dateRange) => {
|
|
96
|
+
if (dateRange && dateRange.length === 2) {
|
|
97
|
+
// 1. Convert JS Date objects to NgbDate for display
|
|
98
|
+
const from = dateRange[0].getTime();
|
|
99
|
+
const to = dateRange[1].getTime();
|
|
100
|
+
this.fromDate = this.getNgbDate(from);
|
|
101
|
+
this.toDate = this.getNgbDate(to);
|
|
102
|
+
// 2. Update local cache reference to prevent the "Apply" button from activating
|
|
103
|
+
this.cache = { from, to };
|
|
104
|
+
// 3. Update visual state
|
|
105
|
+
this.isDateFilterApplied = true;
|
|
106
|
+
this.dateChanged = false; // We consider it synchronized
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
// If the filter is cleared externally
|
|
110
|
+
this.fromDate = null;
|
|
111
|
+
this.toDate = null;
|
|
112
|
+
this.isDateFilterApplied = false;
|
|
113
|
+
this.cache = null;
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
onSearchKeydown = (event) => {
|
|
118
|
+
if (event.key === 'Enter')
|
|
119
|
+
this.onSubmit();
|
|
120
|
+
};
|
|
121
|
+
ngAfterViewInit() {
|
|
122
|
+
this.searchInput = document.querySelector('#mainSearchBar');
|
|
123
|
+
this.searchInput?.addEventListener('keydown', this.onSearchKeydown);
|
|
124
|
+
}
|
|
125
|
+
ngOnDestroy() {
|
|
126
|
+
this.searchInput?.removeEventListener('keydown', this.onSearchKeydown);
|
|
127
|
+
this.userSubscription?.unsubscribe();
|
|
128
|
+
this.navSubscription?.unsubscribe();
|
|
129
|
+
this.changePositionSubscription?.unsubscribe();
|
|
130
|
+
this.filterSubscription?.unsubscribe();
|
|
131
|
+
}
|
|
132
|
+
async signOut() {
|
|
133
|
+
await this.userService.logoutCurrentAndSignOutAuth();
|
|
134
|
+
this.router.navigate(['auth']);
|
|
135
|
+
}
|
|
136
|
+
async update() {
|
|
137
|
+
this.user = this.userService.cu;
|
|
138
|
+
this.mission = this.userService.currentMissions[0];
|
|
139
|
+
this.isManager = this.userService.hasManagerRoleInAnyMission();
|
|
140
|
+
this.isVisitor = this.userService.isVisitor();
|
|
141
|
+
if (!this.isVisitor) {
|
|
142
|
+
this.isVisible = true;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
// eslint-disable-next-line class-methods-use-this
|
|
146
|
+
onSubmit() {
|
|
147
|
+
const input = document.querySelector('#mainSearchBar');
|
|
148
|
+
const searchValue = input.value.toLowerCase();
|
|
149
|
+
if (searchValue !== '') {
|
|
150
|
+
const baseUrl = location.origin;
|
|
151
|
+
window.open(`${baseUrl}/dashboard/search?term=${searchValue}`, '_blank');
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
onToggleVisible() {
|
|
155
|
+
this.isVisible = !this.isVisible;
|
|
156
|
+
}
|
|
157
|
+
openSupportForm() {
|
|
158
|
+
this.supportService.openSupportForm(SupportModalComponent);
|
|
159
|
+
}
|
|
160
|
+
onChangePositionClick() {
|
|
161
|
+
this.baseVisibilityService.isChangePositionVisible.next(!this.isChangePositionVisible);
|
|
162
|
+
}
|
|
163
|
+
getNgbDate(date) {
|
|
164
|
+
let dt = new Date(date);
|
|
165
|
+
dt.setMinutes(dt.getMinutes() - dt.getTimezoneOffset()); // convert to UTC
|
|
166
|
+
return new NgbDate(dt.getUTCFullYear(), dt.getUTCMonth() + 1, dt.getUTCDate());
|
|
167
|
+
}
|
|
168
|
+
onDateSelection(date) {
|
|
169
|
+
if (!this.fromDate && !this.toDate) {
|
|
170
|
+
this.fromDate = date;
|
|
171
|
+
}
|
|
172
|
+
else if (this.fromDate &&
|
|
173
|
+
!this.toDate &&
|
|
174
|
+
date &&
|
|
175
|
+
date.after(this.fromDate)) {
|
|
176
|
+
this.toDate = date;
|
|
177
|
+
}
|
|
178
|
+
else {
|
|
179
|
+
this.toDate = null;
|
|
180
|
+
this.fromDate = date;
|
|
181
|
+
}
|
|
182
|
+
this.isDateChanged();
|
|
183
|
+
}
|
|
184
|
+
isDateChanged() {
|
|
185
|
+
if (this.fromDate && this.toDate) {
|
|
186
|
+
if (this.cache) {
|
|
187
|
+
this.dateChanged =
|
|
188
|
+
!this.fromDate.equals(this.getNgbDate(this.cache.from)) ||
|
|
189
|
+
!this.toDate.equals(this.getNgbDate(this.cache.to));
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
isHovered(date) {
|
|
194
|
+
return (this.fromDate &&
|
|
195
|
+
!this.toDate &&
|
|
196
|
+
this.hoveredDate &&
|
|
197
|
+
date.after(this.fromDate) &&
|
|
198
|
+
date.before(this.hoveredDate));
|
|
199
|
+
}
|
|
200
|
+
isInside(date) {
|
|
201
|
+
return this.toDate && date.after(this.fromDate) && date.before(this.toDate);
|
|
202
|
+
}
|
|
203
|
+
isRange(date) {
|
|
204
|
+
return (date.equals(this.fromDate) ||
|
|
205
|
+
(this.toDate && date.equals(this.toDate)) ||
|
|
206
|
+
this.isInside(date) ||
|
|
207
|
+
this.isHovered(date));
|
|
208
|
+
}
|
|
209
|
+
validateInput(currentValue, input) {
|
|
210
|
+
const parsed = this.formatter.parse(input);
|
|
211
|
+
return parsed && this.calendar.isValid(NgbDate.from(parsed))
|
|
212
|
+
? NgbDate.from(parsed)
|
|
213
|
+
: currentValue;
|
|
214
|
+
}
|
|
215
|
+
emitRange() {
|
|
216
|
+
if (this.fromDate && this.toDate) {
|
|
217
|
+
const from = new Date(this.fromDate.year, this.fromDate.month - 1, this.fromDate.day);
|
|
218
|
+
const to = new Date(this.toDate.year, this.toDate.month - 1, this.toDate.day, 23, 59);
|
|
219
|
+
this.cacheService.putInCache(this.cacheName, {
|
|
220
|
+
from: from.getTime(),
|
|
221
|
+
to: to.getTime(),
|
|
222
|
+
});
|
|
223
|
+
this.cache = { from: from.getTime(), to: to.getTime() };
|
|
224
|
+
this.filterService.dateFilterUpdated([from, to]);
|
|
225
|
+
this.isDateFilterApplied = true;
|
|
226
|
+
this.dateChanged = false;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
onClearDates() {
|
|
230
|
+
this.fromDate = null;
|
|
231
|
+
this.toDate = null;
|
|
232
|
+
this.isDateFilterApplied = false;
|
|
233
|
+
this.cache = null;
|
|
234
|
+
this.cacheService.removeFromCache(this.cacheName);
|
|
235
|
+
this.filterService.dateFilterUpdated(null);
|
|
236
|
+
}
|
|
237
|
+
onApply() {
|
|
238
|
+
if (this.fromDate && this.toDate) {
|
|
239
|
+
this.emitRange();
|
|
240
|
+
}
|
|
241
|
+
//transform ngbDate to date objet then put dates in timestamp in localStorage to share it with Retool
|
|
242
|
+
if (this.fromDate) {
|
|
243
|
+
const startDate = new Date(this.fromDate.year, this.fromDate.month - 1, this.fromDate.day);
|
|
244
|
+
localStorage.setItem('startDate', startDate.getTime().toString());
|
|
245
|
+
}
|
|
246
|
+
if (this.toDate) {
|
|
247
|
+
const endDate = new Date(this.toDate.year, this.toDate.month - 1, this.toDate.day);
|
|
248
|
+
localStorage.setItem('endDate', endDate.getTime().toString());
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MenuBarComponent, deps: [{ token: i1.Router }, { token: i2.LocaleService }, { token: i3.BaseUserService }, { token: i4.NavigatorService }, { token: i5.SupportService }, { token: i6.BaseVisibilityService }, { token: i7.NgbCalendar }, { token: i7.NgbDateParserFormatter }, { token: i8.FilterService }, { token: i9.AmplifyCacheService }], target: i0.ɵɵFactoryTarget.Component });
|
|
252
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MenuBarComponent, selector: "lib-menu-bar", inputs: { cacheName: "cacheName" }, ngImport: i0, template: "<div id=\"menu-bar\">\r\n <div *ngIf=\"!isVisitor\">\r\n <nav class=\"navbar navbar-expand-md navbar-light p-0\">\r\n <div class=\"container-fluid\" *ngIf=\"isVisible\">\r\n <div class=\"navbar-brand order-md-0\" [routerLink]=\"['/dashboard']\">\r\n <img alt=\"SmarterPlan\" src=\"../assets/images/logos/logo-immo.png\">\r\n </div>\r\n <div class=\"ms-auto nav-item dropdown profile_pic-container order-md-2\">\r\n <div class=\"profile_pic dropdown-toggle\" data-testid=\"dropdown-menu-button\" data-bs-toggle=\"dropdown\">\r\n <lib-avatar></lib-avatar>\r\n </div>\r\n <div class=\"dropdown-menu dropdown-menu-right\">\r\n <p *ngIf=\"user && mission\" class=\"p-2\">\r\n <span class=\"username\">{{ user.displayName }}</span><br />\r\n <span class=\"user-role\">{{ mission.role }}</span><br />\r\n <span class=\"org\">{{ mission.organisation ? mission.organisation.name : \"No organisation\" |\r\n translate}}</span>\r\n </p>\r\n <div class=\"dropdown-divider\"></div>\r\n <!-- <a class=\"dropdown-item\" routerLink=\"/debug\" *ngIf=\"isManager\">Debug</a> -->\r\n <a class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</a>\r\n <a class=\"dropdown-item\" routerLink=\"/dashboard\">{{'Data management' | translate}}</a>\r\n <a class=\"dropdown-item\" data-testid=\"user-management-btn\" routerLink=\"/admin\" *ngIf=\"isManager\">\r\n {{'Users management' | translate}}</a>\r\n <a class=\"dropdown-item\" routerLink=\"/profile\">\r\n {{'Profile' | translate}}</a>\r\n <div class=\"dropdown-divider\"></div>\r\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\r\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\r\n translate}}</button>\r\n </div>\r\n </div>\r\n <button class=\"navbar-toggler order-md-1\" (click)=\"navbarCollapse.toggle()\" type=\"button\"\r\n [attr.aria-expanded]=\"!isCollapsed\" aria-controls=\"navbar-collapse\">\r\n <span class=\"navbar-toggler-icon\"></span>\r\n </button>\r\n <div class=\"navbar-collapse order-md-1\" #navbarCollapse=\"ngbCollapse\" [(ngbCollapse)]=\"isCollapsed\"\r\n [animation]=\"false\">\r\n <form\r\n class=\"form-inline m-0 mt-2 form-container d-flex justify-content-start align-items-start align-items-md-center flex-column flex-md-row flex-nowrap filters-menu-block\">\r\n <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-0\">\r\n <input class=\"form-control search-button m-1\" placeholder=\"keyword\" id=\"mainSearchBar\" type=\"text\">\r\n <button class=\"btn btn-outline-primary rounded-pill m-1 w-fit-content h-fit-content align-self-md-center\"\r\n (click)=\"onSubmit()\">{{'Search' |\r\n translate}}</button>\r\n </div>\r\n <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-0\">\r\n <div class=\"input-group date-selector m-1\">\r\n <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\r\n [value]=\"fromDate | formatDateNumberToDigits\"\r\n (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\"\r\n type=\"button\"></button>\r\n </div>\r\n </div>\r\n <input name=\"datepicker\" class=\"form-control visually-hidden\" ngbDatepicker #datepicker=\"ngbDatepicker\"\r\n [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\r\n outsideDays=\"hidden\" [startDate]=\"fromDate || calendar.getToday()\" [container]=\"'body'\" tabindex=\"-1\">\r\n <ng-template #t let-date let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\r\n [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\r\n (mouseleave)=\"hoveredDate = null\">\r\n {{ date.day }}\r\n </span>\r\n </ng-template>\r\n <span class=\"ms-1 p-2\">{{'to' | translate}}</span>\r\n <div class=\"input-group date-selector m-1\">\r\n <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\r\n [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\"\r\n type=\"button\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-1 justify-content-evenly\">\r\n <button\r\n class=\"btn btn-primary rounded-pill ms-1 w-25 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n type=\"button\" (click)=\"onApply()\" *ngIf=\"!isDateFilterApplied || dateChanged\">\r\n {{'Apply' | translate}}\r\n </button>\r\n <span\r\n class=\"appliedText ms-1 py-2 align-self-md-center pb-md-0 mx-2 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n *ngIf=\"isDateFilterApplied && !dateChanged\">\r\n <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\r\n {{\"Applied\" | translate}}\r\n </span>\r\n <button\r\n class=\"btn btn-outline-primary rounded-pill w-25 mx-2 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n type=\"button\" (click)=\"onClearDates()\">{{'Clear'\r\n |\r\n translate}}</button>\r\n <div\r\n class=\"change-position-button align-self-end pb-2 align-self-md-center mx-2 pb-md-0 flex-nowrap w-25 w-md-fit-content h-md-fit-content\">\r\n <input type=\"checkbox\" class=\"btn-check\" id=\"btn-check-outlined\" autocomplete=\"off\">\r\n <label class=\"link-primary cursor-pointer text-decoration-underline\" (click)=\"onChangePositionClick()\"\r\n for=\"btn-check-outlined\">{{\r\n (isChangePositionVisible ? \"Close\" : \"Move to\") | translate }}</label>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n </nav>\r\n <lib-navigation-bar *ngIf=\"isVisible && isChangePositionVisible\"></lib-navigation-bar>\r\n </div>\r\n <div *ngIf=\"isVisitor && isVisible\">\r\n <div class=\"visitor-div\">\r\n <div class=\"logo-container\" data-testid=\"dropdown-menu-button\">\r\n <img class=\"img-logo\" alt=\"SmarterPlanLogo\" src=\"../assets/images/logos/logo-reserve.png\">\r\n </div>\r\n <div class=\"avatar-container-menu\">\r\n <div class=\"profile_pic dropdown-toggle cursor-pointer\" data-bs-toggle=\"dropdown\">\r\n <lib-avatar></lib-avatar>\r\n </div>\r\n <div class=\"dropdown-menu dropdown-menu-right\">\r\n <button class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</button>\r\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\r\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\r\n translate}}</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: ["#menu-bar{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 rgb(150,150,150)}.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}.navbar form{width:100%;margin:0;padding:0}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0;width:auto}button{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-container{width:auto;align-items:stretch;justify-items:start}.search-button-container .search-button{width:auto;border-radius:1rem!important}.visitor-div{background-color:var(--smarterplan-primary);height:60px;display:flex;justify-content:space-between}.profile_pic-container{margin-right:1em}.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}.filters-menu-block{width:auto}@media (min-width: 1200px){.navbar-brand img{height:100px}.profile_pic{height:60px;width:60px;margin:15px}}@media (min-width: 992px) and (max-width: 1199.98px){.navbar-brand img{height:80px}.profile_pic{height:50px;width:50px;margin:12px}}@media (min-width: 768px) and (max-width: 991.98px){.navbar-brand img{height:60px}.profile_pic{height:40px;width:40px;margin:10px}}@media (max-width: 767.98px){.navbar-brand img{height:50px}.profile_pic{height:30px;width:30px;margin:8px}.search-button-container,.filters-menu-block{width:100%}}.form-container{margin:.5rem 0}.navbar-collapse.show{display:flex;padding-bottom:.5rem}.hidden{width:0;margin:0;border:none;padding:0}.custom-day{text-align:center;padding:.185rem .25rem;display:inline-block;height:2rem;width:2rem}.custom-day.focused{background-color:#e6e6e6}.custom-day.range,.custom-day:hover{background-color:var(--smarterplan-primary-lighter);color:#fff}.custom-day.faded{background-color:var(--smarterplan-primary-transparent)}.calendar{height:100%}.appliedText,.appliedText span{color:var(--smarterplan-primary)}@media (max-width: 767px){.form-inline{flex-direction:column}}.hidden{opacity:0}.date-selector{flex-wrap:nowrap}.date-selector input{min-width:80px;margin:0}@media (min-width: 768px){.w-md-fit-content{width:-moz-fit-content!important;width:fit-content!important}.h-md-content{height:-moz-fit-content!important;height:fit-content!important}}\n"], dependencies: [{ kind: "directive", type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i10.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i7.NgbCollapse, selector: "[ngbCollapse]", inputs: ["animation", "ngbCollapse", "horizontal"], outputs: ["ngbCollapseChange", "shown", "hidden"], exportAs: ["ngbCollapse"] }, { kind: "directive", type: i7.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "contentTemplate", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "popperOptions", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { kind: "component", type: i12.AvatarComponent, selector: "lib-avatar", inputs: ["size", "userID"] }, { kind: "component", type: i13.NavigationBarComponent, selector: "lib-navigation-bar" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }, { kind: "pipe", type: i15.FormatDateNumberToDigitsPipe, name: "formatDateNumberToDigits" }] });
|
|
253
|
+
}
|
|
254
|
+
export { MenuBarComponent };
|
|
255
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MenuBarComponent, decorators: [{
|
|
256
|
+
type: Component,
|
|
257
|
+
args: [{ selector: 'lib-menu-bar', template: "<div id=\"menu-bar\">\r\n <div *ngIf=\"!isVisitor\">\r\n <nav class=\"navbar navbar-expand-md navbar-light p-0\">\r\n <div class=\"container-fluid\" *ngIf=\"isVisible\">\r\n <div class=\"navbar-brand order-md-0\" [routerLink]=\"['/dashboard']\">\r\n <img alt=\"SmarterPlan\" src=\"../assets/images/logos/logo-immo.png\">\r\n </div>\r\n <div class=\"ms-auto nav-item dropdown profile_pic-container order-md-2\">\r\n <div class=\"profile_pic dropdown-toggle\" data-testid=\"dropdown-menu-button\" data-bs-toggle=\"dropdown\">\r\n <lib-avatar></lib-avatar>\r\n </div>\r\n <div class=\"dropdown-menu dropdown-menu-right\">\r\n <p *ngIf=\"user && mission\" class=\"p-2\">\r\n <span class=\"username\">{{ user.displayName }}</span><br />\r\n <span class=\"user-role\">{{ mission.role }}</span><br />\r\n <span class=\"org\">{{ mission.organisation ? mission.organisation.name : \"No organisation\" |\r\n translate}}</span>\r\n </p>\r\n <div class=\"dropdown-divider\"></div>\r\n <!-- <a class=\"dropdown-item\" routerLink=\"/debug\" *ngIf=\"isManager\">Debug</a> -->\r\n <a class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</a>\r\n <a class=\"dropdown-item\" routerLink=\"/dashboard\">{{'Data management' | translate}}</a>\r\n <a class=\"dropdown-item\" data-testid=\"user-management-btn\" routerLink=\"/admin\" *ngIf=\"isManager\">\r\n {{'Users management' | translate}}</a>\r\n <a class=\"dropdown-item\" routerLink=\"/profile\">\r\n {{'Profile' | translate}}</a>\r\n <div class=\"dropdown-divider\"></div>\r\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\r\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\r\n translate}}</button>\r\n </div>\r\n </div>\r\n <button class=\"navbar-toggler order-md-1\" (click)=\"navbarCollapse.toggle()\" type=\"button\"\r\n [attr.aria-expanded]=\"!isCollapsed\" aria-controls=\"navbar-collapse\">\r\n <span class=\"navbar-toggler-icon\"></span>\r\n </button>\r\n <div class=\"navbar-collapse order-md-1\" #navbarCollapse=\"ngbCollapse\" [(ngbCollapse)]=\"isCollapsed\"\r\n [animation]=\"false\">\r\n <form\r\n class=\"form-inline m-0 mt-2 form-container d-flex justify-content-start align-items-start align-items-md-center flex-column flex-md-row flex-nowrap filters-menu-block\">\r\n <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-0\">\r\n <input class=\"form-control search-button m-1\" placeholder=\"keyword\" id=\"mainSearchBar\" type=\"text\">\r\n <button class=\"btn btn-outline-primary rounded-pill m-1 w-fit-content h-fit-content align-self-md-center\"\r\n (click)=\"onSubmit()\">{{'Search' |\r\n translate}}</button>\r\n </div>\r\n <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-0\">\r\n <div class=\"input-group date-selector m-1\">\r\n <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\r\n [value]=\"fromDate | formatDateNumberToDigits\"\r\n (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\"\r\n type=\"button\"></button>\r\n </div>\r\n </div>\r\n <input name=\"datepicker\" class=\"form-control visually-hidden\" ngbDatepicker #datepicker=\"ngbDatepicker\"\r\n [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\r\n outsideDays=\"hidden\" [startDate]=\"fromDate || calendar.getToday()\" [container]=\"'body'\" tabindex=\"-1\">\r\n <ng-template #t let-date let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\r\n [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\r\n (mouseleave)=\"hoveredDate = null\">\r\n {{ date.day }}\r\n </span>\r\n </ng-template>\r\n <span class=\"ms-1 p-2\">{{'to' | translate}}</span>\r\n <div class=\"input-group date-selector m-1\">\r\n <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\r\n [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\r\n <div class=\"input-group-append\">\r\n <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\"\r\n type=\"button\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-1 justify-content-evenly\">\r\n <button\r\n class=\"btn btn-primary rounded-pill ms-1 w-25 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n type=\"button\" (click)=\"onApply()\" *ngIf=\"!isDateFilterApplied || dateChanged\">\r\n {{'Apply' | translate}}\r\n </button>\r\n <span\r\n class=\"appliedText ms-1 py-2 align-self-md-center pb-md-0 mx-2 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n *ngIf=\"isDateFilterApplied && !dateChanged\">\r\n <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\r\n {{\"Applied\" | translate}}\r\n </span>\r\n <button\r\n class=\"btn btn-outline-primary rounded-pill w-25 mx-2 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n type=\"button\" (click)=\"onClearDates()\">{{'Clear'\r\n |\r\n translate}}</button>\r\n <div\r\n class=\"change-position-button align-self-end pb-2 align-self-md-center mx-2 pb-md-0 flex-nowrap w-25 w-md-fit-content h-md-fit-content\">\r\n <input type=\"checkbox\" class=\"btn-check\" id=\"btn-check-outlined\" autocomplete=\"off\">\r\n <label class=\"link-primary cursor-pointer text-decoration-underline\" (click)=\"onChangePositionClick()\"\r\n for=\"btn-check-outlined\">{{\r\n (isChangePositionVisible ? \"Close\" : \"Move to\") | translate }}</label>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n </nav>\r\n <lib-navigation-bar *ngIf=\"isVisible && isChangePositionVisible\"></lib-navigation-bar>\r\n </div>\r\n <div *ngIf=\"isVisitor && isVisible\">\r\n <div class=\"visitor-div\">\r\n <div class=\"logo-container\" data-testid=\"dropdown-menu-button\">\r\n <img class=\"img-logo\" alt=\"SmarterPlanLogo\" src=\"../assets/images/logos/logo-reserve.png\">\r\n </div>\r\n <div class=\"avatar-container-menu\">\r\n <div class=\"profile_pic dropdown-toggle cursor-pointer\" data-bs-toggle=\"dropdown\">\r\n <lib-avatar></lib-avatar>\r\n </div>\r\n <div class=\"dropdown-menu dropdown-menu-right\">\r\n <button class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</button>\r\n <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\r\n <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\r\n translate}}</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: ["#menu-bar{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 rgb(150,150,150)}.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}.navbar form{width:100%;margin:0;padding:0}input,select{margin-right:15px}.select{background:transparent;border:none;color:#fff;margin:6px 20px 0;width:auto}button{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-container{width:auto;align-items:stretch;justify-items:start}.search-button-container .search-button{width:auto;border-radius:1rem!important}.visitor-div{background-color:var(--smarterplan-primary);height:60px;display:flex;justify-content:space-between}.profile_pic-container{margin-right:1em}.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}.filters-menu-block{width:auto}@media (min-width: 1200px){.navbar-brand img{height:100px}.profile_pic{height:60px;width:60px;margin:15px}}@media (min-width: 992px) and (max-width: 1199.98px){.navbar-brand img{height:80px}.profile_pic{height:50px;width:50px;margin:12px}}@media (min-width: 768px) and (max-width: 991.98px){.navbar-brand img{height:60px}.profile_pic{height:40px;width:40px;margin:10px}}@media (max-width: 767.98px){.navbar-brand img{height:50px}.profile_pic{height:30px;width:30px;margin:8px}.search-button-container,.filters-menu-block{width:100%}}.form-container{margin:.5rem 0}.navbar-collapse.show{display:flex;padding-bottom:.5rem}.hidden{width:0;margin:0;border:none;padding:0}.custom-day{text-align:center;padding:.185rem .25rem;display:inline-block;height:2rem;width:2rem}.custom-day.focused{background-color:#e6e6e6}.custom-day.range,.custom-day:hover{background-color:var(--smarterplan-primary-lighter);color:#fff}.custom-day.faded{background-color:var(--smarterplan-primary-transparent)}.calendar{height:100%}.appliedText,.appliedText span{color:var(--smarterplan-primary)}@media (max-width: 767px){.form-inline{flex-direction:column}}.hidden{opacity:0}.date-selector{flex-wrap:nowrap}.date-selector input{min-width:80px;margin:0}@media (min-width: 768px){.w-md-fit-content{width:-moz-fit-content!important;width:fit-content!important}.h-md-content{height:-moz-fit-content!important;height:fit-content!important}}\n"] }]
|
|
258
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.LocaleService }, { type: i3.BaseUserService }, { type: i4.NavigatorService }, { type: i5.SupportService }, { type: i6.BaseVisibilityService }, { type: i7.NgbCalendar }, { type: i7.NgbDateParserFormatter }, { type: i8.FilterService }, { type: i9.AmplifyCacheService }]; }, propDecorators: { cacheName: [{
|
|
259
|
+
type: Input
|
|
260
|
+
}] } });
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/menu-bar.component.ts","../../../../../../projects/ngx-smarterplan-core/src/lib/components/menu-bar/menu-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { Subscription } from 'rxjs';\r\nimport { LocaleService } from '../../services/locale.service';\r\nimport { NavigatorService } from '../../services/navigator.service';\r\nimport { SupportService } from '../../services/support.service';\r\nimport { BaseUserService } from '../../services/user.service';\r\nimport { ProfileEntity, Mission } from '../../types.service';\r\nimport { SupportModalComponent } from '../support-modal/support-modal.component';\r\nimport { BaseVisibilityService } from '../../services/baseVisibility.service';\r\nimport {\r\n  NgbDate,\r\n  NgbCalendar,\r\n  NgbDateParserFormatter,\r\n} from '@ng-bootstrap/ng-bootstrap';\r\nimport { AmplifyCacheService } from '../../services/amplify-cache.service';\r\nimport { FilterService } from '../../services/filter.service';\r\n\r\n@Component({\r\n  selector: 'lib-menu-bar',\r\n  templateUrl: './menu-bar.component.html',\r\n  styleUrls: ['./menu-bar.component.scss'],\r\n})\r\nexport class MenuBarComponent implements OnInit {\r\n  user: ProfileEntity;\r\n\r\n  mission: Mission;\r\n\r\n  public isCollapsed = true;\r\n\r\n  isVisitor = true;\r\n\r\n  isVisible = false;\r\n\r\n  isChangePositionVisible: boolean = false;\r\n\r\n  isManager: boolean;\r\n\r\n  userSubscription: Subscription;\r\n\r\n  navSubscription: Subscription;\r\n\r\n  hoveredDate: NgbDate | null = null;\r\n\r\n  fromDate: NgbDate | null;\r\n\r\n  toDate: NgbDate | null;\r\n\r\n  @Input() cacheName: string | null;\r\n\r\n  cache: { from: number; to: number } | null;\r\n\r\n  isDateFilterApplied: boolean = false;\r\n\r\n  dateChanged: boolean = false;\r\n\r\n  changePositionSubscription?: Subscription;\r\n\r\n  private searchInput?: HTMLInputElement;\r\n\r\n  filterSubscription\r\n\r\n  constructor(\r\n    private router: Router,\r\n    public localeService: LocaleService,\r\n    private userService: BaseUserService,\r\n    private navigatorService: NavigatorService,\r\n    private supportService: SupportService,\r\n    private baseVisibilityService: BaseVisibilityService,\r\n    public calendar: NgbCalendar,\r\n    public formatter: NgbDateParserFormatter,\r\n    private filterService: FilterService,\r\n    private cacheService: AmplifyCacheService\r\n  ) {\r\n    this.userSubscription = this.userService.isChanged.subscribe(\r\n      (isChanged) => {\r\n        if (isChanged) {\r\n          this.update();\r\n        }\r\n      }\r\n    );\r\n    this.navSubscription = this.navigatorService.isVisibleChanged.subscribe(\r\n      (data) => {\r\n        this.isVisible = data;\r\n      }\r\n    );\r\n\r\n    this.changePositionSubscription = this.baseVisibilityService.isChangePositionVisible.subscribe((data) => {\r\n      this.isChangePositionVisible = data;\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.update();\r\n\r\n    if (this.cacheName) {\r\n      this.cache = this.cacheService.getFromCache(this.cacheName);\r\n    }\r\n\r\n    if (this.cache) {\r\n      this.isDateFilterApplied = true;\r\n      let { from, to } = this.cache;\r\n      this.toDate = this.getNgbDate(to);\r\n      this.fromDate = this.getNgbDate(from);\r\n\r\n      localStorage.setItem('startDate', from.toString());\r\n      localStorage.setItem('endDate', to.toString());\r\n      this.filterService.dateFilterUpdated([new Date(from), new Date(to)]);\r\n    } else {\r\n      this.fromDate = null;\r\n      this.toDate = null;\r\n      localStorage.removeItem('startDate');\r\n      localStorage.removeItem('endDate');\r\n\r\n      this.filterService.dateFilterUpdated(null);\r\n    }\r\n\r\n    // This allows updating the inputs when measurement.service changes the date programmatically\r\n    this.filterSubscription = this.filterService.subscribeToDataFilterUpdate((dateRange: Date[] | null) => {\r\n      if (dateRange && dateRange.length === 2) {\r\n        // 1. Convert JS Date objects to NgbDate for display\r\n        const from = dateRange[0].getTime();\r\n        const to = dateRange[1].getTime();\r\n\r\n        this.fromDate = this.getNgbDate(from);\r\n        this.toDate = this.getNgbDate(to);\r\n\r\n        // 2. Update local cache reference to prevent the \"Apply\" button from activating\r\n        this.cache = { from, to };\r\n\r\n        // 3. Update visual state\r\n        this.isDateFilterApplied = true;\r\n        this.dateChanged = false; // We consider it synchronized\r\n      } else {\r\n        // If the filter is cleared externally\r\n        this.fromDate = null;\r\n        this.toDate = null;\r\n        this.isDateFilterApplied = false;\r\n        this.cache = null;\r\n      }\r\n    });\r\n  }\r\n\r\n  private onSearchKeydown = (event: KeyboardEvent) => {\r\n    if (event.key === 'Enter') this.onSubmit();\r\n  };\r\n\r\n  ngAfterViewInit() {\r\n    this.searchInput = document.querySelector('#mainSearchBar') as HTMLInputElement;\r\n    this.searchInput?.addEventListener('keydown', this.onSearchKeydown);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.searchInput?.removeEventListener('keydown', this.onSearchKeydown);\r\n    this.userSubscription?.unsubscribe();\r\n    this.navSubscription?.unsubscribe();\r\n    this.changePositionSubscription?.unsubscribe();\r\n    this.filterSubscription?.unsubscribe();\r\n  }\r\n\r\n  async signOut() {\r\n    await this.userService.logoutCurrentAndSignOutAuth();\r\n    this.router.navigate(['auth']);\r\n  }\r\n\r\n  async update() {\r\n    this.user = this.userService.cu;\r\n    this.mission = this.userService.currentMissions[0];\r\n    this.isManager = this.userService.hasManagerRoleInAnyMission();\r\n    this.isVisitor = this.userService.isVisitor();\r\n    if (!this.isVisitor) {\r\n      this.isVisible = true;\r\n    }\r\n  }\r\n\r\n  // eslint-disable-next-line class-methods-use-this\r\n  onSubmit() {\r\n    const input = document.querySelector('#mainSearchBar') as HTMLInputElement;\r\n    const searchValue = input.value.toLowerCase();\r\n    if (searchValue !== '') {\r\n      const baseUrl = location.origin;\r\n      window.open(`${baseUrl}/dashboard/search?term=${searchValue}`, '_blank');\r\n    }\r\n  }\r\n\r\n  onToggleVisible() {\r\n    this.isVisible = !this.isVisible;\r\n  }\r\n\r\n  openSupportForm() {\r\n    this.supportService.openSupportForm(SupportModalComponent);\r\n  }\r\n\r\n  onChangePositionClick() {\r\n    this.baseVisibilityService.isChangePositionVisible.next(\r\n      !this.isChangePositionVisible\r\n    );\r\n  }\r\n\r\n  getNgbDate(date: number): NgbDate {\r\n    let dt = new Date(date);\r\n    dt.setMinutes(dt.getMinutes() - dt.getTimezoneOffset()); // convert to UTC\r\n    return new NgbDate(\r\n      dt.getUTCFullYear(),\r\n      dt.getUTCMonth() + 1,\r\n      dt.getUTCDate()\r\n    );\r\n  }\r\n\r\n  onDateSelection(date: NgbDate) {\r\n    if (!this.fromDate && !this.toDate) {\r\n      this.fromDate = date;\r\n    } else if (\r\n      this.fromDate &&\r\n      !this.toDate &&\r\n      date &&\r\n      date.after(this.fromDate)\r\n    ) {\r\n      this.toDate = date;\r\n    } else {\r\n      this.toDate = null;\r\n      this.fromDate = date;\r\n    }\r\n    this.isDateChanged();\r\n  }\r\n\r\n  isDateChanged() {\r\n    if (this.fromDate && this.toDate) {\r\n      if (this.cache) {\r\n        this.dateChanged =\r\n          !this.fromDate.equals(this.getNgbDate(this.cache.from)) ||\r\n          !this.toDate.equals(this.getNgbDate(this.cache.to));\r\n      }\r\n    }\r\n  }\r\n\r\n  isHovered(date: NgbDate) {\r\n    return (\r\n      this.fromDate &&\r\n      !this.toDate &&\r\n      this.hoveredDate &&\r\n      date.after(this.fromDate) &&\r\n      date.before(this.hoveredDate)\r\n    );\r\n  }\r\n\r\n  isInside(date: NgbDate) {\r\n    return this.toDate && date.after(this.fromDate) && date.before(this.toDate);\r\n  }\r\n\r\n  isRange(date: NgbDate) {\r\n    return (\r\n      date.equals(this.fromDate) ||\r\n      (this.toDate && date.equals(this.toDate)) ||\r\n      this.isInside(date) ||\r\n      this.isHovered(date)\r\n    );\r\n  }\r\n\r\n  validateInput(currentValue: NgbDate | null, input: string): NgbDate | null {\r\n    const parsed = this.formatter.parse(input);\r\n    return parsed && this.calendar.isValid(NgbDate.from(parsed))\r\n      ? NgbDate.from(parsed)\r\n      : currentValue;\r\n  }\r\n\r\n  emitRange() {\r\n    if (this.fromDate && this.toDate) {\r\n      const from = new Date(\r\n        this.fromDate.year,\r\n        this.fromDate.month - 1,\r\n        this.fromDate.day\r\n      );\r\n      const to = new Date(\r\n        this.toDate.year,\r\n        this.toDate.month - 1,\r\n        this.toDate.day,\r\n        23,\r\n        59\r\n      );\r\n      this.cacheService.putInCache(this.cacheName, {\r\n        from: from.getTime(),\r\n        to: to.getTime(),\r\n      });\r\n      this.cache = { from: from.getTime(), to: to.getTime() };\r\n      this.filterService.dateFilterUpdated([from, to]);\r\n      this.isDateFilterApplied = true;\r\n      this.dateChanged = false;\r\n    }\r\n  }\r\n\r\n  onClearDates() {\r\n    this.fromDate = null;\r\n    this.toDate = null;\r\n    this.isDateFilterApplied = false;\r\n    this.cache = null;\r\n    this.cacheService.removeFromCache(this.cacheName);\r\n    this.filterService.dateFilterUpdated(null);\r\n  }\r\n\r\n  onApply() {\r\n    if (this.fromDate && this.toDate) {\r\n      this.emitRange();\r\n    }\r\n\r\n    //transform ngbDate to date objet then put dates in timestamp in localStorage to share it with Retool\r\n    if (this.fromDate) {\r\n      const startDate = new Date(\r\n        this.fromDate.year,\r\n        this.fromDate.month - 1,\r\n        this.fromDate.day\r\n      );\r\n      localStorage.setItem('startDate', startDate.getTime().toString());\r\n    }\r\n    if (this.toDate) {\r\n      const endDate = new Date(\r\n        this.toDate.year,\r\n        this.toDate.month - 1,\r\n        this.toDate.day\r\n      );\r\n      localStorage.setItem('endDate', endDate.getTime().toString());\r\n    }\r\n  }\r\n}\r\n","<div id=\"menu-bar\">\r\n  <div *ngIf=\"!isVisitor\">\r\n    <nav class=\"navbar navbar-expand-md navbar-light p-0\">\r\n      <div class=\"container-fluid\" *ngIf=\"isVisible\">\r\n        <div class=\"navbar-brand order-md-0\" [routerLink]=\"['/dashboard']\">\r\n          <img alt=\"SmarterPlan\" src=\"../assets/images/logos/logo-immo.png\">\r\n        </div>\r\n        <div class=\"ms-auto nav-item dropdown profile_pic-container order-md-2\">\r\n          <div class=\"profile_pic dropdown-toggle\" data-testid=\"dropdown-menu-button\" data-bs-toggle=\"dropdown\">\r\n            <lib-avatar></lib-avatar>\r\n          </div>\r\n          <div class=\"dropdown-menu dropdown-menu-right\">\r\n            <p *ngIf=\"user && mission\" class=\"p-2\">\r\n              <span class=\"username\">{{ user.displayName }}</span><br />\r\n              <span class=\"user-role\">{{ mission.role }}</span><br />\r\n              <span class=\"org\">{{ mission.organisation ? mission.organisation.name : \"No organisation\" |\r\n                translate}}</span>\r\n            </p>\r\n            <div class=\"dropdown-divider\"></div>\r\n            <!-- <a class=\"dropdown-item\" routerLink=\"/debug\" *ngIf=\"isManager\">Debug</a> -->\r\n            <a class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</a>\r\n            <a class=\"dropdown-item\" routerLink=\"/dashboard\">{{'Data management' | translate}}</a>\r\n            <a class=\"dropdown-item\" data-testid=\"user-management-btn\" routerLink=\"/admin\" *ngIf=\"isManager\">\r\n              {{'Users management' | translate}}</a>\r\n            <a class=\"dropdown-item\" routerLink=\"/profile\">\r\n              {{'Profile' | translate}}</a>\r\n            <div class=\"dropdown-divider\"></div>\r\n            <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\r\n            <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\r\n              translate}}</button>\r\n          </div>\r\n        </div>\r\n        <button class=\"navbar-toggler order-md-1\" (click)=\"navbarCollapse.toggle()\" type=\"button\"\r\n          [attr.aria-expanded]=\"!isCollapsed\" aria-controls=\"navbar-collapse\">\r\n          <span class=\"navbar-toggler-icon\"></span>\r\n        </button>\r\n        <div class=\"navbar-collapse order-md-1\" #navbarCollapse=\"ngbCollapse\" [(ngbCollapse)]=\"isCollapsed\"\r\n          [animation]=\"false\">\r\n          <form\r\n            class=\"form-inline m-0 mt-2 form-container d-flex justify-content-start align-items-start align-items-md-center flex-column flex-md-row flex-nowrap filters-menu-block\">\r\n            <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-0\">\r\n              <input class=\"form-control search-button m-1\" placeholder=\"keyword\" id=\"mainSearchBar\" type=\"text\">\r\n              <button class=\"btn btn-outline-primary rounded-pill m-1 w-fit-content h-fit-content align-self-md-center\"\r\n                (click)=\"onSubmit()\">{{'Search' |\r\n                translate}}</button>\r\n            </div>\r\n            <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-0\">\r\n              <div class=\"input-group date-selector m-1\">\r\n                <input #dpFromDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpFromDate\"\r\n                  [value]=\"fromDate | formatDateNumberToDigits\"\r\n                  (input)=\"fromDate = validateInput(fromDate, dpFromDate.value)\">\r\n                <div class=\"input-group-append\">\r\n                  <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\"\r\n                    type=\"button\"></button>\r\n                </div>\r\n              </div>\r\n              <input name=\"datepicker\" class=\"form-control visually-hidden\" ngbDatepicker #datepicker=\"ngbDatepicker\"\r\n                [autoClose]=\"'outside'\" (dateSelect)=\"onDateSelection($event)\" [displayMonths]=\"2\" [dayTemplate]=\"t\"\r\n                outsideDays=\"hidden\" [startDate]=\"fromDate || calendar.getToday()\" [container]=\"'body'\" tabindex=\"-1\">\r\n              <ng-template #t let-date let-focused=\"focused\">\r\n                <span class=\"custom-day\" [class.focused]=\"focused\" [class.range]=\"isRange(date)\"\r\n                  [class.faded]=\"isHovered(date) || isInside(date)\" (mouseenter)=\"hoveredDate = date\"\r\n                  (mouseleave)=\"hoveredDate = null\">\r\n                  {{ date.day }}\r\n                </span>\r\n              </ng-template>\r\n              <span class=\"ms-1 p-2\">{{'to' | translate}}</span>\r\n              <div class=\"input-group date-selector m-1\">\r\n                <input #dpToDate class=\"form-control\" placeholder=\"dd/MM/yyyy\" name=\"dpToDate\"\r\n                  [value]=\"toDate | formatDateNumberToDigits\" (input)=\"toDate = validateInput(toDate, dpToDate.value)\">\r\n                <div class=\"input-group-append\">\r\n                  <button class=\"btn btn-outline-secondary calendar\" (click)=\"datepicker.toggle()\"\r\n                    type=\"button\"></button>\r\n                </div>\r\n              </div>\r\n            </div>\r\n            <div class=\"input-group search-button-container d-flex flex-row flex-nowrap p-0 m-1 justify-content-evenly\">\r\n              <button\r\n                class=\"btn btn-primary rounded-pill ms-1 w-25 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n                type=\"button\" (click)=\"onApply()\" *ngIf=\"!isDateFilterApplied || dateChanged\">\r\n                {{'Apply' | translate}}\r\n              </button>\r\n              <span\r\n                class=\"appliedText ms-1 py-2 align-self-md-center pb-md-0 mx-2 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n                *ngIf=\"isDateFilterApplied && !dateChanged\">\r\n                <span class=\"iconify\" data-icon=\"ion:checkmark\" data-width=\"15\" data-height=\"15\"></span>\r\n                {{\"Applied\" | translate}}\r\n              </span>\r\n              <button\r\n                class=\"btn btn-outline-primary rounded-pill w-25 mx-2 w-md-fit-content h-md-fit-content align-self-md-center\"\r\n                type=\"button\" (click)=\"onClearDates()\">{{'Clear'\r\n                |\r\n                translate}}</button>\r\n              <div\r\n                class=\"change-position-button align-self-end pb-2 align-self-md-center mx-2 pb-md-0 flex-nowrap w-25 w-md-fit-content h-md-fit-content\">\r\n                <input type=\"checkbox\" class=\"btn-check\" id=\"btn-check-outlined\" autocomplete=\"off\">\r\n                <label class=\"link-primary cursor-pointer text-decoration-underline\" (click)=\"onChangePositionClick()\"\r\n                  for=\"btn-check-outlined\">{{\r\n                  (isChangePositionVisible ? \"Close\" : \"Move to\") | translate }}</label>\r\n              </div>\r\n            </div>\r\n          </form>\r\n        </div>\r\n      </div>\r\n    </nav>\r\n    <lib-navigation-bar *ngIf=\"isVisible && isChangePositionVisible\"></lib-navigation-bar>\r\n  </div>\r\n  <div *ngIf=\"isVisitor && isVisible\">\r\n    <div class=\"visitor-div\">\r\n      <div class=\"logo-container\" data-testid=\"dropdown-menu-button\">\r\n        <img class=\"img-logo\" alt=\"SmarterPlanLogo\" src=\"../assets/images/logos/logo-reserve.png\">\r\n      </div>\r\n      <div class=\"avatar-container-menu\">\r\n        <div class=\"profile_pic dropdown-toggle cursor-pointer\" data-bs-toggle=\"dropdown\">\r\n          <lib-avatar></lib-avatar>\r\n        </div>\r\n        <div class=\"dropdown-menu dropdown-menu-right\">\r\n          <button class=\"dropdown-item\" (click)=\"localeService.modal()\">{{'Language' | translate}}</button>\r\n          <button class=\"dropdown-item\" (click)=\"openSupportForm()\">{{\"Help\" | translate}}</button>\r\n          <button data-testid=\"logout-auth-btn\" class=\"dropdown-item\" (click)=\"signOut()\">{{\"Logout\" |\r\n            translate}}</button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>"]}
|