2016-08-22 7 views
8

でWooCommerceの顧客の注文の詳細、ユーザーが自分の(デフォルト)パーソナルエリアにログインし、同じような情報を表示することができます。WooCommerceを実行しているWordPressのウェブサイトでBSモーダル

  • 注文履歴
  • ダウンロード
  • アドレス
  • 編集情報
  • ログアウト

ordersタブには、デフォルトで表が表示され、すべての注文のリストが表示され、Viewボタンがその注文の完全な詳細ページにリダイレクトされます。

私がしようとしているのは、そのテーブルビューをモーダルウィンドウで表示することです。

ターゲットURLをロードしてモーダルを表示する際に問題はありません。 実際の問題は、ターゲットURLがのように表示されている全ページのURLであり、私が望むものではないということです。

ちょうどそのテーブルをロードすることを許可するショートコードがあると思うか、またはおそらくload_order_content_by_id($id)のようないくつかのwoocommerce関数がありますか?

誰かが正しい方向に向けることができますか?

おかげ

=== ===に正しい関数に私を指​​しているためラウナクグプタに

感謝を解決しました。 私は、orders.phpテンプレートを上書きするモーダルウィンドウのhtmlを追加し、編集:

'view' => array(
    'url' => 'javascript:;', 
    'data' => [ 
     'order-number' => $order->get_order_number() 
    ], 
    'name' => __('View', 'woocommerce') 
), 

と同じファイル上:

foreach ($actions as $key => $action) { 
    echo '<a href="' . esc_url($action['url']) . '" class="button ' . sanitize_html_class($key) . '"'; 
    if(isset($action['data']) && is_array($action['data'])){ 
     foreach($action['data'] AS $data_attr=>$data_value){ 
      echo 'data-' . sanitize_html_class($data_attr) .'="' .esc_html($data_value) . '" '; 
     } 
    } 
    echo '>' . esc_html($action['name']) . '</a>'; 
} 

少しJS

$('.woocommerce-MyAccount-orders .button.view').on('click', function(e){ 
    e.preventDefault(); 
    var data = {}; 
    data.action = 'modal_order'; 
    data.order_number = $(this).data('order-number'); 

    $.get(ajax_script.ajax_url, data, function(response) { 
     $('#modalOrderDetail').modal('show').find('.modal-body').html(response); 
    }); 
}); 

とワードプレスにフックby function.php

function modal_order() { 
    if(is_user_logged_in()) { 
     $order_number = $_GET['order_number']; 
     woocommerce_order_details_table($order_number); 
    } 
} 

add_action('wp_ajax_modal_order', 'modal_order'); 
add_action('wp_ajax_nopriv_modal_order', 'modal_order'); 
+0

私はwoocommerceを知らないが、あなたの質問は非常に曖昧であるようだ。詳細(おそらく[https://jsfiddle.net/](https://jsfiddle.net/))を追加しようとすると、さらに反応が出る可能性があります。 –

+0

私はそれにwordpressをロードすることが可能だった場合、私はフィドルを作るだろう:)私は自分の投稿を明確にしようとする – Yuri

+0

誰かがdownvotingの必要性を感じたら、少なくとも、それのexplainationを追加 – Yuri

答えて

4

woocommerce_order_details_table($order_id)

このWooCommerce機能は、ここで$order_id

+0

ニース:)そして私は推測するそれが使用するテンプレート - 'order/order-details.php'は、必要な構造でなければテーマ内でオーバーライド可能です。 +1 –

+1

はい、あなたの必要に応じて 'order/order-details.php'、' order/order-details-item.php'と 'order/order-details-customer.php'ファイルを上書きすることができます。 –

+0

パートが元のテンプレートを上書きしないようにするには、使用するためにどのようなグローバル変数を含める必要がありますか? – Yuri

2

あなたが必要とする注文の詳細をすべて得ることができると私が知っている機能はありませんが、あなたが必要とするものを得るためにWC_Orderクラスに電話することができます。いくつかの呼び出しメソッドをこれらと同様にすると、必要な情報が得られます。必要な正確な情報に応じて、get_items()メソッド以外の呼び出しを行う必要があります。一般的には、オブジェクトをポストオブジェクトと同じように構造体に返します。

$order = new WC_Order($post->ID); 
$_order = $order->get_items(); 

はあなたが必要なすべての情報を取得するために呼び出す必要があるかもしれません方法を見つけるために、「継承されたメソッド」セクションの下にここを見て。https://docs.woocommerce.com/wc-apidocs/class-WC_Order.html

4

により、HTML形式のフルオーダーの詳細を返すモーダルウィンドウで海流顧客の注文を表示するための完全なコードです。その古典的なクエリに基づいて、現在のユーザーの注文を取得し、テンプレートmy-account/orders.php(軽くカスタマイズされた) ...

<?php 

