@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).
209 lines • 23.4 kB
JavaScript
import { Component, Input } from '@angular/core';
import { downloadDetail, } from '../../shared';
import * as i0 from "@angular/core";
import * as i1 from "../../shared";
// Ne peut pas être déplacé dans 'shared' à cause de la dépendance sur DsfrBadge et DsfrTag
export const DEFAULT_HEADING_LEVEL = 'H3';
export class BasePanelComponent {
constructor(langService) {
this.langService = langService;
/**
* Permet de positionner des badges (jusqu'à 4 badges maxi) en haut du composant, optionnel.
* @see DsfrBadge
*/
this.badges = [];
/**
* Permet d'avoir un fond gris ou transparent.
*/
this.customBackground = 'default';
/**
* Permet d'afficher une ombre ou ne pas mettre de bordure.
*/
this.customBorder = 'default';
/**
* Permet de désactiver le composant.
*/
this.disabled = false;
/**
* Equivalent à l'attribut html natif 'download'.
* - true : la fenêtre de téléchargement s'affiche directement,
* - false : le fichier est ouvert avant d'être téléchargé,
* - string : nouveau nom de fichier proposé au téléchargement.
*/
this.downloadDirect = true;
/**
* Si 'true' (défaut) : le détail du téléchargement est automatiquement renseigné par le script DSFR.
* - Dans ce cas, les propriétés : 'downloadMimeType', 'downloadSizeBytes', 'downloadLangCode' sont ignorées.
* Si 'false' : le détail est calculé par la librairie 'ngx-dsfr'.
* Dans les 2 cas, l'unité dépend de la langue du site, en octets (ko, Mo, ...) pour 'fr', en 'bytes' (KB, MB...) pour les autres langues.
* Ce mécanisme peut être forcé avec 'downloadSizeUnit'.
*/
this.downloadAssessFile = true;
/**
* Permet de désactiver le lien étendu de la carte.
*/
this.enlargeLink = true;
/**
* Le niveau de titre devant être utilisé (tag `h4` par défaut).
* Cette balise ne produit pas de style, mais de la structure.
*/
this.headingLevel = DEFAULT_HEADING_LEVEL;
/**
* Passe le composant en mode horizontal.
*/
this.horizontal = false;
/**
* Dimension du composant, 'MD' par défaut ('SM, 'MD' uniquement pour la tuile).
*/
this.size = 'MD';
this._download = false;
this._tags = [];
}
get downloadSizeUnit() {
return this._downloadSizeUnit || this.langService.lang ? 'octets' : 'bytes';
}
get linkTarget() {
return this._linkTarget;
}
get tags() {
return this._tags;
}
get itemLink() {
const label = this.heading ? this.heading : '';
const itemLink = { label: label, ariaLabel: this.ariaLabel }; // ariaLabel @since 1.7
if (this.link) {
itemLink.link = this.link;
}
else if (this.route) {
itemLink.route = this.route;
}
return itemLink;
}
get download() {
return this._download;
}
get detailBottom() {
return !this.download ? this._detailBottom : this.downloadDetail;
}
/**
* Dans le cas d'un téléchargement sans l'option 'downloadAssessFile',
* on crée le détail à l'aide des propriétés 'downloadSizeBytes', 'downloadMimeType'.
* @internal
*/
get downloadDetail() {
return downloadDetail(this.downloadMimeType, this.downloadSizeBytes, this.downloadSizeUnit);
}
/**
* Transforme le composant classique en composant de téléchargement.
*/
set download(download) {
this._download = download;
if (this._download)
this.enlargeLink = true;
}
/** Zone de détail se trouvant visuellement sous la description et à côté de l’icône, optionnel.
* Pour la tuile, on peut passer un slot de sélecteur "detail".
* En cas de téléchargement le détail est remplacé par les informations du fichier calculées selon downloadAssessFile.
*/
set detailBottom(value) {
this._detailBottom = value;
}
/**
* Force l'unité par défaut qui dépend de la langue du site, en octets (ko, Mo, ...) pour 'fr', en 'bytes' (KB, MB...) pour les autres langues.
*/
set downloadSizeUnit(value) {
this._downloadSizeUnit = value;
}
/**
* Attribut target du lien.
*/
set linkTarget(target) {
this._linkTarget = target;
// Si un lien est externe, le composant ne peut pas être entièrement cliquable
if (target === '_blank')
this.enlargeLink = false;
}
/**
* Permet de positionner des tags en haut de la carte (cliquables ou non), optionnel.
* @see DsfrTag
*/
set tags(tags) {
this._tags = tags;
// Vérifie si un tag est cliquable pour désactiver enlargeLink.
if (tags?.find((tag) => tag.link))
this.enlargeLink = false;
}
/**
* @deprecated (@since 1.11.5) utiliser `routePath` à la place.
* routerLink provoque un bug accessibilité sur la navigation au clavier (ajout d'un tabindex=0)
**/
set routerLink(value) {
if (value)
this.routePath = value;
}
/** @internal */
hasLink() {
return !!(this.link || this.route || this.routePath);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BasePanelComponent, deps: [{ token: i1.LangService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BasePanelComponent, selector: "ng-component", inputs: { ariaLabel: "ariaLabel", badges: "badges", customBackground: "customBackground", customBorder: "customBorder", description: "description", disabled: "disabled", downloadDirect: "downloadDirect", downloadAssessFile: "downloadAssessFile", downloadLangCode: "downloadLangCode", downloadMimeType: "downloadMimeType", downloadSizeBytes: "downloadSizeBytes", enlargeLink: "enlargeLink", heading: "heading", headingLevel: "headingLevel", horizontal: "horizontal", link: "link", route: "route", routePath: "routePath", routerLinkActive: "routerLinkActive", routerLinkExtras: "routerLinkExtras", size: "size", download: "download", detailBottom: "detailBottom", downloadSizeUnit: "downloadSizeUnit", linkTarget: "linkTarget", tags: "tags", routerLink: "routerLink" }, ngImport: i0, template: '', isInline: true }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BasePanelComponent, decorators: [{
type: Component,
args: [{ template: '' }]
}], ctorParameters: function () { return [{ type: i1.LangService }]; }, propDecorators: { ariaLabel: [{
type: Input
}], badges: [{
type: Input
}], customBackground: [{
type: Input
}], customBorder: [{
type: Input
}], description: [{
type: Input
}], disabled: [{
type: Input
}], downloadDirect: [{
type: Input
}], downloadAssessFile: [{
type: Input
}], downloadLangCode: [{
type: Input
}], downloadMimeType: [{
type: Input
}], downloadSizeBytes: [{
type: Input
}], enlargeLink: [{
type: Input
}], heading: [{
type: Input
}], headingLevel: [{
type: Input
}], horizontal: [{
type: Input
}], link: [{
type: Input
}], route: [{
type: Input
}], routePath: [{
type: Input
}], routerLinkActive: [{
type: Input
}], routerLinkExtras: [{
type: Input
}], size: [{
type: Input
}], download: [{
type: Input
}], detailBottom: [{
type: Input
}], downloadSizeUnit: [{
type: Input
}], linkTarget: [{
type: Input
}], tags: [{
type: Input
}], routerLink: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dsfr-components/src/lib/components/card/base-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { NavigationExtras } from '@angular/router';\nimport {\n  DsfrFileSizeUnit,\n  DsfrHeadingLevel,\n  DsfrLink,\n  DsfrLinkTarget,\n  DsfrNavigation,\n  DsfrSize,\n  LangService,\n  downloadDetail,\n} from '../../shared';\nimport { DsfrBadge } from '../badge';\nimport { DsfrPanelBackground, DsfrPanelBorder } from '../card';\nimport { DsfrTag } from '../tag';\n// Ne peut pas être déplacé dans 'shared' à cause de la dépendance sur DsfrBadge et DsfrTag\n\nexport const DEFAULT_HEADING_LEVEL: DsfrHeadingLevel = 'H3';\n\n@Component({ template: '' })\nexport abstract class BasePanelComponent implements DsfrNavigation {\n  /** @since 1.7 La propriété ariaLabel définit une valeur de chaîne qui étiquette un élément interactif. */\n  @Input() ariaLabel?: string;\n\n  /**\n   * Permet de positionner des badges (jusqu'à 4 badges maxi) en haut du composant, optionnel.\n   * @see DsfrBadge\n   */\n  @Input() badges: DsfrBadge[] = [];\n\n  /**\n   * Permet d'avoir un fond gris ou transparent.\n   */\n  @Input() customBackground: DsfrPanelBackground = 'default';\n\n  /**\n   * Permet d'afficher une ombre ou ne pas mettre de bordure.\n   */\n  @Input() customBorder: DsfrPanelBorder = 'default';\n\n  /**\n   * Une description optionnelle plein texte.\n   */\n  @Input() description: string;\n\n  /**\n   * Permet de désactiver le composant.\n   */\n  @Input() disabled = false;\n\n  /**\n   * Equivalent à l'attribut html natif 'download'.\n   * - true : la fenêtre de téléchargement s'affiche directement,\n   * - false : le fichier est ouvert avant d'être téléchargé,\n   * - string : nouveau nom de fichier proposé au téléchargement.\n   */\n  @Input() downloadDirect: boolean | string = true;\n\n  /**\n   * Si 'true' (défaut) : le détail du téléchargement est automatiquement renseigné par le script DSFR.\n   * - Dans ce cas, les propriétés : 'downloadMimeType', 'downloadSizeBytes', 'downloadLangCode' sont ignorées.\n   * Si 'false' : le détail est calculé par la librairie 'ngx-dsfr'.\n   * Dans les 2 cas, l'unité dépend de la langue du site, en octets (ko, Mo, ...) pour 'fr', en 'bytes' (KB, MB...) pour les autres langues.\n   * Ce mécanisme peut être forcé avec 'downloadSizeUnit'.\n   */\n  @Input() downloadAssessFile = true;\n\n  /**\n   * Obligatoire, dans le cas d'un téléchargement si le document n'est pas du même langage que la page courante.\n   * Ex : downloadLangCode=\"en\".\n   */\n  @Input() downloadLangCode: string;\n\n  /**\n   * Format du fichier, à renseigner si downloadAssessFile est faux.\n   */\n  @Input() downloadMimeType: string;\n\n  /**\n   * Poids du fichier en octets, à renseigner si downloadAssessFile est faux.\n   * */\n  @Input() downloadSizeBytes: number;\n\n  /**\n   * Permet de désactiver le lien étendu de la carte.\n   */\n  @Input() enlargeLink = true;\n\n  /**\n   * Titre du composant.\n   * Le fait de valoriser cette propriété est prioritaire sur le ng-content [heading].\n   * Attention fonctionnellement la présence d'un titre est obligatoire.\n   */\n  @Input() heading: string;\n\n  /**\n   * Le niveau de titre devant être utilisé (tag `h4` par défaut).\n   * Cette balise ne produit pas de style, mais de la structure.\n   */\n  @Input() headingLevel: string = DEFAULT_HEADING_LEVEL;\n\n  /**\n   * Passe le composant en mode horizontal.\n   */\n  @Input() horizontal = false;\n\n  /**\n   * Permet de positionner un lien de type href.\n   * Sert aussi de lien de téléchargement.\n   */\n  @Input() link: string;\n\n  /**\n   * Permet de positionner une route Angular qui sera récupérée via 'output tileSelect.\n   */\n  @Input() route: string;\n\n  /**\n   * Path angular géré en tant que directive routerLink. Prioritaire et exclusif avec link et route.\n   */\n  @Input() routePath: string | string[];\n\n  /**\n   * Classe CSS utilisée pour la directive routerLink active.\n   */\n  @Input() routerLinkActive: string | string[] | undefined;\n\n  /**\n   * RouterLink : valeurs additionnelles de navigation pour le routerLink (queryParams, state, etc.)\n   */\n  @Input() routerLinkExtras: NavigationExtras;\n\n  /**\n   * Dimension du composant, 'MD' par défaut ('SM, 'MD' uniquement pour la tuile).\n   */\n  @Input() size: DsfrSize = 'MD';\n\n  private _download = false;\n  private _downloadSizeUnit: DsfrFileSizeUnit;\n  private _linkTarget: DsfrLinkTarget;\n  private _tags: DsfrTag[] = [];\n  private _detailBottom: string;\n\n  protected constructor(private langService: LangService) {}\n\n  get downloadSizeUnit(): DsfrFileSizeUnit {\n    return this._downloadSizeUnit || this.langService.lang ? 'octets' : 'bytes';\n  }\n\n  get linkTarget(): DsfrLinkTarget {\n    return this._linkTarget;\n  }\n\n  get tags(): DsfrTag[] {\n    return this._tags;\n  }\n\n  get itemLink(): DsfrLink {\n    const label = this.heading ? this.heading : '';\n    const itemLink: DsfrLink = { label: label, ariaLabel: this.ariaLabel }; // ariaLabel @since 1.7\n    if (this.link) {\n      itemLink.link = this.link;\n    } else if (this.route) {\n      itemLink.route = this.route;\n    }\n    return itemLink;\n  }\n\n  get download(): boolean {\n    return this._download;\n  }\n\n  get detailBottom(): string {\n    return !this.download ? this._detailBottom : this.downloadDetail;\n  }\n\n  /**\n   * Dans le cas d'un téléchargement sans l'option 'downloadAssessFile',\n   * on crée le détail à l'aide des propriétés 'downloadSizeBytes', 'downloadMimeType'.\n   * @internal\n   */\n  protected get downloadDetail(): string {\n    return downloadDetail(this.downloadMimeType, this.downloadSizeBytes, this.downloadSizeUnit);\n  }\n\n  /**\n   * Transforme le composant classique en composant de téléchargement.\n   */\n  @Input() set download(download: boolean) {\n    this._download = download;\n    if (this._download) this.enlargeLink = true;\n  }\n\n  /** Zone de détail se trouvant visuellement sous la description et à côté de l’icône, optionnel.\n   * Pour la tuile, on peut passer un slot de sélecteur \"detail\".\n   * En cas de téléchargement le détail est remplacé par les informations du fichier calculées selon downloadAssessFile.\n   */\n  @Input() set detailBottom(value: string) {\n    this._detailBottom = value;\n  }\n\n  /**\n   * Force l'unité par défaut qui dépend de la langue du site, en octets (ko, Mo, ...) pour 'fr', en 'bytes' (KB, MB...) pour les autres langues.\n   */\n  @Input() set downloadSizeUnit(value: DsfrFileSizeUnit) {\n    this._downloadSizeUnit = value;\n  }\n\n  /**\n   * Attribut target du lien.\n   */\n  @Input() set linkTarget(target: DsfrLinkTarget) {\n    this._linkTarget = target;\n\n    // Si un lien est externe, le composant ne peut pas être entièrement cliquable\n    if (target === '_blank') this.enlargeLink = false;\n  }\n\n  /**\n   * Permet de positionner des tags en haut de la carte (cliquables ou non), optionnel.\n   * @see DsfrTag\n   */\n  @Input() set tags(tags: DsfrTag[]) {\n    this._tags = tags;\n\n    // Vérifie si un tag est cliquable pour désactiver enlargeLink.\n    if (tags?.find((tag) => tag.link)) this.enlargeLink = false;\n  }\n\n  /**\n   * @deprecated (@since 1.11.5) utiliser `routePath` à la place.\n   * routerLink provoque un bug accessibilité sur la navigation au clavier (ajout d'un tabindex=0)\n   **/\n  @Input() set routerLink(value: string | string[] | undefined) {\n    if (value) this.routePath = value;\n  }\n\n  /** @internal */\n  hasLink(): boolean {\n    return !!(this.link || this.route || this.routePath);\n  }\n}\n"]}