¿El editor TinyMCE extra elimina las etiquetas p y br?

22

Hola chicos, agregué un TinyMCE a algunas áreas de texto que se muestran en una meta caja personalizada. Todo el formato funciona perfectamente bien, excepto que el editor no guardará las etiquetas <p> o <br/> . No conserva los saltos de línea.

El TinyMCE se configura así:

wp_tiny_mce(true, array('editor_selector' => $field['class'] ) );

'<textarea name="', $field['id'], '" class="', $field['class'], '" id="', $field['id'], '" cols="60" rows="8" style="width:97%">', $meta ? esc_html($meta) : $field['std'], '</textarea>';

Y que todo funciona perfectamente bien. Todos los botones de formato funcionan bien, excepto las etiquetas <P> y <BR> .

No estoy seguro de si el editor los está eliminando antes o después de guardar el metadatos de la publicación.

Ideas?

    
pregunta Pippin 22.04.2011 - 17:25

7 respuestas

16

Hace poco conseguí este trabajo. Debes buscar y reemplazar metaname con el nombre de tu meta box.

La clave para mantener el formato fue utilizar wpautop(); al guardar los datos.

add_action( 'add_meta_boxes', 'add_metaname_box');

add_action( 'save_post', 'metaname_save');

function add_metaname_box() {
    add_meta_box(
        'metaname_id',
        __( 'metaname text', 'metaname_textdomain'),
        'metaname_custom_box',
        'page'
    );
}

function metaname_custom_box() {
    global $post;
    wp_nonce_field( plugin_basename( __FILE__ ), 'metaname_noncename' );
    $data = get_post_meta($post->ID, 'metaname_custom_box', true);
    echo <<<EOT
    <script type="text/javascript">
jQuery(document).ready(function() {
    jQuery("#metaname_custom_box").addClass("mceEditor");
    if ( typeof( tinyMCE ) == "object" &&
         typeof( tinyMCE.execCommand ) == "function" ) {
        tinyMCE.execCommand("mceAddControl", false, "metaname_custom_box");
    }
});
</script>
    <textarea id="metaname_custom_box" name="metaname_custom_box">$data</textarea>
EOT;
}

function metaname_save($post_id) {
    global $post;

    // Verify
     if ( !wp_verify_nonce( $_POST['metaname_noncename'], plugin_basename(__FILE__) )) {
         return $post_id;
     }
     if ( 'page' == $_POST['post_type'] ) {
         if ( !current_user_can( 'edit_page', $post_id ))
             return $post_id;
     } else {
         if ( !current_user_can( 'edit_post', $post_id ))
             return $post_id;
     }

     $key = 'metaname_custom_box';
    $data = wpautop($_POST[$key]);

     // New, Update, and Delete
     if(get_post_meta($post_id, $key) == "") 
         add_post_meta($post_id, $key, $data, true);
     elseif($data != get_post_meta($post_id, $key, true))
         update_post_meta($post_id, $key, $data); 
     elseif($data == "")
         delete_post_meta($post_id, $key, get_post_meta($post_id, $key, true));        
}
    
respondido por el Arthur Carabott 22.05.2011 - 23:07
5

Aquí (una versión reducida de) lo que utilizo para configurar TinyMCE a medida:

// http://tinymce.moxiecode.com/wiki.php/Configuration
function cbnet_tinymce_config( $init ) {

    // Don't remove line breaks
    $init['remove_linebreaks'] = false; 

    // Pass $init back to WordPress
    return $init;
}
add_filter('tiny_mce_before_init', 'cbnet_tinymce_config');

Supongo que esto es lo que ya intentaste?

EDITAR:

Es posible que deba incluir algunos otros cambios de configuración, como:

// Convert newline characters to BR tags
$init['convert_newlines_to_brs'] = true; 
// Do not remove redundant BR tags
$init['remove_redundant_brs'] = false;

Juega con los parámetros de configuración de TinyMCE y encuentra el que necesitas cambiar.

    
respondido por el Chip Bennett 26.04.2011 - 19:28
5

Esto parece haber cambiado un poco en las versiones posteriores de Wordpress. Ahora puedes deshabilitar esta funcionalidad así:

add_filter('tiny_mce_before_init', function($init) {
    $init['wpautop'] = false;
    return $init;
}
    
respondido por el Nathan Crause 04.10.2015 - 04:12
3

Se encontró quizás una solución más sencilla para esto:

en la plantilla actual, cambia esto:

<?php echo get_the_content());?>

a esto:

<?php echo wpautop(get_the_content());?>

De esta manera wpautop () agrega las etiquetas eliminadas por TinyMCE en una plantilla por plantilla.

    
respondido por el patricksayshi 08.03.2013 - 16:09
2

¿por qué no usas la nueva función wordpress wp_editor para representar el tinymce. De esa manera todo será manejado. Y cuando muestres el contenido al usuario, aplica el filtro the_content .

Me gusta esto:

$meta = "content of the metabox";
echo apply_filters('the_content', $meta);

El filtro the_content convertirá automáticamente los frenos de enlace en <br> y <p> .

    
respondido por el Sisir 21.01.2012 - 21:44
1

Otra solución simple: ¡Usa códigos cortos!

Coloque este código en functions.php y use [br] en el editor de contenido, HTML o visual, donde quiera que aparezca una etiqueta br.

add_shortcode("br", "br_tag");

function br_tag(){
    return("<br/>");                            

}
    
respondido por el Tapefreak 30.08.2012 - 23:11
1

esto es para quienes usan los metaboxes para wordpress: Nombre del complemento: Meta Box URI de complemento: deluxeblogtips com / meta-box

He modificado el /vendor/meta-box/inc/fields/wysiwyg.php en función estática:

static function html( $html, $meta, $field )

//just after the else i have added :
$meta = html_entity_decode($meta); // 
//and solve the problem ;)

- PERO LA MEJOR SOLUCIÓN ES -

Coloca esto en functions.php, llama al filtro desde el complemento de metaboxes:

function meta_wysiwyg_antes_save($meta)
{   
    $meta = html_entity_decode($meta);
    return $meta;
}
add_filter("rwmb_(ID-OF-METABOX-FIELD)_meta", "meta_wysiwyg_antes_save"); //en meta-box.php 194
    
respondido por el claudio 06.11.2013 - 12:42

Lea otras preguntas en las etiquetas