當前位置: 首頁>>代碼示例>>PHP>>正文


PHP wcs_get_canonical_product_id函數代碼示例

本文整理匯總了PHP中wcs_get_canonical_product_id函數的典型用法代碼示例。如果您正苦於以下問題:PHP wcs_get_canonical_product_id函數的具體用法?PHP wcs_get_canonical_product_id怎麽用?PHP wcs_get_canonical_product_id使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了wcs_get_canonical_product_id函數的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: migrate_download_permissions

 /**
  * Move download permissions from original order to the new subscription created for the order.
  *
  * @param WC_Subscription $subscription A subscription object
  * @param int $subscription_item_id ID of the product line item on the subscription
  * @param WC_Order $original_order The original order that was created to purchase the subscription
  * @since 2.0
  */
 private static function migrate_download_permissions($subscription, $subscription_item_id, $order)
 {
     global $wpdb;
     $product_id = wcs_get_canonical_product_id(wcs_get_order_item($subscription_item_id, $subscription));
     $rows_affected = $wpdb->update($wpdb->prefix . 'woocommerce_downloadable_product_permissions', array('order_id' => $subscription->id, 'order_key' => $subscription->order_key), array('order_id' => $order->id, 'order_key' => $order->order_key, 'product_id' => $product_id, 'user_id' => absint($subscription->get_user_id())), array('%d', '%s'), array('%d', '%s', '%d', '%d'));
     WCS_Upgrade_Logger::add(sprintf('For subscription %d: migrated %d download permissions for product %d', $subscription->id, $rows_affected, $product_id));
 }
開發者ID:slavic18,項目名稱:cats,代碼行數:15,代碼來源:class-wcs-upgrade-2-0.php

示例2: is_subscription_discountable

 /**
  * Checks a given product / coupon combination to determine if the subscription should be discounted
  *
  * @since 1.2
  */
 private static function is_subscription_discountable($cart_item, $coupon)
 {
     $product_cats = wp_get_post_terms($cart_item['product_id'], 'product_cat', array('fields' => 'ids'));
     $this_item_is_discounted = false;
     // Specific products get the discount
     if (sizeof($coupon->product_ids) > 0) {
         if (in_array(wcs_get_canonical_product_id($cart_item), $coupon->product_ids) || in_array($cart_item['data']->get_parent(), $coupon->product_ids)) {
             $this_item_is_discounted = true;
         }
         // Category discounts
     } elseif (sizeof($coupon->product_categories) > 0) {
         if (sizeof(array_intersect($product_cats, $coupon->product_categories)) > 0) {
             $this_item_is_discounted = true;
         }
     } else {
         // No product ids - all items discounted
         $this_item_is_discounted = true;
     }
     // Specific product ID's excluded from the discount
     if (sizeof($coupon->exclude_product_ids) > 0) {
         if (in_array(wcs_get_canonical_product_id($cart_item), $coupon->exclude_product_ids) || in_array($cart_item['data']->get_parent(), $coupon->exclude_product_ids)) {
             $this_item_is_discounted = false;
         }
     }
     // Specific categories excluded from the discount
     if (sizeof($coupon->exclude_product_categories) > 0) {
         if (sizeof(array_intersect($product_cats, $coupon->exclude_product_categories)) > 0) {
             $this_item_is_discounted = false;
         }
     }
     // Apply filter
     return apply_filters('woocommerce_item_is_discounted', $this_item_is_discounted, $cart_item, $before_tax = false);
 }
開發者ID:ltdat287,項目名稱:id.nhomdichvu,代碼行數:38,代碼來源:class-wc-subscriptions-coupon.php

