Avisos
Vaciar todo

[Resuelto] Agregar una clase a los productos variables agotados en Woocommerce  

 
Joel Alexander
 Joel Alexander
Nuevo usuario

Hola a todos, actualmente tengo instalado el tema Ciyashop para mi tienda online.

Necesito agregar una clase a los productos variables agotados, ya que con CSS le daré estilo con el objetivo de que los clientes tengan claro que variables están disponibles y cuales agotadas. He intentado con varios fragmentos que encontré en linea y agregue a través de hooks pero ni uno a funcionado ya que esto afecta directamente a Woocommerce y no a mi tema.

Necesito modificar directamente el archivo variable.php de mi tema, ¿Podrían ayudarme?

 

<?php
/**
* Variable product add to cart
*
* This template can be overridden by copying it to yourtheme/woocommerce/single-product/add-to-cart/variable.php.
*
* HOWEVER, on occasion WooCommerce will need to update template files and you
* (the theme developer) will need to copy the new files to your theme to
* maintain compatibility. We try to do this as little as possible, but it does
* happen. When this occurs the version of the template file will be bumped and
* the readme will list any important changes.
*
* @see https://docs.woocommerce.com/document/template-structure/
* @package WooCommerce/Templates
* @version 6.1.0
*/

defined( 'ABSPATH' ) || exit;

global $product, $ciyashop_options;

$attribute_keys = array_keys( $attributes );
$variations_json = wp_json_encode( $available_variations );
$variations_attr = function_exists( 'wc_esc_json' ) ? wc_esc_json( $variations_json ) : _wp_specialchars( $variations_json, ENT_QUOTES, 'UTF-8', true );

do_action( 'woocommerce_before_add_to_cart_form' ); ?>

<form class="variations_form cart" action="<?php echo esc_url( apply_filters( 'woocommerce_add_to_cart_form_action', $product->get_permalink() ) ); ?>"
method="post" enctype='multipart/form-data'
data-product_id="<?php echo absint( $product->get_id() ); ?>"
data-product_variations="<?php echo $variations_attr; // phpcs:ignore WordPress.XSS.EscapeOutput.OutputNotE ?>">

<?php do_action( 'woocommerce_before_variations_form' ); ?>

<?php
if ( empty( $available_variations ) && false !== $available_variations ) {
?>
<p class="stock out-of-stock"><?php echo esc_html( apply_filters( 'woocommerce_out_of_stock_message', __( 'This product is currently out of stock and unavailable.', 'ciyashop' ) ) ); ?></p>
<?php
} else {
?>
<table class="variations" cellspacing="0">
<tbody>
<?php

// Get default attributes of the product.
$default_attributes = $product->get_default_attributes();

foreach ( $attributes as $attribute_name => $options ) {
$swatches = ciyashop_get_swatches( $product->get_id(), $attribute_name, $options, $available_variations );

// Gheck swatch option is not disabled for attribute.
$enable_swatch = get_option( 'ciyashop_' . $attribute_name . '_swatch' );
?>
<tr>
<td class="label">
<label for="<?php echo esc_attr( sanitize_title( $attribute_name ) ); ?>"><?php echo ucwords( wc_attribute_label( $attribute_name ) ); // phpcs:ignore WordPress.XSS.EscapeOutput.OutputNotE ?></label>
</td>
<td class="value<?php echo ! empty( $enable_swatch ) ? esc_attr( ' ciyashop-swatches' ) : ''; ?>">
<?php
if ( $enable_swatch ) {
?>
<div class="swatches-select" data-id="<?php echo esc_attr( sanitize_title( $attribute_name ) ); ?>">
<?php
if ( is_array( $options ) ) {

if ( isset( $_REQUEST[ 'attribute_' . $attribute_name ] ) ) {
$selected_value = sanitize_text_field( wp_unslash( $_REQUEST[ 'attribute_' . $attribute_name ] ) );
} else {
$selected_value = '';
}

// Get terms if this is a taxonomy - ordered.
if ( taxonomy_exists( $attribute_name ) ) {

$terms = wc_get_product_terms( $product->get_id(), $attribute_name, array( 'fields' => 'all' ) );
$options_fliped = array_flip( $options );
foreach ( $terms as $term ) { // phpcs:ignore WordPress.WP.GlobalVariablesOverride
if ( ! in_array( $term->slug, $options, true ) ) {
continue;
}

$style = '';
$key = $options_fliped[ $term->slug ];
$class = 'ciyashop-swatch ';

if ( isset( $swatches[ $key ]['color'] ) && ! empty( $swatches[ $key ]['color'] ) && isset( $swatches[ $key ]['image'] ) && ! empty( $swatches[ $key ]['image'] ) ) {
$class .= 'swatch-image';
$img_url = wp_get_attachment_image_src( $swatches[ $key ]['image'], 'ciyashop-brand-logo' );
$style = 'background-image: url(' . $img_url[0] . ')';
} elseif ( isset( $swatches[ $key ]['color'] ) && ! empty( $swatches[ $key ]['color'] ) ) {
$class .= 'swatch-colored';
$style = 'background-color:' . $swatches[ $key ]['color'];
} elseif ( ! empty( $swatches[ $key ]['image'] ) ) {
$class .= 'swatch-image';
$img_url = wp_get_attachment_image_src( $swatches[ $key ]['image'], 'ciyashop-brand-logo' );
$style = 'background-image: url(' . $img_url[0] . ')';
} else {
$class .= 'ciyashop-text-only';
}

if ( $selected_value ) {
if ( (string) $term->slug === (string) $selected_value ) {
$class .= ' cs-attr-selected';
}
} else {
// Check if default attribuet is set for current attribute and default selected attibute is current value.
if ( isset( $default_attributes[ $attribute_name ] ) && (string) $term->slug === (string) $default_attributes[ $attribute_name ] ) {
$class .= ' cs-attr-selected';
}
}

echo '<a class="' . esc_attr( $class ) . '" data-value="' . esc_attr( $term->slug ) . '" ' . selected( sanitize_title( $selected_value ), sanitize_title( $term->slug ), false ) . ' style="' . esc_attr( $style ) . '" title="' . esc_attr( $term->name ) . '" data-toggle="tooltip" data-cs_parent="' . esc_attr( sanitize_title( $attribute_name ) ) . '">' . apply_filters( 'woocommerce_variation_option_name', $term->name ) . '</a>'; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
}
} else {
foreach ( $options as $option ) {
echo '<a data-value="' . esc_attr( sanitize_title( $option ) ) . '" ' . selected( sanitize_title( $selected_value ), sanitize_title( $option ), false ) . ' data-toggle="tooltip" data-cs_parent="' . esc_attr( sanitize_title( $attribute_name ) ) . '">' . esc_html( apply_filters( 'woocommerce_variation_option_name', $option ) ) . '</a>';
}
}
}
?>

</div>
<?php
}

wc_dropdown_variation_attribute_options(
array(
'options' => $options,
'attribute' => $attribute_name,
'product' => $product,
)
);
echo end( $attribute_keys ) === $attribute_name ? wp_kses_post( apply_filters( 'woocommerce_reset_variations_link', '<a class="reset_variations" href="#">' . esc_html__( 'Clear', 'ciyashop' ) . '</a>' ) ) : '';
?>
</td>
</tr>
<?php
}
?>
</tbody>
</table>

<div class="single_variation_wrap">
<?php
/**
* Hook: woocommerce_before_single_variation.
*/
do_action( 'woocommerce_before_single_variation' );

/**
* Hook: woocommerce_single_variation. Used to output the cart button and placeholder for variation data.
*
* @since 2.4.0
* @hooked woocommerce_single_variation - 10 Empty div for variation data.
* @hooked woocommerce_single_variation_add_to_cart_button - 20 Qty and cart button.
*/
do_action( 'woocommerce_single_variation' );

/**
* Hook: woocommerce_after_single_variation.
*/
do_action( 'woocommerce_after_single_variation' );
?>
</div>
<?php
}
do_action( 'woocommerce_after_variations_form' );
?>
</form>
<?php
do_action( 'woocommerce_after_add_to_cart_form' );

 

 

Muchas gracias.

Contenido solo visible a usuarios registrados

Respondido : 20/03/2022 5:07 pm
Karen Rios
 Karen Rios
Soporte CMS Webempresa Moderator

Hola Joel, 

En este caso, en que sección de los productos variables necesitas añadir una clase, disculpa no me queda muy claro que tipo de cambio necesitas hacer. Si es posible puedes enviarnos algunas capturas sobre los cambios que deseas realizar y algunos ejemplos? de esta forma podemos verificarlo con mayor detalle. 

Por otro lado ten en cuenta que el tema que nos comentas es un tema de pago y no podemos comprobar como funciona, si necesitas modificar algo especifico desde el código del tema en este caso te sugiero consultes con los desarrolladores de la plantilla para que te indiquen de forma precisa como  realizar la modificación que necesitas. 

Un Saludo 

Respondido : 20/03/2022 5:40 pm

wpdoctor-revisa-la-salud-de-tu-wordpress

Joel Alexander
 Joel Alexander
Nuevo usuario

Hola @karen,

Necesito añadir una clase específicamente a los productos variables que se encuentran agotados, con esto a través de CSS puedo darles un estilo diferente y así los clientes pueden diferenciar a primera vista que tallas no están disponibles.

imagen01

Como puedes observar en la imagen, todas la variables tienen una clase ciyashop-swatch y ciyashop-text-only (cuando se trata de variables de texto, como tallas y etc). Lo que intento es colocar algún fragmento que me deje agregar una clase adicional si el producto variable esta agotado, imagino que tengo que agregar algún código con un condicional pero no manejo mucho sobre php.

Con respecto al soporte del tema pago, no e podido establecer contacto con ellos a pesar de las múltiples consultas.

Gracias por tu respuesta.

Respondido : 20/03/2022 5:57 pm
Bruno
 Bruno
Soporte CMS Webempresa Moderator

Que tal Joel

Entendemos tu solicitud pero al tratarse de ser una modificación a medida no podemos indicarla por este medio por ello te podemos recomendar lo siguiente

Por una parte lo ya comentado por mi compañera lo cual es considerar que el tema al ser pago puedes hacer esta solicitud los desarrolladores de dicho tema

Por otra parte al ser un ajuste a medidas podemos recomendarte a nuestros colaboradores que con gusto podrán ver tu solicitud a mayor detalle https://www.webempresa.com/directorio-colaboradores.html

Saludos! 

Esta publicación ha sido modificada el hace 3 años por Bruno
Respondido : 20/03/2022 9:15 pm

Joel Alexander
 Joel Alexander
Nuevo usuario

Ok, estaré en contacto.

Muchas gracias.

Respondido : 21/03/2022 12:24 am
Bruno
 Bruno
Soporte CMS Webempresa Moderator

Hola Joel,

Entendido! estaremos atentos y dispuesto a colaborar con cualquier otra consulta

Saludos!

Respondido : 21/03/2022 2:50 am

Gestor de Contraseñas - VPN Conexión Segura - Gestor 2FA (Segundo Factor de Autenticación