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

123 lines 16.3 kB
import { Component, ContentChildren, Input, ViewEncapsulation, } from '@angular/core'; import { DomUtils, DsfrPositionConst, DsfrSizeConst } from '../../shared'; import { DsfrButtonComponent } from '../button'; import { DsfrAlignConst, DsfrInlineConst } from './buttons-group.model'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class DsfrButtonsGroupComponent { constructor(_elementRef) { this._elementRef = _elementRef; /** * Permet de basculer la disposition des boutons en mode horizontal. * En mode vertical, mode par défaut, les boutons prennent 100% de la largeur du conteneur. */ this.inline = DsfrInlineConst.NEVER; /** * Permet de mettre automatiquement tous les boutons d’un groupe à la même largeur. * Cela permet une uniformité des boutons en mode horizontal. * (en mode vertical, les boutons prennent 100% de la largeur du conteneur) * Cette option peut être combinée avec la propriété d'alignement. */ this.equisized = false; /** Taille des boutons du groupe. */ this.size = DsfrSizeConst.MD; } get iconPosition() { return this._iconPosition; } /** * Positionnement (gauche ou droite) au niveau du groupe des icônes dans les boutons qui * contiennent à la fois une icône et un label. */ set iconPosition(value) { this._iconPosition = value; this.updateButtonsIconPosition(); } /** * Cette méthode calcule les styles du composant en évitant les magic strings. * @internal */ getClasses() { let classes = []; // Inline class switch (this.inline) { case 'always': classes.push('fr-btns-group--inline'); break; case 'LG': classes.push('fr-btns-group--inline-lg'); break; case 'MD': classes.push('fr-btns-group--inline-md'); break; case 'SM': classes.push('fr-btns-group--inline-sm'); break; default: break; } // Alignment class switch (this.alignment) { case DsfrAlignConst.CENTER: classes.push('fr-btns-group--center'); break; case DsfrAlignConst.BETWEEN: classes.push('fr-btns-group--between'); break; case DsfrAlignConst.RIGHT: classes.push('fr-btns-group--right'); break; case DsfrAlignConst.REVERSE: classes.push('fr-btns-group--inline-reverse', 'fr-btns-group--right'); break; default: break; } // Size class if (this.size === DsfrSizeConst.SM) { classes.push('fr-btns-group--sm'); } else if (this.size === DsfrSizeConst.LG) { classes.push('fr-btns-group--lg'); } // Equisized class if (this.equisized) { classes.push('fr-btns-group--equisized'); } // IconPosition class if (this._iconPosition) { classes.push(this._iconPosition === DsfrPositionConst.LEFT ? 'fr-btns-group--icon-left' : 'fr-btns-group--icon-right'); } return classes; } ngAfterViewInit() { // Position des icônes de boutons this.updateButtonsIconPosition(); // Ajout de <li> autour des boutons DomUtils.surroundChildWithli(this._elementRef, 'dsfr-button'); } /** On force la position des icônes des boutons. */ updateButtonsIconPosition() { this.buttons?.forEach((button) => (button.iconPosition = this._iconPosition)); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrButtonsGroupComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DsfrButtonsGroupComponent, selector: "dsfr-buttons-group", inputs: { inline: "inline", alignment: "alignment", equisized: "equisized", size: "size", iconPosition: "iconPosition" }, queries: [{ propertyName: "buttons", predicate: DsfrButtonComponent }], ngImport: i0, template: "<ul class=\"fr-btns-group\" [ngClass]=\"getClasses()\">\n <ng-content></ng-content>\n</ul>\n", styles: ["@charset \"UTF-8\";.fr-btns-group--sm:not([class^=fr-btns-group--icon-]):not([class*=\" fr-btns-group--icon-\"]) .fr-btn[class*=\" fa-icon\"]{max-width:2rem;max-height:2rem}.fr-btns-group li{margin:0 .5rem 1rem}.fr-btns-group li .fr-btn{margin:0}.fr-btns-group--inline li{margin-left:.5rem;margin-right:.5rem}.fr-btns-group--inline li .fr-btn{margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DsfrButtonsGroupComponent, decorators: [{ type: Component, args: [{ selector: 'dsfr-buttons-group', encapsulation: ViewEncapsulation.None, template: "<ul class=\"fr-btns-group\" [ngClass]=\"getClasses()\">\n <ng-content></ng-content>\n</ul>\n", styles: ["@charset \"UTF-8\";.fr-btns-group--sm:not([class^=fr-btns-group--icon-]):not([class*=\" fr-btns-group--icon-\"]) .fr-btn[class*=\" fa-icon\"]{max-width:2rem;max-height:2rem}.fr-btns-group li{margin:0 .5rem 1rem}.fr-btns-group li .fr-btn{margin:0}.fr-btns-group--inline li{margin-left:.5rem;margin-right:.5rem}.fr-btns-group--inline li .fr-btn{margin:0}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { buttons: [{ type: ContentChildren, args: [DsfrButtonComponent] }], inline: [{ type: Input }], alignment: [{ type: Input }], equisized: [{ type: Input }], size: [{ type: Input }], iconPosition: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"buttons-group.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dsfr-components/src/lib/components/buttons-group/buttons-group.component.ts","../../../../../../projects/ngx-dsfr-components/src/lib/components/buttons-group/buttons-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ContentChildren,\n  ElementRef,\n  Input,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { DomUtils, DsfrPosition, DsfrPositionConst, DsfrSize, DsfrSizeConst } from '../../shared';\nimport { DsfrButtonComponent } from '../button';\nimport { DsfrAlign, DsfrAlignConst, DsfrInline, DsfrInlineConst } from './buttons-group.model';\n\n@Component({\n  selector: 'dsfr-buttons-group',\n  templateUrl: './buttons-group.component.html',\n  styleUrls: ['./buttons-group.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DsfrButtonsGroupComponent implements AfterViewInit {\n  /** @internal */\n  @ContentChildren(DsfrButtonComponent) buttons!: QueryList<DsfrButtonComponent>;\n\n  /**\n   * Permet de basculer la disposition des boutons en mode horizontal.\n   * En mode vertical, mode par défaut, les boutons prennent 100% de la largeur du conteneur.\n   */\n  @Input() inline: DsfrInline = DsfrInlineConst.NEVER;\n\n  /**\n   * Placement des boutons en mode `inline` :\n   * - `default` : aligne les boutons sur la gauche.\n   * - `right` : aligne les boutons sur la droite\n   * - `between` : les boutons ont les mêmes espacements ente eux.\n   * - `center` : aligne les boutons au centre du conteneur.\n   * - `reverse` : les boutons se lisent de droite à gauche (implique nécessairement un placement à droite).\n   *\n   * 📌 n'a aucun effet en mode vertical.\n   */\n  @Input() alignment: DsfrAlign;\n\n  /**\n   * Permet de mettre automatiquement tous les boutons d’un groupe à la même largeur.\n   * Cela permet une uniformité des boutons en mode horizontal.\n   * (en mode vertical, les boutons prennent 100% de la largeur du conteneur)\n   * Cette option peut être combinée avec la propriété d'alignement.\n   */\n  @Input() equisized = false;\n\n  /** Taille des boutons du groupe. */\n  @Input() size: DsfrSize = DsfrSizeConst.MD;\n\n  private _iconPosition: DsfrPosition;\n\n  constructor(private _elementRef: ElementRef) {}\n\n  get iconPosition(): DsfrPosition {\n    return this._iconPosition;\n  }\n\n  /**\n   * Positionnement (gauche ou droite) au niveau du groupe des icônes dans les boutons qui\n   * contiennent à la fois une icône et un label.\n   */\n  @Input() set iconPosition(value: DsfrPosition) {\n    this._iconPosition = value;\n    this.updateButtonsIconPosition();\n  }\n\n  /**\n   * Cette méthode calcule les styles du composant en évitant les magic strings.\n   * @internal\n   */\n  getClasses(): string[] {\n    let classes: string[] = [];\n\n    // Inline class\n    switch (this.inline) {\n      case 'always':\n        classes.push('fr-btns-group--inline');\n        break;\n      case 'LG':\n        classes.push('fr-btns-group--inline-lg');\n        break;\n      case 'MD':\n        classes.push('fr-btns-group--inline-md');\n        break;\n      case 'SM':\n        classes.push('fr-btns-group--inline-sm');\n        break;\n\n      default:\n        break;\n    }\n\n    // Alignment class\n    switch (this.alignment) {\n      case DsfrAlignConst.CENTER:\n        classes.push('fr-btns-group--center');\n        break;\n      case DsfrAlignConst.BETWEEN:\n        classes.push('fr-btns-group--between');\n        break;\n      case DsfrAlignConst.RIGHT:\n        classes.push('fr-btns-group--right');\n        break;\n      case DsfrAlignConst.REVERSE:\n        classes.push('fr-btns-group--inline-reverse', 'fr-btns-group--right');\n        break;\n\n      default:\n        break;\n    }\n\n    // Size class\n    if (this.size === DsfrSizeConst.SM) {\n      classes.push('fr-btns-group--sm');\n    } else if (this.size === DsfrSizeConst.LG) {\n      classes.push('fr-btns-group--lg');\n    }\n\n    // Equisized class\n    if (this.equisized) {\n      classes.push('fr-btns-group--equisized');\n    }\n\n    // IconPosition class\n    if (this._iconPosition) {\n      classes.push(\n        this._iconPosition === DsfrPositionConst.LEFT ? 'fr-btns-group--icon-left' : 'fr-btns-group--icon-right',\n      );\n    }\n\n    return classes;\n  }\n\n  ngAfterViewInit() {\n    // Position des icônes de boutons\n    this.updateButtonsIconPosition();\n\n    // Ajout de <li> autour des boutons\n    DomUtils.surroundChildWithli(this._elementRef, 'dsfr-button');\n  }\n\n  /** On force la position des icônes des boutons. */\n  private updateButtonsIconPosition(): void {\n    this.buttons?.forEach((button) => (button.iconPosition = this._iconPosition));\n  }\n}\n","<ul class=\"fr-btns-group\" [ngClass]=\"getClasses()\">\n  <ng-content></ng-content>\n</ul>\n"]}