2016-01-14 19:48:30 +00:00
|
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* WooCommerce Account Functions
|
|
|
|
|
*
|
|
|
|
|
* Functions for account specific things.
|
|
|
|
|
*
|
|
|
|
|
* @author WooThemes
|
|
|
|
|
* @category Core
|
|
|
|
|
* @package WooCommerce/Functions
|
|
|
|
|
* @version 2.6.0
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
|
|
|
exit;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the url to the lost password endpoint url.
|
|
|
|
|
*
|
|
|
|
|
* @access public
|
|
|
|
|
* @param string $default_url
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function wc_lostpassword_url( $default_url = '' ) {
|
|
|
|
|
$wc_password_reset_url = wc_get_page_permalink( 'myaccount' );
|
|
|
|
|
|
|
|
|
|
if ( false !== $wc_password_reset_url ) {
|
|
|
|
|
return wc_get_endpoint_url( 'lost-password', '', $wc_password_reset_url );
|
|
|
|
|
} else {
|
|
|
|
|
return $default_url;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
add_filter( 'lostpassword_url', 'wc_lostpassword_url', 10, 1 );
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the link to the edit account details page.
|
|
|
|
|
*
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function wc_customer_edit_account_url() {
|
|
|
|
|
$edit_account_url = wc_get_endpoint_url( 'edit-account', '', wc_get_page_permalink( 'myaccount' ) );
|
|
|
|
|
|
|
|
|
|
return apply_filters( 'woocommerce_customer_edit_account_url', $edit_account_url );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the edit address slug translation.
|
|
|
|
|
*
|
|
|
|
|
* @param string $id Address ID.
|
|
|
|
|
* @param bool $flip Flip the array to make it possible to retrieve the values from both sides.
|
|
|
|
|
*
|
|
|
|
|
* @return string Address slug i18n.
|
|
|
|
|
*/
|
|
|
|
|
function wc_edit_address_i18n( $id, $flip = false ) {
|
|
|
|
|
$slugs = apply_filters( 'woocommerce_edit_address_slugs', array(
|
|
|
|
|
'billing' => sanitize_title( _x( 'billing', 'edit-address-slug', 'woocommerce' ) ),
|
|
|
|
|
'shipping' => sanitize_title( _x( 'shipping', 'edit-address-slug', 'woocommerce' ) )
|
|
|
|
|
) );
|
|
|
|
|
|
|
|
|
|
if ( $flip ) {
|
|
|
|
|
$slugs = array_flip( $slugs );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( ! isset( $slugs[ $id ] ) ) {
|
|
|
|
|
return $id;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $slugs[ $id ];
|
|
|
|
|
}
|
2016-01-15 20:34:37 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get My Account menu items.
|
|
|
|
|
*
|
|
|
|
|
* @since 2.6.0
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
function wc_get_account_menu_items() {
|
2016-01-19 19:47:36 +00:00
|
|
|
|
return apply_filters( 'woocommerce_account_menu_items', array(
|
2016-01-20 16:11:07 +00:00
|
|
|
|
'dashboard' => __( 'Dashboard', 'woocommerce' ),
|
2016-01-19 19:47:36 +00:00
|
|
|
|
'orders' => __( 'Orders', 'woocommerce' ),
|
|
|
|
|
'downloads' => __( 'Downloads', 'woocommerce' ),
|
|
|
|
|
'edit-address' => __( 'Addresses', 'woocommerce' ),
|
2016-01-20 20:13:17 +00:00
|
|
|
|
'payment-methods' => __( 'Payment Methods', 'woocommerce' ),
|
2016-01-19 19:47:36 +00:00
|
|
|
|
'edit-account' => __( 'Account Details', 'woocommerce' ),
|
|
|
|
|
'customer-logout' => __( 'Logout', 'woocommerce' ),
|
2016-01-15 20:34:37 +00:00
|
|
|
|
) );
|
|
|
|
|
}
|
2016-01-19 21:02:26 +00:00
|
|
|
|
|
2016-01-20 16:11:07 +00:00
|
|
|
|
/**
|
|
|
|
|
* Get account menu item classes.
|
|
|
|
|
*
|
|
|
|
|
* @since 2.6.0
|
|
|
|
|
* @param string $endpoint
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function wc_get_account_menu_item_classes( $endpoint ) {
|
|
|
|
|
global $wp;
|
|
|
|
|
|
|
|
|
|
$classes = array(
|
|
|
|
|
'my-account-menu-item-' . $endpoint,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// Set current item class.
|
|
|
|
|
$current = isset( $wp->query_vars[ $endpoint ] );
|
|
|
|
|
if ( 'dashboard' === $endpoint && ( isset( $wp->query_vars['page'] ) || empty( $wp->query_vars ) ) ) {
|
|
|
|
|
$current = true; // Dashboard is not an endpoint, so needs a custom check.
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( $current ) {
|
|
|
|
|
$classes[] = 'current-item';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$classes = apply_filters( 'woocommerce_account_menu_item_classes', $classes, $endpoint );
|
|
|
|
|
|
|
|
|
|
return implode( ' ', array_map( 'sanitize_html_class', $classes ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get account endpoint URL.
|
|
|
|
|
*
|
|
|
|
|
* @since 2.6.0
|
|
|
|
|
* @param string $endpoint
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function wc_get_account_endpoint_url( $endpoint ) {
|
|
|
|
|
if ( 'dashboard' === $endpoint ) {
|
|
|
|
|
return wc_get_page_permalink( 'myaccount' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return wc_get_endpoint_url( $endpoint );
|
|
|
|
|
}
|
|
|
|
|
|
2016-01-19 21:02:26 +00:00
|
|
|
|
/**
|
2016-01-19 23:22:39 +00:00
|
|
|
|
* Get My Account > Orders columns.
|
2016-01-19 21:02:26 +00:00
|
|
|
|
*
|
|
|
|
|
* @since 2.6.0
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
function wc_get_account_orders_columns() {
|
|
|
|
|
$columns = apply_filters( 'woocommerce_account_orders_columns', array(
|
|
|
|
|
'order-number' => __( 'Order', 'woocommerce' ),
|
|
|
|
|
'order-date' => __( 'Date', 'woocommerce' ),
|
|
|
|
|
'order-status' => __( 'Status', 'woocommerce' ),
|
|
|
|
|
'order-total' => __( 'Total', 'woocommerce' ),
|
|
|
|
|
'order-actions' => ' ',
|
|
|
|
|
) );
|
|
|
|
|
|
|
|
|
|
// Deprecated filter since 2.6.0.
|
|
|
|
|
return apply_filters( 'woocommerce_my_account_my_orders_columns', $columns );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get My Account > Orders query args.
|
|
|
|
|
*
|
2016-01-20 15:46:59 +00:00
|
|
|
|
* @since 2.6.0
|
|
|
|
|
* @param int $current_page
|
2016-01-19 21:02:26 +00:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
2016-01-20 15:46:59 +00:00
|
|
|
|
function wc_get_account_orders_query_args( $current_page = 1 ) {
|
2016-01-19 21:02:26 +00:00
|
|
|
|
$args = array(
|
2016-01-20 17:34:35 +00:00
|
|
|
|
'numberposts' => 15,
|
2016-01-19 21:02:26 +00:00
|
|
|
|
'meta_key' => '_customer_user',
|
|
|
|
|
'meta_value' => get_current_user_id(),
|
|
|
|
|
'post_type' => wc_get_order_types( 'view-orders' ),
|
2016-01-19 23:37:39 +00:00
|
|
|
|
'post_status' => array_keys( wc_get_order_statuses() ),
|
2016-01-19 21:02:26 +00:00
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// @deprecated 2.6.0.
|
|
|
|
|
$args = apply_filters( 'woocommerce_my_account_my_orders_query', $args );
|
|
|
|
|
|
|
|
|
|
// Remove deprecated option.
|
|
|
|
|
$args['posts_per_page'] = $args['numberposts'];
|
|
|
|
|
unset( $args['numberposts'] );
|
|
|
|
|
|
2016-01-20 15:46:59 +00:00
|
|
|
|
if ( 1 < $current_page ) {
|
|
|
|
|
$args['paged'] = absint( $current_page );
|
2016-01-19 21:02:26 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return apply_filters( 'woocommerce_account_orders_query', $args );
|
|
|
|
|
}
|
2016-01-19 23:22:39 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get My Account > Downloads columns.
|
|
|
|
|
*
|
|
|
|
|
* @since 2.6.0
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
function wc_get_account_downloads_columns() {
|
2016-02-16 19:52:08 +00:00
|
|
|
|
return apply_filters( 'woocommerce_account_downloads_columns', array(
|
2016-01-19 23:22:39 +00:00
|
|
|
|
'download-file' => __( 'File', 'woocommerce' ),
|
|
|
|
|
'download-remaining' => __( 'Remaining', 'woocommerce' ),
|
|
|
|
|
'download-expires' => __( 'Expires', 'woocommerce' ),
|
|
|
|
|
'download-actions' => ' ',
|
|
|
|
|
) );
|
|
|
|
|
}
|
2016-01-20 20:13:17 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get My Account > Payment methods columns.
|
|
|
|
|
*
|
|
|
|
|
* @since 2.6.0
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
function wc_get_account_payment_methods_columns() {
|
2016-02-16 19:52:08 +00:00
|
|
|
|
return apply_filters( 'woocommerce_account_payment_methods_columns', array(
|
2016-01-20 20:13:17 +00:00
|
|
|
|
'method' => __( 'Method', 'woocommerce' ),
|
|
|
|
|
'expires' => __( 'Expires', 'woocommerce' ),
|
|
|
|
|
'actions' => ' ',
|
|
|
|
|
) );
|
|
|
|
|
}
|