woocommerce/includes/gateways/cod/class-wc-gateway-cod.php

246 lines
7.5 KiB
PHP
Raw Normal View History

2012-05-26 16:25:07 +00:00
<?php
2013-02-20 17:14:46 +00:00
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly
}
2013-02-20 17:14:46 +00:00
2012-05-26 16:25:07 +00:00
/**
2015-11-03 13:31:20 +00:00
* Cash on Delivery Gateway.
2012-08-15 18:15:06 +00:00
*
2012-05-26 16:25:07 +00:00
* Provides a Cash on Delivery Payment Gateway.
*
* @class WC_Gateway_COD
2012-08-15 18:15:06 +00:00
* @extends WC_Payment_Gateway
* @version 2.1.0
2012-08-15 18:15:06 +00:00
* @package WooCommerce/Classes/Payment
* @author WooThemes
2012-05-26 16:25:07 +00:00
*/
class WC_Gateway_COD extends WC_Payment_Gateway {
2012-08-15 18:15:06 +00:00
2016-07-11 14:56:35 +00:00
/**
* Constructor for the gateway.
*/
public function __construct() {
// Setup general properties
$this->setup_properties();
2012-08-15 18:15:06 +00:00
// Load the settings
2013-01-02 13:38:33 +00:00
$this->init_form_fields();
2012-05-26 16:25:07 +00:00
$this->init_settings();
2012-08-15 18:15:06 +00:00
// Get settings
$this->title = $this->get_option( 'title' );
$this->description = $this->get_option( 'description' );
$this->instructions = $this->get_option( 'instructions' );
$this->enable_for_methods = $this->get_option( 'enable_for_methods', array() );
$this->enable_for_virtual = $this->get_option( 'enable_for_virtual', 'yes' ) === 'yes' ? true : false;
2012-08-15 18:15:06 +00:00
add_action( 'woocommerce_update_options_payment_gateways_' . $this->id, array( $this, 'process_admin_options' ) );
add_action( 'woocommerce_thankyou_' . $this->id, array( $this, 'thankyou_page' ) );
2016-07-11 14:56:35 +00:00
// Customer Emails
add_action( 'woocommerce_email_before_order_table', array( $this, 'email_instructions' ), 10, 3 );
2012-05-26 16:25:07 +00:00
}
/**
* Setup general properties for the gateway.
*/
protected function setup_properties() {
$this->id = 'cod';
$this->icon = apply_filters( 'woocommerce_cod_icon', '' );
$this->method_title = __( 'Cash on delivery', 'woocommerce' );
$this->method_description = __( 'Have your customers pay with cash (or by other means) upon delivery.', 'woocommerce' );
$this->has_fields = false;
}
2012-08-15 18:15:06 +00:00
2016-07-11 14:56:35 +00:00
/**
* Initialise Gateway Settings Form Fields.
*/
public function init_form_fields() {
$shipping_methods = array();
2012-11-27 16:22:47 +00:00
foreach ( WC()->shipping()->load_shipping_methods() as $method ) {
$shipping_methods[ $method->id ] = $method->get_method_title();
}
2012-11-27 16:22:47 +00:00
2016-07-11 14:56:35 +00:00
$this->form_fields = array(
2012-05-26 16:25:07 +00:00
'enabled' => array(
'title' => __( 'Enable/Disable', 'woocommerce' ),
'label' => __( 'Enable cash on delivery', 'woocommerce' ),
'type' => 'checkbox',
2012-08-15 18:15:06 +00:00
'description' => '',
'default' => 'no',
2012-08-15 18:15:06 +00:00
),
2012-05-26 16:25:07 +00:00
'title' => array(
'title' => __( 'Title', 'woocommerce' ),
'type' => 'text',
'description' => __( 'Payment method description that the customer will see on your checkout.', 'woocommerce' ),
'default' => __( 'Cash on delivery', 'woocommerce' ),
'desc_tip' => true,
2012-08-15 18:15:06 +00:00
),
2012-05-26 16:25:07 +00:00
'description' => array(
'title' => __( 'Description', 'woocommerce' ),
'type' => 'textarea',
2012-08-15 18:15:06 +00:00
'description' => __( 'Payment method description that the customer will see on your website.', 'woocommerce' ),
'default' => __( 'Pay with cash upon delivery.', 'woocommerce' ),
'desc_tip' => true,
2012-08-15 18:15:06 +00:00
),
2012-05-26 16:25:07 +00:00
'instructions' => array(
'title' => __( 'Instructions', 'woocommerce' ),
'type' => 'textarea',
2012-08-15 18:15:06 +00:00
'description' => __( 'Instructions that will be added to the thank you page.', 'woocommerce' ),
'default' => __( 'Pay with cash upon delivery.', 'woocommerce' ),
'desc_tip' => true,
2012-08-15 18:15:06 +00:00
),
'enable_for_methods' => array(
2013-10-11 14:27:04 +00:00
'title' => __( 'Enable for shipping methods', 'woocommerce' ),
'type' => 'multiselect',
2015-01-12 16:29:01 +00:00
'class' => 'wc-enhanced-select',
2016-12-21 11:36:48 +00:00
'css' => 'width: 400px;',
2013-10-11 14:27:04 +00:00
'default' => '',
'description' => __( 'If COD is only available for certain methods, set it up here. Leave blank to enable for all methods.', 'woocommerce' ),
'options' => $shipping_methods,
'desc_tip' => true,
'custom_attributes' => array(
'data-placeholder' => __( 'Select shipping methods', 'woocommerce' ),
),
),
'enable_for_virtual' => array(
'title' => __( 'Accept for virtual orders', 'woocommerce' ),
'label' => __( 'Accept COD if the order is virtual', 'woocommerce' ),
'type' => 'checkbox',
'default' => 'yes',
),
2016-07-11 14:56:35 +00:00
);
}
2012-08-15 18:15:06 +00:00
/**
2015-11-03 13:31:20 +00:00
* Check If The Gateway Is Available For Use.
*
* @return bool
*/
public function is_available() {
$order = null;
$needs_shipping = false;
// Test if shipping is needed first
if ( WC()->cart && WC()->cart->needs_shipping() ) {
$needs_shipping = true;
} elseif ( is_page( wc_get_page_id( 'checkout' ) ) && 0 < get_query_var( 'order-pay' ) ) {
$order_id = absint( get_query_var( 'order-pay' ) );
$order = wc_get_order( $order_id );
// Test if order needs shipping.
if ( 0 < sizeof( $order->get_items() ) ) {
foreach ( $order->get_items() as $item ) {
2016-08-22 15:51:24 +00:00
$_product = $item->get_product();
2015-10-15 07:43:53 +00:00
if ( $_product && $_product->needs_shipping() ) {
$needs_shipping = true;
break;
}
}
}
}
$needs_shipping = apply_filters( 'woocommerce_cart_needs_shipping', $needs_shipping );
// Virtual order, with virtual disabled
if ( ! $this->enable_for_virtual && ! $needs_shipping ) {
return false;
}
// Check methods
if ( ! empty( $this->enable_for_methods ) && $needs_shipping ) {
2012-11-27 16:22:47 +00:00
// Only apply if all packages are being shipped via chosen methods, or order is virtual
$chosen_shipping_methods_session = WC()->session->get( 'chosen_shipping_methods' );
2014-02-18 11:27:05 +00:00
if ( isset( $chosen_shipping_methods_session ) ) {
$chosen_shipping_methods = array_unique( $chosen_shipping_methods_session );
2014-02-18 11:27:05 +00:00
} else {
$chosen_shipping_methods = array();
}
$check_method = false;
if ( is_object( $order ) ) {
if ( $order->shipping_method ) {
$check_method = $order->shipping_method;
}
} elseif ( empty( $chosen_shipping_methods ) || sizeof( $chosen_shipping_methods ) > 1 ) {
$check_method = false;
} elseif ( sizeof( $chosen_shipping_methods ) == 1 ) {
$check_method = $chosen_shipping_methods[0];
}
2012-11-27 16:22:47 +00:00
if ( ! $check_method ) {
return false;
}
2012-11-27 16:22:47 +00:00
2012-09-07 17:26:13 +00:00
$found = false;
2012-11-27 16:22:47 +00:00
foreach ( $this->enable_for_methods as $method_id ) {
if ( strpos( $check_method, $method_id ) === 0 ) {
$found = true;
break;
}
}
2012-11-27 16:22:47 +00:00
if ( ! $found ) {
return false;
}
}
2012-11-27 16:22:47 +00:00
return parent::is_available();
}
2012-11-27 16:22:47 +00:00
2016-07-11 14:56:35 +00:00
/**
* Process the payment and return the result.
*
* @param int $order_id
* @return array
*/
public function process_payment( $order_id ) {
$order = wc_get_order( $order_id );
2012-05-26 16:25:07 +00:00
// Mark as processing or on-hold (payment won't be taken until delivery)
$order->update_status( apply_filters( 'woocommerce_cod_process_payment_order_status', $order->has_downloadable_item() ? 'on-hold' : 'processing', $order ), __( 'Payment to be made upon delivery.', 'woocommerce' ) );
2012-08-15 18:15:06 +00:00
2012-05-26 16:25:07 +00:00
// Reduce stock levels
2016-08-09 13:15:04 +00:00
wc_reduce_stock_levels( $order_id );
2012-08-15 18:15:06 +00:00
2012-05-26 16:25:07 +00:00
// Remove cart
WC()->cart->empty_cart();
2012-08-15 18:15:06 +00:00
2012-05-26 16:25:07 +00:00
// Return thankyou redirect
return array(
'result' => 'success',
'redirect' => $this->get_return_url( $order ),
2012-05-26 16:25:07 +00:00
);
}
2012-08-15 18:15:06 +00:00
2016-07-11 14:56:35 +00:00
/**
* Output for the order received page.
*/
public function thankyou_page() {
if ( $this->instructions ) {
2016-07-11 14:56:35 +00:00
echo wpautop( wptexturize( $this->instructions ) );
}
2012-05-26 16:25:07 +00:00
}
2016-07-11 14:56:35 +00:00
/**
* Add content to the WC emails.
*
* @access public
* @param WC_Order $order
* @param bool $sent_to_admin
* @param bool $plain_text
*/
public function email_instructions( $order, $sent_to_admin, $plain_text = false ) {
if ( $this->instructions && ! $sent_to_admin && $this->id === $order->get_payment_method() ) {
echo wpautop( wptexturize( $this->instructions ) ) . PHP_EOL;
}
}
2014-02-18 11:27:05 +00:00
}