Come aggiungere una categoria personalizzata come wrapper per blocchi personalizzati nell'editor Gutenberg
Come sappiamo dall'API fornita da Gutenberg possiamo creare un blocco personalizzato come
const { registerBlockType } = wp.blocks;
registerBlockType( 'my-namespace/my-block', {
})
ma come posso creare un wrapper (una categoria tipo layout) intorno ai miei blocchi personalizzati nell'editor Gutenberg? Diciamo che voglio avere un contenitore per i miei elementi personalizzati come slider, gallerie...

Scavando più a fondo nella documentazione, ho ottenuto il seguente risultato.
Esiste un modo per raggruppare i tuoi blocchi personalizzati in una determinata categoria in Gutenberg, e per questo abbiamo il metodo block_categories_all
. Quindi con un filtro, puoi estendere le categorie predefinite con quelle personalizzate.
Ecco il mio esempio:
add_filter( 'block_categories_all', function( $categories, $post ) {
return array_merge(
$categories,
array(
array(
'slug' => 'my-slug',
'title' => 'my-title',
),
)
);
}, 10, 2 );
Puoi trovare maggiori informazioni su questo nell'API fornita.

Sembra buono ma non riesco a farlo funzionare. Posso confermare che il filtro viene chiamato in get_block_categories() in post.php come trovato da Pat J.

È possibile filtrare l'elenco delle categorie di blocchi predefinite utilizzando il filtro block_categories
. Inserisci il codice nel file functions.php
o your-plugin.php
. Spiegato qui nel manuale di WordPress Gutenberg
function my_plugin_block_categories( $categories, $post ) {
if ( $post->post_type !== 'post' ) {
return $categories;
}
return array_merge(
$categories,
array(
array(
'slug' => 'my-category',
'title' => __( 'La mia categoria', 'my-plugin' ),
'icon' => 'wordpress',
),
)
);
}
add_filter( 'block_categories', 'my_plugin_block_categories', 10, 2 );
Per utilizzare un'icona SVG puoi sostituire l'icona in js. Definisci la tua icona.
const icon = <svg className='components-panel__icon' width='20' height='20' viewBox='0 0 20 20' aria-hidden='true' role='img' focusable='false' xmlns='http://www.w3.org/2000/svg'>
<rect fill="#ffffff" x="0" y="0" width="20" height="20"/>
<rect fill="#1163EB" x="2" y="2" width="16" height="16" rx="16"/>
</svg>;
e sostituisci l'icona utilizzando la funzione updateCategory
da wp.blocks;
aggiungendo la classe components-panel__icon
aggiungerà uno spazio di 6px
sul lato sinistro dell'icona.
( function() {
wp.blocks.updateCategory( 'my-category', { icon: icon } );
} )();

E dove dovresti aggiungere la funzione wp.blocks.updateCategory
. Ho provato questo ma non riesco a farlo funzionare. Puoi condividere un file .js completo che funzioni? Inoltre, se registro una categoria e non ho blocchi assegnati a quella categoria, dovrebbe comunque essere elencata? Non riesco nemmeno a registrare la mia categoria. Inoltre non vedo il filtro block_categories nella documentazione dei filtri di riferimento: https://codex.wordpress.org/Plugin_API/Filter_Reference

Non sto usando alcun boilerplate. ecco il file di ingresso per i miei blocchi https://codepen.io/talentedaamer/pen/YMZzjY utilizzato in https://wordpress.org/plugins/easy-blocks/
