mirror of
https://github.com/pronamic/woocommerce-subscriptions.git
synced 2025-10-12 12:22:56 +00:00
197 lines
5.8 KiB
PHP
197 lines
5.8 KiB
PHP
<?php
|
|
/**
|
|
* Subscription Product Class
|
|
*
|
|
* The subscription product class is an extension of the simple product class.
|
|
*
|
|
* @class WC_Product_Subscription
|
|
* @package WooCommerce Subscriptions
|
|
* @subpackage WC_Product_Subscription
|
|
* @category Class
|
|
* @since 1.3
|
|
*
|
|
*/
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit; // Exit if accessed directly
|
|
}
|
|
|
|
class WC_Product_Subscription extends WC_Product_Simple {
|
|
|
|
var $subscription_price;
|
|
|
|
var $subscription_period;
|
|
|
|
var $subscription_period_interval;
|
|
|
|
var $subscription_length;
|
|
|
|
var $subscription_trial_length;
|
|
|
|
var $subscription_trial_period;
|
|
|
|
var $subscription_sign_up_fee;
|
|
|
|
/**
|
|
* Create a simple subscription product object.
|
|
*
|
|
* @access public
|
|
* @param mixed $product
|
|
*/
|
|
public function __construct( $product ) {
|
|
parent::__construct( $product );
|
|
$this->product_type = 'subscription';
|
|
|
|
// Load all meta fields
|
|
$this->product_custom_fields = get_post_meta( $this->id );
|
|
|
|
// Convert selected subscription meta fields for easy access
|
|
if ( ! empty( $this->product_custom_fields['_subscription_price'][0] ) ) {
|
|
$this->subscription_price = $this->product_custom_fields['_subscription_price'][0];
|
|
}
|
|
|
|
if ( ! empty( $this->product_custom_fields['_subscription_sign_up_fee'][0] ) ) {
|
|
$this->subscription_sign_up_fee = $this->product_custom_fields['_subscription_sign_up_fee'][0];
|
|
}
|
|
|
|
if ( ! empty( $this->product_custom_fields['_subscription_period'][0] ) ) {
|
|
$this->subscription_period = $this->product_custom_fields['_subscription_period'][0];
|
|
}
|
|
|
|
if ( ! empty( $this->product_custom_fields['_subscription_period_interval'][0] ) ) {
|
|
$this->subscription_period_interval = $this->product_custom_fields['_subscription_period_interval'][0];
|
|
}
|
|
|
|
if ( ! empty( $this->product_custom_fields['_subscription_length'][0] ) ) {
|
|
$this->subscription_length = $this->product_custom_fields['_subscription_length'][0];
|
|
}
|
|
|
|
if ( ! empty( $this->product_custom_fields['_subscription_trial_length'][0] ) ) {
|
|
$this->subscription_trial_length = $this->product_custom_fields['_subscription_trial_length'][0];
|
|
}
|
|
|
|
if ( ! empty( $this->product_custom_fields['_subscription_trial_period'][0] ) ) {
|
|
$this->subscription_trial_period = $this->product_custom_fields['_subscription_trial_period'][0];
|
|
}
|
|
|
|
$this->subscription_payment_sync_date = ( ! isset( $this->product_custom_fields['_subscription_payment_sync_date'][0] ) ) ? 0 : maybe_unserialize( $this->product_custom_fields['_subscription_payment_sync_date'][0] );
|
|
|
|
$this->subscription_one_time_shipping = ( ! isset( $this->product_custom_fields['_subscription_one_time_shipping'][0] ) ) ? 'no' : $this->product_custom_fields['_subscription_one_time_shipping'][0];
|
|
|
|
}
|
|
|
|
/**
|
|
* Auto-load in-accessible properties on demand.
|
|
*
|
|
* @param mixed $key
|
|
* @return mixed
|
|
*/
|
|
public function __get( $key ) {
|
|
if ( 'limit_subscriptions' === $key ) {
|
|
_deprecated_argument( 'WC_Product_Subscription->limit_subscriptions', '2.1', 'Use wcs_get_product_limitation directly' );
|
|
return wcs_get_product_limitation( $this );
|
|
} else {
|
|
return parent::__get( $key );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get subscription's price HTML.
|
|
*
|
|
* @return string containing the formatted price
|
|
*/
|
|
public function get_price_html( $price = '' ) {
|
|
|
|
$price = parent::get_price_html( $price );
|
|
|
|
if ( ! empty( $price ) ) {
|
|
$price = WC_Subscriptions_Product::get_price_string( $this, array( 'price' => $price ) );
|
|
}
|
|
|
|
return $price;
|
|
}
|
|
|
|
/**
|
|
* Get the add to cart button text
|
|
*
|
|
* @access public
|
|
* @return string
|
|
*/
|
|
public function add_to_cart_text() {
|
|
|
|
if ( $this->is_purchasable() && $this->is_in_stock() ) {
|
|
$text = get_option( WC_Subscriptions_Admin::$option_prefix . '_add_to_cart_button_text', __( 'Sign Up Now', 'woocommerce-subscriptions' ) );
|
|
} else {
|
|
$text = parent::add_to_cart_text(); // translated "Read More"
|
|
}
|
|
|
|
return apply_filters( 'woocommerce_product_add_to_cart_text', $text, $this );
|
|
}
|
|
|
|
/**
|
|
* Get the add to cart button text for the single page
|
|
*
|
|
* @access public
|
|
* @return string
|
|
*/
|
|
public function single_add_to_cart_text() {
|
|
return apply_filters( 'woocommerce_product_single_add_to_cart_text', self::add_to_cart_text(), $this );
|
|
}
|
|
|
|
/**
|
|
* Returns the sign up fee (including tax) by filtering the products price used in
|
|
* @see WC_Product::get_price_including_tax( $qty )
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_sign_up_fee_including_tax( $qty = 1 ) {
|
|
|
|
add_filter( 'woocommerce_get_price', array( &$this, 'get_sign_up_fee' ), 100, 0 );
|
|
|
|
$sign_up_fee_including_tax = parent::get_price_including_tax( $qty );
|
|
|
|
remove_filter( 'woocommerce_get_price', array( &$this, 'get_sign_up_fee' ), 100, 0 );
|
|
|
|
return $sign_up_fee_including_tax;
|
|
}
|
|
|
|
/**
|
|
* Returns the sign up fee (excluding tax) by filtering the products price used in
|
|
* @see WC_Product::get_price_excluding_tax( $qty )
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_sign_up_fee_excluding_tax( $qty = 1 ) {
|
|
|
|
add_filter( 'woocommerce_get_price', array( &$this, 'get_sign_up_fee' ), 100, 0 );
|
|
|
|
$sign_up_fee_excluding_tax = parent::get_price_excluding_tax( $qty );
|
|
|
|
remove_filter( 'woocommerce_get_price', array( &$this, 'get_sign_up_fee' ), 100, 0 );
|
|
|
|
return $sign_up_fee_excluding_tax;
|
|
}
|
|
|
|
/**
|
|
* Return the sign-up fee for this product
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_sign_up_fee() {
|
|
return WC_Subscriptions_Product::get_sign_up_fee( $this );
|
|
}
|
|
|
|
/**
|
|
* Checks if the store manager has requested the current product be limited to one purchase
|
|
* per customer, and if so, checks whether the customer already has an active subscription to
|
|
* the product.
|
|
*
|
|
* @access public
|
|
* @return bool
|
|
*/
|
|
function is_purchasable() {
|
|
$purchasable = WCS_Limiter::is_purchasable( parent::is_purchasable(), $this );
|
|
|
|
return apply_filters( 'woocommerce_subscription_is_purchasable', $purchasable, $this );
|
|
}
|
|
}
|