_data = WC()->session->get( 'customer' ); if ( empty( $this->_data ) ) { // Defaults $this->_data = array( 'country' => $this->get_default_country(), 'state' => $this->get_default_state(), 'postcode' => '', 'city' => '', 'address' => '', 'address_2' => '', 'shipping_country' => $this->get_default_country(), 'shipping_state' => $this->get_default_state(), 'shipping_postcode' => '', 'shipping_city' => '', 'shipping_address' => '', 'shipping_address_2' => '', 'is_vat_exempt' => false, 'calculated_shipping' => false ); } // When leaving or ending page load, store data add_action( 'shutdown', array( $this, 'save_data' ), 10 ); } /** * Save data function. */ public function save_data() { if ( $this->_changed ) { WC()->session->set( 'customer', $this->_data ); } } /** * __set function. * * @param mixed $property * @return bool */ public function __isset( $property ) { return isset( $this->_data[ $property ] ); } /** * __get function. * * @param string $property * @return string */ public function __get( $property ) { return isset( $this->_data[ $property ] ) ? $this->_data[ $property ] : ''; } /** * __set function. * * @param mixed $property * @param mixed $value */ public function __set( $property, $value ) { $this->_data[ $property ] = $value; $this->_changed = true; } /** * Get default country for a customer * @return string */ public function get_default_country() { $default = wc_get_customer_default_location(); return $default['country']; } /** * Get default state for a customer * @return string */ public function get_default_state() { $default = wc_get_customer_default_location(); return $default['state']; } /** * has_calculated_shipping function. * * @return bool */ public function has_calculated_shipping() { return ( ! empty( $this->calculated_shipping ) ) ? true : false; } /** * Set customer address to match shop base address. */ public function set_to_base() { $this->country = $this->get_default_country(); $this->state = $this->get_default_state(); $this->postcode = ''; $this->city = ''; } /** * Set customer shipping address to base address. */ public function set_shipping_to_base() { $this->shipping_country = $this->get_default_country(); $this->shipping_state = $this->get_default_state(); $this->shipping_postcode = ''; $this->shipping_city = ''; } /** * Is customer outside base country (for tax purposes)? * * @return bool */ public function is_customer_outside_base() { list( $country, $state ) = $this->get_taxable_address(); if ( $country ) { $default = wc_get_base_location(); if ( $default['country'] !== $country ) { return true; } if ( $default['state'] && $default['state'] !== $state ) { return true; } } return false; } /** * Is the user a paying customer? * * @return bool */ function is_paying_customer( $user_id ) { return '1' === get_user_meta( $user_id, 'paying_customer', true ); } /** * Is customer VAT exempt? * * @return bool */ public function is_vat_exempt() { return ( ! empty( $this->is_vat_exempt ) ) ? true : false; } /** * Gets the state from the current session. * * @return string */ public function get_state() { return $this->state; } /** * Gets the country from the current session * * @return string */ public function get_country() { return $this->country; } /** * Gets the postcode from the current session. * * @return string */ public function get_postcode() { return empty( $this->postcode ) ? '' : wc_format_postcode( $this->postcode, $this->get_country() ); } /** * Get the city from the current session. * * @return string */ public function get_city() { return $this->city; } /** * Gets the address from the current session. * * @return string */ public function get_address() { return $this->address; } /** * Gets the address_2 from the current session. * * @return string */ public function get_address_2() { return $this->address_2; } /** * Gets the state from the current session. * * @return string */ public function get_shipping_state() { return $this->shipping_state; } /** * Gets the country from the current session. * * @return string */ public function get_shipping_country() { return $this->shipping_country; } /** * Gets the postcode from the current session. * * @return string */ public function get_shipping_postcode() { return empty( $this->shipping_postcode ) ? '' : wc_format_postcode( $this->shipping_postcode, $this->get_shipping_country() ); } /** * Gets the city from the current session. * * @return string */ public function get_shipping_city() { return $this->shipping_city; } /** * Gets the address from the current session. * * @return string */ public function get_shipping_address() { return $this->shipping_address; } /** * Gets the address_2 from the current session. * * @return string */ public function get_shipping_address_2() { return $this->shipping_address_2; } /** * get_taxable_address function. * * @return array */ public function get_taxable_address() { $tax_based_on = get_option( 'woocommerce_tax_based_on' ); // Check shipping method at this point to see if we need special handling if ( true == apply_filters( 'woocommerce_apply_base_tax_for_local_pickup', true ) && WC()->cart->needs_shipping() && sizeof( array_intersect( WC()->session->get( 'chosen_shipping_methods', array( get_option( 'woocommerce_default_shipping_method' ) ) ), apply_filters( 'woocommerce_local_pickup_methods', array( 'local_pickup' ) ) ) ) > 0 ) { $tax_based_on = 'base'; } if ( $tax_based_on == 'base' ) { $default = wc_get_base_location(); $country = $default['country']; $state = $default['state']; $postcode = ''; $city = ''; } elseif ( $tax_based_on == 'billing' ) { $country = $this->get_country(); $state = $this->get_state(); $postcode = $this->get_postcode(); $city = $this->get_city(); } else { $country = $this->get_shipping_country(); $state = $this->get_shipping_state(); $postcode = $this->get_shipping_postcode(); $city = $this->get_shipping_city(); } return apply_filters( 'woocommerce_customer_taxable_address', array( $country, $state, $postcode, $city ) ); } /** * Sets session data for the location. * * @param string $country * @param string $state * @param string $postcode (default: '') * @param string $city (default: '') */ public function set_location( $country, $state, $postcode = '', $city = '' ) { $this->country = $country; $this->state = $state; $this->postcode = $postcode; $this->city = $city; } /** * Sets session data for the country. * * @param mixed $country */ public function set_country( $country ) { $this->country = $country; } /** * Sets session data for the state. * * @param mixed $state */ public function set_state( $state ) { $this->state = $state; } /** * Sets session data for the postcode. * * @param mixed $postcode */ public function set_postcode( $postcode ) { $this->postcode = $postcode; } /** * Sets session data for the city. * * @param mixed $city */ public function set_city( $city ) { $this->city = $city; } /** * Sets session data for the address. * * @param mixed $address */ public function set_address( $address ) { $this->address = $address; } /** * Sets session data for the address_2. * * @param mixed $address_2 */ public function set_address_2( $address_2 ) { $this->address_2 = $address_2; } /** * Sets session data for the location. * * @param string $country * @param string $state (default: '') * @param string $postcode (default: '') * @param string $city (default: '') */ public function set_shipping_location( $country, $state = '', $postcode = '', $city = '' ) { $this->shipping_country = $country; $this->shipping_state = $state; $this->shipping_postcode = $postcode; $this->shipping_city = $city; } /** * Sets session data for the country. * * @param string $country */ public function set_shipping_country( $country ) { $this->shipping_country = $country; } /** * Sets session data for the state. * * @param string $state */ public function set_shipping_state( $state ) { $this->shipping_state = $state; } /** * Sets session data for the postcode. * * @param string $postcode */ public function set_shipping_postcode( $postcode ) { $this->shipping_postcode = $postcode; } /** * Sets session data for the city. * * @param string $city */ public function set_shipping_city( $city ) { $this->shipping_city = $city; } /** * Sets session data for the address. * * @param string $address */ public function set_shipping_address( $address ) { $this->shipping_address = $address; } /** * Sets session data for the address_2. * * @param string $address_2 */ public function set_shipping_address_2( $address_2 ) { $this->shipping_address_2 = $address_2; } /** * Sets session data for the tax exemption. * * @param bool $is_vat_exempt */ public function set_is_vat_exempt( $is_vat_exempt ) { $this->is_vat_exempt = $is_vat_exempt; } /** * calculated_shipping function. * * @param boolean $calculated */ public function calculated_shipping( $calculated = true ) { $this->calculated_shipping = $calculated; } /** * Gets a user's downloadable products if they are logged in. * * @return array Array of downloadable products */ public function get_downloadable_products() { $downloads = array(); if ( is_user_logged_in() ) { $downloads = wc_get_customer_available_downloads( get_current_user_id() ); } return apply_filters( 'woocommerce_customer_get_downloadable_products', $downloads ); } }