示例3: get_subscription_interval

 /**
  * Returns the billing interval for a each subscription product in an order.
  *
  * For example, this would return 3 for a subscription charged every 3 months or 1 for a subscription charged every month.
  *
  * @param mixed $order A WC_Order object or the ID of the order which the subscription was purchased in.
  * @param int $product_id (optional) The post ID of the subscription WC_Product object purchased in the order. Defaults to the ID of the first product purchased in the order.
  * @return int The billing interval for a each subscription product in an order.
  * @since 1.0
  */
 public static function get_subscription_interval($order, $product_id = '')
 {
     _deprecated_function(__METHOD__, '2.0', 'the billing interval for each individual subscription object. Since Subscriptions v2.0, an order can be used to create multiple different subscriptions with different billing schedules, so use the subscription object');
     $billing_interval = '';
     foreach (wcs_get_subscriptions_for_order($order, array('order_type' => 'parent')) as $subscription) {
         // Find the billing interval for all recurring items
         if (empty($product_id)) {
             $billing_interval = $subscription->billing_interval;
             break;
         } else {
             // We want the billing interval for a specific item (so we need to find if this subscription contains that item)
             foreach ($subscription->get_items() as $line_item) {
                 if (wcs_get_canonical_product_id($line_item) == $product_id) {
                     $billing_interval = $subscription->billing_interval;
                     break 2;
                 }
             }
         }
     }
     return $billing_interval;
 }
開發者ID:slavic18,項目名稱:cats,代碼行數:31,代碼來源:class-wc-subscriptions-order.php

示例4: ajax_maybe_add_meta_for_item

 /**
  * When adding an item to an order/subscription via the Add/Edit Subscription administration interface, check if we should be setting
  * the sync meta on the subscription.
  *
  * @param int The order item ID of an item that was just added to the order
  * @param array The order item details
  * @since 2.0
  */
 public static function ajax_maybe_add_meta_for_item($item_id, $item)
 {
     check_ajax_referer('order-item', 'security');
     if (self::is_product_synced(wcs_get_canonical_product_id($item))) {
         self::maybe_add_subscription_meta(absint($_POST['order_id']));
     }
 }
開發者ID:bself,項目名稱:nuimage-wp,代碼行數:15,代碼來源:class-wc-subscriptions-synchroniser.php

示例5: remove_download_permissions_after_switch

 /**
  * Revoke download permissions granted on the old switch item.
  *
  * @since 2.0.9
  * @param WC_Subscription $subscription
  * @param array $new_item
  * @param array $old_item
  */
 public static function remove_download_permissions_after_switch($subscription, $new_item, $old_item)
 {
     if (!is_object($subscription)) {
         $subscription = wcs_get_subscription($subscription);
     }
     $product_id = wcs_get_canonical_product_id($old_item);
     WCS_Download_Handler::revoke_downloadable_file_permission($product_id, $subscription->id, $subscription->customer_user);
 }
開發者ID:bself,項目名稱:nuimage-wp,代碼行數:16,代碼來源:class-wc-subscriptions-switcher.php

示例6: get_items_product_id

 /**
  * Returns a cart item's product ID. For a variation, this will be a variation ID, for a simple product,
  * it will be the product's ID.
  *
  * @since 1.5
  */
 public static function get_items_product_id($cart_item)
 {
     _deprecated_function(__METHOD__, '2.0', 'wcs_get_canonical_product_id( $cart_item )');
     return wcs_get_canonical_product_id($cart_item);
 }
開發者ID:slavic18,項目名稱:cats,代碼行數:11,代碼來源:class-wc-subscriptions-cart.php

示例7: get_item_downloads

 /**
  * WooCommerce's function receives the original order ID, the item and the list of files. This does not work for
  * download permissions stored on the subscription rather than the original order as the URL would have the wrong order
  * key. This function takes the same parameters, but queries the database again for download ids belonging to all the
  * subscriptions that were in the original order. Then for all subscriptions, it checks all items, and if the item
  * passed in here is in that subscription, it creates the correct download link to be passsed to the email.
  *
  * @param array $files List of files already included in the list
  * @param array $item An item (you get it by doing $order->get_items())
  * @param WC_Order $order The original order
  * @return array List of files with correct download urls
  */
 public static function get_item_downloads($files, $item, $order)
 {
     global $wpdb;
     if (wcs_order_contains_subscription($order, 'any')) {
         $subscriptions = wcs_get_subscriptions_for_order($order, array('order_type' => array('any')));
     } else {
         return $files;
     }
     $product_id = wcs_get_canonical_product_id($item);
     foreach ($subscriptions as $subscription) {
         foreach ($subscription->get_items() as $subscription_item) {
             if (wcs_get_canonical_product_id($subscription_item) === $product_id) {
                 $files = $subscription->get_item_downloads($subscription_item);
             }
         }
     }
     return $files;
 }
