Upgrade to Pro — share decks privately, control downloads, hide ads and more …

WordPress Customizer: configurando tu sitio en tiempo real

WordPress Customizer: configurando tu sitio en tiempo real

Disertación brindada en WordCamp Buenos Aires 2015 sobre el Customizer en WordPress y como emplearlo para
1. crear páginas de ajustes para plugins
2. guardar post meta específico a cada post (en vez de un setting como theme_mod u option)

Elio

May 30, 2015
Tweet

More Decks by Elio

Other Decks in Programming

Transcript

  1. WP Customizer Personalizando tu sitio en tiempo real Elio Rivero

    - http://queryloop.com WordCamp Buenos Aires 2015
  2. Inicializando el Customizer /** * Registrar paneles, secciones y controles

    para el Customizer. * @param object $wp_customize Instancia de WP_Customizer_Manager. */ function queryloop_customize_register( $wp_customize ) { // Iniciar panels, sections, controls y sus settings. } add_action( 'customize_register', 'queryloop_customize_register' );
  3. $wp_customize->add_panel( 'panel_id', array( 'title' => __( 'Un Panel', 'queryloop' ),

    ) ); $wp_customize->add_section( 'section_id', array( 'title' => __( 'Una Sección', 'queryloop' ), 'panel' => 'panel_id', ) ); $wp_customize->add_setting( 'setting_id', array( 'type' => 'theme_mod', // u 'option' 'default' => '', // Valor predeterminado 'transport' => 'refresh', // o postMessage para cambios instantáneos 'capability' => 'edit_theme_options', // capacidad necesaria 'sanitize_callback' => '', // sanear el valor a guardar en el setting 'sanitize_js_callback' => '', // sanear el valor a volcar a la página. ) ); $wp_customize->add_control( new WP_Customize_Control( $wp_customize, 'setting_id', array( 'label' => __( 'Un Control', 'queryloop' ), 'type' => 'text', // 'text' es el predeterminado así que no haría falta 'section' => 'section_id', 'settings' => 'setting_id', ) ) );
  4. Customizer puede usar distintos Settings option Options API https://codex.wordpress.org/Options_API theme_mod

    Theme Modification API https://codex.wordpress.org/Theme_Modification_API ¿Otros? (un wrapper de Options API)
  5. Para emplear el Customizer en Opciones persistentes e independientes del

    theme. Plugins $wp_customize->add_setting( 'settings[key]', array( 'type' => 'option', 'capability' => 'customize', // nueva capacidad en 4.0 - Trac #28605 ) );
  6. Le decimos al Customizer qué vista cargar y a dónde

    volver // http://ejemplo.com/wp-admin/customize.php $link = add_query_arg( array( // http://ejemplo.com/documents/ 'url' => urlencode( get_post_type_archive_link( 'document' ) ), // http://ejemplo.com/wp-admin/options-general.php?page=opciones_plugin 'return' => urlencode( add_query_arg( 'page', 'opciones_plugin', admin_url( 'options-general.php' ) ) ) ), admin_url( 'customize.php' ) ); // http://ejemplo.com/wp-admin/customize.php?url=URL&return=RETURN echo '<a href="' . esc_url( $link ) . '" class="button">' . __( 'Personalizar', 'queryloop' ) . '</a>';
  7. Agregamos un parámetro para saber que es una vista del

    plugin // http://ejemplo.com/wp-admin/customize.php?url=URL&return=RETURN&miplugin=true $link = add_query_arg( 'miplugin', 'true', $link ); Visible en los controles // http://ejemplo.com/documents/?document_id=true 'url' => urlencode( add_query_arg( ‘document_id', 'true', get_post_type_archive_link( 'document' ) ) ), Visible en la previsualización ¡Cuidado aquí que el nombre del parámetro no sea un post type!
  8. Mostramos sólo las secciones de nuestro plugin /** * Remueve

    todas las secciones salvo seccion_1 y seccion_2 de nuestro plugin. * @param bool Estado de la sección * @param object Sección a deshabilitar o no. * @return bool */ function queryloop_quitar_secciones( $active, $section ) { if ( isset( $_GET['document'] ) || ( is_singular( 'document' ) ) ) { if ( in_array( $section->id, array( 'seccion_1', 'seccion_2' ) ) ) { return true; } return false; } return true; } add_filter( ‘customize_section_active','queryloop_quitar_secciones', 10, 2 );
  9. Cargamos JavaScript para los controles /** * Cargamos scripts, sus

    dependencias y pasamos variables. */ function queryloop_cargar_js_controles() { wp_enqueue_script( 'queryloop-controles', UNA_URL . '/js/customizer- controls.js', array( 'customize-views' ) ); wp_localize_script( 'queryloop-controles', 'queryloopCustomizerControls', array( 'focus' => 'control_3', // id de un control ) ); } add_action( 'customize_controls_enqueue_scripts', array( $this, 'queryloop_cargar_js_controles' ) );
  10. Enfocamos un control específico (function($){ $(window).load(function(){ if ( ! _.isUndefined(

    queryloopCustomizerControls ) ) { wp.customize.control( queryloopCustomizerControls.focus ).focus(); } }); })(jQuery);
  11. JavaScript en la previsualización /** * Carga JavaScript y pasa

    variables en previsualización. * * @since 1.0.0 */ function queryloop_cargar_js_previa() { wp_enqueue_script( 'queryloop-customizer', UNA_URL . '/js/ql-customizer- preview.js', array( 'customize-preview' ) ); $estilos = array(); foreach ( queryloop_obtener_estilos() as $key => $style ) { $estilos['queryloop_settings[' . $key . ']'] = array( 'selector' => $style['css']['selector'], 'property' => $style['css']['property'], ); } wp_localize_script( 'queryloop-customizer', 'queryloopCustomizerPrevia', $estilos ); } add_action( 'customize_preview_init', 'queryloop_cargar_js_previa' );
  12. Cambios de CSS instantáneos if ( ! _.isUndefined( queryloopCustomizerPrevia )

    ) { _.each( queryloopCustomizerPrevia, function(rule, key) { wp.customize( key, function( value ) { value.bind( function( valor ) { $( rule.selector ).css( rule.property, '' ); if ( valor ) { $( rule.selector ).css( rule.property, valor ); } }); }); }); } $wp_customize->add_setting( 'setting', array( ‘transport' => 'postMessage', ) );
  13. Usamos la personalización en el Front End $settings = get_option(

    'queryloop_settings' ); if ( isset( $settings['mostrar_titulo_pagina'] ) ) { // mostrar el título de esta página } else { // no mostrar título } $mostrar_titulo = get_option( 'queryloop_setting_unico' ); if ( $mostrar_titulo ) { // mostrar el título de esta página } else { // no mostrar título }
  14. Añadimos CSS al front-end con wp_add_inline_style /** * Genera CSS

    y carga luego del estilo principal. */ function queryloop_agregar_estilo() { $css = ''; foreach ( queryloop_obtener_estilos() as $key => $style ) { $css .= queryloop_generar_css( $style['selector'], $style['property'], $key ); } if ( ! empty( $css ) ) { wp_add_inline_style( 'estilo-principal', $css ); } } add_action( 'wp_enqueue_scripts', 'queryloop_agregar_estilo' );
  15. Usar el Customizer para guardar Post Meta con un setting

    distinto de option y theme_mod $wp_customize->add_setting( 'un_meta_key', array( 'type' => 'ql_meta', 'capability' => 'customize', ) );
  16. Creamos el botón para personalizar nuestra entrada $permalink = get_the_permalink(

    $post->ID ); printf( __( '<a href="%s" class="button">Personalizar Documento</a>', 'queryloop' ), esc_url( add_query_arg( array( 'url' => urlencode( add_query_arg( array( 'document_id' => $post->ID ), $permalink ) ), 'return' => urlencode( add_query_arg( array( 'post' => $post->ID, 'action' => 'edit', ), admin_url( 'post.php' ) ) ), 'document' => $post->ID, ), admin_url( 'customize.php' ) ) ) );
  17. Pasamos a JavaScript el ID de la entrada a personalizar

    /** * Cargamos scripts con dependencias y pasamos variables. */ function queryloop_cargar_js_controles() { wp_enqueue_script( 'queryloop-controles', UNA_URL . '/js/customizer- controls.js', array( 'customize-views' ) ); wp_localize_script( 'queryloop-controles', 'queryloopCustomizerControls', array( 'focus' => 'control_3', 'customize' => isset( $_GET['document'] ) ? $_GET['document'] : ‘general', // id de la entrada a personalizar ) ); } add_action( 'customize_controls_enqueue_scripts', array( $this,
  18. Si estamos personalizando el post, alteramos la URL de AJAX

    $(window).load(function(){ if ( ! _.isUndefined( queryloopCustomizerControls ) ) { if ( 'general' !== queryloopCustomizerControls.customize ) { wp.customize.control( queryloopCustomizerControls.focus ).focus(); // agregamos ?document=1234 a la URL wp.ajax.settings.url += '?document=' + queryloopCustomizerControls.customize; } } });
  19. Intervenimos el guardado de settings para guardar el nuestro /**

    * Si se provee el id del post, guardar post meta. * @param mixed $valor Valor a guardar en el setting. * @param WP_Customize_Setting $setting Instancia de WP_Customize_Setting. */ function queryloop_guardar_meta( $valor, $setting ) { if ( isset( $_GET['document'] ) && ctype_digit( $_GET['document'] ) ) { update_post_meta( $_GET['document'], $setting->id, $valor ); } } // wp-includes/class-wp-customize-setting.php add_action( 'customize_update_ql_meta', 'queryloop_guardar_meta', 10, 2 );
  20. Mostramos el meta guardado $wp_customize->add_setting( 'un_meta_key', array( 'type' => 'ql_meta',

    'default' => isset( $_GET['document'] ) ? get_post_meta( $_GET['document'], 'un_meta_key', true ) : '', 'capability' => 'customize', ) ); $valor = get_post_meta( get_the_ID(), 'un_meta_key', true ); Usamos la propiedad ‘default’ para los controles En la previsualización o front end final