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

124 lines 26.3 kB
import { Component, EventEmitter, Inject, Input, Output, ViewEncapsulation } from '@angular/core'; import { LocalStorage, StorageEnum, isOnBrowser } from '../../shared'; import { DSFR_CONFIG_TOKEN } from '../../shared/config/config-token'; import * as i0 from "@angular/core"; import * as i1 from "../../shared"; import * as i2 from "@angular/common"; import * as i3 from "@angular/forms"; export const DISPLAY_MODAL_ID = 'theme-modal-id'; export class DsfrDisplayComponent { /** @internal */ constructor(config, i18n, elementRef) { this.config = config; this.i18n = i18n; this.elementRef = elementRef; /** * l'identifiant de la modale portant les paramètres d'affichage. */ this.displayId = DISPLAY_MODAL_ID; /** * Événement émis lorsque le thème change avec la valeur du nouveau thème : `light`, `dark` ou `system`. */ this.displayChange = new EventEmitter(); /** @internal */ this.themes = { light: { id: 'theme-light', value: 'light', label: this.i18n.t('display.light.label'), img: 'sun.svg', link: '/pictograms/environment/sun.svg', deprecatedLink: '/sun.svg', }, dark: { id: 'theme-dark', value: 'dark', label: this.i18n.t('display.dark.label'), img: 'moon.svg', link: '/pictograms/environment/moon.svg', deprecatedLink: '/moon.svg', }, system: { id: 'theme-system', value: 'system', label: this.i18n.t('display.system.label'), hint: this.i18n.t('display.system.hint'), img: 'system.svg', link: '/pictograms/system/system.svg', deprecatedLink: '/system.svg', }, }; /** @internal */ this.closeI18n = this.i18n.t('commons.close'); /** @internal */ this.name = 'radios-theme'; /** @internal */ this.themeValues = Object.values(this.themes); this._useDeprecatedLink = false; } get pictoPath() { return this.artworkDirPath; } /** * Chemin des pictogrammes (du composant display) renseigné par le développeur. * * Note: ce chemin doit permettre de récupérer directement les fichiers SVG suivants : moon.svg, sun.svg, system.svg * * @deprecated Use `artworkDirPath` instead. */ set pictoPath(path) { this.artworkDirPath = path; this._useDeprecatedLink = true; } ngOnInit() { this.initDisplayTheme(); if (this.artworkDirPath === undefined) { this.artworkDirPath = this.config.artworkDirPath; } } /** @internal */ onChange() { this.setHtmlSchemeAttribute(this.currentTheme); this.displayChange.emit(this.currentTheme); } /** @internal */ buildSvgPath(theme, sprite) { return this.artworkDirPath + (this._useDeprecatedLink ? theme.deprecatedLink : theme.link) + sprite; } initDisplayTheme() { if (!isOnBrowser()) return; // Si l’utilisateur effectue une modification, son choix est conservé (dans le local storage) pour les visites ultérieures. let savedTheme = LocalStorage.get(StorageEnum.SCHEME); if (savedTheme) { this.setHtmlSchemeAttribute(savedTheme); } // Sinon on prend le theme de la balise HTML else { const nativeElt = this.elementRef?.nativeElement; const html = nativeElt?.ownerDocument?.documentElement; savedTheme = html?.getAttribute('data-fr-scheme'); } this.currentTheme = savedTheme || 'system'; } setHtmlSchemeAttribute(value) { const nativeElt = this.elementRef?.nativeElement; const html = nativeElt?.ownerDocument?.documentElement; html?.setAttribute('data-fr-scheme', value); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrDisplayComponent, deps: [{ token: DSFR_CONFIG_TOKEN }, { token: i1.I18nService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DsfrDisplayComponent, selector: "dsfr-display", inputs: { displayId: "displayId", artworkDirPath: "artworkDirPath", pictoPath: "pictoPath" }, outputs: { displayChange: "displayChange" }, ngImport: i0, template: "<dialog [id]=\"displayId\" class=\"fr-modal\" role=\"dialog\" [attr.aria-labelledby]=\"displayId + '-title'\">\n <div class=\"fr-container fr-container--fluid fr-container-md\">\n <div class=\"fr-grid-row fr-grid-row--center\">\n <div class=\"fr-col-12 fr-col-md-6 fr-col-lg-4\">\n <div class=\"fr-modal__body\">\n <div class=\"fr-modal__header\">\n <button type=\"button\" class=\"fr-btn--close fr-btn\" [attr.aria-controls]=\"displayId\" [title]=\"closeI18n\">\n {{ closeI18n }}\n </button>\n </div>\n <div class=\"fr-modal__content\">\n <h1 [id]=\"displayId + '-title'\" class=\"fr-modal__title\">{{ i18n.t('display.heading') }}</h1>\n <!-- BUG: classe fr-display inexistante c\u00F4t\u00E9 DSFR 1.11 mais utilis\u00E9 dans leur template -->\n <div [id]=\"displayId + '-fr-display'\" class=\"fr-display\">\n <fieldset class=\"fr-fieldset\" [id]=\"displayId + '-display-fieldset'\">\n <legend\n class=\"fr-fieldset__legend--regular fr-fieldset__legend\"\n [id]=\"displayId + '-display-fieldset-legend'\">\n {{ i18n.t('display.hint') }}\n </legend>\n <!-- Groupe radios ------------------------------------------------------------------------------------>\n <!-- TODO A mutualiser avec les radios rich quand on pourra -->\n <div *ngFor=\"let radio of themeValues\" class=\"fr-fieldset__element\">\n <div class=\"fr-radio-group fr-radio-rich\">\n <input\n type=\"radio\"\n [id]=\"radio.id\"\n [name]=\"name\"\n [value]=\"radio.value\"\n [(ngModel)]=\"currentTheme\"\n (ngModelChange)=\"onChange()\" />\n <label class=\"fr-label\" [for]=\"radio.id\">{{ radio.label }}</label>\n <div class=\"fr-radio-rich__img\">\n <svg aria-hidden=\"true\" class=\"fr-artwork\" viewBox=\"0 0 80 80\" width=\"80px\" height=\"80px\">\n <use\n class=\"fr-artwork-decorative\"\n [attr.href]=\"buildSvgPath(radio, '#artwork-decorative')\"></use>\n <use class=\"fr-artwork-minor\" [attr.href]=\"buildSvgPath(radio, '#artwork-minor')\"></use>\n <use class=\"fr-artwork-major\" [attr.href]=\"buildSvgPath(radio, '#artwork-major')\"></use>\n </svg>\n </div>\n </div>\n </div>\n <!----------------------------------------------------------------------------------------------------->\n </fieldset>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</dialog>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { 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.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { 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"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrDisplayComponent, decorators: [{ type: Component, args: [{ selector: 'dsfr-display', encapsulation: ViewEncapsulation.None, template: "<dialog [id]=\"displayId\" class=\"fr-modal\" role=\"dialog\" [attr.aria-labelledby]=\"displayId + '-title'\">\n <div class=\"fr-container fr-container--fluid fr-container-md\">\n <div class=\"fr-grid-row fr-grid-row--center\">\n <div class=\"fr-col-12 fr-col-md-6 fr-col-lg-4\">\n <div class=\"fr-modal__body\">\n <div class=\"fr-modal__header\">\n <button type=\"button\" class=\"fr-btn--close fr-btn\" [attr.aria-controls]=\"displayId\" [title]=\"closeI18n\">\n {{ closeI18n }}\n </button>\n </div>\n <div class=\"fr-modal__content\">\n <h1 [id]=\"displayId + '-title'\" class=\"fr-modal__title\">{{ i18n.t('display.heading') }}</h1>\n <!-- BUG: classe fr-display inexistante c\u00F4t\u00E9 DSFR 1.11 mais utilis\u00E9 dans leur template -->\n <div [id]=\"displayId + '-fr-display'\" class=\"fr-display\">\n <fieldset class=\"fr-fieldset\" [id]=\"displayId + '-display-fieldset'\">\n <legend\n class=\"fr-fieldset__legend--regular fr-fieldset__legend\"\n [id]=\"displayId + '-display-fieldset-legend'\">\n {{ i18n.t('display.hint') }}\n </legend>\n <!-- Groupe radios ------------------------------------------------------------------------------------>\n <!-- TODO A mutualiser avec les radios rich quand on pourra -->\n <div *ngFor=\"let radio of themeValues\" class=\"fr-fieldset__element\">\n <div class=\"fr-radio-group fr-radio-rich\">\n <input\n type=\"radio\"\n [id]=\"radio.id\"\n [name]=\"name\"\n [value]=\"radio.value\"\n [(ngModel)]=\"currentTheme\"\n (ngModelChange)=\"onChange()\" />\n <label class=\"fr-label\" [for]=\"radio.id\">{{ radio.label }}</label>\n <div class=\"fr-radio-rich__img\">\n <svg aria-hidden=\"true\" class=\"fr-artwork\" viewBox=\"0 0 80 80\" width=\"80px\" height=\"80px\">\n <use\n class=\"fr-artwork-decorative\"\n [attr.href]=\"buildSvgPath(radio, '#artwork-decorative')\"></use>\n <use class=\"fr-artwork-minor\" [attr.href]=\"buildSvgPath(radio, '#artwork-minor')\"></use>\n <use class=\"fr-artwork-major\" [attr.href]=\"buildSvgPath(radio, '#artwork-major')\"></use>\n </svg>\n </div>\n </div>\n </div>\n <!----------------------------------------------------------------------------------------------------->\n </fieldset>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</dialog>\n" }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DSFR_CONFIG_TOKEN] }] }, { type: i1.I18nService }, { type: i0.ElementRef }]; }, propDecorators: { displayId: [{ type: Input }], artworkDirPath: [{ type: Input }], displayChange: [{ type: Output }], pictoPath: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dsfr-components/src/lib/components/display/display.component.ts","../../../../../../projects/ngx-dsfr-components/src/lib/components/display/display.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACtH,OAAO,EAAe,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AACnF,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;;;;;AAGrE,MAAM,CAAC,MAAM,gBAAgB,GAAG,gBAAgB,CAAC;AASjD,MAAM,OAAO,oBAAoB;IA2D/B,gBAAgB;IAChB,YACqC,MAAkB,EAC9C,IAAiB,EAChB,UAAsB;QAFK,WAAM,GAAN,MAAM,CAAY;QAC9C,SAAI,GAAJ,IAAI,CAAa;QAChB,eAAU,GAAV,UAAU,CAAY;QA9DhC;;WAEG;QACM,cAAS,GAAG,gBAAgB,CAAC;QAOtC;;WAEG;QACO,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QASrD,gBAAgB;QACP,WAAM,GAAG;YAChB,KAAK,EAAE;gBACL,EAAE,EAAE,aAAa;gBACjB,KAAK,EAAE,OAAO;gBACd,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,qBAAqB,CAAC;gBACzC,GAAG,EAAE,SAAS;gBACd,IAAI,EAAE,iCAAiC;gBACvC,cAAc,EAAE,UAAU;aAC3B;YACD,IAAI,EAAE;gBACJ,EAAE,EAAE,YAAY;gBAChB,KAAK,EAAE,MAAM;gBACb,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,oBAAoB,CAAC;gBACxC,GAAG,EAAE,UAAU;gBACf,IAAI,EAAE,kCAAkC;gBACxC,cAAc,EAAE,WAAW;aAC5B;YACD,MAAM,EAAE;gBACN,EAAE,EAAE,cAAc;gBAClB,KAAK,EAAE,QAAQ;gBACf,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,sBAAsB,CAAC;gBAC1C,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,qBAAqB,CAAC;gBACxC,GAAG,EAAE,YAAY;gBACjB,IAAI,EAAE,+BAA+B;gBACrC,cAAc,EAAE,aAAa;aAC9B;SACF,CAAC;QAEF,gBAAgB,CAAU,cAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACnE,gBAAgB,CAAC,SAAI,GAAG,cAAc,CAAC;QACvC,gBAAgB,CAAC,gBAAW,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAGlD,uBAAkB,GAAG,KAAK,CAAC;IAOhC,CAAC;IAEJ,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED;;;;;;OAMG;IACH,IAAa,SAAS,CAAC,IAAY;QACjC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;IACjC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,cAAc,KAAK,SAAS,EAAE;YACrC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC;SAClD;IACH,CAAC;IAED,gBAAgB;IAChB,QAAQ;QACN,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC/C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7C,CAAC;IAED,gBAAgB;IAChB,YAAY,CAAC,KAAU,EAAE,MAAc;QACrC,OAAO,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;IACtG,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,WAAW,EAAE;YAAE,OAAO;QAE3B,2HAA2H;QAC3H,IAAI,UAAU,GAAiB,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QACpE,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC;SACzC;QAED,4CAA4C;aACvC;YACH,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC;YACjD,MAAM,IAAI,GAAG,SAAS,EAAE,aAAa,EAAE,eAAe,CAAC;YACvD,UAAU,GAAG,IAAI,EAAE,YAAY,CAAC,gBAAgB,CAAC,CAAC;SACnD;QAED,IAAI,CAAC,YAAY,GAAG,UAAU,IAAI,QAAQ,CAAC;IAC7C,CAAC;IAEO,sBAAsB,CAAC,KAAmB;QAChD,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC;QACjD,MAAM,IAAI,GAAG,SAAS,EAAE,aAAa,EAAE,eAAe,CAAC;QACvD,IAAI,EAAE,YAAY,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;IAC9C,CAAC;+GA3HU,oBAAoB,kBA6DrB,iBAAiB;mGA7DhB,oBAAoB,+LCdjC,q5FAoDA;;4FDtCa,oBAAoB;kBALhC,SAAS;+BACE,cAAc,iBAET,iBAAiB,CAAC,IAAI;;0BA+DlC,MAAM;2BAAC,iBAAiB;+FAzDlB,SAAS;sBAAjB,KAAK;gBAKG,cAAc;sBAAtB,KAAK;gBAKI,aAAa;sBAAtB,MAAM;gBA+DM,SAAS;sBAArB,KAAK","sourcesContent":["import { Component, ElementRef, EventEmitter, Inject, Input, OnInit, Output, ViewEncapsulation } from '@angular/core';\nimport { I18nService, LocalStorage, StorageEnum, isOnBrowser } from '../../shared';\nimport { DSFR_CONFIG_TOKEN } from '../../shared/config/config-token';\nimport { DsfrConfig } from '../../shared/config/config.model';\n\nexport const DISPLAY_MODAL_ID = 'theme-modal-id';\n\ntype DisplayTheme = 'light' | 'dark' | 'system';\n\n@Component({\n  selector: 'dsfr-display',\n  templateUrl: './display.component.html',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DsfrDisplayComponent implements OnInit {\n  /**\n   * l'identifiant de la modale portant les paramètres d'affichage.\n   */\n  @Input() displayId = DISPLAY_MODAL_ID;\n\n  /**\n   * Chemin vers le répertoire exposant les pictogrammes illustratifs DSFR.\n   */\n  @Input() artworkDirPath: string;\n\n  /**\n   * Événement émis lorsque le thème change avec la valeur du nouveau thème : `light`, `dark` ou `system`.\n   */\n  @Output() displayChange = new EventEmitter<string>();\n\n  /**\n   * Thème courant du composant.\n   *\n   * @internal\n   */\n  currentTheme: DisplayTheme;\n\n  /** @internal */\n  readonly themes = {\n    light: {\n      id: 'theme-light',\n      value: 'light',\n      label: this.i18n.t('display.light.label'),\n      img: 'sun.svg',\n      link: '/pictograms/environment/sun.svg',\n      deprecatedLink: '/sun.svg',\n    },\n    dark: {\n      id: 'theme-dark',\n      value: 'dark',\n      label: this.i18n.t('display.dark.label'),\n      img: 'moon.svg',\n      link: '/pictograms/environment/moon.svg',\n      deprecatedLink: '/moon.svg',\n    },\n    system: {\n      id: 'theme-system',\n      value: 'system',\n      label: this.i18n.t('display.system.label'),\n      hint: this.i18n.t('display.system.hint'),\n      img: 'system.svg',\n      link: '/pictograms/system/system.svg',\n      deprecatedLink: '/system.svg',\n    },\n  };\n\n  /** @internal */ readonly closeI18n = this.i18n.t('commons.close');\n  /** @internal */ name = 'radios-theme';\n  /** @internal */ themeValues = Object.values(this.themes);\n  /** @internal */ _svgRootPath: string;\n\n  private _useDeprecatedLink = false;\n\n  /** @internal */\n  constructor(\n    @Inject(DSFR_CONFIG_TOKEN) private config: DsfrConfig,\n    public i18n: I18nService,\n    private elementRef: ElementRef,\n  ) {}\n\n  get pictoPath(): string {\n    return this.artworkDirPath;\n  }\n\n  /**\n   * Chemin des pictogrammes (du composant display) renseigné par le développeur.\n   *\n   * Note: ce chemin doit permettre de récupérer directement les fichiers SVG suivants : moon.svg, sun.svg, system.svg\n   *\n   * @deprecated Use `artworkDirPath` instead.\n   */\n  @Input() set pictoPath(path: string) {\n    this.artworkDirPath = path;\n    this._useDeprecatedLink = true;\n  }\n\n  ngOnInit(): void {\n    this.initDisplayTheme();\n    if (this.artworkDirPath === undefined) {\n      this.artworkDirPath = this.config.artworkDirPath;\n    }\n  }\n\n  /** @internal */\n  onChange() {\n    this.setHtmlSchemeAttribute(this.currentTheme);\n    this.displayChange.emit(this.currentTheme);\n  }\n\n  /** @internal */\n  buildSvgPath(theme: any, sprite: string) {\n    return this.artworkDirPath + (this._useDeprecatedLink ? theme.deprecatedLink : theme.link) + sprite;\n  }\n\n  private initDisplayTheme(): void {\n    if (!isOnBrowser()) return;\n\n    // Si l’utilisateur effectue une modification, son choix est conservé (dans le local storage) pour les visites ultérieures.\n    let savedTheme = <DisplayTheme>LocalStorage.get(StorageEnum.SCHEME);\n    if (savedTheme) {\n      this.setHtmlSchemeAttribute(savedTheme);\n    }\n\n    // Sinon on prend le theme de la balise HTML\n    else {\n      const nativeElt = this.elementRef?.nativeElement;\n      const html = nativeElt?.ownerDocument?.documentElement;\n      savedTheme = html?.getAttribute('data-fr-scheme');\n    }\n\n    this.currentTheme = savedTheme || 'system';\n  }\n\n  private setHtmlSchemeAttribute(value: DisplayTheme) {\n    const nativeElt = this.elementRef?.nativeElement;\n    const html = nativeElt?.ownerDocument?.documentElement;\n    html?.setAttribute('data-fr-scheme', value);\n  }\n}\n","<dialog [id]=\"displayId\" class=\"fr-modal\" role=\"dialog\" [attr.aria-labelledby]=\"displayId + '-title'\">\n  <div class=\"fr-container fr-container--fluid fr-container-md\">\n    <div class=\"fr-grid-row fr-grid-row--center\">\n      <div class=\"fr-col-12 fr-col-md-6 fr-col-lg-4\">\n        <div class=\"fr-modal__body\">\n          <div class=\"fr-modal__header\">\n            <button type=\"button\" class=\"fr-btn--close fr-btn\" [attr.aria-controls]=\"displayId\" [title]=\"closeI18n\">\n              {{ closeI18n }}\n            </button>\n          </div>\n          <div class=\"fr-modal__content\">\n            <h1 [id]=\"displayId + '-title'\" class=\"fr-modal__title\">{{ i18n.t('display.heading') }}</h1>\n            <!-- BUG: classe fr-display inexistante côté DSFR 1.11 mais utilisé dans leur template -->\n            <div [id]=\"displayId + '-fr-display'\" class=\"fr-display\">\n              <fieldset class=\"fr-fieldset\" [id]=\"displayId + '-display-fieldset'\">\n                <legend\n                  class=\"fr-fieldset__legend--regular fr-fieldset__legend\"\n                  [id]=\"displayId + '-display-fieldset-legend'\">\n                  {{ i18n.t('display.hint') }}\n                </legend>\n                <!-- Groupe radios ------------------------------------------------------------------------------------>\n                <!-- TODO A mutualiser avec les radios rich quand on pourra -->\n                <div *ngFor=\"let radio of themeValues\" class=\"fr-fieldset__element\">\n                  <div class=\"fr-radio-group fr-radio-rich\">\n                    <input\n                      type=\"radio\"\n                      [id]=\"radio.id\"\n                      [name]=\"name\"\n                      [value]=\"radio.value\"\n                      [(ngModel)]=\"currentTheme\"\n                      (ngModelChange)=\"onChange()\" />\n                    <label class=\"fr-label\" [for]=\"radio.id\">{{ radio.label }}</label>\n                    <div class=\"fr-radio-rich__img\">\n                      <svg aria-hidden=\"true\" class=\"fr-artwork\" viewBox=\"0 0 80 80\" width=\"80px\" height=\"80px\">\n                        <use\n                          class=\"fr-artwork-decorative\"\n                          [attr.href]=\"buildSvgPath(radio, '#artwork-decorative')\"></use>\n                        <use class=\"fr-artwork-minor\" [attr.href]=\"buildSvgPath(radio, '#artwork-minor')\"></use>\n                        <use class=\"fr-artwork-major\" [attr.href]=\"buildSvgPath(radio, '#artwork-major')\"></use>\n                      </svg>\n                    </div>\n                  </div>\n                </div>\n                <!----------------------------------------------------------------------------------------------------->\n              </fieldset>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</dialog>\n"]}