開發者ID:ltdat287,項目名稱:id.nhomdichvu,代碼行數:30,代碼來源:class-wcs-download-handler.php

示例8: add_cart_item

 /**
  * Add a cart item to a subscription.
  *
  * @since 2.0
  */
 public static function add_cart_item($subscription, $cart_item, $cart_item_key)
 {
     $item_id = $subscription->add_product($cart_item['data'], $cart_item['quantity'], array('variation' => $cart_item['variation'], 'totals' => array('subtotal' => $cart_item['line_subtotal'], 'subtotal_tax' => $cart_item['line_subtotal_tax'], 'total' => $cart_item['line_total'], 'tax' => $cart_item['line_tax'], 'tax_data' => $cart_item['line_tax_data'])));
     if (!$item_id) {
         // translators: placeholder is an internal error number
         throw new Exception(sprintf(__('Error %d: Unable to create subscription. Please try again.', 'woocommerce-subscriptions'), 402));
     }
     $cart_item_product_id = 0 != $cart_item['variation_id'] ? $cart_item['variation_id'] : $cart_item['product_id'];
     if (WC_Subscriptions_Product::get_trial_length(wcs_get_canonical_product_id($cart_item)) > 0) {
         wc_add_order_item_meta($item_id, '_has_trial', 'true');
     }
     // Allow plugins to add order item meta
     do_action('woocommerce_add_order_item_meta', $item_id, $cart_item, $cart_item_key);
     do_action('woocommerce_add_subscription_item_meta', $item_id, $cart_item, $cart_item_key);
     return $item_id;
 }
開發者ID:DustinHartzler,項目名稱:TheCLEFT,代碼行數:21,代碼來源:class-wc-subscriptions-checkout.php

示例9: get_items_sign_up_fee

 /**
  * Check if a given line item on the subscription had a sign-up fee, and if so, return the value of the sign-up fee.
  *
  * The single quantity sign-up fee will be returned instead of the total sign-up fee paid. For example, if 3 x a product
  * with a 10 BTC sign-up fee was purchased, a total 30 BTC was paid as the sign-up fee but this function will return 10 BTC.
  *
  * @param array|int Either an order item (in the array format returned by self::get_items()) or the ID of an order item.
  * @return bool
  * @since 2.0
  */
 public function get_items_sign_up_fee($line_item)
 {
     if (!is_array($line_item)) {
         $line_item = wcs_get_order_item($line_item, $this);
     }
     // If there was no original order, nothing was paid up-front which means no sign-up fee
     if (empty($this->order)) {
         $sign_up_fee = 0;
     } else {
         $original_order_item = '';
         // Find the matching item on the order
         foreach ($this->order->get_items() as $order_item) {
             if (wcs_get_canonical_product_id($line_item) == wcs_get_canonical_product_id($order_item)) {
                 $original_order_item = $order_item;
                 break;
             }
         }
         // No matching order item, so this item wasn't purchased in the original order
         if (empty($original_order_item)) {
             $sign_up_fee = 0;
         } elseif (isset($line_item['item_meta']['_has_trial'])) {
             // Sign up was was total amount paid for this item on original order
             $sign_up_fee = $original_order_item['line_total'] / $original_order_item['qty'];
         } else {
             // Sign-up fee is any amount on top of recurring amount
             $sign_up_fee = max($original_order_item['line_total'] / $original_order_item['qty'] - $line_item['line_total'] / $line_item['qty'], 0);
         }
     }
     return apply_filters('woocommerce_subscription_items_sign_up_fee', $sign_up_fee, $line_item, $this);
 }
開發者ID:ltdat287,項目名稱:id.nhomdichvu,代碼行數:40,代碼來源:class-wc-subscription.php

