Search code examples
phpwordpresswoocommercehook-woocommerceorders

Additional action buttons to admin order list on Preview Lightbox in Woocommerce 3.3+


In Woocommerce Admin orders list, when clicking the icon "eye" enter image description here, it opens a preview of the order in a Lightbox. At the bottom of that Lightbox (preview), there are some actions buttons that allow to change the order status.

I have 5 more custom order statuses that I would like to add as action buttons too, but I don't know which hook I need to use.

Does anyone know how to add more buttons to that area?

Any help or advice is appreciated.


Solution

  • The correct hook to get this done is woocommerce_admin_order_preview_actions filter hook.

    You will need to define in the function below in a multidimensional array your custom order statuses data, one by one as follow, to get an action button for each:

    • The status slug (without starting with "wc-") as a key
    • The status label name
    • The allowed statuses array slugs (to display the current status action button for)

    The example code (here for 2 custom fake statuses "Custom One" and "Custom two"):

    add_filter( 'woocommerce_admin_order_preview_actions', 'additional_admin_order_preview_buttons_actions', 25, 2 );
    function additional_admin_order_preview_buttons_actions( $actions, $order ){
        // Below set your custom order statuses (key / label / allowed statuses) that needs a button
        $custom_statuses = array(
            'custom_one' => array( // The key (slug without "wc-")
                'label'     => __("Custom One", "woocommerce"), // Label name
                'allowed'   => array( 'pending', 'on-hold', 'processing', 'custom_two' ), // Button displayed for this statuses (slugs without "wc-")
            ),
            'custom_two' => array( // The key (slug without "wc-")
                'label'     => __("Custom Two", "woocommerce"), // Label name
                'allowed'   => array( 'pending', 'on-hold', 'processing', 'custom_one' ), // Button displayed for this statuses (slugs without "wc-")
            ),
        );
    
        // Loop through your custom orders Statuses
        foreach ( $custom_statuses as $status_slug => $values ){
            if ( $order->has_status( $values['allowed'] ) ) {
                $actions['status']['actions'][$status_slug] = array(
                    'url'    => wp_nonce_url( admin_url( 'admin-ajax.php?action=woocommerce_mark_order_status&status='.$status_slug.'&order_id=' . $order->get_id() ), 'woocommerce-mark-order-status' ),
                    'name'   => $values['label'],
                    'title'  => __( 'Change order status to', 'woocommerce' ) . ' ' . strtolower($values['label']),
                    'action' => $status_slug,
                );
            }
        }
        return $actions;
    }
    

    Code goes in function.php file of your active child theme (active theme). Tested and works.

    enter image description here