2012-05-26 16:25:07 +00:00
< ? php
2013-02-20 17:14:46 +00:00
2014-09-20 19:44:32 +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
/**
* Local Pickup Shipping Method
2012-08-14 22:43:48 +00:00
*
2012-05-26 16:25:07 +00:00
* A simple shipping method allowing free pickup as a shipping method
*
2012-12-31 18:25:09 +00:00
* @ class WC_Shipping_Local_Pickup
2014-11-11 15:46:54 +00:00
* @ version 2.3 . 0
2012-08-14 22:43:48 +00:00
* @ package WooCommerce / Classes / Shipping
* @ author WooThemes
*/
2012-12-31 18:25:09 +00:00
class WC_Shipping_Local_Pickup extends WC_Shipping_Method {
2012-05-26 16:25:07 +00:00
2012-08-14 22:43:48 +00:00
/**
2014-11-11 15:46:54 +00:00
* Constructor
2012-08-14 22:43:48 +00:00
*/
2014-11-11 15:46:54 +00:00
public function __construct () {
$this -> id = 'local_pickup' ;
$this -> method_title = __ ( 'Local Pickup' , 'woocommerce' );
$this -> method_description = __ ( 'Local pickup is a simple method which allows the customer to pick up their order themselves.' , 'woocommerce' );
2012-05-26 16:25:07 +00:00
$this -> init ();
2012-08-14 22:43:48 +00:00
}
2013-08-12 21:09:04 +00:00
/**
* init function .
*/
2014-11-11 15:46:54 +00:00
public function init () {
2012-08-14 22:43:48 +00:00
2012-05-26 16:25:07 +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-14 22:43:48 +00:00
2012-05-26 16:25:07 +00:00
// Define user set variables
2012-12-31 12:07:43 +00:00
$this -> enabled = $this -> get_option ( 'enabled' );
$this -> title = $this -> get_option ( 'title' );
$this -> codes = $this -> get_option ( 'codes' );
$this -> availability = $this -> get_option ( 'availability' );
$this -> countries = $this -> get_option ( 'countries' );
2012-08-14 22:43:48 +00:00
2012-10-01 09:45:07 +00:00
// Actions
2012-12-15 11:53:32 +00:00
add_action ( 'woocommerce_update_options_shipping_' . $this -> id , array ( $this , 'process_admin_options' ) );
2012-05-26 16:25:07 +00:00
}
2012-08-14 22:43:48 +00:00
/**
* calculate_shipping function .
*/
2014-11-11 15:46:54 +00:00
public function calculate_shipping () {
2012-05-26 16:25:07 +00:00
$rate = array (
'id' => $this -> id ,
'label' => $this -> title ,
);
2014-11-11 15:46:54 +00:00
$this -> add_rate ( $rate );
2012-05-26 16:25:07 +00:00
}
2012-08-14 22:43:48 +00:00
/**
* init_form_fields function .
*/
2014-11-11 15:46:54 +00:00
public function init_form_fields () {
2013-08-12 21:09:04 +00:00
$this -> form_fields = array (
2012-05-26 16:25:07 +00:00
'enabled' => array (
2014-11-11 15:46:54 +00:00
'title' => __ ( 'Enable' , 'woocommerce' ),
'type' => 'checkbox' ,
'label' => __ ( 'Enable local pickup' , 'woocommerce' ),
'default' => 'no'
2012-08-14 22:43:48 +00:00
),
2012-05-26 16:25:07 +00:00
'title' => array (
2014-11-11 15:46:54 +00:00
'title' => __ ( 'Title' , 'woocommerce' ),
'type' => 'text' ,
'description' => __ ( 'This controls the title which the user sees during checkout.' , 'woocommerce' ),
'default' => __ ( 'Local Pickup' , 'woocommerce' ),
'desc_tip' => true ,
2012-05-26 16:25:07 +00:00
),
2012-11-27 11:25:21 +00:00
'codes' => array (
2014-10-30 16:10:57 +00:00
'title' => __ ( 'Allowed Zip/Post Codes' , 'woocommerce' ),
'type' => 'text' ,
'desc_tip' => __ ( 'What zip/post codes are available for local pickup?' , 'woocommerce' ),
'default' => '' ,
2014-11-11 15:46:54 +00:00
'description' => __ ( 'Separate codes with a comma. Accepts wildcards, e.g. <code>P*</code> will match a postcode of PE30. Also accepts a pattern, e.g. <code>NG1___</code> would match NG1 1AA but not NG10 1AA' , 'woocommerce' ),
2014-10-30 16:10:57 +00:00
'placeholder' => 'e.g. 12345, 56789'
2012-11-27 11:25:21 +00:00
),
2012-05-26 16:25:07 +00:00
'availability' => array (
2014-11-11 15:46:54 +00:00
'title' => __ ( 'Method availability' , 'woocommerce' ),
'type' => 'select' ,
'default' => 'all' ,
'class' => 'availability' ,
'options' => array (
'all' => __ ( 'All allowed countries' , 'woocommerce' ),
'specific' => __ ( 'Specific Countries' , 'woocommerce' )
2012-10-01 09:45:07 +00:00
)
),
2012-05-26 16:25:07 +00:00
'countries' => array (
2014-11-11 15:46:54 +00:00
'title' => __ ( 'Specific Countries' , 'woocommerce' ),
'type' => 'multiselect' ,
2015-01-12 16:29:01 +00:00
'class' => 'wc-enhanced-select' ,
2014-11-11 15:46:54 +00:00
'css' => 'width: 450px;' ,
'default' => '' ,
'options' => WC () -> countries -> get_shipping_countries (),
2013-10-11 14:27:04 +00:00
'custom_attributes' => array (
2014-11-11 15:46:54 +00:00
'data-placeholder' => __ ( 'Select some countries' , 'woocommerce' )
2013-10-11 14:27:04 +00:00
)
2013-09-03 15:26:02 +00:00
)
2012-05-26 16:25:07 +00:00
);
}
2012-08-14 22:43:48 +00:00
/**
2014-11-11 15:46:54 +00:00
* Get postcodes for this method
* @ return array
2012-08-14 22:43:48 +00:00
*/
2014-11-11 15:46:54 +00:00
public function get_valid_postcodes () {
$codes = array ();
if ( $this -> codes != '' ) {
foreach ( explode ( ',' , $this -> codes ) as $code ) {
$codes [] = strtoupper ( trim ( $code ) );
}
}
return $codes ;
2012-05-26 16:25:07 +00:00
}
2012-08-14 22:43:48 +00:00
/**
2014-11-11 15:46:54 +00:00
* See if a given postcode matches valid postcodes
* @ param string postcode
* @ param string country code
* @ return boolean
2012-08-14 22:43:48 +00:00
*/
2014-11-11 15:46:54 +00:00
public function is_valid_postcode ( $postcode , $country ) {
$codes = $this -> get_valid_postcodes ();
$postcode = $this -> clean ( $postcode );
$formatted_postcode = wc_format_postcode ( $postcode , $country );
2012-11-27 16:22:47 +00:00
2014-11-11 15:46:54 +00:00
if ( in_array ( $postcode , $codes ) || in_array ( $formatted_postcode , $codes ) ) {
return true ;
}
2014-04-07 14:46:40 +00:00
2014-11-11 15:46:54 +00:00
// Pattern matching
foreach ( $codes as $c ) {
$pattern = '/^' . str_replace ( '_' , '[0-9a-zA-Z]' , $c ) . '$/i' ;
if ( preg_match ( $pattern , $postcode ) ) {
return true ;
2012-06-05 07:48:46 +00:00
}
2014-11-11 15:46:54 +00:00
}
2012-11-27 16:22:47 +00:00
2014-11-11 15:46:54 +00:00
// Wildcard search
$wildcard_postcode = $formatted_postcode . '*' ;
$postcode_length = strlen ( $formatted_postcode );
2012-11-27 16:22:47 +00:00
2014-11-11 15:46:54 +00:00
for ( $i = 0 ; $i < $postcode_length ; $i ++ ) {
if ( in_array ( $wildcard_postcode , $codes ) ) {
return true ;
}
$wildcard_postcode = substr ( $wildcard_postcode , 0 , - 2 ) . '*' ;
}
2012-11-27 16:22:47 +00:00
2014-11-11 15:46:54 +00:00
return false ;
}
2012-11-27 16:22:47 +00:00
2014-11-11 15:46:54 +00:00
/**
* See if the method is available .
*
* @ param array $package
* @ return bool
*/
public function is_available ( $package ) {
$is_available = " yes " === $this -> enabled ;
2012-11-27 16:22:47 +00:00
2014-11-11 15:46:54 +00:00
if ( $is_available && $this -> get_valid_postcodes () ) {
$is_available = $this -> is_valid_postcode ( $package [ 'destination' ][ 'postcode' ], $package [ 'destination' ][ 'country' ] );
}
2012-11-27 16:22:47 +00:00
2014-11-11 15:46:54 +00:00
if ( $is_available && $this -> get_valid_postcodes () ) {
if ( $this -> availability === 'specific' ) {
$ship_to_countries = $this -> countries ;
2013-04-15 11:10:12 +00:00
} else {
2014-11-11 15:46:54 +00:00
$ship_to_countries = array_keys ( WC () -> countries -> get_shipping_countries () );
}
if ( is_array ( $ship_to_countries ) && ! in_array ( $package [ 'destination' ][ 'country' ], $ship_to_countries ) ) {
$is_available = false ;
2012-06-05 07:48:46 +00:00
}
}
2012-06-05 08:13:25 +00:00
return apply_filters ( 'woocommerce_shipping_' . $this -> id . '_is_available' , $is_available , $package );
2012-06-05 07:48:46 +00:00
}
2012-11-27 16:22:47 +00:00
2013-08-12 21:09:04 +00:00
/**
* clean function .
*
* @ access public
* @ param mixed $code
* @ return string
*/
2014-11-11 15:46:54 +00:00
public function clean ( $code ) {
2013-08-12 21:09:04 +00:00
return str_replace ( '-' , '' , sanitize_title ( $code ) ) . ( strstr ( $code , '*' ) ? '*' : '' );
}
2014-09-20 19:44:32 +00:00
}