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

88 lines 19 kB
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { DefaultControlComponent, newUniqueId } from '../../shared'; 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/link/link.component"; export class DsfrFormPasswordComponent extends DefaultControlComponent { /** @internal */ constructor(i18n) { super(); this.i18n = i18n; /** @since 1.6 'current-password' par défaut */ this.autocomplete = 'current-password'; /** Propage l'évènement Event du DOM à la sélection d'un lien. */ this.recoveryRouteSelect = new EventEmitter(); this.label = i18n.t('password.label'); } /** @internal */ ngOnInit() { super.ngOnInit(); this.checkboxId = newUniqueId(); this.messagesGroupId = newUniqueId(); } /** @internal */ getIdRule(rule, i) { let status = 'info'; if (rule.onError === false) { status = 'error'; } else if (rule.onError === true) { status = 'error'; } return `password-${this.inputId}-input-message-${status}-${i}`; } /** @internal */ hasRecovery() { return this.recoveryLink || this.recoveryRoute || this.recoveryRouterLink; } /** @internal */ onRecovery(route) { if (this.recoveryRoute) { this.recoveryRouteSelect.emit(this.recoveryRoute); } } /** @internal */ hasMessages() { return this.validationRules && this.validationRules.length > 0; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrFormPasswordComponent, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DsfrFormPasswordComponent, selector: "dsfr-form-password", inputs: { autocomplete: "autocomplete", validationRules: "validationRules", recoveryLink: "recoveryLink", recoveryTargetLink: "recoveryTargetLink", recoveryRouterLink: "recoveryRouterLink", recoveryRouterLinkActive: "recoveryRouterLinkActive", recoveryRouterLinkExtras: "recoveryRouterLinkExtras", recoveryRoute: "recoveryRoute" }, outputs: { recoveryRouteSelect: "recoveryRouteSelect" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: DsfrFormPasswordComponent, multi: true, }, ], usesInheritance: true, ngImport: i0, template: "<div class=\"fr-password\">\n <label class=\"fr-label\" [for]=\"inputId\">\n {{ label }}\n <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n </label>\n\n <div class=\"fr-input-wrap\">\n <input\n class=\"fr-password__input fr-input\"\n autocapitalize=\"off\"\n autocorrect=\"off\"\n [attr.aria-describedby]=\"hasMessages() ? messagesGroupId : null\"\n aria-required=\"true\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled ?? false\"\n [attr.name]=\"name || null\"\n [autocomplete]=\"autocomplete\"\n [id]=\"inputId\"\n type=\"password\" />\n </div>\n\n <div *ngIf=\"hasMessages()\" class=\"fr-messages-group\" [id]=\"messagesGroupId\" aria-live=\"polite\">\n <p class=\"fr-message\">{{ i18n.t('password.message') }}</p>\n <p\n class=\"fr-message\"\n [id]=\"getIdRule(rule, i)\"\n [ngClass]=\"{\n 'fr-message--error': rule.onError,\n 'fr-message--info': rule.onError === undefined,\n 'fr-message--valid': rule.onError === false\n }\"\n *ngFor=\"let rule of validationRules; let i = index\">\n {{ rule.message }}\n </p>\n </div>\n\n <div class=\"fr-password__checkbox fr-checkbox-group fr-checkbox-group--sm\">\n <input [attr.aria-label]=\"i18n.t('password.aria.label')\" [id]=\"checkboxId\" type=\"checkbox\" />\n <label class=\"fr-password__checkbox fr-label\" [for]=\"checkboxId\"> {{ i18n.t('password.show') }} </label>\n </div>\n\n <p *ngIf=\"hasRecovery()\">\n <dsfr-link\n [label]=\"i18n.t('password.forgotPassword')\"\n [link]=\"recoveryLink\"\n [targetLink]=\"recoveryTargetLink\"\n [route]=\"recoveryRoute\"\n [routePath]=\"recoveryRouterLink\"\n [routerLinkActive]=\"recoveryRouterLinkActive ?? ''\"\n [routerLinkExtras]=\"recoveryRouterLinkExtras\"\n (linkSelect)=\"onRecovery($event)\"></dsfr-link>\n </p>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.DsfrLinkComponent, selector: "dsfr-link", inputs: ["ariaCurrent", "ariaLabel", "ariaControls", "customClass", "disabled", "icon", "iconPosition", "linkId", "label", "link", "linkTarget", "route", "routePath", "routerLinkActive", "routerLinkActiveOptions", "routerLinkExtras", "size", "tooltipMessage", "mode", "targetLink", "routerLink"], outputs: ["linkSelect"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrFormPasswordComponent, decorators: [{ type: Component, args: [{ selector: 'dsfr-form-password', encapsulation: ViewEncapsulation.None, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: DsfrFormPasswordComponent, multi: true, }, ], template: "<div class=\"fr-password\">\n <label class=\"fr-label\" [for]=\"inputId\">\n {{ label }}\n <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n </label>\n\n <div class=\"fr-input-wrap\">\n <input\n class=\"fr-password__input fr-input\"\n autocapitalize=\"off\"\n autocorrect=\"off\"\n [attr.aria-describedby]=\"hasMessages() ? messagesGroupId : null\"\n aria-required=\"true\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled ?? false\"\n [attr.name]=\"name || null\"\n [autocomplete]=\"autocomplete\"\n [id]=\"inputId\"\n type=\"password\" />\n </div>\n\n <div *ngIf=\"hasMessages()\" class=\"fr-messages-group\" [id]=\"messagesGroupId\" aria-live=\"polite\">\n <p class=\"fr-message\">{{ i18n.t('password.message') }}</p>\n <p\n class=\"fr-message\"\n [id]=\"getIdRule(rule, i)\"\n [ngClass]=\"{\n 'fr-message--error': rule.onError,\n 'fr-message--info': rule.onError === undefined,\n 'fr-message--valid': rule.onError === false\n }\"\n *ngFor=\"let rule of validationRules; let i = index\">\n {{ rule.message }}\n </p>\n </div>\n\n <div class=\"fr-password__checkbox fr-checkbox-group fr-checkbox-group--sm\">\n <input [attr.aria-label]=\"i18n.t('password.aria.label')\" [id]=\"checkboxId\" type=\"checkbox\" />\n <label class=\"fr-password__checkbox fr-label\" [for]=\"checkboxId\"> {{ i18n.t('password.show') }} </label>\n </div>\n\n <p *ngIf=\"hasRecovery()\">\n <dsfr-link\n [label]=\"i18n.t('password.forgotPassword')\"\n [link]=\"recoveryLink\"\n [targetLink]=\"recoveryTargetLink\"\n [route]=\"recoveryRoute\"\n [routePath]=\"recoveryRouterLink\"\n [routerLinkActive]=\"recoveryRouterLinkActive ?? ''\"\n [routerLinkExtras]=\"recoveryRouterLinkExtras\"\n (linkSelect)=\"onRecovery($event)\"></dsfr-link>\n </p>\n</div>\n" }] }], ctorParameters: function () { return [{ type: i1.I18nService }]; }, propDecorators: { autocomplete: [{ type: Input }], validationRules: [{ type: Input }], recoveryLink: [{ type: Input }], recoveryTargetLink: [{ type: Input }], recoveryRouterLink: [{ type: Input }], recoveryRouterLinkActive: [{ type: Input }], recoveryRouterLinkExtras: [{ type: Input }], recoveryRoute: [{ type: Input }], recoveryRouteSelect: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-password.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dsfr-components/src/lib/forms/form-password/form-password.component.ts","../../../../../../projects/ngx-dsfr-components/src/lib/forms/form-password/form-password.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAClG,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,uBAAuB,EAA+B,WAAW,EAAE,MAAM,cAAc,CAAC;;;;;;AAejG,MAAM,OAAO,yBAA0B,SAAQ,uBAA+B;IAmC5E,gBAAgB;IAChB,YAAmB,IAAiB;QAClC,KAAK,EAAE,CAAC;QADS,SAAI,GAAJ,IAAI,CAAa;QAnCpC,+CAA+C;QACtC,iBAAY,GAAG,kBAAkB,CAAC;QA2B3C,iEAAiE;QACvD,wBAAmB,GAAG,IAAI,YAAY,EAAU,CAAC;QAQzD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC;IACxC,CAAC;IAED,gBAAgB;IAChB,QAAQ;QACN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,UAAU,GAAG,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,eAAe,GAAG,WAAW,EAAE,CAAC;IACvC,CAAC;IAED,gBAAgB;IAChB,SAAS,CAAC,IAAoC,EAAE,CAAS;QACvD,IAAI,MAAM,GAAW,MAAM,CAAC;QAC5B,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK,EAAE;YAC1B,MAAM,GAAG,OAAO,CAAC;SAClB;aAAM,IAAI,IAAI,CAAC,OAAO,KAAK,IAAI,EAAE;YAChC,MAAM,GAAG,OAAO,CAAC;SAClB;QAED,OAAO,YAAY,IAAI,CAAC,OAAO,kBAAkB,MAAM,IAAI,CAAC,EAAE,CAAC;IACjE,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,kBAAkB,CAAC;IAC5E,CAAC;IAED,gBAAgB;IAChB,UAAU,CAAC,KAAa;QACtB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACnD;IACH,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,OAAO,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;IACjE,CAAC;+GA3EU,yBAAyB;mGAAzB,yBAAyB,kbARzB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,yBAAyB;gBACtC,KAAK,EAAE,IAAI;aACZ;SACF,iDChBH,q4DAqDA;;4FDnCa,yBAAyB;kBAZrC,SAAS;+BACE,oBAAoB,iBAEf,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,2BAA2B;4BACtC,KAAK,EAAE,IAAI;yBACZ;qBACF;kGAIQ,YAAY;sBAApB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBAGG,wBAAwB;sBAAhC,KAAK;gBAGG,wBAAwB;sBAAhC,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGI,mBAAmB;sBAA5B,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NavigationExtras } from '@angular/router';\nimport { DefaultControlComponent, DsfrLinkTarget, I18nService, newUniqueId } from '../../shared';\nimport { DsfrFormPasswordValidationRule } from './form-password.model';\n\n@Component({\n  selector: 'dsfr-form-password',\n  templateUrl: './form-password.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: DsfrFormPasswordComponent,\n      multi: true,\n    },\n  ],\n})\nexport class DsfrFormPasswordComponent extends DefaultControlComponent<string> implements OnInit {\n  /** @since 1.6 'current-password' par défaut */\n  @Input() autocomplete = 'current-password';\n\n  /**\n   * Liste des règles de sécurisation du mot de passe, valides ou en erreur - Optionnel.\n   * Sous la forme [{message: '', onError: false}]\n   */\n  // TODO A discuter renommer validationRules en rules et DsfrFormPasswordValidationRule en DsfrPasswordRule\n  @Input() validationRules: DsfrFormPasswordValidationRule[];\n\n  /** Url de récupération du mot de passe (optionnel) */\n  @Input() recoveryLink: string;\n\n  /** Target du lien. Target par défaut de l'application si la propriété est non renseignée. */\n  @Input() recoveryTargetLink: DsfrLinkTarget;\n\n  /** Path angular géré en tant que directive routerLink. Exclusif avec link et route. Prioritaire sur route. */\n  @Input() recoveryRouterLink: string | string[];\n\n  /** RouterLink: classe utilisée pour la directive routerLink active. */\n  @Input() recoveryRouterLinkActive: string | string[] | undefined;\n\n  /** RouterLink: valeurs additionnelles de navigation pour le routerLink (queryParams, state etc.) */\n  @Input() recoveryRouterLinkExtras: NavigationExtras;\n\n  /** Path interne. Exclusif avec link et routerLink */\n  @Input() recoveryRoute: string;\n\n  /** Propage l'évènement Event du DOM à la sélection d'un lien. */\n  @Output() recoveryRouteSelect = new EventEmitter<string>();\n\n  /** @internal */ checkboxId: string;\n  /** @internal */ messagesGroupId: string;\n\n  /** @internal */\n  constructor(public i18n: I18nService) {\n    super();\n    this.label = i18n.t('password.label');\n  }\n\n  /** @internal */\n  ngOnInit() {\n    super.ngOnInit();\n    this.checkboxId = newUniqueId();\n    this.messagesGroupId = newUniqueId();\n  }\n\n  /** @internal */\n  getIdRule(rule: DsfrFormPasswordValidationRule, i: number): string {\n    let status: string = 'info';\n    if (rule.onError === false) {\n      status = 'error';\n    } else if (rule.onError === true) {\n      status = 'error';\n    }\n\n    return `password-${this.inputId}-input-message-${status}-${i}`;\n  }\n\n  /** @internal */\n  hasRecovery() {\n    return this.recoveryLink || this.recoveryRoute || this.recoveryRouterLink;\n  }\n\n  /** @internal */\n  onRecovery(route: string) {\n    if (this.recoveryRoute) {\n      this.recoveryRouteSelect.emit(this.recoveryRoute);\n    }\n  }\n\n  /** @internal */\n  hasMessages(): boolean {\n    return this.validationRules && this.validationRules.length > 0;\n  }\n}\n","<div class=\"fr-password\">\n  <label class=\"fr-label\" [for]=\"inputId\">\n    {{ label }}\n    <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n  </label>\n\n  <div class=\"fr-input-wrap\">\n    <input\n      class=\"fr-password__input fr-input\"\n      autocapitalize=\"off\"\n      autocorrect=\"off\"\n      [attr.aria-describedby]=\"hasMessages() ? messagesGroupId : null\"\n      aria-required=\"true\"\n      [(ngModel)]=\"value\"\n      [disabled]=\"disabled ?? false\"\n      [attr.name]=\"name || null\"\n      [autocomplete]=\"autocomplete\"\n      [id]=\"inputId\"\n      type=\"password\" />\n  </div>\n\n  <div *ngIf=\"hasMessages()\" class=\"fr-messages-group\" [id]=\"messagesGroupId\" aria-live=\"polite\">\n    <p class=\"fr-message\">{{ i18n.t('password.message') }}</p>\n    <p\n      class=\"fr-message\"\n      [id]=\"getIdRule(rule, i)\"\n      [ngClass]=\"{\n        'fr-message--error': rule.onError,\n        'fr-message--info': rule.onError === undefined,\n        'fr-message--valid': rule.onError === false\n      }\"\n      *ngFor=\"let rule of validationRules; let i = index\">\n      {{ rule.message }}\n    </p>\n  </div>\n\n  <div class=\"fr-password__checkbox fr-checkbox-group fr-checkbox-group--sm\">\n    <input [attr.aria-label]=\"i18n.t('password.aria.label')\" [id]=\"checkboxId\" type=\"checkbox\" />\n    <label class=\"fr-password__checkbox fr-label\" [for]=\"checkboxId\"> {{ i18n.t('password.show') }} </label>\n  </div>\n\n  <p *ngIf=\"hasRecovery()\">\n    <dsfr-link\n      [label]=\"i18n.t('password.forgotPassword')\"\n      [link]=\"recoveryLink\"\n      [targetLink]=\"recoveryTargetLink\"\n      [route]=\"recoveryRoute\"\n      [routePath]=\"recoveryRouterLink\"\n      [routerLinkActive]=\"recoveryRouterLinkActive ?? ''\"\n      [routerLinkExtras]=\"recoveryRouterLinkExtras\"\n      (linkSelect)=\"onRecovery($event)\"></dsfr-link>\n  </p>\n</div>\n"]}