


Ajout d'un guide de bienvenue personnalisé à l'éditeur de blocs WordPress
Cet article détaille la création d'un plugin WordPress qui fournit une documentation dans l'application, en évitant la nécessité de liens externes pour séparer la documentation. La solution intègre un guide utile directement dans l'éditeur de blocs WordPress, accessible tandis que les utilisateurs travaillent activement avec le plugin.
Le plugin utilise des types de publication personnalisés (CPTS) et un composant de guide de style modal. Le défi réside dans l'intégration de ce guide de manière transparente dans l'éditeur sans perturber le flux de travail de l'utilisateur.
L'objectif: Le plugin, un serveur GraphQL pour WordPress, est édité par CPTS via des blocs personnalisés ("Graphiql Client" et "Options de requête persistantes"). Étant donné que la création de requête GraphQL peut être complexe, un guide intégré est crucial. Ce guide, consulté via un panneau dans les paramètres du document ("Guide de bienvenue"), fournit une vidéo de tutoriel et des instructions détaillées sur plusieurs pages.
Étapes de mise en œuvre:
Création du script: le processus commence par échafaudage un nouveau script pour enregistrer un panneau de barre latérale personnalisé dans les paramètres de document de l'éditeur. L'auteur rencontre initialement des défis en utilisant le composant
PluginDocumentSettingPanel
en raison de la nécessité d'une étape de construction JavaScript (ESNEXT / JSX). La solution consiste à exploiter le package@wordpress/create-block
pour échafauner un bloc, puis à modifier le code généré pour enregistrer un script régulier à la place. Cela permet une compilation ESNext via WebPack. Un détail clé consiste à ajouter une dépendance au scriptwp-edit-post
pour assurer un chargement approprié de la variablewp.editPost
.Restriction du panneau: Pour empêcher le panneau d'apparaître sur les CPT non apparentés, l'auteur met en œuvre une solution basée sur PHP. Cette méthode vérifie le type de poste actuel à l'aide
get_editing_post_type()
et enregistre uniquement le script s'il correspond à la cible CPT. Il s'agit d'une approche plus efficace que d'utiliser JavaScript pour rendre conditionnellement le panneau.Construire le guide: le guide lui-même est construit en utilisant le wordpress
<guide></guide>
composant et son associé<guidepage></guidepage>
pour la pagination. L'auteur détaille le processus de découverte de ce composant grâce à la recherche de code et à l'exploration du livre de contes Gutenberg. Le guide comprend un tutoriel vidéo (hébergé en externe) et des pages suivantes avec des instructions détaillées.Intégration du contenu: le contenu du guide est structuré en utilisant
<guidepage></guidepage>
Composants, chacun contenant du HTML, incluant potentiellement d'autres composants personnalisés. L'auteur note des problèmes mineurs tels que les limitations vidéo de l'intégration<guide></guide>
Composant et le besoin d'améliorations CSS.
Bonus: accès indépendant sur la documentation:
L'auteur montre comment créer des composants réutilisables pour la documentation. Un composant CacheControlDescription
, par exemple, peut être utilisé à la fois dans le guide et un modal distinct, améliorant l'expérience utilisateur. Le rendu conditionnel du bouton d'accès de la documentation en fonction de la sélection des blocs améliore la convivialité.
Conclusion:
Cette procédure détaillée présente efficacement le développement d'un système de documentation intégré dans l'application au sein de l'éditeur de blocs WordPress. L'expérience de l'auteur met en évidence l'importance de comprendre React et l'architecture de l'éditeur de blocs WordPress pour le développement de plugins réussi. La solution fournit un modèle pratique et réutilisable pour d'autres développeurs de plugins cherchant à améliorer l'intégration et la prise en charge des utilisateurs.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Si vous avez récemment commencé à travailler avec GraphQL ou examiné ses avantages et ses inconvénients, vous avez sans aucun doute entendu des choses comme "GraphQL ne prend pas en charge la mise en cache" ou

Avec la récente montée du prix du bitcoin sur 20k $ USD, et pour lui, récemment en train de briser 30k, je pensais que cela valait la peine de reprendre une profonde plongeon dans la création d'Ethereum

Quelle que soit le stade dans lequel vous vous trouvez en tant que développeur, les tâches que nous effectuons - qu'elles soient grandes ou petites - ont un impact énorme dans notre croissance personnelle et professionnelle.

Il est sorti! Félicitations à l'équipe Vue pour l'avoir fait, je sais que ce fut un effort massif et une longue période à venir. Tous les nouveaux documents aussi.

J'ai eu quelqu'un qui écrivait avec cette question très légitime. Lea vient de bloguer sur la façon dont vous pouvez obtenir les propriétés CSS valides elles-mêmes du navigateur. C'est comme ça.

Je dirais que "Site Web" correspond mieux que "Application mobile" mais j'aime ce cadrage de Max Lynch:

L'autre jour, j'ai repéré ce morceau particulièrement charmant sur le site Web de Corey Ginnivan où une collection de cartes se cassent les uns sur les autres pendant que vous faites défiler.

Il existe un certain nombre de ces applications de bureau où l'objectif montre votre site à différentes dimensions en même temps. Vous pouvez donc, par exemple, écrire
