@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 +20 -1
- package/UPGRADING_V17.md +30 -21
- package/dsivd-prestations-ng-17.0.0-beta.4.tgz +0 -0
- package/esm2022/foehn-breadcrumb/breadcrumb-event.service.mjs +22 -15
- package/esm2022/foehn-input-time/foehn-input-time.component.mjs +3 -3
- package/esm2022/gesdem-confirmation/gesdem-confirmation.component.mjs +14 -10
- package/esm2022/sdk-appinfo/application-info.mjs +7 -1
- package/esm2022/sdk-appinfo/application-info.service.mjs +21 -3
- package/esm2022/sdk-dictionary/default-dictionary.mjs +5 -3
- package/esm2022/sdk-redirect/iam-expired-interceptor.service.mjs +4 -6
- package/esm2022/sdk-redirect/redirect.component.mjs +26 -15
- package/fesm2022/dsivd-prestations-ng.mjs +279 -237
- package/fesm2022/dsivd-prestations-ng.mjs.map +1 -1
- package/foehn-breadcrumb/breadcrumb-event.service.d.ts +3 -1
- package/gesdem-confirmation/gesdem-confirmation.component.d.ts +2 -0
- package/package.json +1 -1
- package/sdk-appinfo/application-info.d.ts +3 -2
- package/sdk-redirect/redirect.component.d.ts +4 -2
- package/dsivd-prestations-ng-17.0.0-beta.3.tgz +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -14,7 +14,26 @@
|
|
|
14
14
|
|
|
15
15
|
- Added migration guide
|
|
16
16
|
|
|
17
|
-
## [16.5.
|
|
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
|
|
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+
|
|
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**.
|
|
123
|
-
|
|
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
|
|
166
|
-
|
|
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
|
-
-
|
|
171
|
-
-
|
|
172
|
-
-
|
|
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
|
-
|
|
187
|
-
`warning Deprecated: Use `provideRouter`or`RouterModule`/`RouterModule.forRoot` instead`
|
|
196
|
+
**`warning Deprecated: Use provideRouter or RouterModule/RouterModule.forRoot instead`**
|
|
188
197
|
|
|
189
|
-
|
|
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
|
|
|
Binary file
|
|
@@ -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:
|
|
11
|
-
descriptionPageBaseUrl:
|
|
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
|
|
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:
|
|
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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,aAAa,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AACtE,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAIrC,OAAO,EACH,UAAU,EAGb,MAAM,cAAc,CAAC;;;AAEtB,MAAM,cAAc,GAA4B;IAC5C,iBAAiB,EAAE,iBAAiB;IACpC,iBAAiB,EAAE,qBAAqB;IACxC,OAAO,EAAE,oBAAoB;IAC7B,sBAAsB,EAAE,qCAAqC;IAC7D,0FAA0F;IAC1F,cAAc,EAAE,IAAI;CACvB,CAAC;AAEF,+CAA+C;AAC/C,SAAS,yBAAyB,CAAC,EAC/B,OAAO,GAAG,cAAc,CAAC,OAAO,EAChC,sBAAsB,GAAG,cAAc,CAAC,sBAAsB,EAC9D,cAAc,GAAG,cAAc,CAAC,cAAc,EACxB;IACtB,MAAM,WAAW,GAAmB;QAChC,GAAG,EAAE,OAAO;QACZ,UAAU,EAAE,IAAI;QAChB,KAAK,EAAE,OAAO;KACjB,CAAC;IAEF,mFAAmF;IACnF,sFAAsF;IACtF,iCAAiC;IACjC,IAAI,CAAC,cAAc,EAAE,CAAC;QAClB,OAAO,CAAC,WAAW,CAAC,CAAC;IACzB,CAAC;IAED,OAAO;QACH,WAAW;QACX;YACI,iDAAiD;YACjD,GAAG,EAAE,GAAG,sBAAsB,GAAG,cAAc,EAAE;YACjD,UAAU,EAAE,IAAI;YAChB,KAAK,EAAE,8BAA8B;SACxC;KACJ,CAAC;AACN,CAAC;AAED,+CAA+C;AAC/C,SAAS,sBAAsB,CAC3B,EACI,iBAAiB,GAAG,cAAc,CAAC,iBAAiB,EAC9B,EAC1B,eAAgC;IAEhC,OAAO;QACH;YACI,GAAG,EAAE,iBAAiB;YACtB,UAAU,EAAE,IAAI;YAChB,KAAK,EAAE,eAAe,CAAC,WAAW;SACrC;KACJ,CAAC;AACN,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAS,aAAa,CAClB,eAAgC,EAChC,aAAsC,EACtC,WAA2B;IAE3B,8DAA8D;IAC9D,MAAM,gBAAgB,GAAG,CAAC,CAAC,eAAe,IAAI,CAAC,CAAC,eAAe,CAAC,OAAO,CAAC;IAExE,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;IAEpC,+EAA+E;IAC/E,UAAU,CAAC,eAAe,GAAG,gBAAgB;QACzC,CAAC,CAAC,sBAAsB,CAAC,aAAa,EAAE,eAAe,CAAC;QACxD,CAAC,CAAC,yBAAyB,CAAC,aAAa,CAAC,CAAC;IAE/C,mCAAmC;IACnC,UAAU,CAAC,OAAO,GAAG,WAAW,CAAC;IAEjC,OAAO,UAAU,CAAC;AACtB,CAAC;AAED,+CAA+C;AAC/C,SAAS,aAAa,CAAC,CACnB,QAAQ,EACR,aAAa,EACb,WAAW,EACX,eAAe,CAMlB;IACG,iCAAiC;IACjC,IAAI,QAAQ,EAAE,CAAC;QACX,sEAAsE;QACtE,sEAAsE;QACtE,eAAe;QACf,IAAI,WAAW,EAAE,CAAC;YACd,QAAQ,CAAC,OAAO,GAAG,WAAW,CAAC;QACnC,CAAC;QACD,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED,wDAAwD;IACxD,IAAI,aAAa,EAAE,CAAC;QAChB,OAAO,aAAa,CAAC,eAAe,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;IACtE,CAAC;IAED,qEAAqE;IACrE,OAAO,IAAI,CAAC;AAChB,CAAC;AAKD,MAAM,OAAO,sBAAsB;IAU/B,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;QATpC,wBAAmB,GAAG,IAAI,eAAe,CAAa,IAAI,CAAC,CAAC;QAC5D,6BAAwB,GAC5B,IAAI,eAAe,CAA0B,IAAI,CAAC,CAAC;QAC/C,2BAAsB,GAAG,IAAI,eAAe,CAAiB,IAAI,CAAC,CAAC;QAInE,gDAA2C,GAAG,KAAK,CAAC;QAGxD,mCAAmC;QACnC,IAAI,CAAC,qBAAqB,GAAG,aAAa,CAAC;YACvC,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,wBAAwB;YAC7B,IAAI,CAAC,sBAAsB;YAC3B,IAAI,CAAC,WAAW,CAAC,IAAI;SACxB,CAAC,CAAC,IAAI;QACH,uEAAuE;QACvE,GAAG,CAAC,aAAa,CAAC,CACrB,CAAC;QAEF,8DAA8D;QAC9D,IAAI,CAAC,mCAAmC,GAAG,aAAa,CAAC;YACrD,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,wBAAwB;YAC7B,IAAI,CAAC,sBAAsB;YAC3B,EAAE,CAAC,IAAI,CAAC;SACX,CAAC,CAAC,IAAI;QACH,uEAAuE;QACvE,GAAG,CAAC,aAAa,CAAC,CACrB,CAAC;IACN,CAAC;IAED,IAAI,0CAA0C;QAC1C,OAAO,IAAI,CAAC,2CAA2C,CAAC;IAC5D,CAAC;IAED,IAAI,0CAA0C,CAAC,KAAc;QACzD,IAAI,CAAC,2CAA2C,GAAG,KAAK,CAAC;IAC7D,CAAC;IAED;;;;OAIG;IACH,aAAa,CAAC,UAAsB;QAChC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC9C,CAAC;IAED;;;OAGG;IACH,oBAAoB;QAChB,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACtC,CAAC;IAED;;;OAGG;IACH,kCAAkC;QAC9B,OAAO,IAAI,CAAC,mCAAmC,CAAC;IACpD,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,WAA2B;QAC5C,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAClD,CAAC;IAED;;;;;OAKG;IACH,gBAAgB,CAAC,aAAsC;QACnD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACtD,CAAC;8GAnFQ,sBAAsB;kHAAtB,sBAAsB,cAFnB,MAAM;;2FAET,sBAAsB;kBAHlC,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","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"]}
|