示例10: get_items_sign_up_fee

 /**
  * Check if a given line item on the subscription had a sign-up fee, and if so, return the value of the sign-up fee.
  *
  * The single quantity sign-up fee will be returned instead of the total sign-up fee paid. For example, if 3 x a product
  * with a 10 BTC sign-up fee was purchased, a total 30 BTC was paid as the sign-up fee but this function will return 10 BTC.
  *
  * @param array|int Either an order item (in the array format returned by self::get_items()) or the ID of an order item.
  * @param  string $tax_inclusive_or_exclusive Whether or not to adjust sign up fee if prices inc tax - ensures that the sign up fee paid amount includes the paid tax if inc
  * @return bool
  * @since 2.0
  */
 public function get_items_sign_up_fee($line_item, $tax_inclusive_or_exclusive = 'exclusive_of_tax')
 {
     if (!is_array($line_item)) {
         $line_item = wcs_get_order_item($line_item, $this);
     }
     // If there was no original order, nothing was paid up-front which means no sign-up fee
     if (empty($this->order)) {
         $sign_up_fee = 0;
     } else {
         $original_order_item = '';
         // Find the matching item on the order
         foreach ($this->order->get_items() as $order_item) {
             if (wcs_get_canonical_product_id($line_item) == wcs_get_canonical_product_id($order_item)) {
                 $original_order_item = $order_item;
                 break;
             }
         }
         // No matching order item, so this item wasn't purchased in the original order
         if (empty($original_order_item)) {
             $sign_up_fee = 0;
         } elseif (isset($line_item['item_meta']['_has_trial'])) {
             // Sign up was was total amount paid for this item on original order
             $sign_up_fee = $original_order_item['line_total'] / $original_order_item['qty'];
         } else {
             // Sign-up fee is any amount on top of recurring amount
             $sign_up_fee = max($original_order_item['line_total'] / $original_order_item['qty'] - $line_item['line_total'] / $line_item['qty'], 0);
         }
         // If prices inc tax, ensure that the sign up fee amount includes the tax
         if ('inclusive_of_tax' === $tax_inclusive_or_exclusive && !empty($original_order_item) && 'yes' == $this->prices_include_tax) {
             $proportion = $sign_up_fee / ($original_order_item['line_total'] / $original_order_item['qty']);
             $sign_up_fee += round($original_order_item['line_tax'] * $proportion, 2);
         }
     }
     return apply_filters('woocommerce_subscription_items_sign_up_fee', $sign_up_fee, $line_item, $this, $tax_inclusive_or_exclusive);
 }
開發者ID:DustinHartzler,項目名稱:TheCLEFT,代碼行數:46,代碼來源:class-wc-subscription.php

