在Woocommerce 3

时间:2018-03-29 17:47:35

标签: php woocommerce backend bulk orders

在Woocommerce后端(管理员)中,我有一个功能,允许店铺经理使用一组特定的数据下载两个日期之间的所有订单:

function write_to_file($date_initial, $date_final) {
    global $attach_download_dir, $attach_download_file;

    // Opens/creates file
    $myfile = fopen($attach_download_dir . '/' . $attach_download_file, "w") or die("Unable to open file!");

    // Populates first line
    fwrite($myfile, 'Date; Parent Order ID; Order ID' . PHP_EOL);

    // Retrieves orders data
    if ( isset($date_initial) && isset($date_final) ) $args = array( 'date_created' => $date_initial . '...' . $date_final );
    if ( isset($date_initial) && empty($date_final) ) $args = array( 'date_created' => '>=' . $date_initial );
    if ( empty($date_initial) && isset($date_final) ) $args = array( 'date_created' => '<=' . $date_final );
    if ( empty($date_initial) && empty($date_final) ) $args = array( );
    $orders = wc_get_orders( $args );

    // Populates file with orders data
    foreach ($orders as $order) {
        $order_data = $order->get_data();
        fwrite($myfile,
            // Date of order creation
            $order_data['date_created']->date('d/M/Y') . '; ' .

            // Parent Order ID
            '#' . ( ( $order->get_type() === 'shop_order' ) ? $order->get_id() : $order->get_parent_id() ) . '; ' .

            // Order ID
            '#' . $order->get_id()
        )
    }
}

点击按钮时会触发此功能......

我想从管理订单列表批量选择功能中启用类似的功能。因此,店铺经理在管理订单列表(参见下面的屏幕截图)上选择的订单将被发送到类似的自定义脚本,然后下载。

在这种情况下,所选订单将覆盖订单检索中的指定日期(如果有)。

enter image description here

但是,我找不到要访问的变量,告诉我管理员用户当时选择了哪些订单。

任何帮助将不胜感激......

1 个答案:

答案 0 :(得分:5)

以下是使您的功能适用于批量订单列表操作选择的完整方法,而不是日期范围:

// Adding to admin order list bulk dropdown a custom action 'custom_downloads'
add_filter( 'bulk_actions-edit-shop_order', 'downloads_bulk_actions_edit_product', 20, 1 );
function downloads_bulk_actions_edit_product( $actions ) {
    $actions['write_downloads'] = __( 'Download orders', 'woocommerce' );
    return $actions;
}

// Make the action from selected orders
add_filter( 'handle_bulk_actions-edit-shop_order', 'downloads_handle_bulk_action_edit_shop_order', 10, 3 );
function downloads_handle_bulk_action_edit_shop_order( $redirect_to, $action, $post_ids ) {
    if ( $action !== 'write_downloads' )
        return $redirect_to; // Exit

    global $attach_download_dir, $attach_download_file; // ???

    $processed_ids = array();

    foreach ( $post_ids as $post_id ) {
        $order = wc_get_order( $post_id );
        $order_data = $order->get_data();

        // Your code to be executed on each selected order
        fwrite($myfile,
            $order_data['date_created']->date('d/M/Y') . '; ' .
            '#' . ( ( $order->get_type() === 'shop_order' ) ? $order->get_id() : $order->get_parent_id() ) . '; ' .
            '#' . $order->get_id()
        );
        $processed_ids[] = $post_id;
    }

    return $redirect_to = add_query_arg( array(
        'write_downloads' => '1',
        'processed_count' => count( $processed_ids ),
        'processed_ids' => implode( ',', $processed_ids ),
    ), $redirect_to );
}

// The results notice from bulk action on orders
add_action( 'admin_notices', 'downloads_bulk_action_admin_notice' );
function downloads_bulk_action_admin_notice() {
    if ( empty( $_REQUEST['write_downloads'] ) ) return; // Exit

    $count = intval( $_REQUEST['processed_count'] );

    printf( '<div id="message" class="updated fade"><p>' .
        _n( 'Processed %s Order for downloads.',
        'Processed %s Orders for downloads.',
        $count,
        'write_downloads'
    ) . '</p></div>', $count );
}

代码进入活动子主题(或活动主题)的function.php文件。经过测试并正常工作。

enter image description here

enter image description here

在返回的网址中,我有类似的内容(对于2个选定/已处理的订单): wp-admin/edit.php?post_type=shop_order&paged=1&write_downloads=1&processed_count=2&processed_ids=847%2C846

我无法测试您添加的脚本,但它是在Woocommerce订单管理列表中执行此操作的方法。

<强>变量:

可见变量由add_query_arg()函数设置,如您所见。触发操作后,您可以通过GET方法在URL中获取这些变量...

您也可以自己设置任何变量......

在此示例中,您可以使用$_GET$_REQUEST

  • $_GET['write_downloads'] 名称操作truefalse
  • $_GET['processed_count'] 所选订单数量
  • $_GET['processed_ids'] 订单ID 由网址编码的昏迷%2C隔开)
  

所以你可以执行你的脚本:

     
      
  • 内部我的代码功能(就像在我的代码中一样)......或者......
  •   
  • 之外,触发操作后使用可用变量...
  •   

从下拉订单批量操作中删除特定操作

例如,我们要删除&#34;暂停&#34; 状态更改:

add_filter( 'bulk_actions-edit-shop_order', 'remove_a_bulk_order_action', 20, 1 );
function remove_a_bulk_order_action( $actions ) {
    unset($actions['mark_on-hold']);

    return $actions;
}
  

所有状态更改键都以mark_ +状态段(不带wc-开头。