woocommerce/admin/woocommerce-admin-users.php

87 lines
3.5 KiB
PHP
Raw Normal View History

2011-12-21 23:44:08 +00:00
<?php
/**
* Functions used for modifying the users panel
*
* @author WooThemes
* @category Admin
* @package WooCommerce
*/
function woocommerce_user_columns( $columns ) {
if (!current_user_can('manage_woocommerce')) return $columns;
$columns['woocommerce_billing_address'] = __('Billing Address', 'woothemes');
$columns['woocommerce_shipping_address'] = __('Shipping Address', 'woothemes');
$columns['woocommerce_paying_customer'] = __('Paying Customer?', 'woothemes');
$columns['woocommerce_order_count'] = __('Orders', 'woothemes');
return $columns;
}
function woocommerce_user_column_values($value, $column_name, $user_id) {
global $woocommerce, $wpdb;
switch ($column_name) :
case "woocommerce_order_count" :
$count = $wpdb->get_var( "SELECT COUNT(*)
FROM $wpdb->posts
LEFT JOIN $wpdb->postmeta ON $wpdb->posts.ID = $wpdb->postmeta.post_id
WHERE meta_value = $user_id
AND meta_key = '_customer_user'
AND post_type IN ('shop_order')
AND post_status = 'publish'" );
$value = '<a href="'.admin_url('edit.php?post_status=all&post_type=shop_order&_customer_user='.$user_id.'').'">'.$count.'</a>';
break;
case "woocommerce_billing_address" :
$address = array(
'first_name' => get_user_meta( $user_id, 'billing_first_name', true ),
'last_name' => get_user_meta( $user_id, 'billing_last_name', true ),
'company' => get_user_meta( $user_id, 'billing_company', true ),
'address_1' => get_user_meta( $user_id, 'billing_address_1', true ),
'address_2' => get_user_meta( $user_id, 'billing_address_2', true ),
'city' => get_user_meta( $user_id, 'billing_city', true ),
'state' => get_user_meta( $user_id, 'billing_state', true ),
'postcode' => get_user_meta( $user_id, 'billing_postcode', true ),
'country' => get_user_meta( $user_id, 'billing_country', true )
);
$formatted_address = $woocommerce->countries->get_formatted_address( $address );
if (!$formatted_address) $value = __('N/A', 'woothemes'); else $value = $formatted_address;
$value = wpautop($value);
break;
case "woocommerce_shipping_address" :
$address = array(
'first_name' => get_user_meta( $user_id, 'shipping_first_name', true ),
'last_name' => get_user_meta( $user_id, 'shipping_last_name', true ),
'company' => get_user_meta( $user_id, 'shipping_company', true ),
'address_1' => get_user_meta( $user_id, 'shipping_address_1', true ),
'address_2' => get_user_meta( $user_id, 'shipping_address_2', true ),
'city' => get_user_meta( $user_id, 'shipping_city', true ),
'state' => get_user_meta( $user_id, 'shipping_state', true ),
'postcode' => get_user_meta( $user_id, 'shipping_postcode', true ),
'country' => get_user_meta( $user_id, 'shipping_country', true )
);
$formatted_address = $woocommerce->countries->get_formatted_address( $address );
if (!$formatted_address) $value = __('N/A', 'woothemes'); else $value = $formatted_address;
$value = wpautop($value);
break;
case "woocommerce_paying_customer" :
$paying_customer = get_user_meta( $user_id, 'paying_customer', true );
if ($paying_customer) $value = '<img src="'.$woocommerce->plugin_url().'/assets/images/success.gif" alt="yes" />';
else $value = '<img src="'.$woocommerce->plugin_url().'/assets/images/success-off.gif" alt="no" />';
break;
endswitch;
return $value;
}
add_filter('manage_users_columns', 'woocommerce_user_columns', 10, 1);
add_action('manage_users_custom_column', 'woocommerce_user_column_values', 10, 3);