"; $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, $woocommerce; $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 $woocommerce->get_coupon_discount_type($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, uses slugs for option values. Code adapted by Andrew Benbow - chromeorange.co.uk **/ add_action('restrict_manage_posts','woocommerce_products_by_category'); function woocommerce_products_by_category() { global $typenow, $wp_query; if ($typenow=='product') : woocommerce_product_dropdown_categories(); 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') : // Types $terms = get_terms('product_type'); $output = ""; // Downloadable/virtual $output .= ""; echo $output; endif; } add_filter( 'parse_query', 'woocommerce_products_subtype_query' ); function woocommerce_products_subtype_query($query) { global $typenow, $wp_query; if ($typenow=='product' && isset($_GET['product_subtype']) && $_GET['product_subtype']) : if ($_GET['product_subtype']=='downloadable') : $query->query_vars['meta_value'] = 'yes'; $query->query_vars['meta_key'] = 'downloadable'; endif; if ($_GET['product_subtype']=='virtual') : $query->query_vars['meta_value'] = 'yes'; $query->query_vars['meta_key'] = 'virtual'; endif; endif; } /** * Add functionality to the image uploader on product pages to exlcude an image **/ add_filter('attachment_fields_to_edit', 'woocommerce_exclude_image_from_product_page_field', 1, 2); add_filter('attachment_fields_to_save', 'woocommerce_exclude_image_from_product_page_field_save', 1, 2); function woocommerce_exclude_image_from_product_page_field( $fields, $object ) { if (!$object->post_parent) return $fields; $parent = get_post( $object->post_parent ); if ($parent->post_type!=='product') return $fields; $exclude_image = (int) get_post_meta($object->ID, '_woocommerce_exclude_image', true); $label = __('Exclude image', 'woothemes'); $html = ''; $fields['woocommerce_exclude_image'] = array( 'label' => $label, 'input' => 'html', 'html' => $html, 'value' => '', 'helps' => __('Enabling this option will hide it from the product page image gallery.', 'woothemes') ); return $fields; } function woocommerce_exclude_image_from_product_page_field_save( $post, $attachment ) { if (isset($_REQUEST['attachments'][$post['ID']]['woocommerce_exclude_image'])) : delete_post_meta( (int) $post['ID'], '_woocommerce_exclude_image' ); update_post_meta( (int) $post['ID'], '_woocommerce_exclude_image', 1); else : delete_post_meta( (int) $post['ID'], '_woocommerce_exclude_image' ); update_post_meta( (int) $post['ID'], '_woocommerce_exclude_image', 0); endif; return $post; } /** * 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'); $columns["order_actions"] = __("Actions", '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, 'woothemes') ); 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 .= esc_html( $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', 'woothemes') . ' ' . 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; case "order_actions" : ?>

status, array('pending', 'on-hold'))) : ?> status, array('pending', 'on-hold', 'processing'))) : ?>

