• We have the pro version of the plugin and have custom order status that we want to change the orders to, but when the plugin runs, it changes the orders to wc-on-hold.

    We have a rule (3 different ones), that change order status from wc-processing to custom state wc-momy-jom, but it doesn’t work properly.

    The order goes from wc-on-hold (?eká na platbu) to wc-processing (zpracovává se) from where it goes back to wc-on-hold as seen in the screenshot.

    We have a comgate gateway plugin that later changes the order to wc-cancelled because it doesn’t expect it to be in wc-on-hold.

    When I manually change the order status to wc-processing (as seen in the last newest entry in the order status history), it properly changes the status to wc-momy-jom (Mómy jóm).

    What might be the problem? I saw this problem on the plugin website and shortened the custom statuses, made them public, but nothing worked.

    The status is effectively registered as:

    register_post_status( 'wc-momy-jom', [
     'label' => 'Mómy jóm',
     'public' => true,
     'exclude_from_search'       => false,
     'show_in_admin_all_list'    => true,				'show_in_admin_status_list' => true,
    'label_count'               => _n_noop( 'Mómy jóm <span class="count">(%s)</span>', 'Mómy jóm <span class="count">(%s)</span>', 'xxx' ),
    ] );
    • This topic was modified 1 year, 5 months ago by mlykotom.
