在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()
)
}
}
点击按钮时会触发此功能......
我想从管理订单列表批量选择功能中启用类似的功能。因此,店铺经理在管理订单列表(参见下面的屏幕截图)上选择的订单将被发送到类似的自定义脚本,然后下载。
在这种情况下,所选订单将覆盖订单检索中的指定日期(如果有)。
但是,我找不到要访问的变量,告诉我管理员用户当时选择了哪些订单。
任何帮助将不胜感激......
答案 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文件。经过测试并正常工作。
在返回的网址中,我有类似的内容(对于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']
(名称操作:true
或false
) $_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-
)开头。