Skip to content

Instantly share code, notes, and snippets.

@gregoirenoyelle
Last active September 11, 2021 14:18
Show Gist options
  • Save gregoirenoyelle/3fb2cd562d1f51e5797180b752c6d325 to your computer and use it in GitHub Desktop.
Save gregoirenoyelle/3fb2cd562d1f51e5797180b752c6d325 to your computer and use it in GitHub Desktop.
Block Pattern Gutenberg
<?php
// Test composition Gut 1
// A mettre dans un fichier de function dans votre thème ou dans les fichiers de votre extension
// Catégorie de Pattern
function acf_bloc_gutenberg_register_my_pattern_categories() {
// Vérifier si fonction existe
if (! function_exists('register_block_pattern_category') ) exit;
// déclaration de la catégorie
register_block_pattern_category(
'ma-categorie',
array( 'label' => __( 'Ma categorie', 'plugin-name' ) )
);
}
add_action( 'init', 'acf_bloc_gutenberg_register_my_pattern_categories' );
// Pattern content
function acf_bloc_gutenberg_register_bloc_pattern_contenu() {
// Vérifier si la fonction existe
if (! function_exists('register_block_pattern') ) exit;
// Contenu avec la notation Heredoc/NowDoc
// Lien: https://andy-carter.com/blog/what-are-php-heredoc-nowdoc
$content = <<<'EOD'
<!-- wp:heading -->
<h2>Bloc image simple</h2>
<!-- /wp:heading -->
<!-- wp:image {"id":207,"width":575,"height":323.4375,"sizeSlug":"large"} -->
<figure class="wp-block-image size-large is-resized"><img src="https://test-block-gut.local/wp-content/uploads/2020/12/food-salad-healthy-vegetables-edited.jpg" alt="" class="wp-image-207" width="575" height="323.4375"/></figure>
<!-- /wp:image -->
<!-- wp:heading -->
<h2>Bloc groupe simple l'été</h2>
<!-- /wp:heading -->
<!-- wp:group {"textColor":"black","style":{"color":{"background":"#d3d7db"}}} -->
<div class="wp-block-group has-black-color has-text-color has-background" style="background-color:#d3d7db"><div class="wp-block-group__inner-container"><!-- wp:heading {"align":"center"} -->
<h2 class="has-text-align-center">Mon titre</h2>
<!-- /wp:heading -->
<!-- wp:paragraph -->
<p>Nulla vitae elit libero, a pharetra augue. Etiam porta sem malesuada magna mollis euismod. Vestibulum id ligula porta felis euismod semper. Aenean lacinia bibendum nulla sed consectetur.</p>
<!-- /wp:paragraph --></div></div>
<!-- /wp:group -->
<!-- wp:heading -->
<h2>Bloc image et texte</h2>
<!-- /wp:heading -->
<!-- wp:media-text {"mediaId":9,"mediaLink":"https://test-block-gut.local/tarentella/food-restaurant-fruits-orange/","mediaType":"image","verticalAlignment":"top"} -->
<div class="wp-block-media-text alignwide is-stacked-on-mobile is-vertically-aligned-top"><figure class="wp-block-media-text__media"><img src="https://test-block-gut.local/wp-content/uploads/2016/09/food-restaurant-fruits-orange-1024x678.jpg" alt="" class="wp-image-9"/></figure><div class="wp-block-media-text__content"><!-- wp:heading -->
<h2>Mon titre</h2>
<!-- /wp:heading -->
<!-- wp:paragraph -->
<p>Maecenas sed diam eget risus varius blandit sit amet non magna. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Morbi leo risus, porta ac consectetur ac, vestibulum at eros. Sed posuere consectetur est at lobortis. Cras justo odio, dapibus ac facilisis in, egestas eget quam. </p>
<!-- /wp:paragraph --></div></div>
<!-- /wp:media-text -->
<!-- wp:acf/membre-equipe {"id":"block_5fc7b089375c8","name":"acf/membre-equipe","data":{"blocequipe_prenom":"Jean","_blocequipe_prenom":"field_5bfd23e78fc1d","blocequipe_nom":"Machin","_blocequipe_nom":"field_5bfd23ff8fc1e","blocequipe_photo":62,"_blocequipe_photo":"field_5bfd24088fc1f","blocequipe_bio":"Etiam porta sem malesuada magna mollis euismod. Integer posuere erat a ante venenatis dapibus posuere velit aliquet. Morbi leo risus, porta ac consectetur ac, vestibulum at eros. Cras mattis consectetur purus sit amet fermentum. Vestibulum id ligula porta felis euismod semper. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Donec sed odio dui. Praesent commodo cursus magna, vel scelerisque nisl consectetur et. Maecenas sed diam eget risus varius blandit sit amet non magna. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Etiam porta sem malesuada magna mollis euismod. Vivamus sagittis lacus vel augue laoreet rutrum faucibus dolor auctor.","_blocequipe_bio":"field_5bfd24258fc20","blocequipe_email":"[email protected]","_blocequipe_email":"field_5c62e7046c5c1","blocequipe_site":"","_blocequipe_site":"field_5c62e7256c5c2","blocequipe_arriere_plan":"#6be234","_blocequipe_arriere_plan":"field_5bfd500f68426","blocequipe_marge_interne":"1","_blocequipe_marge_interne":"field_5bfd515c69621"},"align":"","mode":"preview","align_content":"top"} -->
<!-- wp:heading -->
<h2>Titre Innerblock par défaut</h2>
<!-- /wp:heading -->
<!-- wp:paragraph -->
<p>Contenu texte par défaut. </p>
<!-- /wp:paragraph -->
<!-- /wp:acf/membre-equipe -->
EOD;
register_block_pattern(
'my-compo/compo-1',
array(
'title' => __( 'Compo 1' ),
'categories' => array( 'Ma categorie' ),
'description' => __( 'Premier test', 'plugin-name' ),
'content' => $content
)
);
}
add_action( 'init', 'acf_bloc_gutenberg_register_bloc_pattern_contenu' );
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment