yo suelo Reserva Woothemes para mi sitio de woocommerce
A medida que construyo una búsqueda personalizada de productos, también tengo que buscar disponibilidad, así es como debo administrar la disponibilidad de BO y cómo el complemento se almacena en la base de datos
a:8:{i:0;a:4:{s:4:"type";s:4:"days";s:8:"bookable";s:3:"yes";s:4:"from";s:1:"3";s:2:"to";s:1:"3";}i:1;a:4:{s:4:"type";s:6:"custom";s:8:"bookable";s:3:"yes";s:4:"from";s:10:"2015-07-09";s:2:"to";s:10:"2015-07-09";}i:2;a:4:{s:4:"type";s:6:"custom";s:8:"bookable";s:3:"yes";s:4:"from";s:10:"2015-07-08";s:2:"to";s:10:"2015-07-08";}i:3;a:4:{s:4:"type";s:6:"custom";s:8:"bookable";s:3:"yes";s:4:"from";s:10:"2015-07-10";s:2:"to";s:10:"2015-07-10";}i:4;a:4:{s:4:"type";s:6:"custom";s:8:"bookable";s:3:"yes";s:4:"from";s:10:"2015-07-15";s:2:"to";s:10:"2015-07-15";}i:5;a:4:{s:4:"type";s:6:"custom";s:8:"bookable";s:3:"yes";s:4:"from";s:10:"2015-07-16";s:2:"to";s:10:"2015-07-16";}i:6;a:4:{s:4:"type";s:6:"custom";s:8:"bookable";s:3:"yes";s:4:"from";s:10:"2015-07-17";s:2:"to";s:10:"2015-07-17";}i:7;a:4:{s:4:"type";s:6:"months";s:8:"bookable";s:2:"no";s:4:"from";s:1:"8";s:2:"to";s:1:"8";}}
Puedo recuperar estos valores de la función integrada de wordpress get_post_meta,
$avail = get_post_meta($product->id, '_wc_booking_availability');
y el resultado es:
Array
(
[0] => Array
(
[type] => days
[bookable] => yes
[from] => 3
[to] => 3
)
[1] => Array
(
[type] => custom
[bookable] => yes
[from] => 2015-07-09
[to] => 2015-07-09
)
[2] => Array
(
[type] => custom
[bookable] => yes
[from] => 2015-07-08
[to] => 2015-07-08
)
[3] => Array
(
[type] => custom
[bookable] => yes
[from] => 2015-07-10
[to] => 2015-07-10
)
[4] => Array
(
[type] => custom
[bookable] => yes
[from] => 2015-07-15
[to] => 2015-07-15
)
[5] => Array
(
[type] => custom
[bookable] => yes
[from] => 2015-07-16
[to] => 2015-07-16
)
[6] => Array
(
[type] => custom
[bookable] => yes
[from] => 2015-07-17
[to] => 2015-07-17
)
[7] => Array
(
[type] => months
[bookable] => no
[from] => 8
[to] => 8
)
)
Como puede ver, el usuario puede especificar si el producto se puede reservar o no en un rango de días o meses, por lo que mi pregunta es cómo puedo hacer una consulta SQL para verificar si una variable de fecha está disponible para este producto, creo que meta_query servirá. el trabajo (como se muestra a continuación), pero ¿cómo puedo especificar una fecha no disponible? ¿Cómo crees que?
if($_GET['when']){
/* checkIsAValidDate() >> check date format */
if ( checkIsAValidDate( $_GET['when'] ) ){
$quand = $_GET['when'];
$available = array(
"post_type" => "product",
"meta_query" => array(
"relation" => "AND",
"key" => '_wc_booking_availability',
"value" => $when,
'compare' => 'IN'
)
);
}
}
morfático
Dado que el valor meta es una matriz, puede que no sea posible usar WP_Meta_Query
. Si bien estoy de acuerdo en que usar WP_Meta_Query
parece la forma más elegante de hacer esto, siempre he encontrado esta función realmente confusa, y dado que puede obtener la matriz de objetos que se pueden reservar, parece que sería sencillo escribir una función como:
/**
* Returns an array of bookable products according to supplied criteria
*
* @param int $pid the $product->ID of the bookable object
* @param mixed $when a date in YYYY-MM-DD format or integer representing a day or month
* @param string $type a value of 'day', 'month', or 'custom'
* @param string $bookable whether the bookable object is bookable or not ('yes' or 'no')
* @return array an array of bookable objects for the product
*/
function getBookables( $pid, $when, $type, $bookable="yes" ) {
$result = array();
// is $when in the YYYY-MM-DD format?
if ( 'custom' == $type ) {
// it's a custom date so convert $when to DateTime
$when = DateTime::createFromFormat( 'Y-m-d', $when );
}
$availability = get_post_meta( $pid, '_wc_booking_availability' );
foreach ( $availability as $a ) {
if ( $a[ 'bookable' ] == $bookable ) {
// is it in the YYYY-MM-DD format?
if ( $when instanceof DateTime ) {
// it's a custom date so use date compare
$from = DateTime::createFromFormat( 'Y-m-d', $a[ 'from' ] );
$to = DateTime::createFromFormat( 'Y-m-d', $a[ 'to' ] );
if ( $when >= $from && $when <= $to ) {
$result[] = $a;
}
} else {
// it is an integer value (day or month)
if ( $type == $a[ 'type' ] && ( $when >= $from && $when <= $to ) ) {
$result[] = $a;
}
}
}
}
return $result;
}
Tenga en cuenta que probablemente sea necesario pasar el type
a la función de búsqueda ya que aunque puedo distinguir YYYY-MM-DD
valores de int
valores, no hay manera fácil de distinguir month
de day
valores. Como tal, puede usar la función anterior:
if ( $_GET[ 'when' ] && $_GET[ 'type' ] ) {
$when = $_GET[ 'when' ];
$type = $_GET[ 'type' ];
$bookables = getBookables( $product->ID, $when, $type );
}
También tenga en cuenta que si pasa la cadena 'no'
como cuarto parámetro de la función, puede obtener la lista de indisponible veces.
¡Espero que esto ayude!