"; $output .= ''; foreach($terms as $term) : $output .=""; endforeach; $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; } /** * Mark an order as complete */ function woocommerce_mark_order_complete() { if( !is_admin() ) die; if( !current_user_can('edit_posts') ) wp_die( __('You do not have sufficient permissions to access this page.') ); if( !check_admin_referer()) wp_die( __('You have taken too long. Please go back and retry.', 'woothemes') ); $order_id = isset($_GET['order_id']) && (int) $_GET['order_id'] ? (int) $_GET['order_id'] : ''; if(!$order_id) die; $order = &new woocommerce_order( $order_id ); $order->update_status( 'completed' ); wp_safe_redirect( wp_get_referer() ); } add_action('wp_ajax_woocommerce-mark-order-complete', 'woocommerce_mark_order_complete'); /** * Mark an order as processing */ function woocommerce_mark_order_processing() { if( !is_admin() ) die; if( !current_user_can('edit_posts') ) wp_die( __('You do not have sufficient permissions to access this page.') ); if( !check_admin_referer()) wp_die( __('You have taken too long. Please go back and retry.', 'woothemes') ); $order_id = isset($_GET['order_id']) && (int) $_GET['order_id'] ? (int) $_GET['order_id'] : ''; if(!$order_id) die; $order = &new woocommerce_order( $order_id ); $order->update_status( 'processing' ); wp_safe_redirect( wp_get_referer() ); } add_action('wp_ajax_woocommerce-mark-order-processing', 'woocommerce_mark_order_processing'); /** * Feature a product from admin */ function woocommerce_feature_product() { if( !is_admin() ) die; if( !current_user_can('edit_posts') ) wp_die( __('You do not have sufficient permissions to access this page.') ); if( !check_admin_referer()) wp_die( __('You have taken too long. Please go back and retry.', 'woothemes') ); $post_id = isset($_GET['product_id']) && (int)$_GET['product_id'] ? (int)$_GET['product_id'] : ''; if(!$post_id) die; $post = get_post($post_id); if(!$post) die; if($post->post_type !== 'product') die; $product = new woocommerce_product($post->ID); if ($product->is_featured()) update_post_meta($post->ID, 'featured', 'no'); else update_post_meta($post->ID, 'featured', 'yes'); $sendback = remove_query_arg( array('trashed', 'untrashed', 'deleted', 'ids'), wp_get_referer() ); wp_safe_redirect( $sendback ); } add_action('wp_ajax_woocommerce-feature-product', 'woocommerce_feature_product'); /** * Search by SKU or ID for products. Adapted from code by BenIrvin (Admin Search by ID) */ if (is_admin()) : add_action( 'parse_request', 'woocommerce_admin_product_search' ); add_filter( 'get_search_query', 'woocommerce_admin_product_search_label' ); endif; function woocommerce_admin_product_search( $wp ) { global $pagenow, $wpdb; if( 'edit.php' != $pagenow ) return; if( !isset( $wp->query_vars['s'] ) ) return; if ($wp->query_vars['post_type']!='product') return; if( '#' == substr( $wp->query_vars['s'], 0, 1 ) ) : $id = absint( substr( $wp->query_vars['s'], 1 ) ); if( !$id ) return; unset( $wp->query_vars['s'] ); $wp->query_vars['p'] = $id; elseif( 'SKU:' == substr( $wp->query_vars['s'], 0, 4 ) ) : $sku = trim( substr( $wp->query_vars['s'], 4 ) ); if( !$sku ) return; $id = $wpdb->get_var('SELECT post_id FROM '.$wpdb->postmeta.' WHERE meta_key="sku" AND meta_value LIKE "%'.$sku.'%";'); if( !$id ) return; unset( $wp->query_vars['s'] ); $wp->query_vars['p'] = $id; $wp->query_vars['sku'] = $sku; endif; } function woocommerce_admin_product_search_label($query) { global $pagenow, $typenow, $wp; if ( 'edit.php' != $pagenow ) return $query; if ( $typenow!='product' ) return $query; $s = get_query_var( 's' ); if ($s) return $query; $sku = get_query_var( 'sku' ); if($sku) { $post_type = get_post_type_object($wp->query_vars['post_type']); return sprintf(__("[%s with SKU of %s]", 'woothemes'), $post_type->labels->singular_name, $sku); } $p = get_query_var( 'p' ); if ($p) { $post_type = get_post_type_object($wp->query_vars['post_type']); return sprintf(__("[%s with ID of %d]", 'woothemes'), $post_type->labels->singular_name, $p); } return $query; } /** * Order custom field search **/ if (is_admin()) : add_filter( 'parse_query', 'woocommerce_shop_order_search_custom_fields' ); add_filter( 'get_search_query', 'woocommerce_shop_order_search_label' ); endif; function woocommerce_shop_order_search_custom_fields( $wp ) { global $pagenow, $wpdb; if( 'edit.php' != $pagenow ) return $wp; if( !isset( $wp->query_vars['s'] ) || !$wp->query_vars['s'] ) return $wp; if ($wp->query_vars['post_type']!='shop_order') return $wp; $search_fields = array( '_order_key', '_billing_first_name', '_billing_last_name', '_billing_company', '_billing_address_1', '_billing_address_2', '_billing_city', '_billing_postcode', '_billing_country', '_billing_state', '_billing_email', '_order_items', '_billing_phone' ); // Query matching custom fields - this seems faster than meta_query $post_ids = $wpdb->get_col($wpdb->prepare('SELECT post_id FROM '.$wpdb->postmeta.' WHERE meta_key IN ('.'"'.implode('","', $search_fields).'"'.') AND meta_value LIKE "%%%s%%"', esc_attr($_GET['s']) )); // Query matching excerpts and titles $post_ids = array_merge($post_ids, $wpdb->get_col($wpdb->prepare(' SELECT '.$wpdb->posts.'.ID FROM '.$wpdb->posts.' LEFT JOIN '.$wpdb->postmeta.' ON '.$wpdb->posts.'.ID = '.$wpdb->postmeta.'.post_id LEFT JOIN '.$wpdb->users.' ON '.$wpdb->postmeta.'.meta_value = '.$wpdb->users.'.ID WHERE post_excerpt LIKE "%%%1$s%%" OR post_title LIKE "%%%1$s%%" OR ( meta_key = "_customer_user" AND ( user_login LIKE "%%%1$s%%" OR user_nicename LIKE "%%%1$s%%" OR user_email LIKE "%%%1$s%%" OR display_name LIKE "%%%1$s%%" ) ) ', esc_attr($_GET['s']) ))); // Add ID $search_order_id = str_replace('Order #', '', $_GET['s']); if (is_numeric($search_order_id)) $post_ids[] = $search_order_id; // Add blank ID so not all results are returned if the search finds nothing $post_ids[] = 0; // Remove s - we don't want to search order name unset( $wp->query_vars['s'] ); // so we know we're doing this $wp->query_vars['shop_order_search'] = true; // Search by found posts $wp->query_vars['post__in'] = $post_ids; } function woocommerce_shop_order_search_label($query) { global $pagenow, $typenow; if( 'edit.php' != $pagenow ) return $query; if ( $typenow!='shop_order' ) return $query; if ( !get_query_var('shop_order_search')) return $query; return $_GET['s']; } /** * Query vars for custom searches **/ add_filter('query_vars', 'woocommerce_add_custom_query_var'); function woocommerce_add_custom_query_var($public_query_vars) { $public_query_vars[] = 'sku'; $public_query_vars[] = 'shop_order_search'; return $public_query_vars; }