示例11: maybe_repair_subscription

 /**
  * Check if a subscription was created prior to 2.0.0 and has some dates that need to be updated
  * because the meta was borked during the 2.0.0 upgrade process. If it does, then update the dates
  * to the new values.
  *
  * @return bool true if the subscription was repaired, otherwise false
  */
 protected static function maybe_repair_subscription($subscription)
 {
     $repaired_subscription = false;
     // if the subscription doesn't have an order, it must have been created in 2.0, so we can ignore it
     if (false === $subscription->order) {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: no need to repair: it has no order.', $subscription->id));
         return $repaired_subscription;
     }
     $subscription_line_items = $subscription->get_items();
     // if the subscription has more than one line item, it must have been created in 2.0, so we can ignore it
     if (count($subscription_line_items) > 1) {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: no need to repair: it has more than one line item.', $subscription->id));
         return $repaired_subscription;
     }
     $subscription_line_item_id = key($subscription_line_items);
     $subscription_line_item = array_shift($subscription_line_items);
     // Get old order item's meta
     foreach ($subscription->order->get_items() as $line_item_id => $line_item) {
         if (wcs_get_canonical_product_id($line_item) == wcs_get_canonical_product_id($subscription_line_item)) {
             $matching_line_item_id = $line_item_id;
             $matching_line_item = $line_item;
             break;
         }
     }
     // we couldn't find a matching line item so we can't repair it
     if (!isset($matching_line_item)) {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: can not repair: it has no matching line item.', $subscription->id));
         return $repaired_subscription;
     }
     $matching_line_item_meta = $matching_line_item['item_meta'];
     // if the order item doesn't have migrated subscription data, the subscription wasn't migrated from 1.5
     if (!isset($matching_line_item_meta['_wcs_migrated_subscription_status']) && !isset($matching_line_item_meta['_wcs_migrated_subscription_start_date'])) {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: no need to repair: matching line item has no migrated meta data.', $subscription->id));
         return $repaired_subscription;
     }
     if (false !== self::maybe_repair_line_tax_data($subscription_line_item_id, $matching_line_item_id, $matching_line_item)) {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: repaired missing line tax data.', $subscription->id));
         $repaired_subscription = true;
     } else {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: line tax data not added.', $subscription->id));
     }
     // if the subscription has been cancelled, we don't need to repair any other data
     if ($subscription->has_status(array('pending-cancel', 'cancelled'))) {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: no need to repair: it has cancelled status.', $subscription->id));
         return $repaired_subscription;
     }
     $dates_to_update = array();
     if (false !== ($repair_date = self::check_trial_end_date($subscription, $matching_line_item_meta))) {
         $dates_to_update['trial_end'] = $repair_date;
     }
     if (false !== ($repair_date = self::check_next_payment_date($subscription))) {
         $dates_to_update['next_payment'] = $repair_date;
     }
     if (false !== ($repair_date = self::check_end_date($subscription, $matching_line_item_meta))) {
         $dates_to_update['end'] = $repair_date;
     }
     if (!empty($dates_to_update)) {
         WCS_Upgrade_Logger::add(sprintf('For subscription %d: repairing dates = %s', $subscription->id, str_replace(array('{', '}', '"'), '', wcs_json_encode($dates_to_update))));
         try {
             $subscription->update_dates($dates_to_update);
             WCS_Upgrade_Logger::add(sprintf('For subscription %d: repaired dates = %s', $subscription->id, str_replace(array('{', '}', '"'), '', wcs_json_encode($dates_to_update))));
         } catch (Exception $e) {
             WCS_Upgrade_Logger::add(sprintf('!! For subscription %d: unable to repair dates (%s), exception "%s"', $subscription->id, str_replace(array('{', '}', '"'), '', wcs_json_encode($dates_to_update)), $e->getMessage()));
         }
         try {
             self::maybe_repair_status($subscription, $matching_line_item_meta, $dates_to_update);
         } catch (Exception $e) {
             WCS_Upgrade_Logger::add(sprintf('!! For subscription %d: unable to repair status. Exception: "%s"', $subscription->id, $e->getMessage()));
         }
         $repaired_subscription = true;
     }
     if (!empty($subscription->order->customer_note) && empty($subscription->customer_note)) {
         $post_data = array('ID' => $subscription->id, 'post_excerpt' => $subscription->order->customer_note);
         $updated_post_id = wp_update_post($post_data, true);
         if (!is_wp_error($updated_post_id)) {
             WCS_Upgrade_Logger::add(sprintf('For subscription %d: repaired missing customer note.', $subscription->id));
             $repaired_subscription = true;
         } else {
             WCS_Upgrade_Logger::add(sprintf('!! For subscription %d: unable to repair missing customer note. Exception: "%s"', $subscription->id, $updated_post_id->get_error_message()));
         }
     }
     return $repaired_subscription;
 }
開發者ID:DustinHartzler,項目名稱:TheCLEFT,代碼行數:90,代碼來源:class-wcs-repair-2-0-2.php

