Моя учетная запись - загрузки: список всех продуктов - PullRequest
1 голос
/ 19 марта 2020

На моем сайте я предлагаю только виртуальные продукты, поэтому я хочу внести изменения в свой аккаунт - просмотр загрузки.

Я использую следующий код.

function filter_woocommerce_customer_available_downloads($downloads, $customer_id) { 

    // Manipulate download data here, this example we'll get the first 5 downloads in the array
    // $downloads = array_slice($downloads, 0, 5);
 // Sorting the array by Order Ids in DESC order
        arsort($downloads); 

    // Return first five downloads
    return $downloads;

}; 
// Add the filter, this tells wordpress to apply this filter every time available downloads is called
add_filter( 'woocommerce_customer_available_downloads', 'filter_woocommerce_customer_available_downloads', 10, 2 );

/**
 * Group Downloadable products by product ID
 *
 * @param array $downloads
 * @return array
 */
function prefix_group_downloadable_products( array $downloads ) {
    $unique_downloads = [];

    foreach ($downloads as $download ) {
        $list = [
            'download_url' => $download['download_url'],
            'file_name'    => $download['file']['name'],
            'orderid'  => $download['order_id']
        ];


        if ( array_key_exists( $download['product_id'], $unique_downloads ) ) {
            $unique_downloads[ $download['product_id'] ]['list'][] = $list;
            continue;
        }



        $data = $download;
        $data['list'] = [ $list ];
        $unique_downloads[ $download['product_id'] ] = $data;
    }

    return $unique_downloads;
}

add_filter( 'woocommerce_customer_get_downloadable_products', 
'prefix_group_downloadable_products' );

/**
 * Show number list of downloadable files for group product
 *
 * @param array $download
 * @return void
 */

function prefix_downloads_column_download_file( array $download ) {


    $lists = $download['list'];

            // Sorting the array by Order Ids in DESC order
        arsort($lists); 

    if ( empty( $lists ) ) {
        _e( 'No Download Files', 'storefront' );
        return;
    }




    echo '<ul class="charliesub">';
    echo '<li class="accordion">';
    echo '<h3>' .  $order_date . '</h3>';
    echo '<div>';

     echo '<ol>';

    foreach ( $lists as $list ) {
    // Get $order object from order ID 
$order = wc_get_order( $list['orderid']  );

  $order_date = $order->get_date_completed();


         echo '<li>';
        echo '<a href="' . esc_url( $list['download_url'] ) . '" class="woocommerce-MyAccount-downloads-file">';
        echo esc_html( $list['file_name'] );
        echo '</a></li>';
    }

    echo '</ol>';
        echo '</div>';
        echo '</li>';
            echo '</ul>';

}

add_action( 'woocommerce_account_downloads_column_download-file', 'prefix_downloads_column_download_file' );

Однако, дата заказа отображается над каждым скачать ссылка .

Мне нужно было бы иметь только дату один раз прежде всего ссылки . (помещено как я хочу в теге <h3>).

Кто-то, кто может помочь мне с уже внесенными изменениями?

1 Ответ

0 голосов
/ 19 марта 2020

В foreach l oop вы можете сохранить значения в переменной вместо печати (эхо).

После foreach вы можете затем напечатать переменную

function filter_woocommerce_customer_available_downloads($downloads, $customer_id) { 
    // Manipulate download data here, this example we'll get the first 5 downloads in the array
    // $downloads = array_slice($downloads, 0, 5);
    // Sorting the array by Order Ids in DESC order
    arsort($downloads); 

    // Return first five downloads
    return $downloads;
}
add_filter( 'woocommerce_customer_available_downloads', 'filter_woocommerce_customer_available_downloads', 10, 2 );

/**
 * Group Downloadable products by product ID
 *
 * @param array $downloads
 * @return array
 */
function prefix_group_downloadable_products( array $downloads ) {
    $unique_downloads = [];

    foreach ($downloads as $download ) {
        $list = [
            'download_url' => $download['download_url'],
            'file_name'    => $download['file']['name'],
            'orderid'      => $download['order_id']
        ];

        if ( array_key_exists( $download['product_id'], $unique_downloads ) ) {
            $unique_downloads[ $download['product_id'] ]['list'][] = $list;
            continue;
        }

        $data = $download;
        $data['list'] = [ $list ];
        $unique_downloads[ $download['product_id'] ] = $data;
    }

    return $unique_downloads;
}
add_filter( 'woocommerce_customer_get_downloadable_products', 'prefix_group_downloadable_products', 10, 1 );

/**
 * Show number list of downloadable files for group product
 *
 * @param array $download
 * @return void
 */
function prefix_downloads_column_download_file( array $download ) {
    $lists = $download['list'];

    // Sorting the array by Order Ids in DESC order
    arsort($lists); 

    if ( empty( $lists ) ) {
        _e( 'No Download Files', 'storefront' );
        return;
    }

    // Set variable
    $li = '';

    foreach ( $lists as $list ) {
        // Get $order object from order ID 
        $order = wc_get_order( $list['orderid']  );

        $order_date = $order->get_date_completed();

        // Append to
        $li .= '<li><a href="' . esc_url( $list['download_url'] ) . '" class="woocommerce-MyAccount-downloads-file">' . esc_html( $list['file_name'] ) . '</a></li>';
    }

    echo '<ul class="charliesub">';
    echo '<li class="accordion">';
    echo '<h3>' .  $order_date . '</h3>';
    echo '<div>';
    echo '<ol>';

    echo $li;

    echo '</ol>';
    echo '</div>';
    echo '</li>';
    echo '</ul>';
}
add_action( 'woocommerce_account_downloads_column_download-file', 'prefix_downloads_column_download_file' );
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...