gutenberg

Cómo desactivar Gutenberg cuando salga WordPress 5.0

La versión 5.0 de WordPress está a la vuelta de la esquina, prevista para finales de Agosto. Como ya sabrás a esta altura de la película, vendrá con el nuevo editor Gutenberg integrado en su core.

Llevamos sabiendo que este día llegará algo más de un año, y durante todo este tiempo se ha hablado mucho de Gutenberg: si es bueno, si es malo, que si el lock-in, que si voy a perder todo lo que ya tenía, qué pasará con mi Divi/Elementor/loquesea, etc…

Lo que es probable, es que mucha gente en un inicio lo quiera quitar o desactivar, hasta que pueda probarse bien, pase un tiempo, evolucione, madure y dé sus primeros pasos, etc… y hasta que tú o tu cliente esté preparado para ello.

Aunque existen muchos plugins para ello, vamos a ver cómo podemos desactivarlo con apenas unas líneas de código.

Desactiva Gutenberg por completo

Aunque te parezca increíble, sólo necesitarás una línea de código para desactivar Gutenberg por completo, y volver al editor clásico de WordPress. Simplemente añade a tu functions.php o plugin de utilidades lo siguiente:

add_filter('use_block_editor_for_post_type', '__return_false', 100);

Simplemente devolvemos false al filtro gutenberg_can_edit_post_type. __return_false es una función de WordPress, que simplemente hace precisamente lo que indica, devolver un false.

Desactiva Gutenberg para un post type específico

¿Y qué pasa si quiero desactivar Gutenberg sólo para ciertos post types? O dicho de otro modo, ¿qué pasa si sólo quiero Gutenberg para cierto tipo de post type?

Por defecto lo tendremos disponible para las entradas y las páginas. Y también para todos aquellos Custom Post Types que cumplan en su registro los siguientes requisitos:

  • supports => array(‘editor’);
  • show_in_rest => true

Es decir, deben soportar el editor, y ser accesibles desde la REST API. Si no controlamos los CPTs en nuestro sitio porque han sido declarados en un plugin y/o tema el cual no debemos queremos tocar, podemos desactivar Gutenberg de la siguiente manera:

<?php

function disable_gutenberg_in_custom_cpts( $is_enabled, $post_type ) {
    if ( 'product' === $post_type ) {
        return false; // Cambia 'product' por tu CPT
    }

    return $is_enabled;
}
add_filter( 'use_block_editor_for_post_type', 'disable_gutenberg_in_custom_cpts', 100, 2 );

Un ejemplo parecido al anterior, aunque sólo devolveremos false si se cumple la condición de que $post_type sea igual al que queramos desactivar Gutenberg, en este ejemplo ‘product’.

Si quisiéramos desactivarlo por ejemplo en las páginas, podemos añadir una condición más en la misma función:

if ( 'page' === $post_type ) {
    return false;
}

Desactiva Gutenberg para un rol específico

Otra necesidad que podemos tener, es la de desactivar el nuevo editor para un rol determinado. De este modo tus editores, colaboradores, autores, etc… seguirán viendo el editor clásico.

En este ejemplo, desactivamos Gutenberg para todos los roles por debajo de administrador:

<?php

function disable_gutenberg_for_roles( $is_enabled, $post_type ) {
    if ( ! current_user_can('manage_options') ) {
        return false;
    }

    return $is_enabled;
}
add_filter( 'use_block_editor_for_post_type', 'disable_gutenberg_for_roles', 100, 2 );

Conclusiones

Jugando un poco con los roles y con los tipos de contenido, podemos desactivar Gutenberg a nuestro antojo con unas pocas líneas de código, sin necesidad de instalar plugins adicionales.

¿Te ha resultado útil esta información? 🍺

Si este post te ha resuelto un problema, invítame a un café o a una cerveza. Con este pequeño gesto me animas a seguir escribiendo.

Comentarios

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *:

  • El fin del tratamiento es únicamente la moderación de comentarios para evitar spam
  • La legitimación es tu consentimiento al comentar
  • No se comunicará ningún dato a terceros salvo por obligación legal
  • Tienes derecho al acceso, rectificación y eliminación de los comentarios