Anforderungen sind einfach:
Format der benutzerdefinierten fortlaufenden Bestellnummer gewünscht: AS-Y-SNr
- AS = Firmenakronym, Y = Bestelljahr, SNo (Generierte fortlaufende Nummer / Index)
Jährliche Zurücksetzung der oben SNo auf 0001, wenn nächstes Jahr, also 2026, beginnt. - Wenn möglich, manchmal auch ein manuelles Zurücksetzen der SNo, z. B. für Testfälle Jetzt. (Ich hatte den Testauftrag einmal ausgeführt und habe daher die AS-2025-0001 – aber im Moment ist es möglicherweise nicht die richtige SNo, da es sich um einen Testauftrag handelt – ich muss dies manuell zurücksetzen – wenn es sich um eine SQL handelt Abfrage in der PHPMyadmin (Datenbank) wird das tun – ich kann es gerne tun, aber ich kenne die SQL-Abfrage dafür nicht.
LoicTheAztecs Codierung mit $country (Legen Sie in WooCommerce eine fortlaufende Bestellnummer mit Land und Jahr fest Präfix)
Code: Select all
// Set and save the order number as metadata
add_filter( 'woocommerce_checkout_create_order', 'save_order_number_metadata' );
function save_order_number_metadata( $order ) {
$prefix = 'AS';
$digits = 4; // Number of desired digits for the number part
$year = date('Y', time()); // Get the current year
$data = get_option('wc_sequential_order_number'); // Get order number sequencial helper registered data
$number = isset($data[$year]) ? intval($data[$year]) + 1 : 1;
$data[$year] = $number;
// Update order number sequencial helper registered data
update_option('wc_sequential_order_number', $data);
// Add order number as custom metadata
$order->add_meta_data('_order_number', sprintf('%s-%s-%s', $prefix, $year, str_pad($number, $digits, '0', STR_PAD_LEFT)), true);
}
// Read the order number from metadata
add_filter( 'woocommerce_order_number', 'define_order_number', 10, 2 );
function define_order_number( $order_id, $order ) {
if ( $order_number = $order->get_meta('_order_number') ) {
$order_id = $order_number;
}
return $order_id;
}
Code: Select all
// Reset if year has changed
$stored_year = get_option($option_name . "_year", -1);
if ($year > $stored_year) {
update_option($option_name, 1);
update_option($option_name . "_year", $year);
}
$current_number = get_option($option_name, 1);
update_option($option_name, $current_number + 1);
Dies ist der Originalcode von @Dishant mit Sprachcodereferenz, den ich nicht benötige :
Code: Select all
//Orders Prefix
add_filter( 'woocommerce_order_number', 'change_woocommerce_order_number' );
function change_woocommerce_order_number( $order_id ) {
$order = wc_get_order( $order_id );
if ( $order && $order->get_date_created() ) {
$language_code = pll_current_language(); // Detect current language
$new_order_id = generate_woo_order_sequence($language_code);
return $new_order_id;
}
return $order_id;
}
// Generate the sequence with language code passed
function generate_woo_order_sequence($language_code) {
$year = date('Y');
$option_name = "wc_custom_series_{$language_code}";
// Reset if year has changed
$stored_year = get_option($option_name . "_year", -1);
if ($year > $stored_year) {
update_option($option_name, 1);
update_option($option_name . "_year", $year);
}
$current_number = get_option($option_name, 1);
update_option($option_name, $current_number + 1);
return strtoupper($language_code) . '-' . $year . '-' . str_pad($current_number, 3, '0', STR_PAD_LEFT);
}
Ursprünglicher Beitrag:
Format der benutzerdefinierten fortlaufenden Bestellnummer gewünscht: AS-Y-SNo
AS = Firmenakronym, Y = Bestelljahr , SNo (Generierte fortlaufende Nummer / Index)
Bitte siehe unten versuchte Codes: (Diese beiden Codes waren nicht vollständig erfolgreich, da einer nur den Präfix-Y-Teil, nicht aber den SNo-Teil anspricht)
Code: Select all
// Adding Prefix and Date
add_filter( 'woocommerce_order_number', 'ts_change_woocommerce_order_number', 1, 2 );
function ts_change_woocommerce_order_number( $order_id ) {
$prefix = 'AS';
$order = wc_get_order( $order_id );
$order_date = $order->get_date_created();
$display_date = $order_date->date('Y'); // Format date as 'y/m/d'
$new_order_id = $prefix . '-' . $display_date . '-' . $order_id; // Add a hyphen between date and order ID
return $new_order_id;
}
Fügen Sie diesen SNo-Generierungscode in einer separaten Code-Snippet-Instanz hinzu:
Code: Select all
// Generate SNo
add_filter( 'woocommerce_checkout_create_order', 'ts_save_order_number_metadata' );
function ts_save_order_number_metadata( $order ) {
$digits = 4; // Number of desired digits for the number part
$data = get_option('wc_sequential_order_number'); // Get order number sequential helper registered data
$number = isset($data['sequential']) ? intval($data['sequential']) + 1 : 1;
$data['sequential'] = $number;
// Update order number sequential helper registered data
update_option('wc_sequential_order_number', $data);
// Add order number as custom metadata
$order->add_meta_data('_order_number', str_pad($number, $digits, '0', STR_PAD_LEFT), true);
}
// Read the order number from metadata
add_filter( 'woocommerce_order_number', 'ts_define_order_number', 10, 2 );
function ts_define_order_number( $order_id, $order ) {
if ( $order_number = $order->get_meta('_order_number') ) {
$order_id = $order_number;
}
return $order_id;
}