"; $columns["title"] = __("Code", 'woothemes'); $columns["type"] = __("Coupon type", 'woothemes'); $columns["amount"] = __("Coupon amount", 'woothemes'); $columns["products"] = __("Product IDs", 'woothemes'); $columns["usage_limit"] = __("Usage limit", 'woothemes'); $columns["usage_count"] = __("Usage count", 'woothemes'); $columns["expiry_date"] = __("Expiry date", 'woothemes'); return $columns; } /** * Custom Columns for Coupons page **/ add_action('manage_shop_coupon_posts_custom_column', 'woocommerce_custom_coupon_columns', 2); function woocommerce_custom_coupon_columns($column) { global $post; $type = get_post_meta($post->ID, 'discount_type', true); $amount = get_post_meta($post->ID, 'coupon_amount', true); $individual_use = get_post_meta($post->ID, 'individual_use', true); $product_ids = (get_post_meta($post->ID, 'product_ids', true)) ? explode(',', get_post_meta($post->ID, 'product_ids', true)) : array(); $usage_limit = get_post_meta($post->ID, 'usage_limit', true); $usage_count = (int) get_post_meta($post->ID, 'usage_count', true); $expiry_date = get_post_meta($post->ID, 'expiry_date', true); switch ($column) { case "type" : echo $type; break; case "amount" : echo $amount; break; case "products" : if (sizeof($product_ids)>0) echo implode(', ', $product_ids); else echo '–'; break; case "usage_limit" : if ($usage_limit) echo $usage_limit; else echo '–'; break; case "usage_count" : echo $usage_count; break; case "expiry_date" : if ($expiry_date) echo date('F j, Y', strtotime($expiry_date)); else echo '–'; break; } } /** * Columns for Variations page **/ add_filter('manage_edit-product_variation_columns', 'woocommerce_edit_variation_columns'); function woocommerce_edit_variation_columns($columns){ $columns = array(); $columns["cb"] = ""; $columns["thumb"] = __("Thumb", 'woothemes'); $columns["id"] = __("ID", 'woothemes'); $columns["title"] = __("Name", 'woothemes'); $columns["parent"] = __("Parent Product", 'woothemes'); return $columns; } /** * Custom Columns for Variations page **/ add_action('manage_product_variation_posts_custom_column', 'woocommerce_custom_variation_columns', 2); function woocommerce_custom_variation_columns($column) { global $post; $product = &new woocommerce_product($post->ID); switch ($column) { case "thumb" : if (has_post_thumbnail($post->ID)) : echo get_the_post_thumbnail($post->ID, 'shop_thumbnail'); endif; break; case "id" : echo '#'.$post->ID; break; case "parent" : if ($post->post_parent) : $parent = get_post( $post->post_parent ); echo '#'.$parent->ID.' — '.$parent->post_title.''; endif; break; } } /** * Columns for Products page **/ add_filter('manage_edit-product_columns', 'woocommerce_edit_product_columns'); function woocommerce_edit_product_columns($columns){ $columns = array(); $columns["cb"] = ""; $columns["thumb"] = __("Image", 'woothemes'); $columns["title"] = __("Name", 'woothemes'); if( get_option('woocommerce_enable_sku', true) == 'yes' ) $columns["sku"] = __("ID", 'woothemes'); $columns["product_type"] = __("Type", 'woothemes'); $columns["product_cat"] = __("Categories", 'woothemes'); $columns["product_tags"] = __("Tags", 'woothemes'); $columns["featured"] = __("Featured", 'woothemes'); if (get_option('woocommerce_manage_stock')=='yes') : $columns["is_in_stock"] = __("In Stock?", 'woothemes'); endif; $columns["price"] = __("Price", 'woothemes'); $columns["product_date"] = __("Date", 'woothemes'); return $columns; } /** * Custom Columns for Products page **/ add_action('manage_product_posts_custom_column', 'woocommerce_custom_product_columns', 2); function woocommerce_custom_product_columns($column) { global $post, $woocommerce; $product = &new woocommerce_product($post->ID); switch ($column) { case "thumb" : if (has_post_thumbnail($post->ID)) : echo get_the_post_thumbnail($post->ID, 'shop_thumbnail'); endif; break; case "price": echo $product->get_price_html(); break; case "product_cat" : if (!$terms = get_the_term_list($post->ID, 'product_cat', '', ', ','')) echo ''; else echo $terms; break; case "product_tags" : if (!$terms = get_the_term_list($post->ID, 'product_tag', '', ', ','')) echo ''; else echo $terms; break; case "sku" : if ( $sku = get_post_meta( $post->ID, 'sku', true )) : echo '#'.$post->ID.' - SKU: ' . $sku; else : echo '#'.$post->ID; endif; break; case "featured" : $url = wp_nonce_url( admin_url('admin-ajax.php?action=woocommerce-feature-product&product_id=' . $post->ID) ); echo ''; if ($product->is_featured()) echo 'yes'; else echo 'no'; echo ''; break; case "is_in_stock" : if ( !$product->is_type( 'grouped' ) && $product->is_in_stock() ) : echo 'yes '; else : echo 'no '; endif; if ( $product->managing_stock() ) : echo $product->stock.__(' in stock', 'woothemes'); endif; break; case "product_type" : echo ucwords($product->product_type); break; case "product_date" : if ( '0000-00-00 00:00:00' == $post->post_date ) : $t_time = $h_time = __( 'Unpublished' ); $time_diff = 0; else : $t_time = get_the_time( __( 'Y/m/d g:i:s A' ) ); $m_time = $post->post_date; $time = get_post_time( 'G', true, $post ); $time_diff = time() - $time; if ( $time_diff > 0 && $time_diff < 24*60*60 ) $h_time = sprintf( __( '%s ago' ), human_time_diff( $time ) ); else $h_time = mysql2date( __( 'Y/m/d' ), $m_time ); endif; echo '' . apply_filters( 'post_date_column_time', $h_time, $post ) . '
'; if ( 'publish' == $post->post_status ) : _e( 'Published' ); elseif ( 'future' == $post->post_status ) : if ( $time_diff > 0 ) : echo '' . __( 'Missed schedule' ) . ''; else : _e( 'Scheduled' ); endif; else : _e( 'Last Modified' ); endif; if ( $this_data = $product->visibility ) : echo '
' . ucfirst($this_data); endif; break; } } /** * Make product columns sortable * https://gist.github.com/906872 **/ add_filter("manage_edit-product_sortable_columns", 'woocommerce_custom_product_sort'); function woocommerce_custom_product_sort($columns) { $custom = array( 'is_in_stock' => 'inventory', 'price' => 'price', 'featured' => 'featured', 'sku' => 'sku', 'product_date' => 'date' ); return wp_parse_args($custom, $columns); } /** * Product column orderby * http://scribu.net/wordpress/custom-sortable-columns.html#comment-4732 **/ add_filter( 'request', 'woocommerce_custom_product_orderby' ); function woocommerce_custom_product_orderby( $vars ) { if (isset( $vars['orderby'] )) : if ( 'inventory' == $vars['orderby'] ) : $vars = array_merge( $vars, array( 'meta_key' => 'stock', 'orderby' => 'meta_value_num' ) ); endif; if ( 'price' == $vars['orderby'] ) : $vars = array_merge( $vars, array( 'meta_key' => 'price', 'orderby' => 'meta_value_num' ) ); endif; if ( 'featured' == $vars['orderby'] ) : $vars = array_merge( $vars, array( 'meta_key' => 'featured', 'orderby' => 'meta_value' ) ); endif; if ( 'sku' == $vars['orderby'] ) : $vars = array_merge( $vars, array( 'orderby' => 'id' ) ); endif; endif; return $vars; } /** * Filter products by category **/ add_action('restrict_manage_posts','woocommerce_products_by_category'); function woocommerce_products_by_category() { global $typenow, $wp_query; if ($typenow=='product') : $terms = get_terms('product_cat'); $output = ""; echo $output; endif; } /** * Filter products by type **/ add_action('restrict_manage_posts', 'woocommerce_products_by_type'); function woocommerce_products_by_type() { global $typenow, $wp_query; if ($typenow=='product') : $terms = get_terms('product_type'); $output = ""; echo $output; endif; } /** * Columns for order page **/ add_filter('manage_edit-shop_order_columns', 'woocommerce_edit_order_columns'); function woocommerce_edit_order_columns($columns){ $columns = array(); $columns["cb"] = ""; $columns["order_status"] = __("Status", 'woothemes'); $columns["order_title"] = __("Order", 'woothemes'); $columns["billing_address"] = __("Billing", 'woothemes'); $columns["shipping_address"] = __("Shipping", 'woothemes'); $columns["total_cost"] = __("Order Total", 'woothemes'); $columns["order_date"] = __("Date", 'woothemes'); return $columns; } /** * Custom Columns for order page **/ add_action('manage_shop_order_posts_custom_column', 'woocommerce_custom_order_columns', 2); function woocommerce_custom_order_columns($column) { global $post; $order = &new woocommerce_order( $post->ID ); switch ($column) { case "order_status" : echo sprintf( __('%s', 'woothemes'), sanitize_title($order->status), $order->status ); break; case "order_title" : echo ''.sprintf( __('Order #%s', 'woothemes'), $post->ID ).' '; if ($order->user_id) $user_info = get_userdata($order->user_id); if (isset($user_info) && $user_info) : $user = ''; if ($user_info->first_name || $user_info->last_name) $user .= $user_info->first_name.' '.$user_info->last_name; else $user .= $user_info->display_name; $user .= ''; else : $user = __('Guest', 'woothemes'); endif; echo '' . __('Customer: ', 'woothemes') . $user . ''; if ($order->billing_email) : echo ''.__('Email: ', 'woothemes').''.esc_html( $order->billing_email ).''; endif; if ($order->billing_phone) : echo ''.__('Tel: ', 'woothemes'). esc_html( $order->billing_phone ) . ''; endif; break; case "billing_address" : echo ''.esc_html( $order->billing_first_name . ' ' . $order->billing_last_name ); if ($order->billing_company) echo ', '.esc_html( $order->billing_company ); echo '
'; echo ''.esc_html( $order->formatted_billing_address ).''; if ($order->payment_method) : echo '' . __('Paid via ', 'woo themes') . esc_html( $order->payment_method ) . ''; endif; break; case "shipping_address" : if ($order->formatted_shipping_address) : echo ''.esc_html( $order->shipping_first_name . ' ' . $order->shipping_last_name ); if ($order->shipping_company) : echo ', '.esc_html( $order->shipping_company ); endif; echo '
'; echo ''.esc_html( $order->formatted_shipping_address ).''; else : echo '–'; endif; if ($order->shipping_method) : echo '' . __('Shipped via ', 'woothemes') . esc_html( $order->shipping_method ) . ''; endif; break; case "total_cost" : echo woocommerce_price($order->order_total); break; case "order_date" : if ( '0000-00-00 00:00:00' == $post->post_date ) : $t_time = $h_time = __( 'Unpublished' ); $time_diff = 0; else : $t_time = get_the_time( __( 'Y/m/d g:i:s A' ) ); $m_time = $post->post_date; $time = get_post_time( 'G', true, $post ); $time_diff = time() - $time; if ( $time_diff > 0 && $time_diff < 24*60*60 ) $h_time = sprintf( __( '%s ago' ), human_time_diff( $time ) ); else $h_time = mysql2date( __( 'Y/m/d' ), $m_time ); endif; echo '' . apply_filters( 'post_date_column_time', $h_time, $post ) . ''; break; } } /** * Order page filters **/ add_filter('views_edit-shop_order', 'woocommerce_custom_order_views'); function woocommerce_custom_order_views( $views ) { unset($views['publish']); if (isset($views['trash'])) : $trash = $views['trash']; unset($views['draft']); unset($views['trash']); $views['trash'] = $trash; endif; return $views; } /** * Order page actions **/ add_filter( 'post_row_actions', 'woocommerce_remove_row_actions', 10, 1 ); function woocommerce_remove_row_actions( $actions ) { if( get_post_type() === 'shop_order' ) : unset( $actions['view'] ); unset( $actions['inline hide-if-no-js'] ); endif; return $actions; } /** * Order page bulk actions **/ add_filter( 'bulk_actions-edit-shop_order', 'woocommerce_bulk_actions' ); function woocommerce_bulk_actions( $actions ) { if (isset($actions['edit'])) unset($actions['edit']); return $actions; } /** * Filter orders by status **/ add_action('restrict_manage_posts','woocommerce_orders_by_status'); function woocommerce_orders_by_status() { global $typenow, $wp_query; if ($typenow=='shop_order') : $terms = get_terms('shop_order_status'); $output = ""; echo $output; endif; } /** * Filter orders by customer **/ add_action('restrict_manage_posts', 'woocommerce_orders_by_customer'); function woocommerce_orders_by_customer() { global $typenow, $wp_query; if ($typenow=='shop_order') : $users_query = new WP_User_Query( array( 'fields' => 'all', //'role' => 'customer', 'orderby' => 'display_name' ) ); $users = $users_query->get_results(); if ($users) : $output = ""; echo $output; endif; endif; } /** * Filter orders by customer query **/ add_filter( 'request', 'woocommerce_orders_by_customer_query' ); function woocommerce_orders_by_customer_query( $vars ) { global $typenow, $wp_query; if ($typenow=='shop_order' && isset( $_GET['_customer_user'] ) && $_GET['_customer_user']>0) : $vars['meta_key'] = '_customer_user'; $vars['meta_value'] = (int) $_GET['_customer_user']; endif; return $vars; } /** * Make order columns sortable * https://gist.github.com/906872 **/ add_filter("manage_edit-shop_order_sortable_columns", 'woocommerce_custom_shop_order_sort'); function woocommerce_custom_shop_order_sort($columns) { $custom = array( 'order_title' => 'ID', 'order_total' => 'order_total', 'order_date' => 'date' ); return wp_parse_args($custom, $columns); } /** * Order column orderby/request **/ add_filter( 'request', 'woocommerce_custom_shop_order_orderby' ); function woocommerce_custom_shop_order_orderby( $vars ) { global $typenow, $wp_query; if ($typenow!='shop_order') return $vars; // Sorting if (isset( $vars['orderby'] )) : if ( 'order_total' == $vars['orderby'] ) : $vars = array_merge( $vars, array( 'meta_key' => '_order_total', 'orderby' => 'meta_value_num' ) ); endif; endif; return $vars; } /** * Order messages **/ add_filter( 'post_updated_messages', 'woocommerce_post_updated_messages' ); function woocommerce_post_updated_messages( $messages ) { if( get_post_type() === 'shop_order' ) : $messages['post'][1] = sprintf( __('Order updated.', 'woothemes') ); $messages['post'][4] = sprintf( __('Order updated.', 'woothemes') ); $messages['post'][6] = sprintf( __('Order published.', 'woothemes') ); $messages['post'][8] = sprintf( __('Order submitted.', 'woothemes') ); $messages['post'][10] = sprintf( __('Order draft updated.', 'woothemes') ); endif; return $messages; }