woocommerce/classes/class-wc-product-simple.php

73 lines
1.7 KiB
PHP
Raw Normal View History

<?php
/**
* Simple Product Class
*
* The default product type kinda product.
*
* @class WC_Product_Simple
2012-12-03 19:19:58 +00:00
* @version 2.0.0
* @package WooCommerce/Classes/Products
* @author WooThemes
*/
if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
class WC_Product_Simple extends WC_Product {
/**
* __construct function.
2012-11-27 16:22:47 +00:00
*
* @access public
* @param mixed $product
*/
public function __construct( $product ) {
2012-12-20 11:54:38 +00:00
$this->product_type = 'simple';
parent::__construct( $product );
}
2012-12-11 17:28:47 +00:00
/**
* Get the title of the post.
*
* @access public
* @return string
*/
public function get_title() {
2012-12-11 17:28:47 +00:00
$title = $this->post->post_title;
if ( $this->get_parent() > 0 ) {
$title = get_the_title( $this->get_parent() ) . ' &rarr; ' . $title;
}
return apply_filters( 'woocommerce_product_title', apply_filters( 'the_title', $title, $this->id ), $this );
}
/**
* Sync grouped products with the childs lowest price (so they can be sorted by price accurately).
*
* @access public
* @return void
*/
public function grouped_product_sync() {
global $wpdb, $woocommerce;
if ( ! $this->get_parent() ) return;
$children_by_price = get_posts( array(
'post_parent' => $this->get_parent(),
'orderby' => 'meta_value_num',
'order' => 'asc',
'meta_key' => '_price',
'posts_per_page' => 1,
'post_type' => 'product',
'fields' => 'ids'
));
if ( $children_by_price ) {
foreach ( $children_by_price as $child ) {
$child_price = get_post_meta( $child, '_price', true );
update_post_meta( $this->get_parent(), '_price', $child_price );
}
}
$woocommerce->clear_product_transients( $this->id );
}
}