Ajoutez du contenu personnalisé qui n'apparaît que sur votre page d'accueil

Une situation très courante que vous rencontrerez en tant que développeur de thème est la nécessité de créer du contenu qui s’affiche uniquement sur la page d’accueil de votre communauté.

Vous pourriez ajouter du HTML dans la section « Après l’en-tête » de votre thème, qui s’affichera alors sur chaque page. Vous pouvez faire des acrobaties en CSS pour masquer cela partout sauf sur la page d’accueil… mais utilisons plutôt un thème Discourse pour créer un composant avec du contenu visible uniquement sur votre page d’accueil.

Si vous n’êtes pas familier avec les thèmes Discourse, consultez Beginner's guide to using Discourse Themes et Structure of themes and theme components

Dans votre thème Discourse, vous devrez configurer la structure de répertoire suivante :

:file_folder: javascripts/discourse/components/
:file_folder: javascripts/discourse/connectors/

À partir de là, nous allons créer un composant Ember. Vous trouverez plus d’informations sur les composants Ember dans leur documentation : Ember.js Guides - Guides and Tutorials - Ember Guides

Mais pour l’instant, il s’agira d’un composant simple, écrit dans un seul fichier .gjs contenant à la fois la logique et le modèle.

:page_facing_up: javascripts/discourse/components/custom-homepage-content.gjs

import Component from "@glimmer/component";
import { service } from "@ember/service";
import { defaultHomepage } from "discourse/lib/utilities";

export default class CustomHomepageContent extends Component {
  @service router;

  get isHomepage() {
    const { currentRouteName } = this.router;
    return currentRouteName === `discovery.${defaultHomepage()}`;
  }

  <template>
    {{#if this.isHomepage}}
      <h1>Voici mon contenu HTML de page d'accueil</h1>
    {{/if}}
  </template>
}

Cela crée un getter isHomepage, qui vérifie le service de routage pour le currentRouteName — si le nom de la route correspond à votre page d’accueil (tel que défini par les paramètres du site), il retournera true. Le modèle à l’intérieur de <template>...</template> vérifie ce getter et n’affiche votre contenu que lorsque c’est true. Vous pouvez ajouter tout le HTML que vous souhaitez entre les blocs {{#if}}.

Maintenant que notre composant est créé, nous devons l’ajouter quelque part dans Discourse. Pour cette étape, vous devrez décider quel point d’extension (plugin outlet) utiliser. Ce sont des zones à travers Discourse où nous avons ajouté un peu de code pour que les développeurs puissent s’y connecter. Vous pouvez rechercher ces points d’extension sur Discourse via Github, ou les parcourir en utilisant (deprecated) Plugin outlet locations theme component.

Pour les pages d’accueil personnalisées, above-main-container est un choix courant, utilisons-le donc.

Nous devons créer notre fichier de connexion dans le bon répertoire :

:page_facing_up: javascripts/discourse/connectors/above-main-container/custom-homepage-connector.gjs

import CustomHomepageContent from "../../components/custom-homepage-content";

<template><CustomHomepageContent /></template>

:point_up: Et c’est tout, il suffit d’une seule ligne pour appeler votre composant :tada:


Ce document est sous contrôle de version — proposez des modifications sur GitHub.

47 « J'aime »

Salut @awesomerobot,

Merci pour l’explication. J’ai essayé les étapes que vous avez suggérées, mais le after_header que j’ai implémenté s’affiche toujours sur les pages de détails des articles. Pouvez-vous me recommander comment je peux corriger cela pour qu’il ne s’affiche que sur ma page d’accueil ?

1 « J'aime »

Salut @Cornelius, puis-je voir ton code ?

2 « J'aime »

Il serait formidable de réécrire cela pour une utilisation moderne du système de fichiers plutôt que de tout coller dans les balises d’en-tête.

La plupart de ces anciens guides pour les thèmes sont obsolètes par rapport à la façon dont les choses sont faites maintenant.

7 « J'aime »

Oui, c’était assez obsolète ! Je l’ai mis à jour pour refléter la structure des thèmes distants et nos composants Ember modernes.

6 « J'aime »

C’est génial !

Et ce getter est la même chose que ceci http://ember-cli-page-object.js.org/docs/v1.11.x/api/getter.html ? Je n’en sais juste assez pour être dangereux. Si c’est la même chose, alors je modifierai l’OP pour y faire référence.

3 « J'aime »

@awesomerobot Salut Kris, j’ai installé Discourse localement sur mon système. Quel est le bon chemin pour ajouter ces fichiers dans mon instance locale de Discourse. Je voulais ajouter un nouveau composant de thème dans mon instance locale de Discourse.

1 « J'aime »

Vous créeriez votre composant de thème et l’installeriez via l’expérience utilisateur.

Installer un thème ou un composant de thème

Installer l’application de console Discourse Theme CLI pour vous aider à créer des thèmes

4 « J'aime »

Si je construis ma page d’accueil par-dessus la vue de catégorie, j’obtiens toujours mon contenu personnalisé même si je vais sur /categories qui n’est pas l’URL d’accueil. Je veux limiter cela à l’URL racine / uniquement, ce qui, je crois, était ce que faisait le code précédent, mais je me demande si defaultHomepage() devrait faire cela.

3 « J'aime »

discovery.${defaultHomepage()} correspondra à la route définie comme page d’accueil par le paramètre top-menu. Elle correspondra à la fois à l’URL racine / ET à la route spécifique, comme /categories.

D’après mon expérience, il y a deux complications lors de la création d’une page d’accueil personnalisée basée sur defaultHomepage() :

  • la route sur laquelle elle est construite n’est plus disponible en tant que simple vue de liste
  • les membres peuvent définir leur propre page d’accueil par défaut dans les paramètres de leur interface. Il faut donc soit désactiver cette fonctionnalité, soit avoir un concept de page d’accueil qui fonctionne sur n’importe quelle route du menu supérieur.

Pour construire une page d’accueil personnalisée uniquement sur l’URL racine, on peut vérifier router.currentURL === '/'. Par défaut, cela ne correspond qu’à l’URL racine / et non à la route d’atterrissage définie par le paramètre top-menu. Cependant, il existe maintenant une logique sur les liens de la barre latérale qui vise en plus à faire correspondre une URL donnée à une route. Donc, cela ne fonctionnera pas par défaut sur les liens de la barre latérale. J’ai juste posté un sujet à ce sujet : Can I have sidebar links that don’t resolve an url to a route?

D’après ce que je comprends, il n’existe actuellement aucun moyen par défaut de construire une page d’accueil personnalisée sur l’URL racine sans cibler également une route du menu supérieur ou rencontrer des problèmes avec la barre latérale. Ce serait formidable d’avoir cette option.

4 « J'aime »

C’est exact, c’est une sorte de solution de contournement de longue date qui permet à / et à la route correspondante /route d’afficher un contenu différent. Nous avons une tâche à accomplir :

  1. Permettre de définir la page d’accueil indépendamment du paramètre top_menu.
  2. Ajouter un nouveau modèle de page d’accueil autonome qui peut être personnalisé sans empiéter sur une route existante.

Les pages d’accueil personnalisées sont une demande très fréquente à ce stade, nous pourrions donc certainement utiliser plus de flexibilité à cet égard.

6 « J'aime »