????
Current Path : /home/webcloude/public_html/wp-content/plugins/woocommerce/templates/emails/ |
Current File : //home/webcloude/public_html/wp-content/plugins/woocommerce/templates/emails/email-order-items.php |
<?php /** * Email Order Items * * This template can be overridden by copying it to yourtheme/woocommerce/emails/email-order-items.php. * * HOWEVER, on occasion WooCommerce will need to update template files and you * (the theme developer) will need to copy the new files to your theme to * maintain compatibility. We try to do this as little as possible, but it does * happen. When this occurs the version of the template file will be bumped and * the readme will list any important changes. * * @see https://woocommerce.com/document/template-structure/ * @package WooCommerce\Templates\Emails * @version 9.7.0 */ use Automattic\WooCommerce\Utilities\FeaturesUtil; defined( 'ABSPATH' ) || exit; $margin_side = is_rtl() ? 'left' : 'right'; $email_improvements_enabled = FeaturesUtil::feature_is_enabled( 'email_improvements' ); $price_text_align = $email_improvements_enabled ? 'right' : 'left'; foreach ( $items as $item_id => $item ) : $product = $item->get_product(); $sku = ''; $purchase_note = ''; $image = ''; if ( ! apply_filters( 'woocommerce_order_item_visible', true, $item ) ) { continue; } if ( is_object( $product ) ) { $sku = $product->get_sku(); $purchase_note = $product->get_purchase_note(); $image = $product->get_image( $image_size ); } ?> <tr class="<?php echo esc_attr( apply_filters( 'woocommerce_order_item_class', 'order_item', $item, $order ) ); ?>"> <td class="td font-family text-align-left" style="vertical-align: middle; word-wrap:break-word;"> <?php if ( $email_improvements_enabled ) { ?> <table class="order-item-data"> <tr> <?php // Show title/image etc. if ( $show_image ) { /** * Email Order Item Thumbnail hook. * * @param string $image The image HTML. * @param WC_Order_Item_Product $item The item being displayed. * @since 2.1.0 */ echo '<td>' . wp_kses_post( apply_filters( 'woocommerce_order_item_thumbnail', $image, $item ) ) . '</td>'; } ?> <td> <?php /** * Order Item Name hook. * * @param string $item_name The item name HTML. * @param WC_Order_Item_Product $item The item being displayed. * @since 2.1.0 */ echo wp_kses_post( apply_filters( 'woocommerce_order_item_name', $item->get_name(), $item, false ) ); // SKU. if ( $show_sku && $sku ) { echo wp_kses_post( ' (#' . $sku . ')' ); } /** * Allow other plugins to add additional product information. * * @param int $item_id The item ID. * @param WC_Order_Item_Product $item The item object. * @param WC_Order $order The order object. * @param bool $plain_text Whether the email is plain text or not. * @since 2.3.0 */ do_action( 'woocommerce_order_item_meta_start', $item_id, $item, $order, $plain_text ); wc_display_item_meta( $item ); /** * Allow other plugins to add additional product information. * * @param int $item_id The item ID. * @param WC_Order_Item_Product $item The item object. * @param WC_Order $order The order object. * @param bool $plain_text Whether the email is plain text or not. * @since 2.3.0 */ do_action( 'woocommerce_order_item_meta_end', $item_id, $item, $order, $plain_text ); ?> </td> </tr> </table> <?php } else { // Show title/image etc. if ( $show_image ) { /** * Email Order Item Thumbnail hook. * * @param string $image The image HTML. * @param WC_Order_Item_Product $item The item being displayed. * @since 2.1.0 */ echo wp_kses_post( apply_filters( 'woocommerce_order_item_thumbnail', $image, $item ) ); } /** * Order Item Name hook. * * @param string $item_name The item name HTML. * @param WC_Order_Item_Product $item The item being displayed. * @since 2.1.0 */ echo wp_kses_post( apply_filters( 'woocommerce_order_item_name', $item->get_name(), $item, false ) ); // SKU. if ( $show_sku && $sku ) { echo wp_kses_post( ' (#' . $sku . ')' ); } /** * Allow other plugins to add additional product information. * * @param int $item_id The item ID. * @param WC_Order_Item_Product $item The item object. * @param WC_Order $order The order object. * @param bool $plain_text Whether the email is plain text or not. * @since 2.3.0 */ do_action( 'woocommerce_order_item_meta_start', $item_id, $item, $order, $plain_text ); wc_display_item_meta( $item, array( 'label_before' => '<strong class="wc-item-meta-label" style="float: ' . ( is_rtl() ? 'right' : 'left' ) . '; margin-' . esc_attr( $margin_side ) . ': .25em; clear: both">', ) ); /** * Allow other plugins to add additional product information. * * @param int $item_id The item ID. * @param WC_Order_Item_Product $item The item object. * @param WC_Order $order The order object. * @param bool $plain_text Whether the email is plain text or not. * @since 2.3.0 */ do_action( 'woocommerce_order_item_meta_end', $item_id, $item, $order, $plain_text ); } ?> </td> <td class="td font-family text-align-<?php echo esc_attr( $price_text_align ); ?>" style="vertical-align:middle;"> <?php echo $email_improvements_enabled ? '×' : ''; $qty = $item->get_quantity(); $refunded_qty = $order->get_qty_refunded_for_item( $item_id ); if ( $refunded_qty ) { $qty_display = '<del>' . esc_html( $qty ) . '</del> <ins>' . esc_html( $qty - ( $refunded_qty * -1 ) ) . '</ins>'; } else { $qty_display = esc_html( $qty ); } echo wp_kses_post( apply_filters( 'woocommerce_email_order_item_quantity', $qty_display, $item ) ); ?> </td> <td class="td font-family text-align-<?php echo esc_attr( $price_text_align ); ?>" style="vertical-align:middle;"> <?php echo wp_kses_post( $order->get_formatted_line_subtotal( $item ) ); ?> </td> </tr> <?php if ( $show_purchase_note && $purchase_note ) { ?> <tr> <td colspan="3" class="font-family text-align-left" style="vertical-align:middle;"> <?php echo wp_kses_post( wpautop( do_shortcode( $purchase_note ) ) ); ?> </td> </tr> <?php } ?> <?php endforeach; ?>