@edugouvfr/ngx-dsfr
Version:
NgxDsfr est un portage Angular des éléments d'interface du Système de Design de l'État Français (DSFR).
80 lines • 22.1 kB
JavaScript
import { CommonModule } from '@angular/common';
import { Component, forwardRef, HostListener } from '@angular/core';
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
import { DsfrButtonModule } from '../../components';
import { InputGroupComponent } from '../../shared';
import { DsfrFormInputComponent } from '../form-input';
import { DsfrInputTypeConst } from '../form-input/form-input.model';
import { formatPhoneNumber, isPhoneNumberValid } from './phone-number-utils';
import * as i0 from "@angular/core";
import * as i1 from "../../shared";
import * as i2 from "@angular/common";
import * as i3 from "@angular/forms";
import * as i4 from "../../components/button/button.component";
/**
* Saisie d'un n° de téléphone et reformatage (sauf dans le cas d'utilisation d'un pattern)
* @since 1.3.0
*/
export class DsfrFormTelComponent extends DsfrFormInputComponent {
/** @internal */
constructor(i18n) {
super();
this.i18n = i18n;
/** @internal */ this.errorMessage = this.i18n.t('tel.error');
}
/**
* Au fil de la saisie, on ne vérifie le n° de téléphone que s'il y avait déjà une erreur
*/
onValueChange() {
if (this.error)
this.validate();
}
/**
* Vérification quand on sort du champ
*/
onFocusOut() {
if (!this.pattern && this.validate())
this.value = formatPhoneNumber(this.value);
}
/** @internal*/
ngOnInit() {
super.ngOnInit();
this.type = DsfrInputTypeConst.TEL;
this.spellCheck = false;
this.label ??= this.i18n.t('tel.label');
this.hint ??= this.i18n.t('tel.hint');
}
/**
* Méthode validation, positionne la propriété error s'il y a lieu.
*/
validate() {
const isValid = isPhoneNumberValid(this.value, this.pattern);
this.error = isValid ? '' : this.errorMessage;
return isValid;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrFormTelComponent, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DsfrFormTelComponent, isStandalone: true, selector: "dsfr-form-tel", host: { listeners: { "input": "onValueChange()", "change": "onFocusOut()" } }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => DsfrFormTelComponent),
multi: true,
},
], usesInheritance: true, ngImport: i0, template: "<edu-input-group\n [inputId]=\"inputId\"\n [label]=\"label\"\n [hint]=\"hint\"\n [messagesGroupId]=\"messagesGroupId\"\n [disabled]=\"disabled\"\n [message]=\"message\"\n [severity]=\"severity\">\n <label class=\"fr-label\" [for]=\"inputId\">\n <ng-container *ngIf=\"label\">{{ label }}</ng-container>\n <ng-content *ngIf=\"!label\" select=\"[label]\"></ng-content>\n <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n </label>\n <ng-container *ngIf=\"!isTextArea(); else textareaTemplate\">\n <ng-container *ngIf=\"!hasInputWrap(); else inputWrapTemplate\" [ngTemplateOutlet]=\"inputTemplate\"></ng-container>\n </ng-container>\n</edu-input-group>\n\n<!-- Templates -------------------------------------------------------------------------------------------------------->\n\n<!-- Template input -->\n<ng-template #inputTemplate>\n <input\n class=\"fr-input\"\n [ngClass]=\"customClass || null\"\n [attr.autocomplete]=\"autocomplete || null\"\n [attr.aria-autocomplete]=\"ariaAutocomplete || null\"\n [attr.aria-describedby]=\"messagesGroupId\"\n [attr.aria-disabled]=\"disabled || null\"\n [attr.aria-expanded]=\"ariaExpanded !== undefined ? ariaExpanded : null\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-required]=\"required || null\"\n [attr.role]=\"role || null\"\n [attr.inputmode]=\"inputMode || null\"\n [attr.autocorrect]=\"autoCorrect ? null : 'off'\"\n [(ngModel)]=\"value\"\n [id]=\"inputId\"\n [attr.name]=\"name || null\"\n [attr.type]=\"type || null\"\n [disabled]=\"disabled ?? false\"\n [required]=\"required ?? false\"\n [attr.pattern]=\"pattern || null\"\n [attr.placeholder]=\"placeHolder || null\"\n [attr.min]=\"min || null\"\n [attr.max]=\"max || null\"\n [attr.maxLength]=\"maxLength || null\"\n [attr.minLength]=\"minLength || null\"\n [attr.spellcheck]=\"spellCheck || null\"\n [ngStyle]=\"width ? { width: width } : {}\" />\n</ng-template>\n\n<!-- Template input wrap -->\n<ng-template #inputWrapTemplate>\n <div [ngClass]=\"getWrapClasses()\">\n <ng-container *ngTemplateOutlet=\"inputTemplate\"></ng-container>\n <dsfr-button\n *ngIf=\"hasButton()\"\n [ariaLabel]=\"buttonAriaLabel\"\n [disabled]=\"buttonDisabled\"\n [icon]=\"buttonIcon\"\n [label]=\"buttonLabel\"\n [tooltipMessage]=\"buttonTooltipMessage\"\n [type]=\"buttonType\"\n [variant]=\"buttonVariant\"\n (click)=\"onButtonClick($event)\"></dsfr-button>\n </div>\n</ng-template>\n\n<!-- Template textarea -->\n<ng-template #textareaTemplate>\n <textarea\n class=\"fr-input\"\n [ngClass]=\"customClass || null\"\n [id]=\"inputId\"\n [attr.name]=\"name || null\"\n [disabled]=\"disabled ?? false\"\n [attr.required]=\"required || null\"\n [attr.placeholder]=\"placeHolder || null\"\n [attr.min]=\"min || null\"\n [attr.max]=\"max || null\"\n [attr.maxLength]=\"maxLength || null\"\n [attr.minLength]=\"minLength || null\"\n [attr.autocomplete]=\"autocomplete || null\"\n [attr.aria-describedby]=\"messagesGroupId\"\n [(ngModel)]=\"value\"\n [ngStyle]=\"width ? { width: width } : {}\"\n [attr.rows]=\"rows || null\"></textarea>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: InputGroupComponent, selector: "edu-input-group", inputs: ["label", "inputId", "hint", "disabled", "message", "severity", "messagesGroupId"] }, { kind: "ngmodule", type: DsfrButtonModule }, { kind: "component", type: i4.DsfrButtonComponent, selector: "dsfr-button", inputs: ["label", "type", "tooltipMessage", "variant", "size", "icon", "iconPosition", "disabled", "uppercase", "loader", "ariaLabel", "invertedOutlineContrast", "id", "ariaControls", "customClass"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrFormTelComponent, decorators: [{
type: Component,
args: [{ selector: 'dsfr-form-tel', standalone: true, imports: [CommonModule, FormsModule, InputGroupComponent, DsfrButtonModule], providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => DsfrFormTelComponent),
multi: true,
},
], template: "<edu-input-group\n [inputId]=\"inputId\"\n [label]=\"label\"\n [hint]=\"hint\"\n [messagesGroupId]=\"messagesGroupId\"\n [disabled]=\"disabled\"\n [message]=\"message\"\n [severity]=\"severity\">\n <label class=\"fr-label\" [for]=\"inputId\">\n <ng-container *ngIf=\"label\">{{ label }}</ng-container>\n <ng-content *ngIf=\"!label\" select=\"[label]\"></ng-content>\n <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n </label>\n <ng-container *ngIf=\"!isTextArea(); else textareaTemplate\">\n <ng-container *ngIf=\"!hasInputWrap(); else inputWrapTemplate\" [ngTemplateOutlet]=\"inputTemplate\"></ng-container>\n </ng-container>\n</edu-input-group>\n\n<!-- Templates -------------------------------------------------------------------------------------------------------->\n\n<!-- Template input -->\n<ng-template #inputTemplate>\n <input\n class=\"fr-input\"\n [ngClass]=\"customClass || null\"\n [attr.autocomplete]=\"autocomplete || null\"\n [attr.aria-autocomplete]=\"ariaAutocomplete || null\"\n [attr.aria-describedby]=\"messagesGroupId\"\n [attr.aria-disabled]=\"disabled || null\"\n [attr.aria-expanded]=\"ariaExpanded !== undefined ? ariaExpanded : null\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-required]=\"required || null\"\n [attr.role]=\"role || null\"\n [attr.inputmode]=\"inputMode || null\"\n [attr.autocorrect]=\"autoCorrect ? null : 'off'\"\n [(ngModel)]=\"value\"\n [id]=\"inputId\"\n [attr.name]=\"name || null\"\n [attr.type]=\"type || null\"\n [disabled]=\"disabled ?? false\"\n [required]=\"required ?? false\"\n [attr.pattern]=\"pattern || null\"\n [attr.placeholder]=\"placeHolder || null\"\n [attr.min]=\"min || null\"\n [attr.max]=\"max || null\"\n [attr.maxLength]=\"maxLength || null\"\n [attr.minLength]=\"minLength || null\"\n [attr.spellcheck]=\"spellCheck || null\"\n [ngStyle]=\"width ? { width: width } : {}\" />\n</ng-template>\n\n<!-- Template input wrap -->\n<ng-template #inputWrapTemplate>\n <div [ngClass]=\"getWrapClasses()\">\n <ng-container *ngTemplateOutlet=\"inputTemplate\"></ng-container>\n <dsfr-button\n *ngIf=\"hasButton()\"\n [ariaLabel]=\"buttonAriaLabel\"\n [disabled]=\"buttonDisabled\"\n [icon]=\"buttonIcon\"\n [label]=\"buttonLabel\"\n [tooltipMessage]=\"buttonTooltipMessage\"\n [type]=\"buttonType\"\n [variant]=\"buttonVariant\"\n (click)=\"onButtonClick($event)\"></dsfr-button>\n </div>\n</ng-template>\n\n<!-- Template textarea -->\n<ng-template #textareaTemplate>\n <textarea\n class=\"fr-input\"\n [ngClass]=\"customClass || null\"\n [id]=\"inputId\"\n [attr.name]=\"name || null\"\n [disabled]=\"disabled ?? false\"\n [attr.required]=\"required || null\"\n [attr.placeholder]=\"placeHolder || null\"\n [attr.min]=\"min || null\"\n [attr.max]=\"max || null\"\n [attr.maxLength]=\"maxLength || null\"\n [attr.minLength]=\"minLength || null\"\n [attr.autocomplete]=\"autocomplete || null\"\n [attr.aria-describedby]=\"messagesGroupId\"\n [(ngModel)]=\"value\"\n [ngStyle]=\"width ? { width: width } : {}\"\n [attr.rows]=\"rows || null\"></textarea>\n</ng-template>\n" }]
}], ctorParameters: function () { return [{ type: i1.I18nService }]; }, propDecorators: { onValueChange: [{
type: HostListener,
args: ['input']
}], onFocusOut: [{
type: HostListener,
args: ['change']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-tel.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dsfr-components/src/lib/forms/form-tel/form-tel.component.ts","../../../../../../projects/ngx-dsfr-components/src/lib/forms/form-input/form-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAU,MAAM,eAAe,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAe,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;;;;;;AAe7E;;;GAGG;AACH,MAAM,OAAO,oBAAqB,SAAQ,sBAAsB;IAG9D,gBAAgB;IAChB,YAAoB,IAAiB;QACnC,KAAK,EAAE,CAAC;QADU,SAAI,GAAJ,IAAI,CAAa;QAHrC,gBAAgB,CAAU,iBAAY,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IAKlE,CAAC;IAED;;OAEG;IACoB,aAAa;QAClC,IAAI,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IAED;;OAEG;IACqB,UAAU;QAChC,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE;YAAE,IAAI,CAAC,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnF,CAAC;IAED,eAAe;IACf,QAAQ;QACN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAC,GAAG,CAAC;QACnC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;QACxC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IACxC,CAAC;IAED;;OAEG;IACK,QAAQ;QACd,MAAM,OAAO,GAAG,kBAAkB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;QAC9C,OAAO,OAAO,CAAC;IACjB,CAAC;+GAtCU,oBAAoB;mGAApB,oBAAoB,2IAZpB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;gBACnD,KAAK,EAAE,IAAI;aACZ;SACF,iDCpBH,isGAwFA,2CD3EY,YAAY,4dAAE,WAAW,40BAAE,mBAAmB,uJAAE,gBAAgB;;4FAa/D,oBAAoB;kBAjBhC,SAAS;+BACE,eAAe,cAEb,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,mBAAmB,EAAE,gBAAgB,CAAC,aAChE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,qBAAqB,CAAC;4BACnD,KAAK,EAAE,IAAI;yBACZ;qBACF;kGAiBsB,aAAa;sBAAnC,YAAY;uBAAC,OAAO;gBAOG,UAAU;sBAAjC,YAAY;uBAAC,QAAQ","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, forwardRef, HostListener, OnInit } from '@angular/core';\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DsfrButtonModule } from '../../components';\nimport { I18nService, InputGroupComponent } from '../../shared';\nimport { DsfrFormInputComponent } from '../form-input';\nimport { DsfrInputTypeConst } from '../form-input/form-input.model';\nimport { formatPhoneNumber, isPhoneNumberValid } from './phone-number-utils';\n\n@Component({\n  selector: 'dsfr-form-tel',\n  templateUrl: '../form-input/form-input.component.html',\n  standalone: true,\n  imports: [CommonModule, FormsModule, InputGroupComponent, DsfrButtonModule],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DsfrFormTelComponent),\n      multi: true,\n    },\n  ],\n})\n/**\n * Saisie d'un n° de téléphone et reformatage (sauf dans le cas d'utilisation d'un pattern)\n * @since 1.3.0\n */\nexport class DsfrFormTelComponent extends DsfrFormInputComponent implements OnInit {\n  /** @internal */ readonly errorMessage = this.i18n.t('tel.error');\n\n  /** @internal */\n  constructor(private i18n: I18nService) {\n    super();\n  }\n\n  /**\n   * Au fil de la saisie, on ne vérifie le n° de téléphone que s'il y avait déjà une erreur\n   */\n  @HostListener('input') onValueChange() {\n    if (this.error) this.validate();\n  }\n\n  /**\n   * Vérification quand on sort du champ\n   */\n  @HostListener('change') onFocusOut() {\n    if (!this.pattern && this.validate()) this.value = formatPhoneNumber(this.value);\n  }\n\n  /** @internal*/\n  ngOnInit() {\n    super.ngOnInit();\n    this.type = DsfrInputTypeConst.TEL;\n    this.spellCheck = false;\n    this.label ??= this.i18n.t('tel.label');\n    this.hint ??= this.i18n.t('tel.hint');\n  }\n\n  /**\n   * Méthode validation, positionne la propriété error s'il y a lieu.\n   */\n  private validate(): boolean {\n    const isValid = isPhoneNumberValid(this.value, this.pattern);\n    this.error = isValid ? '' : this.errorMessage;\n    return isValid;\n  }\n}\n","<edu-input-group\n  [inputId]=\"inputId\"\n  [label]=\"label\"\n  [hint]=\"hint\"\n  [messagesGroupId]=\"messagesGroupId\"\n  [disabled]=\"disabled\"\n  [message]=\"message\"\n  [severity]=\"severity\">\n  <label class=\"fr-label\" [for]=\"inputId\">\n    <ng-container *ngIf=\"label\">{{ label }}</ng-container>\n    <ng-content *ngIf=\"!label\" select=\"[label]\"></ng-content>\n    <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n  </label>\n  <ng-container *ngIf=\"!isTextArea(); else textareaTemplate\">\n    <ng-container *ngIf=\"!hasInputWrap(); else inputWrapTemplate\" [ngTemplateOutlet]=\"inputTemplate\"></ng-container>\n  </ng-container>\n</edu-input-group>\n\n<!-- Templates -------------------------------------------------------------------------------------------------------->\n\n<!-- Template input -->\n<ng-template #inputTemplate>\n  <input\n    class=\"fr-input\"\n    [ngClass]=\"customClass || null\"\n    [attr.autocomplete]=\"autocomplete || null\"\n    [attr.aria-autocomplete]=\"ariaAutocomplete || null\"\n    [attr.aria-describedby]=\"messagesGroupId\"\n    [attr.aria-disabled]=\"disabled || null\"\n    [attr.aria-expanded]=\"ariaExpanded !== undefined ? ariaExpanded : null\"\n    [attr.aria-label]=\"ariaLabel || null\"\n    [attr.aria-required]=\"required || null\"\n    [attr.role]=\"role || null\"\n    [attr.inputmode]=\"inputMode || null\"\n    [attr.autocorrect]=\"autoCorrect ? null : 'off'\"\n    [(ngModel)]=\"value\"\n    [id]=\"inputId\"\n    [attr.name]=\"name || null\"\n    [attr.type]=\"type || null\"\n    [disabled]=\"disabled ?? false\"\n    [required]=\"required ?? false\"\n    [attr.pattern]=\"pattern || null\"\n    [attr.placeholder]=\"placeHolder || null\"\n    [attr.min]=\"min || null\"\n    [attr.max]=\"max || null\"\n    [attr.maxLength]=\"maxLength || null\"\n    [attr.minLength]=\"minLength || null\"\n    [attr.spellcheck]=\"spellCheck || null\"\n    [ngStyle]=\"width ? { width: width } : {}\" />\n</ng-template>\n\n<!-- Template input wrap -->\n<ng-template #inputWrapTemplate>\n  <div [ngClass]=\"getWrapClasses()\">\n    <ng-container *ngTemplateOutlet=\"inputTemplate\"></ng-container>\n    <dsfr-button\n      *ngIf=\"hasButton()\"\n      [ariaLabel]=\"buttonAriaLabel\"\n      [disabled]=\"buttonDisabled\"\n      [icon]=\"buttonIcon\"\n      [label]=\"buttonLabel\"\n      [tooltipMessage]=\"buttonTooltipMessage\"\n      [type]=\"buttonType\"\n      [variant]=\"buttonVariant\"\n      (click)=\"onButtonClick($event)\"></dsfr-button>\n  </div>\n</ng-template>\n\n<!-- Template textarea -->\n<ng-template #textareaTemplate>\n  <textarea\n    class=\"fr-input\"\n    [ngClass]=\"customClass || null\"\n    [id]=\"inputId\"\n    [attr.name]=\"name || null\"\n    [disabled]=\"disabled ?? false\"\n    [attr.required]=\"required || null\"\n    [attr.placeholder]=\"placeHolder || null\"\n    [attr.min]=\"min || null\"\n    [attr.max]=\"max || null\"\n    [attr.maxLength]=\"maxLength || null\"\n    [attr.minLength]=\"minLength || null\"\n    [attr.autocomplete]=\"autocomplete || null\"\n    [attr.aria-describedby]=\"messagesGroupId\"\n    [(ngModel)]=\"value\"\n    [ngStyle]=\"width ? { width: width } : {}\"\n    [attr.rows]=\"rows || null\"></textarea>\n</ng-template>\n"]}