@dsivd/prestations-ng 16.2.1-beta.1 → 16.2.1-beta.2
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 +5 -0
- package/UPGRADING_V16.md +3 -55
- package/dsivd-prestations-ng-v16.2.1-beta.2.tgz +0 -0
- package/esm2020/foehn-input/foehn-input-number.component.mjs +8 -3
- package/esm2020/foehn-input-date/foehn-input-date.component.mjs +1 -1
- package/esm2020/foehn-input-time/foehn-input-time.component.mjs +1 -1
- package/esm2020/foehn-nav13/foehn-input-nav13.component.mjs +3 -3
- package/fesm2015/dsivd-prestations-ng.mjs +11 -6
- package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
- package/fesm2020/dsivd-prestations-ng.mjs +11 -6
- package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
- package/foehn-input/foehn-input-number.component.d.ts +2 -1
- package/package.json +1 -1
- package/dsivd-prestations-ng-v16.2.1-beta.1.tgz +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -31,6 +31,11 @@ A change is considered **breaking** if you have to change your code or update yo
|
|
|
31
31
|
|
|
32
32
|
## [16.2.1]
|
|
33
33
|
|
|
34
|
+
### Added
|
|
35
|
+
|
|
36
|
+
- [foehn-input-number](projects/prestations-ng/src/foehn-input/foehn-input-number.component.ts)
|
|
37
|
+
- add `@Input() allowLeadingZero = false` to specify if we allow leading `0` such as NAVS13 numbers
|
|
38
|
+
|
|
34
39
|
### Updated
|
|
35
40
|
|
|
36
41
|
- [breadcrumb-event.service.ts](projects/prestations-ng/src/foehn-breadcrumb/breadcrumb-event.service.ts)
|
package/UPGRADING_V16.md
CHANGED
|
@@ -15,23 +15,15 @@ Follow [our migration guide](ESLINT_MIGRATION_GUIDE.md) to migrate your project
|
|
|
15
15
|
|
|
16
16
|
##### If you are using our `slave-apps`
|
|
17
17
|
|
|
18
|
-
Be sure to update your `slave-apps` git repository and
|
|
18
|
+
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 node16 by default, verify by executing :
|
|
19
19
|
|
|
20
20
|
```bash
|
|
21
|
-
|
|
21
|
+
node -v
|
|
22
22
|
```
|
|
23
23
|
|
|
24
|
-
which should switch your node version to 16+
|
|
25
|
-
|
|
26
24
|
##### If you are NOT using our `slave-apps`
|
|
27
25
|
|
|
28
|
-
Be sure to use a node version 16
|
|
29
|
-
|
|
30
|
-
```bash
|
|
31
|
-
node --version
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
which should print out a version 16+ otherwise, install a node 16+
|
|
26
|
+
Be sure to use a node version 16+ and use the same command as above.
|
|
35
27
|
|
|
36
28
|
#### In your project
|
|
37
29
|
|
|
@@ -45,47 +37,6 @@ Update your `package.json` to specify node engine
|
|
|
45
37
|
}
|
|
46
38
|
```
|
|
47
39
|
|
|
48
|
-
#### In your build
|
|
49
|
-
|
|
50
|
-
- Open your `jenkins` folder and update your jenkins files.
|
|
51
|
-
- Define a variable if it does not already exist and add `nodeVersion: 16` then pass it on to the build.
|
|
52
|
-
|
|
53
|
-
##### UT folder
|
|
54
|
-
|
|
55
|
-
```groovy
|
|
56
|
-
def args = [
|
|
57
|
-
nodeVersion: 16
|
|
58
|
-
]
|
|
59
|
-
|
|
60
|
-
stage('Build pipeline') {
|
|
61
|
-
buildPipeline(args)
|
|
62
|
-
}
|
|
63
|
-
```
|
|
64
|
-
|
|
65
|
-
##### devex > snap folder
|
|
66
|
-
|
|
67
|
-
```groovy
|
|
68
|
-
def buildArgs = [
|
|
69
|
-
nodeVersion : 16
|
|
70
|
-
]
|
|
71
|
-
|
|
72
|
-
stage('Snap2Devex Skeleton') {
|
|
73
|
-
snap2Devex(buildArgs)
|
|
74
|
-
}
|
|
75
|
-
```
|
|
76
|
-
|
|
77
|
-
##### devex > stable folder
|
|
78
|
-
|
|
79
|
-
```groovy
|
|
80
|
-
def args = [
|
|
81
|
-
nodeVersion : 16
|
|
82
|
-
]
|
|
83
|
-
|
|
84
|
-
stage('Stable2Devex') {
|
|
85
|
-
stable2Devex(args)
|
|
86
|
-
}
|
|
87
|
-
```
|
|
88
|
-
|
|
89
40
|
### Updating Angular
|
|
90
41
|
|
|
91
42
|
`prestations-ng` **v16+** now supports **Angular v15**. You can follow the Angular update guide
|
|
@@ -399,7 +350,6 @@ Remove `chromium-headless` label attribute on your args.
|
|
|
399
350
|
|
|
400
351
|
```diff
|
|
401
352
|
def args = [
|
|
402
|
-
nodeVersion: 16,
|
|
403
353
|
- label: 'chromium-headless'
|
|
404
354
|
]
|
|
405
355
|
```
|
|
@@ -408,7 +358,6 @@ def args = [
|
|
|
408
358
|
|
|
409
359
|
```diff
|
|
410
360
|
def buildArgs = [
|
|
411
|
-
nodeVersion : 16,
|
|
412
361
|
- label: 'chromium-headless'
|
|
413
362
|
]
|
|
414
363
|
```
|
|
@@ -417,7 +366,6 @@ def buildArgs = [
|
|
|
417
366
|
|
|
418
367
|
```diff
|
|
419
368
|
def args = [
|
|
420
|
-
nodeVersion : 16,
|
|
421
369
|
- label: 'chromium-headless'
|
|
422
370
|
]
|
|
423
371
|
```
|
|
Binary file
|
|
@@ -23,6 +23,7 @@ export class FoehnInputNumberComponent extends FoehnInputStringComponent {
|
|
|
23
23
|
this.hideStandardHelpText = false;
|
|
24
24
|
this.maxDecimalCount = 2;
|
|
25
25
|
this.allowFreeInput = false;
|
|
26
|
+
this.allowLeadingZero = false;
|
|
26
27
|
}
|
|
27
28
|
get model() {
|
|
28
29
|
// If the setter is overridden, it's critical to override the getter too.
|
|
@@ -154,7 +155,9 @@ export class FoehnInputNumberComponent extends FoehnInputStringComponent {
|
|
|
154
155
|
const noCommaString = this.replaceCommaWithDot(value);
|
|
155
156
|
const cleanDecimals = this.cleanDecimals(noCommaString);
|
|
156
157
|
const cleanNonNumericCharacters = this.removeNonNumericCharacters(cleanDecimals);
|
|
157
|
-
const cleanNumber = this.
|
|
158
|
+
const cleanNumber = !this.allowLeadingZero
|
|
159
|
+
? this.removeLeadingZero(cleanNonNumericCharacters, this.allowDecimal)
|
|
160
|
+
: cleanNonNumericCharacters;
|
|
158
161
|
if (cleanNumber && cleanNumber.length) {
|
|
159
162
|
return cleanNumber.substring(0, this.getMaxLength());
|
|
160
163
|
}
|
|
@@ -281,7 +284,7 @@ export class FoehnInputNumberComponent extends FoehnInputStringComponent {
|
|
|
281
284
|
}
|
|
282
285
|
}
|
|
283
286
|
FoehnInputNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FoehnInputNumberComponent, deps: [{ token: i1.CurrencyHelper }, { token: i2.SdkDictionaryService }], target: i0.ɵɵFactoryTarget.Component });
|
|
284
|
-
FoehnInputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: FoehnInputNumberComponent, selector: "foehn-input-number", inputs: { hideStandardHelpText: "hideStandardHelpText", allowDecimal: "allowDecimal", allowNegative: "allowNegative", maxDecimalCount: "maxDecimalCount", allowFreeInput: "allowFreeInput", model: "model" }, providers: [
|
|
287
|
+
FoehnInputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: FoehnInputNumberComponent, selector: "foehn-input-number", inputs: { hideStandardHelpText: "hideStandardHelpText", allowDecimal: "allowDecimal", allowNegative: "allowNegative", maxDecimalCount: "maxDecimalCount", allowFreeInput: "allowFreeInput", allowLeadingZero: "allowLeadingZero", model: "model" }, providers: [
|
|
285
288
|
{
|
|
286
289
|
provide: FoehnInputComponent,
|
|
287
290
|
useExisting: forwardRef(() => FoehnInputNumberComponent),
|
|
@@ -307,7 +310,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
307
310
|
type: Input
|
|
308
311
|
}], allowFreeInput: [{
|
|
309
312
|
type: Input
|
|
313
|
+
}], allowLeadingZero: [{
|
|
314
|
+
type: Input
|
|
310
315
|
}], model: [{
|
|
311
316
|
type: Input
|
|
312
317
|
}] } });
|
|
313
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-number.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input/foehn-input-number.component.ts","../../../../projects/prestations-ng/src/foehn-input/foehn-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    forwardRef,\n    Input,\n    OnChanges,\n    OnInit,\n    SimpleChanges\n} from '@angular/core';\n\n// eslint-disable-next-line import/no-cycle\nimport {\n    formatDecimalCurrency,\n    formatNonDecimalCurrency,\n    formatNumberAsGiven\n} from '../directives/currency-formatter.directive';\nimport {\n    CurrencyHelper,\n    DECIMALS_SEPARATOR\n} from '../sdk-currency/currency.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { FoehnInputComponent } from './foehn-input.component';\nimport { FoehnInputStringComponent } from './foehn-input-string.component';\nimport {\n    CLEAN_DECIMAL_NUMBERS_PATTERN,\n    CLEAN_NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN,\n    CLEAN_NEGATIVE_NUMBERS_PATTERN,\n    CLEAN_NUMBERS_PATTERN,\n    DECIMAL_NUMBERS_PATTERN,\n    HTML_DECIMAL_PATTERN,\n    HTML_NO_DECIMAL_PATTERN,\n    NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN,\n    NEGATIVE_NUMBERS_PATTERN,\n    NUMBERS_PATTERN\n} from './pattern.const';\n\nconst isDefined = (value: number): boolean => value === 0 || !!value;\n\n@Component({\n    selector: 'foehn-input-number',\n    templateUrl: './foehn-input.component.html',\n    styleUrls: ['./foehn-input.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputNumberComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputNumberComponent\n    extends FoehnInputStringComponent\n    implements OnInit, OnChanges {\n    @Input()\n    hideStandardHelpText = false;\n\n    @Input()\n    allowDecimal: boolean;\n\n    @Input()\n    allowNegative: boolean;\n\n    @Input()\n    maxDecimalCount = 2;\n\n    @Input()\n    allowFreeInput = false;\n\n    private initialHelpText: string;\n\n    constructor(\n        private currencyHelper: CurrencyHelper,\n        private dictionaryService: SdkDictionaryService\n    ) {\n        super();\n    }\n\n    get model(): string {\n        // If the setter is overridden, it's critical to override the getter too.\n        return this.model_;\n    }\n\n    @Input()\n    set model(value: string) {\n        // This doesn't trigger the component's version of updateNgModel strait away as this might\n        // be called before allowDecimal or allowNegative are properly set (before the init lifecycle\n        // of the component). This is critical to not re-format the input before the OnInit, otherwise\n        // we might end up with invalid value displayed to the user. this.updateNgModel is called implicitly\n        // as super.updateNgModel will emit a change on this.modelChange.\n        // FIXME this is a hack and should be refactored.\n        super.updateNgModel(value);\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this.type = 'text';\n\n        // Pattern used only for numpad trigger on mobile phones\n        this.pattern = this.allowDecimal\n            ? HTML_DECIMAL_PATTERN\n            : HTML_NO_DECIMAL_PATTERN;\n\n        this.maxlength = !!this.maxlength ? this.maxlength : 9;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const hasChanges = Object.keys(changes)\n            .filter(k => k !== 'model')\n            .map(k => changes[k])\n            .find(change => change.currentValue !== change.previousValue);\n\n        const helpTextHasChanged =\n            changes.helpText?.currentValue !== changes.helpText?.previousValue;\n\n        if (helpTextHasChanged) {\n            this.initialHelpText = changes.helpText.currentValue;\n        }\n\n        if (hasChanges) {\n            this.manageHelpText();\n        }\n    }\n\n    getMaxLength(): number {\n        if (this.allowFreeInput) {\n            return null;\n        }\n        return super.getMaxLength();\n    }\n\n    updateNgModel(value: string): void {\n        if (this.isEmpty(value)) {\n            this.setToEmpty(value);\n            return;\n        }\n        const isDeleting = value.toString()?.length < this.model?.length;\n\n        let cleanNumber;\n        if (!this.allowFreeInput) {\n            cleanNumber = this.getCleanNumber(value.toString());\n            const isModelValid = this.isModelValid(cleanNumber);\n            if (!isModelValid && !isDeleting) {\n                cleanNumber = this.model;\n            }\n        } else {\n            const noCommaString = this.replaceCommaWithDot(value);\n            cleanNumber =\n                noCommaString && typeof noCommaString === 'string'\n                    ? noCommaString.replace(\n                          CLEAN_NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN,\n                          ''\n                      )\n                    : noCommaString;\n            // check that it is a number in any of its possible form\n            // to avoid -3.14-23--534\n            if (\n                !NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN.test(cleanNumber) &&\n                !isDeleting\n            ) {\n                cleanNumber = this.model;\n            }\n        }\n\n        super.updateNgModel(cleanNumber);\n\n        // Need to update HTML input value because we let user input what he wants and then we clean model\n        this.updateInputElementValue(cleanNumber);\n    }\n\n    /**\n     * To be used for post-formatting by directives.\n     *\n     * @param value of model\n     */\n    forceUpdateNgModel(value: string): void {\n        this.model_ = value;\n        this.updateInputElementValue(value);\n    }\n\n    private isStringAValidNumber(value: string): boolean {\n        return this.getValidationRegex().test(value);\n    }\n\n    private isModelValid(value: string): boolean {\n        return this.isStringAValidNumber(value);\n    }\n\n    private getValidationRegex(isForClean: boolean = false): RegExp {\n        if (this.allowDecimal || this.allowNegative) {\n            // Allow decimal and negative\n            if (this.allowDecimal && this.allowNegative) {\n                return !isForClean\n                    ? NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN\n                    : CLEAN_NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN;\n            }\n            // Allow decimal\n            if (this.allowDecimal) {\n                return !isForClean\n                    ? DECIMAL_NUMBERS_PATTERN\n                    : CLEAN_DECIMAL_NUMBERS_PATTERN;\n            }\n            // Allow negative\n            return !isForClean\n                ? NEGATIVE_NUMBERS_PATTERN\n                : CLEAN_NEGATIVE_NUMBERS_PATTERN;\n        }\n        return !isForClean ? NUMBERS_PATTERN : CLEAN_NUMBERS_PATTERN;\n    }\n\n    private replaceCommaWithDot(value: string): string {\n        return value && typeof value === 'string'\n            ? value.replace(new RegExp(',', 'g'), DECIMALS_SEPARATOR)\n            : value;\n    }\n\n    private removeNonNumericCharacters(value: string): string {\n        return value && typeof value === 'string'\n            ? value.replace(this.getValidationRegex(true), '')\n            : value;\n    }\n\n    private cleanDecimals(\n        value: string,\n        separator: string = DECIMALS_SEPARATOR\n    ): string {\n        if (!value || !this.allowDecimal || !value.includes(separator)) {\n            return value;\n        }\n\n        const [intg, dec] = value.split(separator);\n        const cleanDec = dec.substring(0, this.maxDecimalCount);\n\n        return intg + separator + cleanDec;\n    }\n\n    private getCleanNumber(value: string): string {\n        const noCommaString = this.replaceCommaWithDot(value);\n        const cleanDecimals = this.cleanDecimals(noCommaString);\n        const cleanNonNumericCharacters = this.removeNonNumericCharacters(\n            cleanDecimals\n        );\n        const cleanNumber = this.removeLeadingZero(\n            cleanNonNumericCharacters,\n            this.allowDecimal\n        );\n\n        if (cleanNumber && cleanNumber.length) {\n            return cleanNumber.substring(0, this.getMaxLength());\n        }\n\n        return cleanNumber;\n    }\n\n    private updateInputElementValue(cleanNumber: string): void {\n        if (!this.inputElement) {\n            // No need to update the native element if it doesn't yet exist.\n            return;\n        }\n\n        const inputElemValue = this.inputElement.nativeElement.value;\n        if (inputElemValue !== cleanNumber) {\n            // Need to update HTML input value because we let user input what he wants and then we clean model\n            this.inputElement.nativeElement.value = cleanNumber;\n        }\n    }\n\n    private setToEmpty(value: string): void {\n        // Empty means null, otherwise the backend doesn't handle numbers properly. We have to keep 'undefined'\n        // if 'undefined' otherwise Angular complains about the value of the model being changed without updating\n        // the view.\n        const emptyValue = value === '' ? null : value;\n        super.updateNgModel(emptyValue);\n        this.updateInputElementValue(emptyValue);\n    }\n\n    private manageHelpText(): void {\n        if (!!this.hideStandardHelpText) {\n            this.helpText = this.initialHelpText;\n            return;\n        }\n\n        if (!this.allowFreeInput) {\n            if (isDefined(this.min) && isDefined(this.max)) {\n                if (!!this.initialHelpText?.length) {\n                    this.helpText = `${this.initialHelpText}<br/>`;\n                } else {\n                    this.helpText = '';\n                }\n                this.helpText += this.dictionaryService.getKeySync(\n                    'foehn-input-number.standard-help-text.label',\n                    {\n                        minValue: formatNumberAsGiven(this.min.toString()),\n                        maxValue: formatNumberAsGiven(this.max.toString())\n                    }\n                );\n            }\n            return;\n        }\n\n        if (!!this.initialHelpText?.length) {\n            this.helpText = `${this.initialHelpText}<br/>`;\n        } else {\n            this.helpText = '';\n        }\n\n        const maxIntegerCount = this.allowDecimal\n            ? this.maxlength - this.maxDecimalCount - 1\n            : this.maxlength;\n\n        let maxAsString;\n        if (!!this.max) {\n            maxAsString = this.max;\n        } else {\n            maxAsString = '9'.repeat(maxIntegerCount);\n            if (this.allowDecimal) {\n                maxAsString += `.${'9'.repeat(this.maxDecimalCount)}`;\n            }\n        }\n\n        let minAsString;\n        if (this.min) {\n            minAsString = this.min;\n        } else {\n            minAsString = this.allowNegative\n                ? `-${'9'.repeat(maxIntegerCount - 1)}`\n                : '0';\n            if (this.allowDecimal) {\n                minAsString += this.allowNegative\n                    ? `.${'9'.repeat(this.maxDecimalCount || 0)}`\n                    : `.${'0'.repeat(this.maxDecimalCount || 0)}`;\n            }\n        }\n\n        this.helpText += this.dictionaryService.getKeySync(\n            'foehn-input-number.standard-help-text.label',\n            {\n                minValue: this.formatValue(minAsString),\n                maxValue: this.formatValue(maxAsString)\n            }\n        );\n    }\n\n    private formatValue(value: string | number): string {\n        if (this.allowDecimal) {\n            return formatDecimalCurrency(\n                value?.toString(),\n                this.maxDecimalCount,\n                this.maxlength,\n                this.allowFreeInput\n            );\n        }\n        return formatNonDecimalCurrency(value?.toString());\n    }\n\n    private removeLeadingZero(\n        value: string,\n        allowDecimal: boolean = false\n    ): string {\n        if (value === undefined || value === null) {\n            return null;\n        }\n\n        // Never clean first character because it could be only \"0\" or \"-\"\n        if (value.length === 1) {\n            return value;\n        }\n\n        // For decimal values, we can't remove \"0\" from \"0.\" or \"-0.\" because we can't predict what comes after the dot\n        if (allowDecimal && (value === '0.' || value === '-0.')) {\n            return value;\n        }\n\n        // Remove \"0\" from \"-0\" for forbidden decimal values\n        if (\n            !allowDecimal &&\n            value.includes('-') &&\n            value.length === 2 &&\n            value.substring(1) === '0'\n        ) {\n            return value.substring(0, 1);\n        }\n\n        // Clean positive or negative integer\n        if (!value.includes(DECIMALS_SEPARATOR)) {\n            // Remove \"0\" from \"01\", \"02\"... numbers\n            if (\n                !value.includes('-') &&\n                value.length === 2 &&\n                value.substring(0, 1) === '0'\n            ) {\n                return value.substring(1);\n            }\n\n            // Remove \"0\" from \"-01\", \"-02\"... numbers\n            if (\n                value.includes('-') &&\n                value.length === 3 &&\n                value.substring(1, 2) === '0'\n            ) {\n                return value.substring(0, 1) + value.substring(2);\n            }\n        }\n\n        return value;\n    }\n}\n","<div\n    class=\"form-group clearable-input-form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <div class=\"d-flex justify-content-between\">\n        <label\n            style=\"display: inline-block\"\n            [attr.for]=\"buildChildId()\"\n            *ngIf=\"label && type !== 'hidden'\"\n            [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\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        </label>\n\n        <foehn-help-modal\n            class=\"removePaddingButton\"\n            *ngIf=\"!!helpModal\"\n            [modalContent]=\"helpModal\"\n        ></foehn-help-modal>\n    </div>\n\n    <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n    <small\n        *ngIf=\"helpText && type !== 'hidden'\"\n        [attr.id]=\"buildChildId() + 'Help'\"\n        class=\"form-text text-secondary\"\n        [innerHTML]=\"helpText\"\n    ></small>\n\n    <ng-content></ng-content>\n\n    <input\n        [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n        [class.clearable-input]=\"displayClearButton() | async\"\n        class=\"form-control\"\n        [name]=\"name || label\"\n        [attr.maxlength]=\"getMaxLength()\"\n        [attr.autocomplete]=\"getAutoComplete()\"\n        [attr.autocapitalize]=\"autocapitalize\"\n        [attr.disabled]=\"disabled ? 'disabled' : null\"\n        [attr.type]=\"type\"\n        [attr.pattern]=\"pattern\"\n        [attr.min]=\"min\"\n        [attr.max]=\"max\"\n        [attr.id]=\"buildChildId()\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n        [attr.aria-required]=\"required || null\"\n        [ngModel]=\"model\"\n        (paste)=\"onPaste($event)\"\n        (ngModelChange)=\"updateNgModel($event)\"\n        (input)=\"handleChange(entryComponent.value)\"\n        (keydown)=\"onKeydown($event)\"\n        (blur)=\"onBlur($event)\"\n        (focus)=\"onFocus($event)\"\n        #entryComponent\n    />\n\n    <button\n        type=\"button\"\n        [id]=\"buildChildId() + 'ClearButton'\"\n        *ngIf=\"displayClearButton() | async\"\n        class=\"clearable-input-clear-button btn\"\n        (click)=\"onClear()\"\n    >\n        <foehn-icon-times\n            class=\"clearable-input-clear-button-icon\"\n            title=\"Réinitialiser le champs\"\n        ></foehn-icon-times>\n    </button>\n</div>\n"]}
|
|
318
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-number.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input/foehn-input-number.component.ts","../../../../projects/prestations-ng/src/foehn-input/foehn-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    forwardRef,\n    Input,\n    OnChanges,\n    OnInit,\n    SimpleChanges\n} from '@angular/core';\n\n// eslint-disable-next-line import/no-cycle\nimport {\n    formatDecimalCurrency,\n    formatNonDecimalCurrency,\n    formatNumberAsGiven\n} from '../directives/currency-formatter.directive';\nimport {\n    CurrencyHelper,\n    DECIMALS_SEPARATOR\n} from '../sdk-currency/currency.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { FoehnInputComponent } from './foehn-input.component';\nimport { FoehnInputStringComponent } from './foehn-input-string.component';\nimport {\n    CLEAN_DECIMAL_NUMBERS_PATTERN,\n    CLEAN_NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN,\n    CLEAN_NEGATIVE_NUMBERS_PATTERN,\n    CLEAN_NUMBERS_PATTERN,\n    DECIMAL_NUMBERS_PATTERN,\n    HTML_DECIMAL_PATTERN,\n    HTML_NO_DECIMAL_PATTERN,\n    NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN,\n    NEGATIVE_NUMBERS_PATTERN,\n    NUMBERS_PATTERN\n} from './pattern.const';\n\nconst isDefined = (value: number): boolean => value === 0 || !!value;\n\n@Component({\n    selector: 'foehn-input-number',\n    templateUrl: './foehn-input.component.html',\n    styleUrls: ['./foehn-input.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputNumberComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputNumberComponent\n    extends FoehnInputStringComponent\n    implements OnInit, OnChanges {\n    @Input()\n    hideStandardHelpText = false;\n\n    @Input()\n    allowDecimal: boolean;\n\n    @Input()\n    allowNegative: boolean;\n\n    @Input()\n    maxDecimalCount = 2;\n\n    @Input()\n    allowFreeInput = false;\n\n    @Input()\n    allowLeadingZero = false;\n\n    private initialHelpText: string;\n\n    constructor(\n        private currencyHelper: CurrencyHelper,\n        private dictionaryService: SdkDictionaryService\n    ) {\n        super();\n    }\n\n    get model(): string {\n        // If the setter is overridden, it's critical to override the getter too.\n        return this.model_;\n    }\n\n    @Input()\n    set model(value: string) {\n        // This doesn't trigger the component's version of updateNgModel strait away as this might\n        // be called before allowDecimal or allowNegative are properly set (before the init lifecycle\n        // of the component). This is critical to not re-format the input before the OnInit, otherwise\n        // we might end up with invalid value displayed to the user. this.updateNgModel is called implicitly\n        // as super.updateNgModel will emit a change on this.modelChange.\n        // FIXME this is a hack and should be refactored.\n        super.updateNgModel(value);\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this.type = 'text';\n\n        // Pattern used only for numpad trigger on mobile phones\n        this.pattern = this.allowDecimal\n            ? HTML_DECIMAL_PATTERN\n            : HTML_NO_DECIMAL_PATTERN;\n\n        this.maxlength = !!this.maxlength ? this.maxlength : 9;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const hasChanges = Object.keys(changes)\n            .filter(k => k !== 'model')\n            .map(k => changes[k])\n            .find(change => change.currentValue !== change.previousValue);\n\n        const helpTextHasChanged =\n            changes.helpText?.currentValue !== changes.helpText?.previousValue;\n\n        if (helpTextHasChanged) {\n            this.initialHelpText = changes.helpText.currentValue;\n        }\n\n        if (hasChanges) {\n            this.manageHelpText();\n        }\n    }\n\n    getMaxLength(): number {\n        if (this.allowFreeInput) {\n            return null;\n        }\n        return super.getMaxLength();\n    }\n\n    updateNgModel(value: string): void {\n        if (this.isEmpty(value)) {\n            this.setToEmpty(value);\n            return;\n        }\n        const isDeleting = value.toString()?.length < this.model?.length;\n\n        let cleanNumber;\n        if (!this.allowFreeInput) {\n            cleanNumber = this.getCleanNumber(value.toString());\n            const isModelValid = this.isModelValid(cleanNumber);\n            if (!isModelValid && !isDeleting) {\n                cleanNumber = this.model;\n            }\n        } else {\n            const noCommaString = this.replaceCommaWithDot(value);\n            cleanNumber =\n                noCommaString && typeof noCommaString === 'string'\n                    ? noCommaString.replace(\n                          CLEAN_NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN,\n                          ''\n                      )\n                    : noCommaString;\n            // check that it is a number in any of its possible form\n            // to avoid -3.14-23--534\n            if (\n                !NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN.test(cleanNumber) &&\n                !isDeleting\n            ) {\n                cleanNumber = this.model;\n            }\n        }\n\n        super.updateNgModel(cleanNumber);\n\n        // Need to update HTML input value because we let user input what he wants and then we clean model\n        this.updateInputElementValue(cleanNumber);\n    }\n\n    /**\n     * To be used for post-formatting by directives.\n     *\n     * @param value of model\n     */\n    forceUpdateNgModel(value: string): void {\n        this.model_ = value;\n        this.updateInputElementValue(value);\n    }\n\n    private isStringAValidNumber(value: string): boolean {\n        return this.getValidationRegex().test(value);\n    }\n\n    private isModelValid(value: string): boolean {\n        return this.isStringAValidNumber(value);\n    }\n\n    private getValidationRegex(isForClean: boolean = false): RegExp {\n        if (this.allowDecimal || this.allowNegative) {\n            // Allow decimal and negative\n            if (this.allowDecimal && this.allowNegative) {\n                return !isForClean\n                    ? NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN\n                    : CLEAN_NEGATIVE_AND_DECIMAL_NUMBERS_PATTERN;\n            }\n            // Allow decimal\n            if (this.allowDecimal) {\n                return !isForClean\n                    ? DECIMAL_NUMBERS_PATTERN\n                    : CLEAN_DECIMAL_NUMBERS_PATTERN;\n            }\n            // Allow negative\n            return !isForClean\n                ? NEGATIVE_NUMBERS_PATTERN\n                : CLEAN_NEGATIVE_NUMBERS_PATTERN;\n        }\n        return !isForClean ? NUMBERS_PATTERN : CLEAN_NUMBERS_PATTERN;\n    }\n\n    private replaceCommaWithDot(value: string): string {\n        return value && typeof value === 'string'\n            ? value.replace(new RegExp(',', 'g'), DECIMALS_SEPARATOR)\n            : value;\n    }\n\n    private removeNonNumericCharacters(value: string): string {\n        return value && typeof value === 'string'\n            ? value.replace(this.getValidationRegex(true), '')\n            : value;\n    }\n\n    private cleanDecimals(\n        value: string,\n        separator: string = DECIMALS_SEPARATOR\n    ): string {\n        if (!value || !this.allowDecimal || !value.includes(separator)) {\n            return value;\n        }\n\n        const [intg, dec] = value.split(separator);\n        const cleanDec = dec.substring(0, this.maxDecimalCount);\n\n        return intg + separator + cleanDec;\n    }\n\n    private getCleanNumber(value: string): string {\n        const noCommaString = this.replaceCommaWithDot(value);\n        const cleanDecimals = this.cleanDecimals(noCommaString);\n        const cleanNonNumericCharacters = this.removeNonNumericCharacters(\n            cleanDecimals\n        );\n        const cleanNumber = !this.allowLeadingZero\n            ? this.removeLeadingZero(\n                  cleanNonNumericCharacters,\n                  this.allowDecimal\n              )\n            : cleanNonNumericCharacters;\n\n        if (cleanNumber && cleanNumber.length) {\n            return cleanNumber.substring(0, this.getMaxLength());\n        }\n\n        return cleanNumber;\n    }\n\n    private updateInputElementValue(cleanNumber: string): void {\n        if (!this.inputElement) {\n            // No need to update the native element if it doesn't yet exist.\n            return;\n        }\n\n        const inputElemValue = this.inputElement.nativeElement.value;\n        if (inputElemValue !== cleanNumber) {\n            // Need to update HTML input value because we let user input what he wants and then we clean model\n            this.inputElement.nativeElement.value = cleanNumber;\n        }\n    }\n\n    private setToEmpty(value: string): void {\n        // Empty means null, otherwise the backend doesn't handle numbers properly. We have to keep 'undefined'\n        // if 'undefined' otherwise Angular complains about the value of the model being changed without updating\n        // the view.\n        const emptyValue = value === '' ? null : value;\n        super.updateNgModel(emptyValue);\n        this.updateInputElementValue(emptyValue);\n    }\n\n    private manageHelpText(): void {\n        if (!!this.hideStandardHelpText) {\n            this.helpText = this.initialHelpText;\n            return;\n        }\n\n        if (!this.allowFreeInput) {\n            if (isDefined(this.min) && isDefined(this.max)) {\n                if (!!this.initialHelpText?.length) {\n                    this.helpText = `${this.initialHelpText}<br/>`;\n                } else {\n                    this.helpText = '';\n                }\n                this.helpText += this.dictionaryService.getKeySync(\n                    'foehn-input-number.standard-help-text.label',\n                    {\n                        minValue: formatNumberAsGiven(this.min.toString()),\n                        maxValue: formatNumberAsGiven(this.max.toString())\n                    }\n                );\n            }\n            return;\n        }\n\n        if (!!this.initialHelpText?.length) {\n            this.helpText = `${this.initialHelpText}<br/>`;\n        } else {\n            this.helpText = '';\n        }\n\n        const maxIntegerCount = this.allowDecimal\n            ? this.maxlength - this.maxDecimalCount - 1\n            : this.maxlength;\n\n        let maxAsString;\n        if (!!this.max) {\n            maxAsString = this.max;\n        } else {\n            maxAsString = '9'.repeat(maxIntegerCount);\n            if (this.allowDecimal) {\n                maxAsString += `.${'9'.repeat(this.maxDecimalCount)}`;\n            }\n        }\n\n        let minAsString;\n        if (this.min) {\n            minAsString = this.min;\n        } else {\n            minAsString = this.allowNegative\n                ? `-${'9'.repeat(maxIntegerCount - 1)}`\n                : '0';\n            if (this.allowDecimal) {\n                minAsString += this.allowNegative\n                    ? `.${'9'.repeat(this.maxDecimalCount || 0)}`\n                    : `.${'0'.repeat(this.maxDecimalCount || 0)}`;\n            }\n        }\n\n        this.helpText += this.dictionaryService.getKeySync(\n            'foehn-input-number.standard-help-text.label',\n            {\n                minValue: this.formatValue(minAsString),\n                maxValue: this.formatValue(maxAsString)\n            }\n        );\n    }\n\n    private formatValue(value: string | number): string {\n        if (this.allowDecimal) {\n            return formatDecimalCurrency(\n                value?.toString(),\n                this.maxDecimalCount,\n                this.maxlength,\n                this.allowFreeInput\n            );\n        }\n        return formatNonDecimalCurrency(value?.toString());\n    }\n\n    private removeLeadingZero(\n        value: string,\n        allowDecimal: boolean = false\n    ): string {\n        if (value === undefined || value === null) {\n            return null;\n        }\n\n        // Never clean first character because it could be only \"0\" or \"-\"\n        if (value.length === 1) {\n            return value;\n        }\n\n        // For decimal values, we can't remove \"0\" from \"0.\" or \"-0.\" because we can't predict what comes after the dot\n        if (allowDecimal && (value === '0.' || value === '-0.')) {\n            return value;\n        }\n\n        // Remove \"0\" from \"-0\" for forbidden decimal values\n        if (\n            !allowDecimal &&\n            value.includes('-') &&\n            value.length === 2 &&\n            value.substring(1) === '0'\n        ) {\n            return value.substring(0, 1);\n        }\n\n        // Clean positive or negative integer\n        if (!value.includes(DECIMALS_SEPARATOR)) {\n            // Remove \"0\" from \"01\", \"02\"... numbers\n            if (\n                !value.includes('-') &&\n                value.length === 2 &&\n                value.substring(0, 1) === '0'\n            ) {\n                return value.substring(1);\n            }\n\n            // Remove \"0\" from \"-01\", \"-02\"... numbers\n            if (\n                value.includes('-') &&\n                value.length === 3 &&\n                value.substring(1, 2) === '0'\n            ) {\n                return value.substring(0, 1) + value.substring(2);\n            }\n        }\n\n        return value;\n    }\n}\n","<div\n    class=\"form-group clearable-input-form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <div class=\"d-flex justify-content-between\">\n        <label\n            style=\"display: inline-block\"\n            [attr.for]=\"buildChildId()\"\n            *ngIf=\"label && type !== 'hidden'\"\n            [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\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        </label>\n\n        <foehn-help-modal\n            class=\"removePaddingButton\"\n            *ngIf=\"!!helpModal\"\n            [modalContent]=\"helpModal\"\n        ></foehn-help-modal>\n    </div>\n\n    <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n    <small\n        *ngIf=\"helpText && type !== 'hidden'\"\n        [attr.id]=\"buildChildId() + 'Help'\"\n        class=\"form-text text-secondary\"\n        [innerHTML]=\"helpText\"\n    ></small>\n\n    <ng-content></ng-content>\n\n    <input\n        [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n        [class.clearable-input]=\"displayClearButton() | async\"\n        class=\"form-control\"\n        [name]=\"name || label\"\n        [attr.maxlength]=\"getMaxLength()\"\n        [attr.autocomplete]=\"getAutoComplete()\"\n        [attr.autocapitalize]=\"autocapitalize\"\n        [attr.disabled]=\"disabled ? 'disabled' : null\"\n        [attr.type]=\"type\"\n        [attr.pattern]=\"pattern\"\n        [attr.min]=\"min\"\n        [attr.max]=\"max\"\n        [attr.id]=\"buildChildId()\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n        [attr.aria-required]=\"required || null\"\n        [ngModel]=\"model\"\n        (paste)=\"onPaste($event)\"\n        (ngModelChange)=\"updateNgModel($event)\"\n        (input)=\"handleChange(entryComponent.value)\"\n        (keydown)=\"onKeydown($event)\"\n        (blur)=\"onBlur($event)\"\n        (focus)=\"onFocus($event)\"\n        #entryComponent\n    />\n\n    <button\n        type=\"button\"\n        [id]=\"buildChildId() + 'ClearButton'\"\n        *ngIf=\"displayClearButton() | async\"\n        class=\"clearable-input-clear-button btn\"\n        (click)=\"onClear()\"\n    >\n        <foehn-icon-times\n            class=\"clearable-input-clear-button-icon\"\n            title=\"Réinitialiser le champs\"\n        ></foehn-icon-times>\n    </button>\n</div>\n"]}
|
|
@@ -93,7 +93,7 @@ FoehnDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", ver
|
|
|
93
93
|
useExisting: forwardRef(() => FoehnDateComponent),
|
|
94
94
|
multi: true
|
|
95
95
|
}
|
|
96
|
-
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\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() + '_day'\"\n [name]=\"name + '_day'\"\n [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n [(model)]=\"day\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableDay\"\n [maxlength]=\"2\"\n [allowNegative]=\"false\"\n [max]=\"31\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\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() + '_month'\"\n [name]=\"name + '_month'\"\n [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n [(model)]=\"month\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableMonth\"\n [maxlength]=\"2\"\n [clearButton]=\"displayClearButton() | async\"\n [allowNegative]=\"false\"\n [max]=\"12\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n ></foehn-input-number>\n </div>\n <div\n class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n [class.mr-0]=\"shouldDisplayDatePicker()\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_year'\"\n [name]=\"name + '_year'\"\n [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n [(model)]=\"year\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableYear\"\n [allowNegative]=\"false\"\n [maxlength]=\"4\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n ></foehn-input-number>\n </div>\n <foehn-date-picker-button\n *ngIf=\"shouldDisplayDatePicker()\"\n [id]=\"buildId() + '_datePickerButton'\"\n [(model)]=\"datePickerModel\"\n (modelChange)=\"updateDateFromDatePicker($event)\"\n (userInput)=\"handleDatePickerUserInput($event)\"\n [displaySelectedDate]=\"false\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n class=\"align-self-center\"\n ></foehn-date-picker-button>\n </div>\n </fieldset>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i3.FoehnDatePickerButtonComponent, selector: "foehn-date-picker-button", inputs: ["id", "name", "minYear", "maxYear", "minDate", "maxDate", "displaySelectedDate", "selectedDateSrOnlyLabelKey", "model"], outputs: ["modelChange", "userInput"] }, { kind: "component", type: i4.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "model"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.SdkDictionaryPipe, name: "fromDictionary" }] });
|
|
96
|
+
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\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() + '_day'\"\n [name]=\"name + '_day'\"\n [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n [(model)]=\"day\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableDay\"\n [maxlength]=\"2\"\n [allowNegative]=\"false\"\n [max]=\"31\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\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() + '_month'\"\n [name]=\"name + '_month'\"\n [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n [(model)]=\"month\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableMonth\"\n [maxlength]=\"2\"\n [clearButton]=\"displayClearButton() | async\"\n [allowNegative]=\"false\"\n [max]=\"12\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n ></foehn-input-number>\n </div>\n <div\n class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n [class.mr-0]=\"shouldDisplayDatePicker()\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_year'\"\n [name]=\"name + '_year'\"\n [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n [(model)]=\"year\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableYear\"\n [allowNegative]=\"false\"\n [maxlength]=\"4\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n [isLabelSrOnly]=\"childrenLabelSrOnly\"\n ></foehn-input-number>\n </div>\n <foehn-date-picker-button\n *ngIf=\"shouldDisplayDatePicker()\"\n [id]=\"buildId() + '_datePickerButton'\"\n [(model)]=\"datePickerModel\"\n (modelChange)=\"updateDateFromDatePicker($event)\"\n (userInput)=\"handleDatePickerUserInput($event)\"\n [displaySelectedDate]=\"false\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n class=\"align-self-center\"\n ></foehn-date-picker-button>\n </div>\n </fieldset>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i3.FoehnDatePickerButtonComponent, selector: "foehn-date-picker-button", inputs: ["id", "name", "minYear", "maxYear", "minDate", "maxDate", "displaySelectedDate", "selectedDateSrOnlyLabelKey", "model"], outputs: ["modelChange", "userInput"] }, { kind: "component", type: i4.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "allowLeadingZero", "model"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.SdkDictionaryPipe, name: "fromDictionary" }] });
|
|
97
97
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FoehnDateComponent, decorators: [{
|
|
98
98
|
type: Component,
|
|
99
99
|
args: [{ selector: 'foehn-input-date', providers: [
|
|
@@ -53,7 +53,7 @@ FoehnTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", ver
|
|
|
53
53
|
useExisting: forwardRef(() => FoehnTimeComponent),
|
|
54
54
|
multi: true
|
|
55
55
|
}
|
|
56
|
-
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\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 </fieldset>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i3.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "model"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SdkDictionaryPipe, name: "fromDictionary" }] });
|
|
56
|
+
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\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 </fieldset>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i3.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "allowLeadingZero", "model"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SdkDictionaryPipe, name: "fromDictionary" }] });
|
|
57
57
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FoehnTimeComponent, decorators: [{
|
|
58
58
|
type: Component,
|
|
59
59
|
args: [{ selector: 'foehn-input-time', providers: [
|
|
@@ -100,7 +100,7 @@ FoehnInputNav13Component.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0
|
|
|
100
100
|
useExisting: forwardRef(() => FoehnInputNav13Component),
|
|
101
101
|
multi: true
|
|
102
102
|
}
|
|
103
|
-
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n [attr.for]=\"buildChildId()\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : '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=\"form-text 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--4-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--3-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part1Child'\"\n class=\"sr-only\"\n >\n Code du pays\n </label>\n <small\n [id]=\"buildId() + '_part1ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Etant obligatoirement un num\u00E9ro AVS suisse, ce\n champs est pr\u00E9rempli\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part1'\"\n [id]=\"buildId() + '_part1'\"\n [model]=\"PREFIX_NAVS\"\n [maxlength]=\"3\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n [disabled]=\"true\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part2Child'\"\n class=\"sr-only\"\n >\n Premiers chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part2ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 1234\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part2'\"\n [id]=\"buildId() + '_part2'\"\n [(model)]=\"part2\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n (paste)=\"onPaste($event)\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part3Child'\"\n class=\"sr-only\"\n >\n Deuxi\u00E8mes chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part3ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 5678\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part3'\"\n [id]=\"buildId() + '_part3'\"\n [(model)]=\"part3\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\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 vd-form-flex__item--3-char-width\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part4Child'\"\n class=\"sr-only\"\n >\n Chiffre al\u00E9atoire et anonyme et num\u00E9ro de contr\u00F4le\n </label>\n <small\n [id]=\"buildId() + '_part4ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir deux chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 97\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part4'\"\n [id]=\"buildId() + '_part4'\"\n [(model)]=\"part4\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"2\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i3.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "model"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SdkDictionaryPipe, name: "fromDictionary" }] });
|
|
103
|
+
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n [attr.for]=\"buildChildId()\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : '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=\"form-text 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--4-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--3-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part1Child'\"\n class=\"sr-only\"\n >\n Code du pays\n </label>\n <small\n [id]=\"buildId() + '_part1ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Etant obligatoirement un num\u00E9ro AVS suisse, ce\n champs est pr\u00E9rempli\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part1'\"\n [id]=\"buildId() + '_part1'\"\n [model]=\"PREFIX_NAVS\"\n [maxlength]=\"3\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n [disabled]=\"true\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part2Child'\"\n class=\"sr-only\"\n >\n Premiers chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part2ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 1234\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part2'\"\n [id]=\"buildId() + '_part2'\"\n [(model)]=\"part2\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n (paste)=\"onPaste($event)\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part3Child'\"\n class=\"sr-only\"\n >\n Deuxi\u00E8mes chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part3ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 5678\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part3'\"\n [id]=\"buildId() + '_part3'\"\n [(model)]=\"part3\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\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 vd-form-flex__item--3-char-width\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part4Child'\"\n class=\"sr-only\"\n >\n Chiffre al\u00E9atoire et anonyme et num\u00E9ro de contr\u00F4le\n </label>\n <small\n [id]=\"buildId() + '_part4ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir deux chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 97\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part4'\"\n [id]=\"buildId() + '_part4'\"\n [(model)]=\"part4\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"2\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { kind: "component", type: i3.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "allowFreeInput", "allowLeadingZero", "model"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SdkDictionaryPipe, name: "fromDictionary" }] });
|
|
104
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: FoehnInputNav13Component, decorators: [{
|
|
105
105
|
type: Component,
|
|
106
106
|
args: [{ selector: 'foehn-input-nav13', providers: [
|
|
@@ -109,6 +109,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
109
109
|
useExisting: forwardRef(() => FoehnInputNav13Component),
|
|
110
110
|
multi: true
|
|
111
111
|
}
|
|
112
|
-
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n [attr.for]=\"buildChildId()\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : '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=\"form-text 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--4-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--3-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part1Child'\"\n class=\"sr-only\"\n >\n Code du pays\n </label>\n <small\n [id]=\"buildId() + '_part1ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Etant obligatoirement un num\u00E9ro AVS suisse, ce\n champs est pr\u00E9rempli\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part1'\"\n [id]=\"buildId() + '_part1'\"\n [model]=\"PREFIX_NAVS\"\n [maxlength]=\"3\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n [disabled]=\"true\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part2Child'\"\n class=\"sr-only\"\n >\n Premiers chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part2ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 1234\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part2'\"\n [id]=\"buildId() + '_part2'\"\n [(model)]=\"part2\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n (paste)=\"onPaste($event)\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part3Child'\"\n class=\"sr-only\"\n >\n Deuxi\u00E8mes chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part3ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 5678\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part3'\"\n [id]=\"buildId() + '_part3'\"\n [(model)]=\"part3\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\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 vd-form-flex__item--3-char-width\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part4Child'\"\n class=\"sr-only\"\n >\n Chiffre al\u00E9atoire et anonyme et num\u00E9ro de contr\u00F4le\n </label>\n <small\n [id]=\"buildId() + '_part4ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir deux chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 97\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part4'\"\n [id]=\"buildId() + '_part4'\"\n [(model)]=\"part4\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"2\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n" }]
|
|
112
|
+
], 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 class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend\n [attr.for]=\"buildChildId()\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : '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=\"form-text 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--4-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--3-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part1Child'\"\n class=\"sr-only\"\n >\n Code du pays\n </label>\n <small\n [id]=\"buildId() + '_part1ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Etant obligatoirement un num\u00E9ro AVS suisse, ce\n champs est pr\u00E9rempli\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part1'\"\n [id]=\"buildId() + '_part1'\"\n [model]=\"PREFIX_NAVS\"\n [maxlength]=\"3\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n [disabled]=\"true\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part2Child'\"\n class=\"sr-only\"\n >\n Premiers chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part2ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 1234\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part2'\"\n [id]=\"buildId() + '_part2'\"\n [(model)]=\"part2\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n (paste)=\"onPaste($event)\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\n <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part3Child'\"\n class=\"sr-only\"\n >\n Deuxi\u00E8mes chiffres al\u00E9atoires et anonymes\n </label>\n <small\n [id]=\"buildId() + '_part3ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir quatres chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 5678\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part3'\"\n [id]=\"buildId() + '_part3'\"\n [(model)]=\"part3\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"4\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n\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 vd-form-flex__item--3-char-width\"\n >\n <div class=\"form-group\">\n <label\n [attr.for]=\"buildId() + '_part4Child'\"\n class=\"sr-only\"\n >\n Chiffre al\u00E9atoire et anonyme et num\u00E9ro de contr\u00F4le\n </label>\n <small\n [id]=\"buildId() + '_part4ChildHelp'\"\n class=\"form-text text-secondary\"\n >\n <span class=\"sr-only\">\n Saisir deux chiffres :\n <abbr title=\"Exemple\">Ex.</abbr>\n : 97\n </span>\n </small>\n\n <foehn-input-number\n [name]=\"name + '_part4'\"\n [id]=\"buildId() + '_part4'\"\n [(model)]=\"part4\"\n (modelChange)=\"updateNavs()\"\n [maxlength]=\"2\"\n [autocomplete]=\"'off'\"\n [clearButton]=\"displayClearButton() | async\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n [allowLeadingZero]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n" }]
|
|
113
113
|
}] });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-nav13.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.ts","../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit } 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';\n\n@Component({\n    selector: 'foehn-input-nav13',\n    templateUrl: './foehn-input-nav13.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputNav13Component),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputNav13Component\n    extends FoehnInputStringComponent\n    implements OnInit {\n    PREFIX_NAVS = '756';\n    part2: string;\n    part3: string;\n    part4: string;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (!this.helpText) {\n            this.helpText = 'Par exemple, 756 1234 5678 97';\n        }\n        if (!this.label) {\n            this.label = 'Votre numéro <abbr title=\"Numéro AVS\">AVS</abbr>';\n        }\n    }\n\n    updateNavs(): 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        if (!!value) {\n            this.splitValue(value);\n        } else {\n            this.part2 = null;\n            this.part3 = null;\n            this.part4 = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        return of(this.clearButton);\n    }\n\n    onPaste(event: ClipboardEvent): void {\n        if (this.preventPaste === true) {\n            event.preventDefault();\n        }\n\n        const pastedValue = event.clipboardData\n            .getData('text')\n            ?.replace(/\\D/g, '');\n\n        const isPastedValueMoreThanOneAvsBlock = pastedValue?.length > 4;\n\n        if (isPastedValueMoreThanOneAvsBlock) {\n            let valueToPaste = pastedValue;\n            if (!pastedValue.startsWith(this.PREFIX_NAVS)) {\n                valueToPaste = pastedValue.includes('.')\n                    ? `${this.PREFIX_NAVS}.${pastedValue}`\n                    : this.PREFIX_NAVS + pastedValue;\n            }\n\n            this.onModelChange(valueToPaste);\n            this.handleUserInput();\n            event.preventDefault();\n        }\n    }\n\n    private splitValue(value: string): void {\n        if (value.length === 13 && !value.includes('.')) {\n            this.part2 = value.substring(3, 7);\n            this.part3 = value.substring(7, 11);\n            this.part4 = value.substring(11, 13);\n        } else {\n            const splitted = value.split('.');\n            this.part2 = splitted[1];\n            this.part3 = splitted[2];\n            this.part4 = splitted[3];\n        }\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (!this.part2 && !this.part3 && !this.part4) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        this.part2 = this.part2 || '';\n        this.part3 = this.part3 || '';\n        this.part4 = this.part4 || '';\n        return `${this.PREFIX_NAVS}.${this.part2}.${this.part3}.${this.part4}`;\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        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend\n            [attr.for]=\"buildChildId()\"\n            [ngClass]=\"isLabelSrOnly ? 'sr-only' : '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=\"form-text 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--4-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--3-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part1Child'\"\n                        class=\"sr-only\"\n                    >\n                        Code du pays\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part1ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Etant obligatoirement un numéro AVS suisse, ce\n                            champs est prérempli\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part1'\"\n                        [id]=\"buildId() + '_part1'\"\n                        [model]=\"PREFIX_NAVS\"\n                        [maxlength]=\"3\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        [disabled]=\"true\"\n                        [hideStandardHelpText]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part2Child'\"\n                        class=\"sr-only\"\n                    >\n                        Premiers chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part2ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 1234\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part2'\"\n                        [id]=\"buildId() + '_part2'\"\n                        [(model)]=\"part2\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        (paste)=\"onPaste($event)\"\n                        [hideStandardHelpText]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part3Child'\"\n                        class=\"sr-only\"\n                    >\n                        Deuxièmes chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part3ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 5678\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part3'\"\n                        [id]=\"buildId() + '_part3'\"\n                        [(model)]=\"part3\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        [hideStandardHelpText]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\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 vd-form-flex__item--3-char-width\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part4Child'\"\n                        class=\"sr-only\"\n                    >\n                        Chiffre aléatoire et anonyme et numéro de contrôle\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part4ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir deux chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 97\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part4'\"\n                        [id]=\"buildId() + '_part4'\"\n                        [(model)]=\"part4\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"2\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        [hideStandardHelpText]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-nav13.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.ts","../../../../projects/prestations-ng/src/foehn-nav13/foehn-input-nav13.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, OnInit } 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';\n\n@Component({\n    selector: 'foehn-input-nav13',\n    templateUrl: './foehn-input-nav13.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputNav13Component),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputNav13Component\n    extends FoehnInputStringComponent\n    implements OnInit {\n    PREFIX_NAVS = '756';\n    part2: string;\n    part3: string;\n    part4: string;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (!this.helpText) {\n            this.helpText = 'Par exemple, 756 1234 5678 97';\n        }\n        if (!this.label) {\n            this.label = 'Votre numéro <abbr title=\"Numéro AVS\">AVS</abbr>';\n        }\n    }\n\n    updateNavs(): 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        if (!!value) {\n            this.splitValue(value);\n        } else {\n            this.part2 = null;\n            this.part3 = null;\n            this.part4 = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        return of(this.clearButton);\n    }\n\n    onPaste(event: ClipboardEvent): void {\n        if (this.preventPaste === true) {\n            event.preventDefault();\n        }\n\n        const pastedValue = event.clipboardData\n            .getData('text')\n            ?.replace(/\\D/g, '');\n\n        const isPastedValueMoreThanOneAvsBlock = pastedValue?.length > 4;\n\n        if (isPastedValueMoreThanOneAvsBlock) {\n            let valueToPaste = pastedValue;\n            if (!pastedValue.startsWith(this.PREFIX_NAVS)) {\n                valueToPaste = pastedValue.includes('.')\n                    ? `${this.PREFIX_NAVS}.${pastedValue}`\n                    : this.PREFIX_NAVS + pastedValue;\n            }\n\n            this.onModelChange(valueToPaste);\n            this.handleUserInput();\n            event.preventDefault();\n        }\n    }\n\n    private splitValue(value: string): void {\n        if (value.length === 13 && !value.includes('.')) {\n            this.part2 = value.substring(3, 7);\n            this.part3 = value.substring(7, 11);\n            this.part4 = value.substring(11, 13);\n        } else {\n            const splitted = value.split('.');\n            this.part2 = splitted[1];\n            this.part3 = splitted[2];\n            this.part4 = splitted[3];\n        }\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (!this.part2 && !this.part3 && !this.part4) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        this.part2 = this.part2 || '';\n        this.part3 = this.part3 || '';\n        this.part4 = this.part4 || '';\n        return `${this.PREFIX_NAVS}.${this.part2}.${this.part3}.${this.part4}`;\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        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend\n            [attr.for]=\"buildChildId()\"\n            [ngClass]=\"isLabelSrOnly ? 'sr-only' : '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=\"form-text 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--4-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--3-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part1Child'\"\n                        class=\"sr-only\"\n                    >\n                        Code du pays\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part1ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Etant obligatoirement un numéro AVS suisse, ce\n                            champs est prérempli\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part1'\"\n                        [id]=\"buildId() + '_part1'\"\n                        [model]=\"PREFIX_NAVS\"\n                        [maxlength]=\"3\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        [disabled]=\"true\"\n                        [hideStandardHelpText]=\"true\"\n                        [allowLeadingZero]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part2Child'\"\n                        class=\"sr-only\"\n                    >\n                        Premiers chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part2ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 1234\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part2'\"\n                        [id]=\"buildId() + '_part2'\"\n                        [(model)]=\"part2\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        (paste)=\"onPaste($event)\"\n                        [hideStandardHelpText]=\"true\"\n                        [allowLeadingZero]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\n            <div class=\"vd-form-flex__item vd-form-flex__item--4-char-width\">\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part3Child'\"\n                        class=\"sr-only\"\n                    >\n                        Deuxièmes chiffres aléatoires et anonymes\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part3ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir quatres chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 5678\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part3'\"\n                        [id]=\"buildId() + '_part3'\"\n                        [(model)]=\"part3\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"4\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        [hideStandardHelpText]=\"true\"\n                        [allowLeadingZero]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n\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 vd-form-flex__item--3-char-width\"\n            >\n                <div class=\"form-group\">\n                    <label\n                        [attr.for]=\"buildId() + '_part4Child'\"\n                        class=\"sr-only\"\n                    >\n                        Chiffre aléatoire et anonyme et numéro de contrôle\n                    </label>\n                    <small\n                        [id]=\"buildId() + '_part4ChildHelp'\"\n                        class=\"form-text text-secondary\"\n                    >\n                        <span class=\"sr-only\">\n                            Saisir deux chiffres :\n                            <abbr title=\"Exemple\">Ex.</abbr>\n                            : 97\n                        </span>\n                    </small>\n\n                    <foehn-input-number\n                        [name]=\"name + '_part4'\"\n                        [id]=\"buildId() + '_part4'\"\n                        [(model)]=\"part4\"\n                        (modelChange)=\"updateNavs()\"\n                        [maxlength]=\"2\"\n                        [autocomplete]=\"'off'\"\n                        [clearButton]=\"displayClearButton() | async\"\n                        (userInput)=\"handleUserInput()\"\n                        [isErrorInherited]=\"hasErrorsToDisplay()\"\n                        [disabled]=\"disabled\"\n                        [hideStandardHelpText]=\"true\"\n                        [allowLeadingZero]=\"true\"\n                    ></foehn-input-number>\n                </div>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
|