Categories

Saturday, January 4, 2025
#919814419350 therichposts@gmail.com
DokanmultivendorWoocommerce

Validate fields in the product upload section of the Dokan multi-vendor dashboard

Validate fields in the product upload section of the Dokan multi-vendor dashboard

Hello guys how are you? Welcome back to my blog therichpost.com. Guys today in this post, we will Validate fields in the product upload section of the Dokan multi-vendor dashboard.

Guys if you are new in WordPress or in WooCommerce then please check the below links for some good tutorials:

  1. WooCommerce Hooks
  2. WordPress Tricks
  3. WordPress Hooks
  4. Dokan

Guys to validate fields in the product upload section of the Dokan multi-vendor dashboard, you can use JavaScript/jQuery for frontend validation and hooks for server-side validation.

Frontend Validation:

Add custom JavaScript/jQuery to validate fields before submission.

  1. Locate or Enqueue Your Script
    Guys add the script to your theme’s functions.php or enqueue it properly:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
function custom_dokan_product_validation_scripts() {
if ( function_exists( 'dokan_is_seller_dashboard' ) && dokan_is_seller_dashboard() ) {
wp_enqueue_script( 'custom-dokan-validation', get_template_directory_uri() . '/js/custom-dokan-validation.js', array( 'jquery' ), '1.0', true );
}
}
add_action( 'wp_enqueue_scripts', 'custom_dokan_product_validation_scripts' );
function custom_dokan_product_validation_scripts() { if ( function_exists( 'dokan_is_seller_dashboard' ) && dokan_is_seller_dashboard() ) { wp_enqueue_script( 'custom-dokan-validation', get_template_directory_uri() . '/js/custom-dokan-validation.js', array( 'jquery' ), '1.0', true ); } } add_action( 'wp_enqueue_scripts', 'custom_dokan_product_validation_scripts' );
   function custom_dokan_product_validation_scripts() {
       if ( function_exists( 'dokan_is_seller_dashboard' ) && dokan_is_seller_dashboard() ) {
           wp_enqueue_script( 'custom-dokan-validation', get_template_directory_uri() . '/js/custom-dokan-validation.js', array( 'jquery' ), '1.0', true );
       }
   }
   add_action( 'wp_enqueue_scripts', 'custom_dokan_product_validation_scripts' );
  1. Create the Script (custom-dokan-validation.js):
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
jQuery(document).ready(function ($) {
$('#dokan-product-form').on('submit', function (e) {
let hasError = false;
// Example: Validate Product Title
const productTitle = $('#post_title').val();
if (!productTitle || productTitle.length < 5) {
alert('Product title must be at least 5 characters long.');
hasError = true;
}
// Example: Validate Price
const price = $('#_regular_price').val();
if (!price || isNaN(price) || price <= 0) {
alert('Please enter a valid price.');
hasError = true;
}
// Prevent form submission if there are errors
if (hasError) {
e.preventDefault();
}
});
});
jQuery(document).ready(function ($) { $('#dokan-product-form').on('submit', function (e) { let hasError = false; // Example: Validate Product Title const productTitle = $('#post_title').val(); if (!productTitle || productTitle.length < 5) { alert('Product title must be at least 5 characters long.'); hasError = true; } // Example: Validate Price const price = $('#_regular_price').val(); if (!price || isNaN(price) || price <= 0) { alert('Please enter a valid price.'); hasError = true; } // Prevent form submission if there are errors if (hasError) { e.preventDefault(); } }); });
   jQuery(document).ready(function ($) {
       $('#dokan-product-form').on('submit', function (e) {
           let hasError = false;

           // Example: Validate Product Title
           const productTitle = $('#post_title').val();
           if (!productTitle || productTitle.length < 5) {
               alert('Product title must be at least 5 characters long.');
               hasError = true;
           }

           // Example: Validate Price
           const price = $('#_regular_price').val();
           if (!price || isNaN(price) || price <= 0) {
               alert('Please enter a valid price.');
               hasError = true;
           }

           // Prevent form submission if there are errors
           if (hasError) {
               e.preventDefault();
           }
       });
   });

In this example, #post_title is the field ID for the product title, and #_regular_price is for the regular price. Adjust the selectors based on your form.


Server-Side Validation:

Dokan allows server-side validation using hooks like dokan_new_product_added.

  1. Guys Validate During Product Creation: Add this to your functions.php file:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
function custom_dokan_validate_product_fields( $post_id, $postdata ) {
if ( empty( $postdata['post_title'] ) || strlen( $postdata['post_title'] ) < 5 ) {
wp_die( 'Product title must be at least 5 characters long.' );
}
if ( empty( $postdata['_regular_price'] ) || !is_numeric( $postdata['_regular_price'] ) || $postdata['_regular_price'] <= 0 ) {
wp_die( 'Please enter a valid price.' );
}
}
add_action( 'dokan_new_product_added', 'custom_dokan_validate_product_fields', 10, 2 );
function custom_dokan_validate_product_fields( $post_id, $postdata ) { if ( empty( $postdata['post_title'] ) || strlen( $postdata['post_title'] ) < 5 ) { wp_die( 'Product title must be at least 5 characters long.' ); } if ( empty( $postdata['_regular_price'] ) || !is_numeric( $postdata['_regular_price'] ) || $postdata['_regular_price'] <= 0 ) { wp_die( 'Please enter a valid price.' ); } } add_action( 'dokan_new_product_added', 'custom_dokan_validate_product_fields', 10, 2 );
   function custom_dokan_validate_product_fields( $post_id, $postdata ) {
       if ( empty( $postdata['post_title'] ) || strlen( $postdata['post_title'] ) < 5 ) {
           wp_die( 'Product title must be at least 5 characters long.' );
       }

       if ( empty( $postdata['_regular_price'] ) || !is_numeric( $postdata['_regular_price'] ) || $postdata['_regular_price'] <= 0 ) {
           wp_die( 'Please enter a valid price.' );
       }
   }
   add_action( 'dokan_new_product_added', 'custom_dokan_validate_product_fields', 10, 2 );
  1. Guys Validate During Product Update: Similar to creation, use the dokan_update_product_post hook:
Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
function custom_dokan_validate_updated_product_fields( $post_id, $postdata ) {
if ( empty( $postdata['post_title'] ) || strlen( $postdata['post_title'] ) < 5 ) {
wp_die( 'Product title must be at least 5 characters long.' );
}
if ( empty( $postdata['_regular_price'] ) || !is_numeric( $postdata['_regular_price'] ) || $postdata['_regular_price'] <= 0 ) {
wp_die( 'Please enter a valid price.' );
}
}
add_action( 'dokan_update_product_post', 'custom_dokan_validate_updated_product_fields', 10, 2 );
function custom_dokan_validate_updated_product_fields( $post_id, $postdata ) { if ( empty( $postdata['post_title'] ) || strlen( $postdata['post_title'] ) < 5 ) { wp_die( 'Product title must be at least 5 characters long.' ); } if ( empty( $postdata['_regular_price'] ) || !is_numeric( $postdata['_regular_price'] ) || $postdata['_regular_price'] <= 0 ) { wp_die( 'Please enter a valid price.' ); } } add_action( 'dokan_update_product_post', 'custom_dokan_validate_updated_product_fields', 10, 2 );
   function custom_dokan_validate_updated_product_fields( $post_id, $postdata ) {
       if ( empty( $postdata['post_title'] ) || strlen( $postdata['post_title'] ) < 5 ) {
           wp_die( 'Product title must be at least 5 characters long.' );
       }

       if ( empty( $postdata['_regular_price'] ) || !is_numeric( $postdata['_regular_price'] ) || $postdata['_regular_price'] <= 0 ) {
           wp_die( 'Please enter a valid price.' );
       }
   }
   add_action( 'dokan_update_product_post', 'custom_dokan_validate_updated_product_fields', 10, 2 );

Testing

  1. Add a product as a vendor.
  2. Test with invalid data (e.g., leave the product title blank or set the price to 0).
  3. Ensure validation works both client-side and server-side.

Would you like additional help with specific validation rules or enhancing the UI for error messages? ????

Guys if you will have any kind of query then feel free to comment below.

Thanks

Jassa

therichpost
the authortherichpost
Hello to all. Welcome to therichpost.com. Myself Ajay Malhotra and I am freelance full stack developer. I love coding. I know WordPress, Core php, Angularjs, Angular 19, MedusaJs, Next.js, Bootstrap 5, Nodejs, Laravel, Codeigniter, Shopify, Squarespace, jQuery, Google Map Api, Vuejs, Reactjs, Big commerce etc.

Leave a Reply

This site uses Akismet to reduce spam. Learn how your comment data is processed.