if(is_user_logged_in()): 

    // The query 
    $args = array(
     // WC orders post type 
     'post_type' => 'shop_order', 
     'numberposts' => -1, 
     // for current user id 
     'meta_key' => '_customer_user', 
     'meta_value' => get_current_user_id(), 
     // get orders statuses 
     'post_status' => array_keys(wc_get_order_statuses()), 
    ); 

    // Get all customer orders 
    $customer_orders = get_posts($args); 
    $count_ord = 0; 
    if (!empty($customer_orders)) 
     foreach ($customer_orders as $custo_order) 
      $count_ord++; 

    if ($count_ord > 0) 
     $has_orders = true; 
    else 
     $has_orders = false; 

    // the template my-account/orders.php ?> 

    <?php do_action('woocommerce_before_account_orders', $has_orders); ?> 

    <?php if ($has_orders) : ?> 

    <table class="woocommerce-MyAccount-orders shop_table shop_table_responsive my_account_orders account-orders-table"> 
     <thead> 
      <tr> 
       <?php foreach (wc_get_account_orders_columns() as $column_id => $column_name) : ?> 
        <th class="<?php echo esc_attr($column_id); ?>"><span class="nobr"><?php echo esc_html($column_name); ?></span></th> 
       <?php endforeach; ?> 
      </tr> 
     </thead> 

     <tbody> 
      <?php foreach ($customer_orders as $customer_order) : 
       $order  = wc_get_order($customer_order); 
       $item_count = $order->get_item_count(); 
       ?> 
       <tr class="order"> 
        <?php foreach (wc_get_account_orders_columns() as $column_id => $column_name) : ?> 
         <td class="<?php echo esc_attr($column_id); ?>" data-title="<?php echo esc_attr($column_name); ?>"> 
          <?php if (has_action('woocommerce_my_account_my_orders_column_' . $column_id)) : ?> 
           <?php do_action('woocommerce_my_account_my_orders_column_' . $column_id, $order); ?> 

          <?php elseif ('order-number' === $column_id) : ?> 
           <a href="<?php echo esc_url($order->get_view_order_url()); ?>"> 
            <?php echo _x('#', 'hash before order number', 'woocommerce') . $order->get_order_number(); ?> 
           </a> 

          <?php elseif ('order-date' === $column_id) : ?> 
           <time datetime="<?php echo date('Y-m-d', strtotime($order->order_date)); ?>" title="<?php echo esc_attr(strtotime($order->order_date)); ?>"><?php echo date_i18n(get_option('date_format'), strtotime($order->order_date)); ?></time> 

          <?php elseif ('order-status' === $column_id) : ?> 
           <?php echo wc_get_order_status_name($order->get_status()); ?> 

          <?php elseif ('order-total' === $column_id) : ?> 
           <?php echo sprintf(_n('%s for %s item', '%s for %s items', $item_count, 'woocommerce'), $order->get_formatted_order_total(), $item_count); ?> 

          <?php elseif ('order-actions' === $column_id) : ?> 
           <?php 
            $actions = array(
             'pay' => array(
              'url' => $order->get_checkout_payment_url(), 
              'name' => __('Pay', 'woocommerce') 
             ), 
             'view' => array(
              'url' => $order->get_view_order_url(), 
              'name' => __('View', 'woocommerce') 
             ), 
             'cancel' => array(
              'url' => $order->get_cancel_order_url(wc_get_page_permalink('myaccount')), 
              'name' => __('Cancel', 'woocommerce') 
             ) 
            ); 

            if (! $order->needs_payment()) { 
             unset($actions['pay']); 
            } 

            if (! in_array($order->get_status(), apply_filters('woocommerce_valid_order_statuses_for_cancel', array('pending', 'failed'), $order))) { 
             unset($actions['cancel']); 
            } 

            if ($actions = apply_filters('woocommerce_my_account_my_orders_actions', $actions, $order)) { 
             foreach ($actions as $key => $action) { 
              echo '<a href="' . esc_url($action['url']) . '" class="button ' . sanitize_html_class($key) . '">' . esc_html($action['name']) . '</a>'; 
             } 
            } 
           ?> 
          <?php endif; ?> 
         </td> 
        <?php endforeach; ?> 
       </tr> 
      <?php endforeach; ?> 
     </tbody> 
    </table> 

    <?php do_action('woocommerce_before_account_orders_pagination'); ?> 

    <?php if (1 < $customer_orders->max_num_pages) : ?> 
     <div class="woocommerce-Pagination"> 
      <?php if (1 !== $current_page) : ?> 
       <a class="woocommerce-Button woocommerce-Button--previous button" href="<?php echo esc_url(wc_get_endpoint_url('orders', $current_page - 1)); ?>"><?php _e('Previous', 'woocommerce'); ?></a> 
      <?php endif; ?> 

      <?php if ($current_page !== intval($customer_orders->max_num_pages)) : ?> 
       <a class="woocommerce-Button woocommerce-Button--next button" href="<?php echo esc_url(wc_get_endpoint_url('orders', $current_page + 1)); ?>"><?php _e('Next', 'woocommerce'); ?></a> 
      <?php endif; ?> 
     </div> 
    <?php endif; ?> 

<?php else : ?> 
    <div class="woocommerce-Message woocommerce-Message--info woocommerce-info"> 
     <a class="woocommerce-Button button" href="<?php echo esc_url(apply_filters('woocommerce_return_to_shop_redirect', wc_get_page_permalink('shop'))); ?>"> 
      <?php _e('Go Shop', 'woocommerce') ?> 
     </a> 
<?php endif; ?> 
     <?php _e('No order has been made yet.', 'woocommerce'); ?> 
    </div> 

<?php do_action('woocommerce_after_account_orders', $has_orders); ?> 

<?php endif; ?> 

にあなたのモーダルウィンドウおよび/またはカスタマイズされているCSSに既存のCSSルールを追加する必要がありますルール

このコードはテスト済みで、完全に機能しています。

+0

答えをありがとうが、 'woocommerce_order_details_table($ order_id)'を使用して、ほんの数行のコードで目的の結果を得ることができました。 – Yuri

+0

@Yuri本当に言及していないので、私はこれを仕事にしています。これは、現在の顧客注文のためのワーモノーステンプレートです。ページネーションとすべてのものを、「マイアカウント」=>「注文」あなたが望んでいないこと全て)...これは完全な鍵となるターン・ソリューション(代替)です。 – LoicTheAztec

+0

私はただ一つの注文テーブルを完全な注文リストではなく、モーダルウィンドウに表示したかっただけです。 – Yuri

関連する問題