@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
JavaScript
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"]}