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

209 lines 23.4 kB
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"]}