Viewing 11 replies - 1 through 11 (of 11 total)
  • Hi @mlykotom,

    Sorry for the late reply regarding the issue.

    I have escalated this with our development team. They will get back to you as soon as they can.

    Kind regards,
    Moshtafizur

    Plugin Author Algoritmika

    (@algoritmika)

    Hi, @mlykotom,

    Could you please let me know where did you put your register_post_status() code? Is it in your child theme’s functions.php file? Is it called directly there, or is it hooked to some action, e.g., init?

    Also, can I check the comgate gateway plugin code somewhere?

    Thread Starter mlykotom

    (@mlykotom)

    It was part of the init function as part of custom plugin that registers the post.

    I changed now the hook to woocommerce_register_shop_order_post_statuses that is where Woocommerce registers its own statuses ( I haven’t tested it yet ).

    Unfortunately it’s a paid plugin, so the code is not publicly available
    (this is the website https://toret.cz/produkt/woo-comgate/ ) .. I guess I could privately share the code, just for testing.

    But I actually don’t think it’s a problem with this plugin.
    I think the cycle happens because order status rules change it to wc-on-hold and then comgate plugin changes is again to wc-processing.

    Plugin Author Algoritmika

    (@algoritmika)

    Hi, @mlykotom,

    I guess I could privately share the code, just for testing.

    Yes, I think checking the code will help. If possible, please send it to [email protected].

    P.S. You’ve set the rule’s “Time trigger” option to “0”, right?

    Thread Starter mlykotom

    (@mlykotom)

    I’ve sent an email to the mentioned url.

    I had time trigger set to 0, or even not to 0 — it didn’t make a difference I think.

    Plugin Author Algoritmika

    (@algoritmika)

    Hi, @mlykotom,

    I’ve checked the code. Could you please try adding this PHP snippet to your site, and let me know if it helps:

    /**
     * Order Status Rules for WooCommerce
     *
     * "Toret Comgate" plugin compatibility.
     *
     * @see https://wpfactory.com/item/order-status-rules-for-woocommerce/
     * @see https://www.ads-software.com/support/topic/order-status-changed-to-on-hold/
     * @see https://toret.cz/produkt/woo-comgate/
     */
    add_action( 'template_redirect', function () {
    
        /**
         * Check for the comgate var.
         *
         * @see woo-comgate/woo-comgate.php
         */
        global $wp_query;
        if ( ! isset( $wp_query->query_vars['comgate'] ) ) {
            return;
        }
    
        /**
         * Get order ID.
         *
         * @see woo-comgate/includes/views/notify.php
         */
        $order_id = apply_filters( 'toret_comgate_custom_id', ( isset( $_POST['refId'] ) ? $_POST['refId'] : false ) );
        $order_id = apply_filters( 'toret-sequential-order-id', $order_id );
        if ( function_exists( 'wc_sequential_order_numbers' ) ) {
            $order_id = wc_sequential_order_numbers()->find_order_by_order_number( $order_id );
        } elseif ( function_exists( 'wc_seq_order_number_pro' ) ) {
            $order_id = wc_seq_order_number_pro()->find_order_by_order_number( $order_id );
        } elseif ( function_exists( 'get_order_id_from_order_number' ) ) {
            $order_id = get_order_id_from_order_number( $order_id );
        }
        if ( ! $order_id ) {
            return;
        }
    
        /**
         * Process rules for the order.
         */
        if ( function_exists( 'alg_wc_order_status_rules' ) ) {
            alg_wc_order_status_rules()->core->process_rules_for_order( $order_id );
        }
    
    }, 9 );
    Thread Starter mlykotom

    (@mlykotom)

    Ok, added. Let’s wait if it happens.

    Interesting part is that when I manually change the order status from admin, it changes correctly to the required state.

    Also, maybe worth noting, we have custom order number, because of migration we did in past. But that’s 2 months ago, and the problem occurs with new orders.

    add_filter( 'woocommerce_order_number', [ $this, 'order_number_meta' ] );
    
    function order_number_meta( $original ) {
    	$order_number = get_post_meta( $original, '_order_number', true );
    
    	if ( $order_number ) {
    		return $order_number;
    	}
    
    	return $original;
    }

    + one more thing to note, we already have some template_redirect hook. Just for some low-level redirects

    		add_action( 'template_redirect', function () {
    			global $wp_query;
    
    			if ( ! isset( $wp_query ) ) {
    				return;
    			}
    
    			// TODO 29.03.2023 multilang!
    
    			if ( isset( $wp_query->query['name'] ) ) {
    				switch ( $wp_query->query['name'] ) {
    					case'prihlasit-k-odberu':
    						wp_redirect( '/?prihlasit-k-odberu' );
    						break;
    
    					case'kabelky':
    						wp_redirect( '/produkty' );
    						break;
    				}
    			} else if ( isset( $wp_query->query['product_cat'] ) && $wp_query->query['product_cat'] == 'kabelky' ) {
    				wp_redirect( '/kategorie/kabelky-na-miru' );
    			}
    		} );

    Plugin Author Algoritmika

    (@algoritmika)

    Hi, @mlykotom,

    Ok, added. Let’s wait if it happens.

    Great, please let me know if the snippet helped.

    Interesting part is that when I manually change the order status from admin, it changes correctly to the required state.

    I’m guessing the “Comgate” plugin doesn’t manage to interfere with our status update in admin.

    Also, maybe worth noting, we have custom order number, because of migration we did in past. But that’s 2 months ago, and the problem occurs with new orders.

    No, I don’t think custom order number could be an issue here.

    + one more thing to note, we already have some?template_redirect?hook. Just for some low-level redirects

    Again, I don’t think this will be an issue. Also, in my snippet we are using priority 9, and in your snippet you are using the default priority 10, so my snippet will run earlier.

    Thread Starter mlykotom

    (@mlykotom)

    Unfortunately it didn’t help ??

    Today we got an order with the same problem.

    
    Nr.	Time	From	To
    6	3 ?ervence, 2023 10:53 pm	Zru?ena	Zpracovává se
    5	3 ?ervence, 2023 7:30 pm	?eká na platbu	Zru?ena
    4	3 ?ervence, 2023 6:14 pm	Zpracovává se	?eká na platbu
    3	3 ?ervence, 2023 6:14 pm	?eká na platbu	Zpracovává se
    2	3 ?ervence, 2023 6:13 pm	Zpracovává se	?eká na platbu
    1	3 ?ervence, 2023 6:13 pm	?eká na platbu	Zpracovává se

    Interesting part is that when I manually change the order status from admin, it changes correctly to the required state.

    I’m guessing the “Comgate” plugin doesn’t manage to interfere with our status update in admin.

    When manually selecting the processing state, the order status rules works properly. ??

    Thread Starter mlykotom

    (@mlykotom)

    Can I help in any way with resolving this? It’s really problematic that orders are moved into wrong status because of this issue ??

    Hi @mlykotom,

    I am sorry to know that you are still having the issue.

    I have escalated this with our development team. They will get back to you as soon as they can.

    Kind regards,
    Moshtafizur

Viewing 11 replies - 1 through 11 (of 11 total)
  • The topic ‘Order status changed to ON-HOLD’ is closed to new replies.