get_helper( 'shortcode' )->shortcode_wrapper( array( 'WC_Shortcode_Cart', 'output' ), $atts ); } /** * Checkout page shortcode. * * @access public * @param mixed $atts * @return string */ public function checkout( $atts ) { global $woocommerce; return $woocommerce->get_helper( 'shortcode' )->shortcode_wrapper( array( 'WC_Shortcode_Checkout', 'output' ), $atts ); } /** * Order tracking page shortcode. * * @access public * @param mixed $atts * @return string */ public function order_tracking( $atts ) { global $woocommerce; return $woocommerce->get_helper( 'shortcode' )->shortcode_wrapper( array( 'WC_Shortcode_Order_Tracking', 'output' ), $atts ); } /** * Cart shortcode. * * @access public * @param mixed $atts * @return string */ public function my_account( $atts ) { global $woocommerce; return $woocommerce->get_helper( 'shortcode' )->shortcode_wrapper( array( 'WC_Shortcode_My_Account', 'output' ), $atts ); } /** * List products in a category shortcode * * @access public * @param array $atts * @return string */ public function product_category( $atts ){ global $woocommerce, $woocommerce_loop; if ( empty( $atts ) ) return; extract( shortcode_atts( array( 'per_page' => '12', 'columns' => '4', 'orderby' => 'title', 'order' => 'desc', 'category' => '' ), $atts ) ); if ( ! $category ) return; // Default ordering args $ordering_args = $woocommerce->query->get_catalog_ordering_args( $orderby, $order ); $args = array( 'post_type' => 'product', 'post_status' => 'publish', 'ignore_sticky_posts' => 1, 'orderby' => $ordering_args['orderby'], 'order' => $ordering_args['order'], 'posts_per_page' => $per_page, 'meta_query' => array( array( 'key' => '_visibility', 'value' => array('catalog', 'visible'), 'compare' => 'IN' ) ), 'tax_query' => array( array( 'taxonomy' => 'product_cat', 'terms' => array( esc_attr($category) ), 'field' => 'slug', 'operator' => 'IN' ) ) ); if ( isset( $ordering_args['meta_key'] ) ) { $args['meta_key'] = $ordering_args['meta_key']; } ob_start(); $products = new WP_Query( $args ); $woocommerce_loop['columns'] = $columns; if ( $products->have_posts() ) : ?> have_posts() ) : $products->the_post(); ?> ' . ob_get_clean() . ''; } /** * List all (or limited) product categories * * @access public * @param array $atts * @return string */ public function product_categories( $atts ) { global $woocommerce_loop; extract( shortcode_atts( array ( 'number' => null, 'orderby' => 'name', 'order' => 'ASC', 'columns' => '4', 'hide_empty' => 1, 'parent' => '' ), $atts ) ); if ( isset( $atts[ 'ids' ] ) ) { $ids = explode( ',', $atts[ 'ids' ] ); $ids = array_map( 'trim', $ids ); } else { $ids = array(); } $hide_empty = ( $hide_empty == true || $hide_empty == 1 ) ? 1 : 0; // get terms and workaround WP bug with parents/pad counts $args = array( 'orderby' => $orderby, 'order' => $order, 'hide_empty' => $hide_empty, 'include' => $ids, 'pad_counts' => true, 'child_of' => $parent ); $product_categories = get_terms( 'product_cat', $args ); if ( $parent !== "" ) $product_categories = wp_list_filter( $product_categories, array( 'parent' => $parent ) ); if ( $number ) $product_categories = array_slice( $product_categories, 0, $number ); $woocommerce_loop['columns'] = $columns; ob_start(); // Reset loop/columns globals when starting a new loop $woocommerce_loop['loop'] = $woocommerce_loop['column'] = ''; if ( $product_categories ) { woocommerce_product_loop_start(); foreach ( $product_categories as $category ) { woocommerce_get_template( 'content-product_cat.php', array( 'category' => $category ) ); } woocommerce_product_loop_end(); } woocommerce_reset_loop(); return '
get_price_html(); ?>
post_type ) { $product = get_product( $product_data->post_parent ); $GLOBALS['product'] = $product; $variation = get_product( $product_data ); ob_start(); ?>get_price_html(); ?> add_to_cart_url(); $label = apply_filters('add_to_cart_text', __( 'Add to cart', 'woocommerce' )); $link = add_query_arg( 'variation_id', $variation->variation_id, $link ); foreach ($variation->variation_data as $key => $data) { if ($data) $link = add_query_arg( $key, $data, $link ); } printf('%s', esc_url( $link ), $product->id, $product->product_type, $label); ?>
get_var( $wpdb->prepare( "SELECT post_id FROM $wpdb->postmeta WHERE meta_key='_sku' AND meta_value='%s' LIMIT 1", $atts['sku'] ) ); $product_data = get_post( $product_id ); } else { return; } if ( 'product' !== $product_data->post_type ) return; $_product = get_product( $product_data ); return esc_url( $_product->add_to_cart_url() ); } /** * List all products on sale * * @access public * @param array $atts * @return string */ public function sale_products( $atts ){ global $woocommerce_loop, $woocommerce; extract( shortcode_atts( array( 'per_page' => '12', 'columns' => '4', 'orderby' => 'title', 'order' => 'asc' ), $atts ) ); // Get products on sale $product_ids_on_sale = woocommerce_get_product_ids_on_sale(); $meta_query = array(); $meta_query[] = $woocommerce->query->visibility_meta_query(); $meta_query[] = $woocommerce->query->stock_status_meta_query(); $meta_query = array_filter( $meta_query ); $args = array( 'posts_per_page'=> $per_page, 'orderby' => $orderby, 'order' => $order, 'no_found_rows' => 1, 'post_status' => 'publish', 'post_type' => 'product', 'meta_query' => $meta_query, 'post__in' => $product_ids_on_sale ); ob_start(); $products = new WP_Query( $args ); $woocommerce_loop['columns'] = $columns; if ( $products->have_posts() ) : ?> have_posts() ) : $products->the_post(); ?> ' . ob_get_clean() . ''; } /** * List best selling products on sale * * @access public * @param array $atts * @return string */ public function best_selling_products( $atts ){ global $woocommerce_loop; extract( shortcode_atts( array( 'per_page' => '12', 'columns' => '4' ), $atts ) ); $args = array( 'post_type' => 'product', 'post_status' => 'publish', 'ignore_sticky_posts' => 1, 'posts_per_page' => $per_page, 'meta_key' => 'total_sales', 'orderby' => 'meta_value_num', 'meta_query' => array( array( 'key' => '_visibility', 'value' => array( 'catalog', 'visible' ), 'compare' => 'IN' ) ) ); ob_start(); $products = new WP_Query( $args ); $woocommerce_loop['columns'] = $columns; if ( $products->have_posts() ) : ?> have_posts() ) : $products->the_post(); ?> ' . ob_get_clean() . ''; } /** * List top rated products on sale * * @access public * @param array $atts * @return string */ public function top_rated_products( $atts ){ global $woocommerce_loop; extract( shortcode_atts( array( 'per_page' => '12', 'columns' => '4', 'orderby' => 'title', 'order' => 'asc' ), $atts ) ); $args = array( 'post_type' => 'product', 'post_status' => 'publish', 'ignore_sticky_posts' => 1, 'orderby' => $orderby, 'order' => $order, 'posts_per_page' => $per_page, 'meta_query' => array( array( 'key' => '_visibility', 'value' => array('catalog', 'visible'), 'compare' => 'IN' ) ) ); ob_start(); add_filter( 'posts_clauses', array( &$this, 'order_by_rating_post_clauses' ) ); $products = new WP_Query( $args ); remove_filter( 'posts_clauses', array( &$this, 'order_by_rating_post_clauses' ) ); $woocommerce_loop['columns'] = $columns; if ( $products->have_posts() ) : ?> have_posts() ) : $products->the_post(); ?> ' . ob_get_clean() . ''; } /** * Output featured products * * @access public * @param array $atts * @return string */ public function featured_products( $atts ) { global $woocommerce_loop; extract(shortcode_atts(array( 'per_page' => '12', 'columns' => '4', 'orderby' => 'date', 'order' => 'desc' ), $atts)); $args = array( 'post_type' => 'product', 'post_status' => 'publish', 'ignore_sticky_posts' => 1, 'posts_per_page' => $per_page, 'orderby' => $orderby, 'order' => $order, 'meta_query' => array( array( 'key' => '_visibility', 'value' => array('catalog', 'visible'), 'compare' => 'IN' ), array( 'key' => '_featured', 'value' => 'yes' ) ) ); ob_start(); $products = new WP_Query( $args ); $woocommerce_loop['columns'] = $columns; if ( $products->have_posts() ) : ?> have_posts() ) : $products->the_post(); ?> ' . ob_get_clean() . ''; } /** * Show a single product page * * @access public * @param array $atts * @return string */ public function product_page_shortcode( $atts ) { if ( empty( $atts ) ) return; if ( ! isset( $atts['id'] ) && ! isset( $atts['sku'] ) ) return; $args = array( 'posts_per_page' => 1, 'post_type' => 'product', 'post_status' => 'publish', 'ignore_sticky_posts' => 1, 'no_found_rows' => 1 ); if ( isset( $atts['sku'] ) ) { $args['meta_query'][] = array( 'key' => '_sku', 'value' => $atts['sku'], 'compare' => '=' ); } if ( isset( $atts['id'] ) ) { $args['p'] = $atts['id']; } $single_product = new WP_Query( $args ); ob_start(); while ( $single_product->have_posts() ) : $single_product->the_post(); wp_enqueue_script( 'wc-single-product' ); ?>