custom-field – Agregar subtítulo al título del producto Woocommerce

Pregunta:

Estoy usando WooCommerce en un sitio creado con Pagelines Framework. Necesito que aparezca un campo de subtítulos / personalizable debajo del nombre del producto en cualquier lugar del sitio. Tal como está, WooCommerce no ofrece esa opción.

Intenté usar campos personalizados, pero WooCommerce los usa también y genera un montón de cosas que no quiero junto con mi subtítulo. Si tuviera que nombrar mi campo personalizado "autor del libro", ¿este código funcionaría para mostrar solo el campo personalizado que deseo?

<?php echo get_post_meta($id, "bookauthor", true); ?>

Y si es así, ¿cómo hago mi nueva salida de campo inmediatamente después del título del producto en el front-end?

Encontré los ganchos que necesito en este archivo php (creo que no sé php, por eso te pregunto):

    <?php 
/*
  * @hooked woocommerce_template_single_title - 5
  * @hooked woocommerce_template_single_price - 10
  * @hooked woocommerce_template_single_excerpt - 20
  * @hooked woocommerce_template_single_add_to_cart - 30
  * @hooked woocommerce_template_single_meta - 40
  * @hooked woocommerce_template_single_sharing - 50
*/
?>

Sé cómo filtrar, pero ¿cómo agrego el campo personalizado a esa lista?

¿O hay una forma completamente diferente de lograr lo que necesito?

Agradecimiento inmortal a cualquiera que pueda ayudar.

Respuesta:

Para responder a su primera pregunta, obtener su post meta »bookauthor« de esta manera hará eco / mostrará exactamente eso. Si está definiendo correctamente la variable $id en su código, o puede hacerlo como se muestra a continuación.

El código debería responder a su segunda pregunta, cómo insertar su segunda línea de título en la página del producto a través del woocommerce_single_product_summary . Simplemente agregue su información adicional como esta:

    function wpse116660_wc_add_2nd_title() {
        ?>
        <div class="2nd-tile">
            <?php echo get_post_meta(get_the_ID(), "bookauthor", true); ?>
        </div>
        <?php
    }
    add_action( 'woocommerce_single_product_summary', 'wpse116660_wc_add_2nd_title', 6 );

Para tener un poco más de comodidad con su meta de publicación personalizada, puede hacer lo que @ pl4g4 y @brasofilo sugirieron y agregar una metabox a la pantalla de edición del producto, pero no es necesario, por supuesto, parece que sabe cómo hacerlo con la costumbre estándar de wordpress. campos metabox .


Puede agregar su metabox de esta manera, el código se basa en el primer ejemplo en la página del códice de wordpress add_meta_box .

/**
 * Adds a box to the main column on the Post and Page edit screens.
 */
function wpse116660_wc_2nd_title_mb() {

    $screen = array( 'product' );

        add_meta_box(
            'wc_2nd_title_mb',
            __( '2nd title', 'your_textdomain' ),
            'wc_2nd_title_inner_mb',
            $screen,
            'advanced',
            'high'
        );
}
add_action( 'add_meta_boxes', 'wpse116660_wc_2nd_title_mb', 0 );

/**
 * Prints the box content.
 * 
 * @param WP_Post $post The object for the current post/page.
 */
function wpse116660_wc_2nd_title_inner_mb( $post ) {

  // Add an nonce field so we can check for it later.
  wp_nonce_field( 'wc_2nd_title_inner_mb', 'wc_2nd_title_inner_mb_nonce' );

  /*
   * Use get_post_meta() to retrieve an existing value
   * from the database and use the value for the form.
   */
  $value = get_post_meta( $post->ID, 'bookauthor', true );

  echo '<label for="bookauthor_field">';
       _e( "Bookauthor", 'your_textdomain' );
  echo '</label> ';
  echo '<input type="text" id="bookauthor_field" name="bookauthor_field" value="' . esc_attr( $value ) . '" size="50" />';

}

/**
 * When the post is saved, saves our custom data.
 *
 * @param int $post_id The ID of the post being saved.
 */
function wpse116660_wc_2nd_title_save_postdata( $post_id ) {

  /*
   * We need to verify this came from the our screen and with proper authorization,
   * because save_post can be triggered at other times.
   */

  // Check if our nonce is set.
  if ( ! isset( $_POST['wc_2nd_title_inner_mb_nonce'] ) )
    return $post_id;

  $nonce = $_POST['wc_2nd_title_inner_mb_nonce'];

  // Verify that the nonce is valid.
  if ( ! wp_verify_nonce( $nonce, 'wc_2nd_title_inner_mb' ) )
      return $post_id;

  // If this is an autosave, our form has not been submitted, so we don't want to do anything.
  if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) 
      return $post_id;

  // Check the user's permissions.
  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;
  }

  /* OK, its safe for us to save the data now. */

  // Sanitize user input.
  $mydata = sanitize_text_field( $_POST['bookauthor_field'] );

  // Update the meta field in the database.
  update_post_meta( $post_id, 'bookauthor', $mydata );
}
add_action( 'save_post', 'wpse116660_wc_2nd_title_save_postdata' );

Leave a Comment

Your email address will not be published. Required fields are marked *

Scroll to Top

web tasarım