UNPKG

@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).

69 lines 21.1 kB
import { Component, forwardRef, Input, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { isStringEmptyOrNull } from '../../shared'; import { BaseInputComboComponent } from './base-input-combo.component'; import { DsfrInputTypeConst } from './form-input.model'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; import * as i3 from "../../components/button/button.component"; import * as i4 from "../../shared/components/input-group/input-group.component"; export class DsfrFormInputComponent extends BaseInputComboComponent { /** @deprecated since 1.2 use `type` instead. */ get textarea() { return this.isTextArea(); } /** @deprecated (@since 1.2) utiliser `type` à la place. */ set textarea(value) { this.type = value ? DsfrInputTypeConst.TEXTAREA : DsfrInputTypeConst.TEXT; } /** @internal */ isTextArea() { return this.type === DsfrInputTypeConst.TEXTAREA; } /** @internal */ hasInputWrap() { return this.hasButton() || !isStringEmptyOrNull(this.icon); } /** @internal */ getWrapClasses() { let classes = ['fr-input-wrap']; if (this.hasButton() && this.inputWrapMode === 'addon') classes.push('fr-input-wrap--addon'); if (this.hasButton() && this.inputWrapMode === 'action') classes.push('fr-input-wrap--action'); if (this.icon) classes.push(this.icon); return classes; } /** @internal */ onButtonClick(event) { if (this.buttonType != 'submit') this.buttonSelect.emit(event); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrFormInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DsfrFormInputComponent, selector: "dsfr-form-input", inputs: { rows: "rows", width: "width", textarea: "textarea" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DsfrFormInputComponent), 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: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.DsfrButtonComponent, selector: "dsfr-button", inputs: ["label", "type", "tooltipMessage", "variant", "size", "icon", "iconPosition", "disabled", "uppercase", "loader", "ariaLabel", "invertedOutlineContrast", "id", "ariaControls", "customClass"] }, { kind: "component", type: i4.InputGroupComponent, selector: "edu-input-group", inputs: ["label", "inputId", "hint", "disabled", "message", "severity", "messagesGroupId"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrFormInputComponent, decorators: [{ type: Component, args: [{ selector: 'dsfr-form-input', encapsulation: ViewEncapsulation.None, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DsfrFormInputComponent), 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" }] }], propDecorators: { rows: [{ type: Input }], width: [{ type: Input }], textarea: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dsfr-components/src/lib/forms/form-input/form-input.component.ts","../../../../../../projects/ngx-dsfr-components/src/lib/forms/form-input/form-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAChF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;;;;;;AAcxD,MAAM,OAAO,sBAAuB,SAAQ,uBAAuB;IAYjE,gDAAgD;IAChD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC;IAED,2DAA2D;IAC3D,IAAa,QAAQ,CAAC,KAAc;QAClC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC;IAC5E,CAAC;IAED,gBAAgB;IAChB,UAAU;QACR,OAAO,IAAI,CAAC,IAAI,KAAK,kBAAkB,CAAC,QAAQ,CAAC;IACnD,CAAC;IAED,gBAAgB;IAChB,YAAY;QACV,OAAO,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7D,CAAC;IAED,gBAAgB;IAChB,cAAc;QACZ,IAAI,OAAO,GAAG,CAAC,eAAe,CAAC,CAAC;QAChC,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,aAAa,KAAK,OAAO;YAAE,OAAO,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QAC7F,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,aAAa,KAAK,QAAQ;YAAE,OAAO,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QAC/F,IAAI,IAAI,CAAC,IAAI;YAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEvC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,gBAAgB;IAChB,aAAa,CAAC,KAAY;QACxB,IAAI,IAAI,CAAC,UAAU,IAAI,QAAQ;YAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjE,CAAC;+GA7CU,sBAAsB;mGAAtB,sBAAsB,0GARtB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aACZ;SACF,iDChBH,isGAwFA;;4FDtEa,sBAAsB;kBAZlC,SAAS;+BACE,iBAAiB,iBAEZ,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAMQ,IAAI;sBAAZ,KAAK;gBAMG,KAAK;sBAAb,KAAK;gBAQO,QAAQ;sBAApB,KAAK","sourcesContent":["import { Component, forwardRef, Input, ViewEncapsulation } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isStringEmptyOrNull } from '../../shared';\nimport { BaseInputComboComponent } from './base-input-combo.component';\nimport { DsfrInputTypeConst } from './form-input.model';\n\n@Component({\n  selector: 'dsfr-form-input',\n  templateUrl: './form-input.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DsfrFormInputComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DsfrFormInputComponent extends BaseInputComboComponent {\n  /**\n   * Type 'textarea' : nombre de lignes.\n   */\n  @Input() rows: number;\n\n  /**\n   * @deprecated (since 1.2) utiliser `customClass` à la place.\n   * Largeur de l'input, `'100%'` par défaut, `'10rem'` par défaut pour un type date.\n   */\n  @Input() width: string;\n\n  /** @deprecated since 1.2 use `type` instead. */\n  get textarea(): boolean {\n    return this.isTextArea();\n  }\n\n  /** @deprecated (@since 1.2) utiliser `type` à la place. */\n  @Input() set textarea(value: boolean) {\n    this.type = value ? DsfrInputTypeConst.TEXTAREA : DsfrInputTypeConst.TEXT;\n  }\n\n  /** @internal */\n  isTextArea() {\n    return this.type === DsfrInputTypeConst.TEXTAREA;\n  }\n\n  /** @internal */\n  hasInputWrap(): boolean {\n    return this.hasButton() || !isStringEmptyOrNull(this.icon);\n  }\n\n  /** @internal */\n  getWrapClasses(): string[] {\n    let classes = ['fr-input-wrap'];\n    if (this.hasButton() && this.inputWrapMode === 'addon') classes.push('fr-input-wrap--addon');\n    if (this.hasButton() && this.inputWrapMode === 'action') classes.push('fr-input-wrap--action');\n    if (this.icon) classes.push(this.icon);\n\n    return classes;\n  }\n\n  /** @internal */\n  onButtonClick(event: Event) {\n    if (this.buttonType != 'submit') this.buttonSelect.emit(event);\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"]}