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

78 lines 18 kB
import { CommonModule } from '@angular/common'; import { Component, forwardRef, Input, ViewEncapsulation } from '@angular/core'; import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms'; import { DefaultControlComponent, DsfrSizeConst } from '../../shared'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; export class DsfrRangeComponent extends DefaultControlComponent { constructor() { super(); /** Valeur minimale possible */ this.min = 0; /** Valeur max possible */ this.max = 100; /** Ne pas afficher le minimum et le maximum */ this.hideMinMax = false; /** Désactiver le curseur */ this.disabled = false; /** @internal Curseur double */ this.double = false; } get hintId() { return this.inputId + '-hint-text'; } /**@internal */ isDouble() { return Array.isArray(this.value); } /** @internal */ isSmall() { return this.size == DsfrSizeConst.SM; } /** @internal */ getValue(index) { return Array.isArray(this.value) ? this.value[index] : undefined; } /** @internal */ onInputChange(index, value) { if (Array.isArray(this.value)) { this.value[index] = value; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DsfrRangeComponent, isStandalone: true, selector: "dsfr-range", inputs: { min: "min", max: "max", hideMinMax: "hideMinMax", size: "size", prefix: "prefix", suffix: "suffix", disabled: "disabled", error: "error" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DsfrRangeComponent), multi: true, }, ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"fr-range-group\"\n id=\"{{ inputId }}-group\"\n [ngClass]=\"{ 'fr-range-group--disabled': disabled, 'fr-range-group--error': error }\">\n <label class=\"fr-label\">\n <ng-container *ngIf=\"label\">{{ label }}</ng-container>\n <ng-content *ngIf=\"!label\"></ng-content>\n <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n </label>\n <div\n class=\"fr-range\"\n [attr.data-fr-prefix]=\"prefix\"\n [attr.data-fr-suffix]=\"suffix\"\n [ngClass]=\"{ 'fr-range--double': isDouble(), 'fr-range--sm': isSmall() }\">\n <span class=\"fr-range__output\">{{ value }}</span>\n <ng-container *ngIf=\"!isDouble()\">\n <input\n id=\"{{ inputId }}\"\n name=\"{{ inputId }}\"\n type=\"range\"\n [attr.aria-labelledby]=\"inputId + '-label'\"\n min=\"{{ min }}\"\n max=\"{{ max }}\"\n [disabled]=\"disabled ?? false\"\n [attr.value]=\"value\"\n [(ngModel)]=\"value\"\n [attr.aria-describedby]=\"inputId + '-messages'\" />\n </ng-container>\n <ng-container *ngIf=\"isDouble()\">\n <input\n id=\"{{ inputId }}\"\n name=\"{{ inputId }}\"\n type=\"range\"\n [attr.aria-labelledby]=\"inputId + '-label'\"\n min=\"{{ min }}\"\n max=\"{{ max }}\"\n [disabled]=\"disabled ?? false\"\n [attr.value]=\"getValue(0)\"\n [ngModel]=\"getValue(0)\"\n (ngModelChange)=\"onInputChange(0, $event)\"\n [attr.aria-describedby]=\"inputId + '-messages'\" />\n <input\n id=\"{{ inputId }}-2\"\n name=\"{{ inputId }}-2\"\n type=\"range\"\n [attr.aria-labelledby]=\"inputId + '-label'\"\n max=\"{{ max }}\"\n [disabled]=\"disabled ?? false\"\n [attr.value]=\"getValue(1)\"\n [ngModel]=\"getValue(1)\"\n (ngModelChange)=\"onInputChange(1, $event)\"\n [attr.aria-describedby]=\"inputId + '-messages'\" />\n </ng-container>\n\n <ng-container *ngIf=\"!hideMinMax\">\n <span class=\"fr-range__min\" aria-hidden=\"true\">\n {{ min }}\n </span>\n <span class=\"fr-range__max\" aria-hidden=\"true\">\n {{ max }}\n </span>\n </ng-container>\n </div>\n <div class=\"fr-messages-group\" id=\"{{ inputId }}-messages\" aria-live=\"polite\">\n <p *ngIf=\"error\" class=\"fr-message fr-message--error\" id=\"range-2310-message-error\">\n {{ error }}\n </p>\n </div>\n</div>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { 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.RangeValueAccessor, selector: "input[type=range][formControlName],input[type=range][formControl],input[type=range][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrRangeComponent, decorators: [{ type: Component, args: [{ selector: 'dsfr-range', encapsulation: ViewEncapsulation.None, imports: [CommonModule, FormsModule], standalone: true, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DsfrRangeComponent), multi: true, }, ], template: "<div\n class=\"fr-range-group\"\n id=\"{{ inputId }}-group\"\n [ngClass]=\"{ 'fr-range-group--disabled': disabled, 'fr-range-group--error': error }\">\n <label class=\"fr-label\">\n <ng-container *ngIf=\"label\">{{ label }}</ng-container>\n <ng-content *ngIf=\"!label\"></ng-content>\n <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n </label>\n <div\n class=\"fr-range\"\n [attr.data-fr-prefix]=\"prefix\"\n [attr.data-fr-suffix]=\"suffix\"\n [ngClass]=\"{ 'fr-range--double': isDouble(), 'fr-range--sm': isSmall() }\">\n <span class=\"fr-range__output\">{{ value }}</span>\n <ng-container *ngIf=\"!isDouble()\">\n <input\n id=\"{{ inputId }}\"\n name=\"{{ inputId }}\"\n type=\"range\"\n [attr.aria-labelledby]=\"inputId + '-label'\"\n min=\"{{ min }}\"\n max=\"{{ max }}\"\n [disabled]=\"disabled ?? false\"\n [attr.value]=\"value\"\n [(ngModel)]=\"value\"\n [attr.aria-describedby]=\"inputId + '-messages'\" />\n </ng-container>\n <ng-container *ngIf=\"isDouble()\">\n <input\n id=\"{{ inputId }}\"\n name=\"{{ inputId }}\"\n type=\"range\"\n [attr.aria-labelledby]=\"inputId + '-label'\"\n min=\"{{ min }}\"\n max=\"{{ max }}\"\n [disabled]=\"disabled ?? false\"\n [attr.value]=\"getValue(0)\"\n [ngModel]=\"getValue(0)\"\n (ngModelChange)=\"onInputChange(0, $event)\"\n [attr.aria-describedby]=\"inputId + '-messages'\" />\n <input\n id=\"{{ inputId }}-2\"\n name=\"{{ inputId }}-2\"\n type=\"range\"\n [attr.aria-labelledby]=\"inputId + '-label'\"\n max=\"{{ max }}\"\n [disabled]=\"disabled ?? false\"\n [attr.value]=\"getValue(1)\"\n [ngModel]=\"getValue(1)\"\n (ngModelChange)=\"onInputChange(1, $event)\"\n [attr.aria-describedby]=\"inputId + '-messages'\" />\n </ng-container>\n\n <ng-container *ngIf=\"!hideMinMax\">\n <span class=\"fr-range__min\" aria-hidden=\"true\">\n {{ min }}\n </span>\n <span class=\"fr-range__max\" aria-hidden=\"true\">\n {{ max }}\n </span>\n </ng-container>\n </div>\n <div class=\"fr-messages-group\" id=\"{{ inputId }}-messages\" aria-live=\"polite\">\n <p *ngIf=\"error\" class=\"fr-message fr-message--error\" id=\"range-2310-message-error\">\n {{ error }}\n </p>\n </div>\n</div>\n" }] }], ctorParameters: function () { return []; }, propDecorators: { min: [{ type: Input }], max: [{ type: Input }], hideMinMax: [{ type: Input }], size: [{ type: Input }], prefix: [{ type: Input }], suffix: [{ type: Input }], disabled: [{ type: Input }], error: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dsfr-components/src/lib/components/range/range.component.ts","../../../../../../projects/ngx-dsfr-components/src/lib/components/range/range.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAChF,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAY,aAAa,EAAE,MAAM,cAAc,CAAC;;;;AAgBhF,MAAM,OAAO,kBAAmB,SAAQ,uBAAkD;IA+BxF;QACE,KAAK,EAAE,CAAC;QA/BV,+BAA+B;QACtB,QAAG,GAAW,CAAC,CAAC;QAEzB,0BAA0B;QACjB,QAAG,GAAW,GAAG,CAAC;QAE3B,gDAAgD;QACvC,eAAU,GAAY,KAAK,CAAC;QAcrC,4BAA4B;QACnB,aAAQ,GAAY,KAAK,CAAC;QAKnC,gCAAgC;QAChC,WAAM,GAAY,KAAK,CAAC;IAIxB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC;IACrC,CAAC;IAED,eAAe;IACf,QAAQ;QACN,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,gBAAgB;IAChB,OAAO;QACL,OAAO,IAAI,CAAC,IAAI,IAAI,aAAa,CAAC,EAAE,CAAC;IACvC,CAAC;IAED,gBAAgB;IAChB,QAAQ,CAAC,KAAa;QACpB,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACnE,CAAC;IAED,gBAAgB;IAChB,aAAa,CAAC,KAAa,EAAE,KAAa;QACxC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC7B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;SAC3B;IACH,CAAC;+GA3DU,kBAAkB;mGAAlB,kBAAkB,+MARlB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;gBACjD,KAAK,EAAE,IAAI;aACZ;SACF,iDCjBH,y6EAqEA,2CD5DY,YAAY,gOAAE,WAAW;;4FAUxB,kBAAkB;kBAd9B,SAAS;+BACE,YAAY,iBAEP,iBAAiB,CAAC,IAAI,WAC5B,CAAC,YAAY,EAAE,WAAW,CAAC,cACxB,IAAI,aACL;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACZ;qBACF;0EAIQ,GAAG;sBAAX,KAAK;gBAGG,GAAG;sBAAX,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAMG,IAAI;sBAAZ,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,KAAK;sBAAb,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, forwardRef, Input, ViewEncapsulation } from '@angular/core';\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DefaultControlComponent, DsfrSize, DsfrSizeConst } from '../../shared';\n\n@Component({\n  selector: 'dsfr-range',\n  templateUrl: './range.component.html',\n  encapsulation: ViewEncapsulation.None,\n  imports: [CommonModule, FormsModule],\n  standalone: true,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DsfrRangeComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DsfrRangeComponent extends DefaultControlComponent<number | [number, number]> {\n  /** Valeur minimale possible */\n  @Input() min: number = 0;\n\n  /** Valeur max possible */\n  @Input() max: number = 100;\n\n  /** Ne pas afficher le minimum et le maximum  */\n  @Input() hideMinMax: boolean = false;\n\n  /** Incrément que doit suivre la valeur (1 par défaut)  */\n  // @Input() step: number | undefined;\n\n  /** Taille du curseur (SM et MD possibles, MD par défaut) */\n  @Input() size: DsfrSize;\n\n  /** Préfixe affiché avant les valeurs  */\n  @Input() prefix: string | undefined;\n\n  /** Suffixe affiché après les valeurs  */\n  @Input() suffix: string | undefined;\n\n  /** Désactiver le curseur */\n  @Input() disabled: boolean = false;\n\n  /** Affiche un message d'erreur  */\n  @Input() error: string | undefined;\n\n  /** @internal Curseur double  */\n  double: boolean = false;\n\n  constructor() {\n    super();\n  }\n\n  get hintId() {\n    return this.inputId + '-hint-text';\n  }\n\n  /**@internal */\n  isDouble(): boolean {\n    return Array.isArray(this.value);\n  }\n\n  /** @internal */\n  isSmall(): boolean {\n    return this.size == DsfrSizeConst.SM;\n  }\n\n  /** @internal */\n  getValue(index: number) {\n    return Array.isArray(this.value) ? this.value[index] : undefined;\n  }\n\n  /** @internal */\n  onInputChange(index: number, value: number) {\n    if (Array.isArray(this.value)) {\n      this.value[index] = value;\n    }\n  }\n}\n","<div\n  class=\"fr-range-group\"\n  id=\"{{ inputId }}-group\"\n  [ngClass]=\"{ 'fr-range-group--disabled': disabled, 'fr-range-group--error': error }\">\n  <label class=\"fr-label\">\n    <ng-container *ngIf=\"label\">{{ label }}</ng-container>\n    <ng-content *ngIf=\"!label\"></ng-content>\n    <span *ngIf=\"hint\" class=\"fr-hint-text\">{{ hint }}</span>\n  </label>\n  <div\n    class=\"fr-range\"\n    [attr.data-fr-prefix]=\"prefix\"\n    [attr.data-fr-suffix]=\"suffix\"\n    [ngClass]=\"{ 'fr-range--double': isDouble(), 'fr-range--sm': isSmall() }\">\n    <span class=\"fr-range__output\">{{ value }}</span>\n    <ng-container *ngIf=\"!isDouble()\">\n      <input\n        id=\"{{ inputId }}\"\n        name=\"{{ inputId }}\"\n        type=\"range\"\n        [attr.aria-labelledby]=\"inputId + '-label'\"\n        min=\"{{ min }}\"\n        max=\"{{ max }}\"\n        [disabled]=\"disabled ?? false\"\n        [attr.value]=\"value\"\n        [(ngModel)]=\"value\"\n        [attr.aria-describedby]=\"inputId + '-messages'\" />\n    </ng-container>\n    <ng-container *ngIf=\"isDouble()\">\n      <input\n        id=\"{{ inputId }}\"\n        name=\"{{ inputId }}\"\n        type=\"range\"\n        [attr.aria-labelledby]=\"inputId + '-label'\"\n        min=\"{{ min }}\"\n        max=\"{{ max }}\"\n        [disabled]=\"disabled ?? false\"\n        [attr.value]=\"getValue(0)\"\n        [ngModel]=\"getValue(0)\"\n        (ngModelChange)=\"onInputChange(0, $event)\"\n        [attr.aria-describedby]=\"inputId + '-messages'\" />\n      <input\n        id=\"{{ inputId }}-2\"\n        name=\"{{ inputId }}-2\"\n        type=\"range\"\n        [attr.aria-labelledby]=\"inputId + '-label'\"\n        max=\"{{ max }}\"\n        [disabled]=\"disabled ?? false\"\n        [attr.value]=\"getValue(1)\"\n        [ngModel]=\"getValue(1)\"\n        (ngModelChange)=\"onInputChange(1, $event)\"\n        [attr.aria-describedby]=\"inputId + '-messages'\" />\n    </ng-container>\n\n    <ng-container *ngIf=\"!hideMinMax\">\n      <span class=\"fr-range__min\" aria-hidden=\"true\">\n        {{ min }}\n      </span>\n      <span class=\"fr-range__max\" aria-hidden=\"true\">\n        {{ max }}\n      </span>\n    </ng-container>\n  </div>\n  <div class=\"fr-messages-group\" id=\"{{ inputId }}-messages\" aria-live=\"polite\">\n    <p *ngIf=\"error\" class=\"fr-message fr-message--error\" id=\"range-2310-message-error\">\n      {{ error }}\n    </p>\n  </div>\n</div>\n"]}