esup-multi

Arborescence des pages


Documentation en cours de rédaction / reconstruction


  • Installation de Wordpress (docker-compose)
  • Installation des plugins nécessaires
    • ACF => lien web
    • Polylang => lien web
    • WPGraphQL => lien web
    • WPGraphQL for ACF => lien web
    • WP GraphQL Polylang => lien vers le fichier .zip sur github
    • Multi Custom Types => fichier .zip à importer
  • Réglages
    • Général
    • GraphQL
    • Langues
  • Rédaction d'un contenu multilingue
  • GraphQL
    • Création compte GraphQL en lecture seule + création d'un token d'accès
    • Exemple de requête
  • Pour aller plus loin
    • Création d'un nouveau custom type => plugin Multi Custom Types
    • Création d'un nouveau custom field => plugin Multi Custom Types
    • Ajouter des champs traduisibles => plugin Multi Custom Types










Ancienne documentation de Tristan (en cours de restructuration)

Installation


WordPress peut être déployé avec Docker, voici un exemple d'un docker-compose (pour plus d'informations sur le paramétrage, vous pouvez vous référer à la documentation WordPress) : 

L'exemple utilise une base de données Mysql et WordPress se lance sur le port 9090 que vous pouvez modifier dans la configuration.

docker-compose.yml
version: '3.1'

services:

  wordpress:
    image: wordpress
    restart: always
    ports:
      - 9090:80
    environment:
      WORDPRESS_DB_HOST: db
      WORDPRESS_DB_USER: exampleuser
      WORDPRESS_DB_PASSWORD: examplepass
      WORDPRESS_DB_NAME: exampledb
    volumes:
      - ./wordpress:/var/www/html

  db:
    image: mysql:8.0
    restart: always
    environment:
      MYSQL_DATABASE: exampledb
      MYSQL_USER: exampleuser
      MYSQL_PASSWORD: examplepass
      MYSQL_RANDOM_ROOT_PASSWORD: '1'
    volumes:
      - ./db:/var/lib/mysql


Import de la structure de données

L'import de structure de données se fait au niveau du plugin ACF dans l'onglet Outils :

 


Ensuite, il suffit de sélectionner le fichier à importer : 

Import des données d'exemple

Quand les collections sont importées, on peut utiliser la fonction d'import de WordPress pour importer les données :


Puis importer les données pour chaque collection en suivant les instructions : 


Import des images

Dans l'onglet Médias, on peut importer ou supprimer des images. Pour les collections qui nécessitent des images, on a la possibilité de directement importer ou de sélectionner une image. 

Les extensions


Pour le bon fonctionnement du projet, on a besoin de plusieurs extensions :

  • Advanced Custom Fields (ACF) : permet de créer des collections complexes et de les exposer via des API
  • Code Snippets : (optionnel) permet de configurer facilement et rapidement des webhooks suivant le besoin du projet 


ACF

Dans l'application, on utilise deux fonctionnalités principales de l'extension ACF 

  • Type de publication : permet de créer des collections et de les configurer (accès API, droits utilisateurs, etc) 
  • groupes de champs : permet de définir les champs qui composent une collection


Type de publication


Un type de publication se compose d'un libellé au pluriel et au singulier, ainsi qu'une clé. Pour accéder à la collection dans le menu, il faut la rendre publique. 


Dans les réglages avancés, on va garder cochés seulement les éléments présents ci-dessous : 


C'est également dans les réglages avancés que l'on peut changer les accès utilisateurs et certaines configurations pratiques. Il faudra également penser à définir une route pour l'API et l'activer.


Groupes de champs


Dans la partie groupes de champs, on peut ajouter, modifier et supprimer les champs qui vont composer la collection. Avec la version gratuite de l'extension, on a accès à tous les champs classiques (texte, image, url, etc), la version payante n'ajoute que des champs qui facilitent la mise en page.


Il ne faut pas oublier d'attribuer le groupe de champs au type de publication qui lui correspond dans les réglages.


Les collections


Quand une collection est créée, on peut y accéder via le menu à gauche. Dans la vue de la collection, on a la liste des objets déjà créées, que l'on peut modifier ou supprimer. On a également la possibilité de créer de nouveaux objets.


Pour chaque objet, il faut renseigner un titre et remplir l'ensemble des champs qui composent la collection. Une fois terminé, il faut cliquer sur le bouton publier ou mettre à jour pour sauvegarder l'objet.


Pour aller plus loin


Export des données


Pour exporter les données, on utilise la fonction WordPress dans l'onglet Exporter du menu Outils. Dans cette vue, on a la possibilité d'exporter les données de toutes les collections ou de le faire individuellement pour chaque collection.  

Export de la structure de données


L'export des collections se fait dans le menu ACF, dans la partie Outils. Comme pour l'export des données, on peut choisir entre tout exporter ou exporter seulement les collections qui nous intéressent. On peut aussi choisir d'exporter soit les groupes de champs ou les types de publication.




  • Aucune étiquette