@dsivd/prestations-ng 17.0.0-beta.3 → 17.0.0-beta.4

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/CHANGELOG.md CHANGED
@@ -14,7 +14,26 @@
14
14
 
15
15
  - Added migration guide
16
16
 
17
- ## [16.5.2]
17
+ ## [16.5.4]
18
+
19
+ ### Added
20
+
21
+ - [foehn-input-time.component.html](projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.html)
22
+
23
+ - added `allowLeadingZero` to true to allowed leading 0 in hours and minutes
24
+
25
+ - [ApplicationInfo](projects/prestations-ng/src/sdk-appinfo/application-info.ts)
26
+
27
+ - added `baseVdChUrl?: string` to `ApplicationInfo.Configuration.Portail`
28
+ - with default value by environnement
29
+ - use in `BreadcrumbEventService` and `GesdemConfirmationComponent`
30
+
31
+ ### Fixed
32
+
33
+ - [redirect.component.ts](projects/prestations-ng/src/sdk-redirect/redirect.component.ts)
34
+ - fixed redirect url when IAM ACV session is expired
35
+
36
+ ## [16.5.3]
18
37
 
19
38
  ### Added
20
39
 
package/UPGRADING_V17.md CHANGED
@@ -7,11 +7,12 @@ to `^17.2.4`, using `node 20+` to build, `npm 10+` for package manager and `Foeh
7
7
 
8
8
  ### Migrating to ESLint
9
9
 
10
- Follow [our migration guide](ESLINT_MIGRATION_GUIDE.md) to migrate your project from TSLint to ESLint
10
+ Follow [our migration guide](ESLINT_MIGRATION_GUIDE.md) to migrate your project from TSLint to ESLint.
11
11
 
12
12
  ### Package manager NPM instead of YARN
13
13
 
14
14
  We now recommend using `npm` instead of `yarn`.
15
+
15
16
  **NB: Don't need `run` when running `npm` for https://docs.npmjs.com/cli/v10/commands**
16
17
 
17
18
  - When using `prestations-ng` as a link, you need to run:
@@ -40,7 +41,7 @@ npm update
40
41
 
41
42
  [https://update.angular.io/?l=3&v=15.0-16.0](https://update.angular.io/?l=3&v=15.0-16.0)
42
43
 
43
- **NB: Commit before continuing so your repository is clean**
44
+ **NB: Commit before continuing so your repository is clean.**
44
45
 
45
46
  ```bash
46
47
  # Remove your resolutions in package.json before starting
@@ -57,7 +58,9 @@ ng update @angular/core@16 @angular/cli@16
57
58
 
58
59
  ##### If you are using our `slave-apps`
59
60
 