示例12: calculate_prorated_totals

 /**
  * Set the subscription prices to be used in calculating totals by @see WC_Subscriptions_Cart::calculate_subscription_totals()
  *
  * @since 2.0
  */
 public static function calculate_prorated_totals($cart)
 {
     if (false === self::cart_contains_switches()) {
         return;
     }
     // Maybe charge an initial amount to account for upgrading from a cheaper subscription
     $apportion_recurring_price = get_option(WC_Subscriptions_Admin::$option_prefix . '_apportion_recurring_price', 'no');
     $apportion_sign_up_fee = get_option(WC_Subscriptions_Admin::$option_prefix . '_apportion_sign_up_fee', 'no');
     $apportion_length = get_option(WC_Subscriptions_Admin::$option_prefix . '_apportion_length', 'no');
     foreach (WC()->cart->get_cart() as $cart_item_key => $cart_item) {
         if (!isset($cart_item['subscription_switch']['subscription_id'])) {
             continue;
         }
         $subscription = wcs_get_subscription($cart_item['subscription_switch']['subscription_id']);
         $existing_item = wcs_get_order_item($cart_item['subscription_switch']['item_id'], $subscription);
         if (empty($existing_item)) {
             WC()->cart->remove_cart_item($cart_item_key);
             continue;
         }
         $item_data = $cart_item['data'];
         $product_id = wcs_get_canonical_product_id($cart_item);
         $product = get_product($product_id);
         $is_virtual_product = $product->is_virtual();
         // Set when the first payment and end date for the new subscription should occur
         WC()->cart->cart_contents[$cart_item_key]['subscription_switch']['first_payment_timestamp'] = $cart_item['subscription_switch']['next_payment_timestamp'];
         WC()->cart->cart_contents[$cart_item_key]['subscription_switch']['end_timestamp'] = $end_timestamp = strtotime(WC_Subscriptions_Product::get_expiration_date($product_id, $subscription->get_date('last_payment')));
         // Add any extra sign up fees required to switch to the new subscription
         if ('yes' == $apportion_sign_up_fee) {
             // Because product add-ons etc. don't apply to sign-up fees, it's safe to use the product's sign-up fee value rather than the cart item's
             $sign_up_fee_due = $product->subscription_sign_up_fee;
             $sign_up_fee_paid = $subscription->get_items_sign_up_fee($existing_item);
             // Make sure total prorated sign-up fee is prorated across total amount of sign-up fee so that customer doesn't get extra discounts
             if ($cart_item['quantity'] > $existing_item['qty']) {
                 $sign_up_fee_paid = $sign_up_fee_paid * $existing_item['qty'] / $cart_item['quantity'];
             }
             WC()->cart->cart_contents[$cart_item_key]['data']->subscription_sign_up_fee = max($sign_up_fee_due - $sign_up_fee_paid, 0);
         } elseif ('no' == $apportion_sign_up_fee) {
             // $0 the initial sign-up fee
             WC()->cart->cart_contents[$cart_item_key]['data']->subscription_sign_up_fee = 0;
         }
         // Get the current subscription's last payment date
         $last_payment_timestamp = $subscription->get_time('last_payment');
         $days_since_last_payment = floor((gmdate('U') - $last_payment_timestamp) / (60 * 60 * 24));
         // Get the current subscription's next payment date
         $next_payment_timestamp = $cart_item['subscription_switch']['next_payment_timestamp'];
         $days_until_next_payment = ceil(($next_payment_timestamp - gmdate('U')) / (60 * 60 * 24));
         // Find the number of days between the two
         $days_in_old_cycle = $days_until_next_payment + $days_since_last_payment;
         // Find the actual recurring amount charged for the old subscription (we need to use the '_recurring_line_total' meta here rather than '_subscription_recurring_amount' because we want the recurring amount to include extra from extensions, like Product Add-ons etc.)
         $old_recurring_total = $existing_item['line_total'];
         if ('yes' == $subscription->prices_include_tax || true === $subscription->prices_include_tax) {
             // WC_Abstract_Order::$prices_include_tax can be set to true in __construct() or to 'yes' in populate()
             $old_recurring_total += $existing_item['line_tax'];
         }
         // Find the $price per day for the old subscription's recurring total
         $old_price_per_day = $old_recurring_total / $days_in_old_cycle;
         // Find the price per day for the new subscription's recurring total
         // If the subscription uses the same billing interval & cycle as the old subscription,
         if ($item_data->subscription_period == $subscription->billing_period && $item_data->subscription_period_interval == $subscription->billing_interval) {
             $days_in_new_cycle = $days_in_old_cycle;
             // Use $days_in_old_cycle to make sure they're consistent
         } else {
             // We need to figure out the price per day for the new subscription based on its billing schedule
             switch ($item_data->subscription_period) {
                 case 'day':
                     $days_in_new_cycle = $item_data->subscription_period_interval;
                     break;
                 case 'week':
                     $days_in_new_cycle = $item_data->subscription_period_interval * 7;
                     break;
                 case 'month':
                     $days_in_new_cycle = $item_data->subscription_period_interval * 30.4375;
                     // Average days per month over 4 year period
                     break;
                 case 'year':
                     $days_in_new_cycle = $item_data->subscription_period_interval * 365.25;
                     // Average days per year over 4 year period
                     break;
             }
         }
         // We need to use the cart items price to ensure we include extras added by extensions like Product Add-ons
         $new_price_per_day = $item_data->price * $cart_item['quantity'] / $days_in_new_cycle;
         if ($old_price_per_day < $new_price_per_day) {
             WC()->cart->cart_contents[$cart_item_key]['subscription_switch']['upgraded_or_downgraded'] = 'upgraded';
         } elseif ($old_price_per_day > $new_price_per_day && $new_price_per_day > 0) {
             WC()->cart->cart_contents[$cart_item_key]['subscription_switch']['upgraded_or_downgraded'] = 'downgraded';
         }
         // Now lets see if we should add a prorated amount to the sign-up fee (for upgrades) or extend the next payment date (for downgrades)
         if (in_array($apportion_recurring_price, array('yes', 'yes-upgrade')) || in_array($apportion_recurring_price, array('virtual', 'virtual-upgrade')) && $is_virtual_product) {
             // If the customer is upgrading, we may need to add a gap payment to the sign-up fee or to reduce the pre-paid period (or both)
             if ($old_price_per_day < $new_price_per_day) {
                 // The new subscription may be more expensive, but it's also on a shorter billing cycle, so reduce the next pre-paid term
                 if ($days_in_old_cycle > $days_in_new_cycle) {
                     // Find out how many days at the new price per day the customer would receive for the total amount already paid
                     // (e.g. if the customer paid $10 / month previously, and was switching to a $5 / week subscription, she has pre-paid 14 days at the new price)
//.........這裏部分代碼省略.........
開發者ID:ltdat287,項目名稱:id.nhomdichvu,代碼行數:101,代碼來源:class-wc-subscriptions-switcher.php

示例13: maybe_remove_or_add_item_to_subscription

 /**
  * Process the remove or re-add a line item from a subscription request.
  *
  * @since 2.0
  */
 public static function maybe_remove_or_add_item_to_subscription()
 {
     if (isset($_GET['subscription_id']) && (isset($_GET['remove_item']) || isset($_GET['undo_remove_item'])) && isset($_GET['_wpnonce'])) {
         $subscription = wcs_is_subscription($_GET['subscription_id']) ? wcs_get_subscription($_GET['subscription_id']) : false;
         $undo_request = isset($_GET['undo_remove_item']) ? true : false;
         $item_id = $undo_request ? $_GET['undo_remove_item'] : $_GET['remove_item'];
         if (false === $subscription) {
             wc_add_notice(sprintf(_x('Subscription #%d does not exist.', 'hash before subscription ID', 'woocommerce-subscriptions'), $_GET['subscription_id']), 'error');
             wp_safe_redirect(wc_get_page_permalink('myaccount'));
             exit;
         }
         if (self::validate_remove_items_request($subscription, $item_id, $undo_request)) {
             if ($undo_request) {
                 // handle undo request
                 $removed_item = WC()->session->get('removed_subscription_items', array());
                 if (!empty($removed_item[$item_id]) && $subscription->id == $removed_item[$item_id]) {
                     // restore the item
                     wc_update_order_item($item_id, array('order_item_type' => 'line_item'));
                     unset($removed_item[$item_id]);
                     WC()->session->set('removed_subscription_items', $removed_item);
                     // restore download permissions for this item
                     $line_items = $subscription->get_items();
                     $line_item = $line_items[$item_id];
                     $_product = $subscription->get_product_from_item($line_item);
                     $product_id = wcs_get_canonical_product_id($line_item);
                     if ($_product && $_product->exists() && $_product->is_downloadable()) {
                         $downloads = $_product->get_files();
                         foreach (array_keys($downloads) as $download_id) {
                             wc_downloadable_file_permission($download_id, $product_id, $subscription, $line_item['qty']);
                         }
                     }
                     // translators: 1$: product name, 2$: product id
                     $subscription->add_order_note(sprintf(_x('Customer added "%1$s" (Product ID: #%2$d) via the My Account page.', 'used in order note', 'woocommerce-subscriptions'), wcs_get_line_item_name($line_item), $product_id));
                 } else {
                     wc_add_notice(__('Your request to undo your previous action was unsuccessful.', 'woocommerce-subscriptions'));
                 }
             } else {
                 // handle remove item requests
                 WC()->session->set('removed_subscription_items', array($item_id => $subscription->id));
                 // remove download access for the item
                 $line_items = $subscription->get_items();
                 $line_item = $line_items[$item_id];
                 $product_id = wcs_get_canonical_product_id($line_item);
                 WCS_Download_Handler::revoke_downloadable_file_permission($product_id, $subscription->id, $subscription->get_user_id());
                 // remove the line item from subscription but preserve its data in the DB
                 wc_update_order_item($item_id, array('order_item_type' => 'line_item_removed'));
                 // translators: 1$: product name, 2$: product id
                 $subscription->add_order_note(sprintf(_x('Customer removed "%1$s" (Product ID: #%2$d) via the My Account page.', 'used in order note', 'woocommerce-subscriptions'), wcs_get_line_item_name($line_item), $product_id));
                 // translators: placeholders are 1$: item name, and, 2$: opening and, 3$: closing link tags
                 wc_add_notice(sprintf(__('You have successfully removed "%1$s" from your subscription. %2$sUndo?%3$s', 'woocommerce-subscriptions'), $line_item['name'], '<a href="' . esc_url(self::get_undo_remove_url($subscription->id, $item_id, $subscription->get_view_order_url())) . '" >', '</a>'));
             }
         }
         $subscription->calculate_totals();
         wp_safe_redirect($subscription->get_view_order_url());
         exit;
     }
 }
開發者ID:ltdat287,項目名稱:id.nhomdichvu,代碼行數:62,代碼來源:class-wcs-remove-item.php

示例14: maybe_add_switched_callback

 /**
  * Creates a 2.0 updated version of the "subscriptions_switched" callback for developers to hook onto.
  *
  * The subscription passed to the new `woocommerce_subscriptions_switched_item` callback is strictly the subscription
  * to which the `$new_order_item` belongs to; this may be a new or the original subscription.
  *
  * @since 2.0.5
  * @param WC_Order $order
  */
 public static function maybe_add_switched_callback($order)
 {
     if (wcs_order_contains_switch($order)) {
         $subscriptions = wcs_get_subscriptions_for_order($order);
         foreach ($subscriptions as $subscription) {
             foreach ($subscription->get_items() as $new_order_item) {
                 if (isset($new_order_item['switched_subscription_item_id'])) {
                     $product_id = wcs_get_canonical_product_id($new_order_item);
                     // we need to check if the switch order contains the line item that has just been switched so that we don't call the hook on items that were previously switched in another order
                     foreach ($order->get_items() as $order_item) {
                         if (wcs_get_canonical_product_id($order_item) == $product_id) {
                             do_action('woocommerce_subscriptions_switched_item', $subscription, $new_order_item, WC_Subscriptions_Order::get_item_by_id($new_order_item['switched_subscription_item_id']));
                             break;
                         }
                     }
                 }
             }
         }
     }
 }
開發者ID:slavic18,項目名稱:cats,代碼行數:29,代碼來源:class-wc-subscriptions-switcher.php


注:本文中的wcs_get_canonical_product_id函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。