60
- Be sure to update your `slave-apps` git repository and source your bashrc (or whatever env file you're using) so you will be using node20 by default, verify by executing :
61
+ Be sure to update your `slave-apps` git repository and source your `.bashrc` (or whatever file you're using).
62
+
63
+ Verify your node version in your terminal by executing:
61
64
 
62
65
  ```bash
63
66
  node -v
@@ -71,11 +74,15 @@ node20
71
74
 
72
75
  ##### If you are NOT using our `slave-apps`
73
76
 
74
- Be sure to use a node version 20+ and use the same command as above.
77
+ Be sure to use a node version 20+ in your terminal:
78
+
79
+ ```bash
80
+ node -v
81
+ ```
75
82
 
76
83
  #### In your project
77
84
 
78
- Update your `package.json` to specify node engine
85
+ Update your `package.json` file to specify the node engine:
79
86
 
80
87
  ```json
81
88
  {
@@ -87,8 +94,8 @@ Update your `package.json` to specify node engine
87
94
 
88
95
  #### Update your jenkins files
89
96
 
90
- Add `nodeVersion: 20` to use node 20.
91
- Add `nodeLabel: 'rhel8pee'` to use a RedHat 8 which support node 20
97
+ - Add `nodeVersion: 20` to use node 20
98
+ - Add `nodeLabel: 'rhel8pee'` to use a RedHat 8 which support node 20
92
99
 
93
100
  ##### UT folder
94
101
 
@@ -119,8 +126,9 @@ def args = [
119
126
 
120
127
  ### Updating to Angular 17
121
128
 
122
- `prestations-ng` **v17+** now supports **Angular v17**. You can follow the Angular update guide
123
- at this address [https://update.angular.io/?l=3&v=16.0-17.0](https://update.angular.io/?l=3&v=16.0-17.0).
129
+ `prestations-ng` **v17+** now supports **Angular v17**.
130
+
131
+ You can follow the Angular update guide at this address [https://update.angular.io/?l=3&v=16.0-17.0](https://update.angular.io/?l=3&v=16.0-17.0).
124
132
 
125
133
  #### When having migrated to ESLint
126
134
 
@@ -162,18 +170,20 @@ ng g @dsivd/prestations-ng:foehn2-bootstrap5-migration
162
170
 
163
171
  **NB: Be aware that you will have to check every changes made to your repository to be sure everything is fine.**
164
172
 
165
- You will need to check manually your Java `dictionary.properties` for any HTML styling (search for: `class=`)
166
- You will need to check manually your TypeScript (`.ts`) files for any dynamique CSS classes or tests (`.spec.ts`)
173
+ You will need to check manually your:
174
+
175
+ - Java `dictionary.properties` for any HTML styling (search for: `class=`)
176
+ - TypeScript (`.ts`) files for any dynamique CSS classes or tests (`.spec.ts`)
167
177
 
168
178
  ##### More information here
169
179
 
170
- - Visite https://getbootstrap.com/docs/5.0/migration/ for Bootstrap 5 migration
171
- - Visite https://github.com/twbs/bootstrap/issues/32753 for the list of class changes in Bootstrap 5
172
- - Visite https://github.com/DSI-VD/foehn/blob/master/CHANGELOG.md for Foehn 2 migration
180
+ - https://getbootstrap.com/docs/5.0/migration/ for Bootstrap 5 migration.
181
+ - https://github.com/twbs/bootstrap/issues/32753 for the list of class changes in Bootstrap 5.
182
+ - https://github.com/DSI-VD/foehn/blob/master/CHANGELOG.md for Foehn 2 migration.
173
183
 
174
184
  ### Update ".eslintrc.json" file if your project was already migrated to ESLint
175
185
 
176
- **NB: Replace your current `.eslintrc.json` file by the one found in [ESLINT_MIGRATION.GUIDE](ESLINT_MIGRATION_GUIDE.md#customizing_eslint__inspired_from_otia_and_prestations-ng_s_files_for_rules_)**
186
+ **NB: Replace your current `.eslintrc.json` file by the one found in [ESLINT_MIGRATION.GUIDE](ESLINT_MIGRATION_GUIDE.md#customizing_eslint__inspired_from_otia_and_prestations-ng_s_files_for_rules_).**
177
187
 
178
188
  Then run
179
189
 
@@ -181,12 +191,11 @@ Then run
181
191
  ng lint --fix=true
182
192
  ```
183
193
 
184
- and finally fix manually remaining errors
194
+ and finally fix manually remaining errors. When encountering following warning in your `*.spec.ts`:
185
195
 
186
- If you encounter the following waring in your `*.spec.ts`:
187
- `warning Deprecated: Use `provideRouter`or`RouterModule`/`RouterModule.forRoot` instead`
196
+ **`warning Deprecated: Use provideRouter or RouterModule/RouterModule.forRoot instead`**
188
197
 
189
- You can replace `RouterTestingModule` by `RouterModule.forRoot([])`
198
+ replace `RouterTestingModule` by `RouterModule.forRoot([])`
190
199
 
191
200
  ### Cloudflare (`app.module.ts`)
192
201
 
@@ -208,8 +217,8 @@ Need to remove `CAPTCHA_URL_TOKEN` override
208
217
 
209
218
  When using `intellij`, you can run code inspection on your project to fix manually deprecations. Two ways:
210
219
 
211
- - Intellij window menu, go to: `Code > Analyze code > Run inspection by name...` (or **Ctrl+Alt+Maj+i**) and type `Deprecated symbol used`
212
- - Or select your project in your project panel and `right click` on it then `Analyze > Run inspection by name...` (or **Ctrl+Alt+Maj+i**) and type `Deprecated symbol used`
220
+ - Intellij window menu, go to: `Code > Analyze code > Run inspection by name...` (or **Ctrl+Alt+Maj+i**) and type `Deprecated symbol used`.
221
+ - Or select your project in your project panel and `right click` on it then `Analyze > Run inspection by name...` (or **Ctrl+Alt+Maj+i**) and type `Deprecated symbol used`.
213
222
 
214
223
  ### Last but not least, check if your application is working!!!
215
224
 
@@ -4,18 +4,19 @@ import { map } from 'rxjs/operators';
4
4
  import { Breadcrumb } from './breadcrumb';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../sdk-session-info/session-info.service";
7
+ import * as i2 from "../sdk-appinfo/application-info.service";
7
8
  const DEFAULT_VALUES = {
8
9
  espaceSecuriseUrl: '/100002/accueil',
9
10
  allPrestationsUrl: '/100002/prestations',
10
- vdChUrl: 'https://www.vd.ch/',
11
- descriptionPageBaseUrl: 'https://www.vd.ch/go.to?prestation=',
11
+ vdChUrl: null,
12
+ descriptionPageBaseUrl: null,
12
13
  // It's better to not display the breadcrumb item if the prestation doesn't give its code.
13
14
  prestationCode: null
14
15
  };
15
16
  // eslint-disable-next-line jsdoc/require-jsdoc
16
- function getNotConnectedBreadcrumb({ vdChUrl = DEFAULT_VALUES.vdChUrl, descriptionPageBaseUrl = DEFAULT_VALUES.descriptionPageBaseUrl, prestationCode = DEFAULT_VALUES.prestationCode }) {
17
+ function getNotConnectedBreadcrumb({ vdChUrl, descriptionPageBaseUrl, prestationCode = DEFAULT_VALUES.prestationCode }, vdChUrlFromAppInfo) {
17
18
  const rootElement = {
18
- url: vdChUrl,
19
+ url: vdChUrl || vdChUrlFromAppInfo,
19
20
  routerLink: null,
20
21
  label: 'vd.ch'
21
22
  };
@@ -29,7 +30,9 @@ function getNotConnectedBreadcrumb({ vdChUrl = DEFAULT_VALUES.vdChUrl, descripti
29
30
  rootElement,
30
31
  {
31
32
  // e.g. https://www.vd.ch/go.to?prestation=101016
32
- url: `${descriptionPageBaseUrl}${prestationCode}`,
33
+ url: descriptionPageBaseUrl
34
+ ? `${descriptionPageBaseUrl}${prestationCode}`
35
+ : `${vdChUrlFromAppInfo}/go.to?prestation=${prestationCode}`,
33
36
  routerLink: null,
34
37
  label: 'Description de la prestation'
35
38
  }
@@ -55,22 +58,23 @@ function getConnectedBreadcrumb({ espaceSecuriseUrl = DEFAULT_VALUES.espaceSecur
55
58
  * @param sessionInfoData data info on session
56
59
  * @param configuration as breadcrumb config.
57
60
  * @param currentItem as breadcrumb current item
61
+ * @param vdChBaseUrl typo3 base url for current env
58
62
  * @returns Breadcrumb
59
63
  */
60
- function getBreadcrumb(sessionInfoData, configuration, currentItem) {
64
+ function getBreadcrumb(sessionInfoData, configuration, currentItem, vdChBaseUrl) {
61
65
  // Whether the user has a context we consider it as connected.
62
66
  const isConnectedCyber = !!sessionInfoData && !!sessionInfoData.context;
63
67
  const breadcrumb = new Breadcrumb();
64
68
  // Depending on whether the user is connected, the content of the items change.
65
69
  breadcrumb.breadcrumbItems = isConnectedCyber
66
70
  ? getConnectedBreadcrumb(configuration, sessionInfoData)
67
- : getNotConnectedBreadcrumb(configuration);
71
+ : getNotConnectedBreadcrumb(configuration, vdChBaseUrl);
68
72
  // Optionally set the current item.
69
73
  breadcrumb.current = currentItem;
70
74
  return breadcrumb;
71
75
  }
72
76
  // eslint-disable-next-line jsdoc/require-jsdoc
73
- function mapBreadcrumb([override, configuration, currentItem, sessionInfoData]) {
77
+ function mapBreadcrumb([override, configuration, currentItem, sessionInfoData, applicationInfo]) {
74
78
  // Take the override if it exists
75
79
  if (override) {
76
80
  // Although there's an override, we do want to assign the current item
@@ -83,14 +87,15 @@ function mapBreadcrumb([override, configuration, currentItem, sessionInfoData])
83
87
  }
84
88
  // Otherwise get a breadcrumb based on the configuration
85
89
  if (configuration) {
86
- return getBreadcrumb(sessionInfoData, configuration, currentItem);
90
+ return getBreadcrumb(sessionInfoData, configuration, currentItem, applicationInfo.configuration.portail.baseVdChUrl);
87
91
  }
88
92
  // Only output a breadcrumb of there's a configuration or an override
89
93
  return null;
90
94
  }
91
95
  export class BreadcrumbEventService {
92
- constructor(sessionInfo) {
96
+ constructor(sessionInfo, applicationInfoService) {
93
97
  this.sessionInfo = sessionInfo;
98
+ this.applicationInfoService = applicationInfoService;
94
99
  this._breadcrumbOverride = new BehaviorSubject(null);
95
100
  this._breadcrumbConfiguration = new BehaviorSubject(null);
96
101
  this._currentBreadcrumbItem = new BehaviorSubject(null);
@@ -100,7 +105,8 @@ export class BreadcrumbEventService {
100
105
  this._breadcrumbOverride,
101
106
  this._breadcrumbConfiguration,
102
107
  this._currentBreadcrumbItem,
103
- this.sessionInfo.data
108
+ this.sessionInfo.data,
109
+ this.applicationInfoService.data
104
110
  ]).pipe(
105
111
  // Put together the breadcrumb, or just take the override if it exists.
106
112
  map(mapBreadcrumb));
@@ -109,7 +115,8 @@ export class BreadcrumbEventService {
109
115
  this._breadcrumbOverride,
110
116
  this._breadcrumbConfiguration,
111
117
  this._currentBreadcrumbItem,
112
- of(null)
118
+ of(null),
119
+ this.applicationInfoService.data
113
120
  ]).pipe(
114
121
  // Put together the breadcrumb, or just take the override if it exists.
115
122
  map(mapBreadcrumb));
@@ -158,7 +165,7 @@ export class BreadcrumbEventService {
158
165
  setConfiguration(configuration) {
159
166
  this._breadcrumbConfiguration.next(configuration);
160
167
  }
161
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: BreadcrumbEventService, deps: [{ token: i1.SessionInfo }], target: i0.ɵɵFactoryTarget.Injectable }); }
168
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: BreadcrumbEventService, deps: [{ token: i1.SessionInfo }, { token: i2.ApplicationInfoService }], target: i0.ɵɵFactoryTarget.Injectable }); }
162
169
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: BreadcrumbEventService, providedIn: 'root' }); }
163
170
  }
164
171
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: BreadcrumbEventService, decorators: [{
@@ -166,5 +173,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.1", ngImpor
166
173
  args: [{
167
174
  providedIn: 'root'
168
175
  }]
169
- }], ctorParameters: () => [{ type: i1.SessionInfo }] });
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb-event.service.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-breadcrumb/breadcrumb-event.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { SessionInfo } from '../sdk-session-info/session-info.service';\nimport { SessionInfoData } from '../sdk-session-info/session-info-data';\nimport {\n    Breadcrumb,\n    BreadcrumbConfiguration,\n    BreadcrumbItem\n} from './breadcrumb';\n\nconst DEFAULT_VALUES: BreadcrumbConfiguration = {\n    espaceSecuriseUrl: '/100002/accueil',\n    allPrestationsUrl: '/100002/prestations',\n    vdChUrl: 'https://www.vd.ch/',\n    descriptionPageBaseUrl: 'https://www.vd.ch/go.to?prestation=',\n    // It's better to not display the breadcrumb item if the prestation doesn't give its code.\n    prestationCode: null\n};\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nfunction getNotConnectedBreadcrumb({\n    vdChUrl = DEFAULT_VALUES.vdChUrl,\n    descriptionPageBaseUrl = DEFAULT_VALUES.descriptionPageBaseUrl,\n    prestationCode = DEFAULT_VALUES.prestationCode\n}: BreadcrumbConfiguration): BreadcrumbItem[] {\n    const rootElement: BreadcrumbItem = {\n        url: vdChUrl,\n        routerLink: null,\n        label: 'vd.ch'\n    };\n\n    // Do not display the second element if the prestation code is not there so we have\n    // a chance to realize that something's missing rather than having a link that doesn't\n    // point to something meaningful.\n    if (!prestationCode) {\n        return [rootElement];\n    }\n\n    return [\n        rootElement,\n        {\n            // e.g. https://www.vd.ch/go.to?prestation=101016\n            url: `${descriptionPageBaseUrl}${prestationCode}`,\n            routerLink: null,\n            label: 'Description de la prestation'\n        }\n    ];\n}\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nfunction getConnectedBreadcrumb(\n    {\n        espaceSecuriseUrl = DEFAULT_VALUES.espaceSecuriseUrl\n    }: BreadcrumbConfiguration,\n    sessionInfoData: SessionInfoData\n): BreadcrumbItem[] {\n    return [\n        {\n            url: espaceSecuriseUrl,\n            routerLink: null,\n            label: sessionInfoData.espaceLabel\n        }\n    ];\n}\n\n/**\n * Get the breadcrumb depending on the state of the user.\n *\n * Example:\n *\n * Connected user : \"Mon espace\"\n * Anonymous user : \"vd.ch > Description de la prestation\"\n * @param sessionInfoData data info on session\n * @param configuration as breadcrumb config.\n * @param currentItem as breadcrumb current item\n * @returns Breadcrumb\n */\nfunction getBreadcrumb(\n    sessionInfoData: SessionInfoData,\n    configuration: BreadcrumbConfiguration,\n    currentItem: BreadcrumbItem\n): Breadcrumb {\n    // Whether the user has a context we consider it as connected.\n    const isConnectedCyber = !!sessionInfoData && !!sessionInfoData.context;\n\n    const breadcrumb = new Breadcrumb();\n\n    // Depending on whether the user is connected, the content of the items change.\n    breadcrumb.breadcrumbItems = isConnectedCyber\n        ? getConnectedBreadcrumb(configuration, sessionInfoData)\n        : getNotConnectedBreadcrumb(configuration);\n\n    // Optionally set the current item.\n    breadcrumb.current = currentItem;\n\n    return breadcrumb;\n}\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nfunction mapBreadcrumb([\n    override,\n    configuration,\n    currentItem,\n    sessionInfoData\n]: [\n    Breadcrumb,\n    BreadcrumbConfiguration,\n    BreadcrumbItem,\n    SessionInfoData\n]): Breadcrumb {\n    // Take the override if it exists\n    if (override) {\n        // Although there's an override, we do want to assign the current item\n        // so each page dans set its own name rather than letting the override\n        // handle this.\n        if (currentItem) {\n            override.current = currentItem;\n        }\n        return override;\n    }\n\n    // Otherwise get a breadcrumb based on the configuration\n    if (configuration) {\n        return getBreadcrumb(sessionInfoData, configuration, currentItem);\n    }\n\n    // Only output a breadcrumb of there's a configuration or an override\n    return null;\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class BreadcrumbEventService {\n    private _breadcrumbOverride = new BehaviorSubject<Breadcrumb>(null);\n    private _breadcrumbConfiguration =\n        new BehaviorSubject<BreadcrumbConfiguration>(null);\n    private _currentBreadcrumbItem = new BehaviorSubject<BreadcrumbItem>(null);\n    private readonly _breadcrumbObservable: Observable<Breadcrumb>;\n    private readonly _neverConnectedBreadcrumbObservable: Observable<Breadcrumb>;\n\n    private _skipLeavingAlertBecauseDemandIsTransmitted = false;\n\n    constructor(private sessionInfo: SessionInfo) {\n        // When the user might be connected\n        this._breadcrumbObservable = combineLatest([\n            this._breadcrumbOverride,\n            this._breadcrumbConfiguration,\n            this._currentBreadcrumbItem,\n            this.sessionInfo.data\n        ]).pipe(\n            // Put together the breadcrumb, or just take the override if it exists.\n            map(mapBreadcrumb)\n        );\n\n        // If the user is NEVER connected (for instance in cyberlogin)\n        this._neverConnectedBreadcrumbObservable = combineLatest([\n            this._breadcrumbOverride,\n            this._breadcrumbConfiguration,\n            this._currentBreadcrumbItem,\n            of(null)\n        ]).pipe(\n            // Put together the breadcrumb, or just take the override if it exists.\n            map(mapBreadcrumb)\n        );\n    }\n\n    get skipLeavingAlertBecauseDemandIsTransmitted(): boolean {\n        return this._skipLeavingAlertBecauseDemandIsTransmitted;\n    }\n\n    set skipLeavingAlertBecauseDemandIsTransmitted(value: boolean) {\n        this._skipLeavingAlertBecauseDemandIsTransmitted = value;\n    }\n\n    /**\n     * Set the breadcrumb. This value will override any configuration injected with\n     * `setConfiguration`. Only use if you want to handle the breadcrumb manually.\n     * @param breadcrumb as Breadcrumb\n     */\n    setBreadcrumb(breadcrumb: Breadcrumb): void {\n        this._breadcrumbOverride.next(breadcrumb);\n    }\n\n    /**\n     * The breadcrumb value.\n     * @returns Observable<Breadcrumb>\n     */\n    breadcrumbObservable(): Observable<Breadcrumb> {\n        return this._breadcrumbObservable;\n    }\n\n    /**\n     * The breadcrumb value if never connected.\n     * @returns Observable<Breadcrumb>\n     */\n    neverConnectedBreadcrumbObservable(): Observable<Breadcrumb> {\n        return this._neverConnectedBreadcrumbObservable;\n    }\n\n    /**\n     * Set the current item. Used for accessibility purposes.\n     * @param currentItem as BreadcrumbItem\n     */\n    setCurrentBreadcrumb(currentItem: BreadcrumbItem): void {\n        this._currentBreadcrumbItem.next(currentItem);\n    }\n\n    /**\n     * Set the current breadcrumb configuration.\n     *\n     * Set to `null` to disable the breadcrumb.\n     * @param configuration as BreadcrumbConfiguration\n     */\n    setConfiguration(configuration: BreadcrumbConfiguration): void {\n        this._breadcrumbConfiguration.next(configuration);\n    }\n}\n"]}
176
+ }], ctorParameters: () => [{ type: i1.SessionInfo }, { type: i2.ApplicationInfoService }] });
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb-event.service.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-breadcrumb/breadcrumb-event.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\nimport { ApplicationInfo } from '../sdk-appinfo/application-info';\nimport { ApplicationInfoService } from '../sdk-appinfo/application-info.service';\nimport { SessionInfo } from '../sdk-session-info/session-info.service';\nimport { SessionInfoData } from '../sdk-session-info/session-info-data';\nimport {\n    Breadcrumb,\n    BreadcrumbConfiguration,\n    BreadcrumbItem\n} from './breadcrumb';\n\nconst DEFAULT_VALUES: BreadcrumbConfiguration = {\n    espaceSecuriseUrl: '/100002/accueil',\n    allPrestationsUrl: '/100002/prestations',\n    vdChUrl: null,\n    descriptionPageBaseUrl: null,\n    // It's better to not display the breadcrumb item if the prestation doesn't give its code.\n    prestationCode: null\n};\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nfunction getNotConnectedBreadcrumb(\n    {\n        vdChUrl,\n        descriptionPageBaseUrl,\n        prestationCode = DEFAULT_VALUES.prestationCode\n    }: BreadcrumbConfiguration,\n    vdChUrlFromAppInfo: string\n): BreadcrumbItem[] {\n    const rootElement: BreadcrumbItem = {\n        url: vdChUrl || vdChUrlFromAppInfo,\n        routerLink: null,\n        label: 'vd.ch'\n    };\n\n    // Do not display the second element if the prestation code is not there so we have\n    // a chance to realize that something's missing rather than having a link that doesn't\n    // point to something meaningful.\n    if (!prestationCode) {\n        return [rootElement];\n    }\n\n    return [\n        rootElement,\n        {\n            // e.g. https://www.vd.ch/go.to?prestation=101016\n            url: descriptionPageBaseUrl\n                ? `${descriptionPageBaseUrl}${prestationCode}`\n                : `${vdChUrlFromAppInfo}/go.to?prestation=${prestationCode}`,\n            routerLink: null,\n            label: 'Description de la prestation'\n        }\n    ];\n}\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nfunction getConnectedBreadcrumb(\n    {\n        espaceSecuriseUrl = DEFAULT_VALUES.espaceSecuriseUrl\n    }: BreadcrumbConfiguration,\n    sessionInfoData: SessionInfoData\n): BreadcrumbItem[] {\n    return [\n        {\n            url: espaceSecuriseUrl,\n            routerLink: null,\n            label: sessionInfoData.espaceLabel\n        }\n    ];\n}\n\n/**\n * Get the breadcrumb depending on the state of the user.\n *\n * Example:\n *\n * Connected user : \"Mon espace\"\n * Anonymous user : \"vd.ch > Description de la prestation\"\n * @param sessionInfoData data info on session\n * @param configuration as breadcrumb config.\n * @param currentItem as breadcrumb current item\n * @param vdChBaseUrl typo3 base url for current env\n * @returns Breadcrumb\n */\nfunction getBreadcrumb(\n    sessionInfoData: SessionInfoData,\n    configuration: BreadcrumbConfiguration,\n    currentItem: BreadcrumbItem,\n    vdChBaseUrl: string\n): Breadcrumb {\n    // Whether the user has a context we consider it as connected.\n    const isConnectedCyber = !!sessionInfoData && !!sessionInfoData.context;\n\n    const breadcrumb = new Breadcrumb();\n\n    // Depending on whether the user is connected, the content of the items change.\n    breadcrumb.breadcrumbItems = isConnectedCyber\n        ? getConnectedBreadcrumb(configuration, sessionInfoData)\n        : getNotConnectedBreadcrumb(configuration, vdChBaseUrl);\n\n    // Optionally set the current item.\n    breadcrumb.current = currentItem;\n\n    return breadcrumb;\n}\n\n// eslint-disable-next-line jsdoc/require-jsdoc\nfunction mapBreadcrumb([\n    override,\n    configuration,\n    currentItem,\n    sessionInfoData,\n    applicationInfo\n]: [\n    Breadcrumb,\n    BreadcrumbConfiguration,\n    BreadcrumbItem,\n    SessionInfoData,\n    ApplicationInfo\n]): Breadcrumb {\n    // Take the override if it exists\n    if (override) {\n        // Although there's an override, we do want to assign the current item\n        // so each page dans set its own name rather than letting the override\n        // handle this.\n        if (currentItem) {\n            override.current = currentItem;\n        }\n        return override;\n    }\n\n    // Otherwise get a breadcrumb based on the configuration\n    if (configuration) {\n        return getBreadcrumb(\n            sessionInfoData,\n            configuration,\n            currentItem,\n            applicationInfo.configuration.portail.baseVdChUrl\n        );\n    }\n\n    // Only output a breadcrumb of there's a configuration or an override\n    return null;\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class BreadcrumbEventService {\n    private _breadcrumbOverride = new BehaviorSubject<Breadcrumb>(null);\n    private _breadcrumbConfiguration =\n        new BehaviorSubject<BreadcrumbConfiguration>(null);\n    private _currentBreadcrumbItem = new BehaviorSubject<BreadcrumbItem>(null);\n    private readonly _breadcrumbObservable: Observable<Breadcrumb>;\n    private readonly _neverConnectedBreadcrumbObservable: Observable<Breadcrumb>;\n\n    private _skipLeavingAlertBecauseDemandIsTransmitted = false;\n\n    constructor(\n        private sessionInfo: SessionInfo,\n        private applicationInfoService: ApplicationInfoService\n    ) {\n        // When the user might be connected\n        this._breadcrumbObservable = combineLatest([\n            this._breadcrumbOverride,\n            this._breadcrumbConfiguration,\n            this._currentBreadcrumbItem,\n            this.sessionInfo.data,\n            this.applicationInfoService.data\n        ]).pipe(\n            // Put together the breadcrumb, or just take the override if it exists.\n            map(mapBreadcrumb)\n        );\n\n        // If the user is NEVER connected (for instance in cyberlogin)\n        this._neverConnectedBreadcrumbObservable = combineLatest([\n            this._breadcrumbOverride,\n            this._breadcrumbConfiguration,\n            this._currentBreadcrumbItem,\n            of(null),\n            this.applicationInfoService.data\n        ]).pipe(\n            // Put together the breadcrumb, or just take the override if it exists.\n            map(mapBreadcrumb)\n        );\n    }\n\n    get skipLeavingAlertBecauseDemandIsTransmitted(): boolean {\n        return this._skipLeavingAlertBecauseDemandIsTransmitted;\n    }\n\n    set skipLeavingAlertBecauseDemandIsTransmitted(value: boolean) {\n        this._skipLeavingAlertBecauseDemandIsTransmitted = value;\n    }\n\n    /**\n     * Set the breadcrumb. This value will override any configuration injected with\n     * `setConfiguration`. Only use if you want to handle the breadcrumb manually.\n     * @param breadcrumb as Breadcrumb\n     */\n    setBreadcrumb(breadcrumb: Breadcrumb): void {\n        this._breadcrumbOverride.next(breadcrumb);\n    }\n\n    /**\n     * The breadcrumb value.\n     * @returns Observable<Breadcrumb>\n     */\n    breadcrumbObservable(): Observable<Breadcrumb> {\n        return this._breadcrumbObservable;\n    }\n\n    /**\n     * The breadcrumb value if never connected.\n     * @returns Observable<Breadcrumb>\n     */\n    neverConnectedBreadcrumbObservable(): Observable<Breadcrumb> {\n        return this._neverConnectedBreadcrumbObservable;\n    }\n\n    /**\n     * Set the current item. Used for accessibility purposes.\n     * @param currentItem as BreadcrumbItem\n     */\n    setCurrentBreadcrumb(currentItem: BreadcrumbItem): void {\n        this._currentBreadcrumbItem.next(currentItem);\n    }\n\n    /**\n     * Set the current breadcrumb configuration.\n     *\n     * Set to `null` to disable the breadcrumb.\n     * @param configuration as BreadcrumbConfiguration\n     */\n    setConfiguration(configuration: BreadcrumbConfiguration): void {\n        this._breadcrumbConfiguration.next(configuration);\n    }\n}\n"]}
@@ -72,7 +72,7 @@ export class FoehnTimeComponent extends FoehnInputStringComponent {
72
72
  useExisting: forwardRef(() => FoehnTimeComponent),
73
73
  multi: true
74
74
  }
75
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n ></foehn-input-number>\n </div>\n <div\n class=\"align-self-center position-relative\"\n *ngIf=\"!isEmpty() && (displayClearButton() | async)\"\n >\n <button\n [id]=\"buildId() + '_clearButton'\"\n type=\"button\"\n class=\"clear-button btn btn-link d-flex\"\n (click)=\"resetModel()\"\n >\n <foehn-icon-times\n [title]=\"\n 'foehn-input.clear-button.label' | fromDictionary\n \"\n ></foehn-icon-times>\n </button>\n </div>\n </div>\n </fieldset>\n</div>\n", styles: [":host ::ng-deep .clear-button.btn .svg-inline--fa{font-size:1.5rem;color:#000!important}:host ::ng-deep foehn-input-number div.form-group{margin-bottom:0!important}\n"], dependencies: [{ kind: "component", type: i1.FoehnIconTimesComponent, selector: "foehn-icon-times" }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i4.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "allowLeadingZero", "model"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.SdkDictionaryPipe, name: "fromDictionary" }] }); }
75
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n [allowLeadingZero]=\"true\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n <div\n class=\"align-self-center position-relative\"\n *ngIf=\"!isEmpty() && (displayClearButton() | async)\"\n >\n <button\n [id]=\"buildId() + '_clearButton'\"\n type=\"button\"\n class=\"clear-button btn btn-link d-flex\"\n (click)=\"resetModel()\"\n >\n <foehn-icon-times\n [title]=\"\n 'foehn-input.clear-button.label' | fromDictionary\n \"\n ></foehn-icon-times>\n </button>\n </div>\n </div>\n </fieldset>\n</div>\n", styles: [":host ::ng-deep .clear-button.btn .svg-inline--fa{font-size:1.5rem;color:#000!important}:host ::ng-deep foehn-input-number div.form-group{margin-bottom:0!important}\n"], dependencies: [{ kind: "component", type: i1.FoehnIconTimesComponent, selector: "foehn-icon-times" }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i4.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "allowLeadingZero", "model"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.SdkDictionaryPipe, name: "fromDictionary" }] }); }
76
76
  }
77
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.1", ngImport: i0, type: FoehnTimeComponent, decorators: [{
78
78
  type: Component,
@@ -82,8 +82,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.1", ngImpor
82
82
  useExisting: forwardRef(() => FoehnTimeComponent),
83
83
  multi: true
84
84
  }
85
- ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n ></foehn-input-number>\n </div>\n <div\n class=\"align-self-center position-relative\"\n *ngIf=\"!isEmpty() && (displayClearButton() | async)\"\n >\n <button\n [id]=\"buildId() + '_clearButton'\"\n type=\"button\"\n class=\"clear-button btn btn-link d-flex\"\n (click)=\"resetModel()\"\n >\n <foehn-icon-times\n [title]=\"\n 'foehn-input.clear-button.label' | fromDictionary\n \"\n ></foehn-icon-times>\n </button>\n </div>\n </div>\n </fieldset>\n</div>\n", styles: [":host ::ng-deep .clear-button.btn .svg-inline--fa{font-size:1.5rem;color:#000!important}:host ::ng-deep foehn-input-number div.form-group{margin-bottom:0!important}\n"] }]
85
+ ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n [allowLeadingZero]=\"true\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n <div\n class=\"align-self-center position-relative\"\n *ngIf=\"!isEmpty() && (displayClearButton() | async)\"\n >\n <button\n [id]=\"buildId() + '_clearButton'\"\n type=\"button\"\n class=\"clear-button btn btn-link d-flex\"\n (click)=\"resetModel()\"\n >\n <foehn-icon-times\n [title]=\"\n 'foehn-input.clear-button.label' | fromDictionary\n \"\n ></foehn-icon-times>\n </button>\n </div>\n </div>\n </fieldset>\n</div>\n", styles: [":host ::ng-deep .clear-button.btn .svg-inline--fa{font-size:1.5rem;color:#000!important}:host ::ng-deep foehn-input-number div.form-group{margin-bottom:0!important}\n"] }]
86
86
  }], ctorParameters: () => [], propDecorators: { childrenLabelSrOnly: [{
87
87
  type: Input
88
88
  }] } });
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-time.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.ts","../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input } from '@angular/core';\nimport { Observable, of } from 'rxjs';\n\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { FoehnInputStringComponent } from '../foehn-input/foehn-input-string.component';\nimport { DateHelper } from '../sdk-date/date.helper';\n\n@Component({\n    selector: 'foehn-input-time',\n    templateUrl: './foehn-input-time.component.html',\n    styleUrls: ['./foehn-input-time.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnTimeComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnTimeComponent extends FoehnInputStringComponent {\n    @Input()\n    childrenLabelSrOnly = false;\n    hour: string;\n    minute: string;\n\n    private dateHelper = new DateHelper();\n\n    constructor() {\n        super();\n        this.clearButton = true;\n    }\n\n    updateTime(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    onModelChange(value: string): void {\n        const timeParts = !!value ? value.split(':') : null;\n        if (timeParts && timeParts.length >= 2) {\n            this.hour = timeParts[0];\n            this.minute = timeParts[1];\n        } else if (!value) {\n            this.hour = null;\n            this.minute = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        const visible = this.clearButton && !this.disabled;\n        return of(visible);\n    }\n\n    resetModel(): void {\n        this.hour = null;\n        this.minute = null;\n        this.model_ = null;\n        this.updateTime();\n        this.handleUserInput();\n        this.focus();\n        this.markAsDirty();\n    }\n\n    isEmpty(): boolean {\n        return super.isEmpty(this.hour) && super.isEmpty(this.minute);\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (this.isEmpty()) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n\n        return `${this.dateHelper.leftPad(this.hour)}:${this.dateHelper.leftPad(\n            this.minute\n        )}`;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend\n            *ngIf=\"!!label\"\n            [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n        >\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_hours'\"\n                    [name]=\"name + '_hours'\"\n                    [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"24\"\n                    [(model)]=\"hour\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                    [hideStandardHelpText]=\"true\"\n                    [isLabelSrOnly]=\"childrenLabelSrOnly\"\n                    #entryComponent\n                ></foehn-input-number>\n            </div>\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_minutes'\"\n                    [name]=\"name + '_minutes'\"\n                    [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"59\"\n                    [(model)]=\"minute\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                    [hideStandardHelpText]=\"true\"\n                    [isLabelSrOnly]=\"childrenLabelSrOnly\"\n                ></foehn-input-number>\n            </div>\n            <div\n                class=\"align-self-center position-relative\"\n                *ngIf=\"!isEmpty() && (displayClearButton() | async)\"\n            >\n                <button\n                    [id]=\"buildId() + '_clearButton'\"\n                    type=\"button\"\n                    class=\"clear-button btn btn-link d-flex\"\n                    (click)=\"resetModel()\"\n                >\n                    <foehn-icon-times\n                        [title]=\"\n                            'foehn-input.clear-button.label' | fromDictionary\n                        \"\n                    ></foehn-icon-times>\n                </button>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-time.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.ts","../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input } from '@angular/core';\nimport { Observable, of } from 'rxjs';\n\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { FoehnInputStringComponent } from '../foehn-input/foehn-input-string.component';\nimport { DateHelper } from '../sdk-date/date.helper';\n\n@Component({\n    selector: 'foehn-input-time',\n    templateUrl: './foehn-input-time.component.html',\n    styleUrls: ['./foehn-input-time.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnTimeComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnTimeComponent extends FoehnInputStringComponent {\n    @Input()\n    childrenLabelSrOnly = false;\n    hour: string;\n    minute: string;\n\n    private dateHelper = new DateHelper();\n\n    constructor() {\n        super();\n        this.clearButton = true;\n    }\n\n    updateTime(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    onModelChange(value: string): void {\n        const timeParts = !!value ? value.split(':') : null;\n        if (timeParts && timeParts.length >= 2) {\n            this.hour = timeParts[0];\n            this.minute = timeParts[1];\n        } else if (!value) {\n            this.hour = null;\n            this.minute = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        const visible = this.clearButton && !this.disabled;\n        return of(visible);\n    }\n\n    resetModel(): void {\n        this.hour = null;\n        this.minute = null;\n        this.model_ = null;\n        this.updateTime();\n        this.handleUserInput();\n        this.focus();\n        this.markAsDirty();\n    }\n\n    isEmpty(): boolean {\n        return super.isEmpty(this.hour) && super.isEmpty(this.minute);\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (this.isEmpty()) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n\n        return `${this.dateHelper.leftPad(this.hour)}:${this.dateHelper.leftPad(\n            this.minute\n        )}`;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend\n            *ngIf=\"!!label\"\n            [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n        >\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_hours'\"\n                    [name]=\"name + '_hours'\"\n                    [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"24\"\n                    [(model)]=\"hour\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                    [hideStandardHelpText]=\"true\"\n                    [isLabelSrOnly]=\"childrenLabelSrOnly\"\n                    [allowLeadingZero]=\"true\"\n                    #entryComponent\n                ></foehn-input-number>\n            </div>\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_minutes'\"\n                    [name]=\"name + '_minutes'\"\n                    [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"59\"\n                    [(model)]=\"minute\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                    [hideStandardHelpText]=\"true\"\n                    [isLabelSrOnly]=\"childrenLabelSrOnly\"\n                    [allowLeadingZero]=\"true\"\n                ></foehn-input-number>\n            </div>\n            <div\n                class=\"align-self-center position-relative\"\n                *ngIf=\"!isEmpty() && (displayClearButton() | async)\"\n            >\n                <button\n                    [id]=\"buildId() + '_clearButton'\"\n                    type=\"button\"\n                    class=\"clear-button btn btn-link d-flex\"\n                    (click)=\"resetModel()\"\n                >\n                    <foehn-icon-times\n                        [title]=\"\n                            'foehn-input.clear-button.label' | fromDictionary\n                        \"\n                    ></foehn-icon-times>\n                </button>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}