Checkout Files Upload for WooCommerce
Checkout Files Upload for WooCommerce
Description
Checkout Files Upload for WooCommerce plugin lets your customers upload files on (or after) WooCommerce checkout.
Features
Set field’s position on WooCommerce checkout page:
- Before checkout form.
- After checkout form.
- Do not add on checkout.
Set if file upload is required.
If you need files to be uploaded after order is created, you can optionally add field to:
- WooCommerce Thank You (i.e. Order Received) page.
- WooCommerce My Account page.
Add custom label to the field.
Set accepted file types.
Set custom Upload and Remove button labels.
Set custom messages:
- “Wrong file type”.
- “Wrong image dimensions” and “Couldn’t get image dimensions”.
- “File is required”.
- “File was successfully uploaded”.
- “No file selected”.
- “File was successfully removed”.
Optionally set field to show up only if in cart there are selected:
- Products.
- Product categories.
- Product tags.
Add uploaded files to admin and customers emails.
Send additional emails if user uploads or removes files on “Thank You” or “My Account” pages.
Customize the frontend files upload form.
Optionally enable AJAX form for file uploads.
Set max file size option.
Optionally validate image dimensions.
Feedback
- We are open to your suggestions and feedback. Thank you for using or trying out one of our plugins!
- Drop us a line at www.wpwham.com.
More
Installation
- Upload the entire plugin folder to the
/wp-content/plugins/directory. - Activate the plugin through the “Plugins” menu in WordPress.
- Start by visiting plugin settings at “WooCommerce > Settings > Checkout Files Upload”.
Reviews
upload One image Only!
By neocopia on July 2, 2025
Sure the free version works for One image upload Only! Then you have to buy the Por version. Easy enough to use, could do with some better options within the layout
Ok but doesnt work properly with Divi
By rafaelzrt on January 29, 2025
Simple to configure. Doesn't have a good support to Divi, it needs some custom adjustments to work with Divi Woocommerce Modules.
Awful customer support
By varange on January 4, 2024
They still haven't updated this plugin to be HPOS compatible, although it is a simple thing to do. Asking them to do anything, even in exchange for payment, is futile.
I think at this stage that I'll get my own plugin programmed if they don't update within the next month.
Shame on you!
Exactly What I Needed!
By diamondartdotlove on May 10, 2023
This plugin was ridiculously east to install and setup, and it is exactly what I was looking for - a file upload for a custom product at checkout. And the Free version is fully functional! WOOT!
Works, just as expected!
By ositaka on April 28, 2021
This is the BEST plugin of its kind on the market, hands down
By renisauria on April 1, 2021
Just what I was looking for
By quuuit on March 15, 2021
Attachment not showing
By manindner on August 26, 2020
saved my day 😀
By Akash Shingha Bappy (akashshingha850) on February 28, 2020
Image Dimensions
By Ethan5150 on February 14, 2020
Changelog
2.2.2 – 2025-04-24
- FIX: add filter ‘wpwham_checkout_files_upload_validate_file_type’.
2.2.1 – 2025-04-24
- FIX: “file required” not working if uploader placed outside of main checkout form via shortcode (#89416).
- FIX: PHP notice.
- FIX: escape text in translation shortcodes.
2.2.0 – 2024-08-28
- NEW: add shortcode ‘wpwham_checkout_files_uploader’.
- FIX: issue with uploads sometimes not being processed.
- FIX: issue with metabox not displaying on admin Order page when “HPOS” enabled.
2.1.5 – 2023-07-13
- FIX: PHP 8.2 notices.
2.1.4 – 2022-06-02
- FIX: add nonce checks to AJAX actions.
- UPDATE: updated .pot file for translations.
2.1.3 – 2022-05-10
- FIX: escape filenames on order confirmation/thank you pages.
2.1.2 – 2021-12-23
- FIX: minor display bug in settings due to WooCommerce update.
2.1.1 – 2021-09-16
- UPDATE: PHP 8 now officially supported.
- UPDATE: updated .pot file for translations.
2.1.0 – 2021-04-15
- NEW: added more options to “validate image dimensions” setting: “greater than or equal”, and “less than or equal”.
- NEW: added button to delete file attachments on admin “edit order” page. (If you don’t want the ability to delete files, you can use the filter
wpwham_checkout_files_upload_allow_admin_delete_filesto disable it). - FIX: check if server’s temporary directory is writeable. If not, display an error message. (Solves an issue with 0-byte files being uploaded).
- FIX: bug where sometimes 0-byte files were attached to order emails.
- UPDATE: for text labels/notices, made it possible for a translated string to take precedence over stored settings. (Previously it was the other way around. This should now make things easier if you use a translation plugin like LocoTranslate, Polylang, etc).
- UPDATE: performance improvement — load our admin assets only when needed.
- UPDATE: updated .pot file for translations.
2.0.4 – 2021-01-12
- FIX: clean output buffer before downloads (solves conflict with some 3rd-party plugins which interfere with the output buffer, causing downloads to appear as empty or corrupt).
2.0.3 – 2020-09-17
- UPDATE: display our settings in WC status report.
2.0.2 – 2020-08-21
- FIX: upload button translation issue (removed old label settings, added new ones).
- UPDATE: updated .pot file for translations.
2.0.1 – 2020-06-17
- FIX: issue with upload button not working in certain themes.
- FIX: user permissions issue incorrectly preventing downloading of images from the WP admin side.
- FIX: JS typo.
2.0.0 – 2020-06-11
- NEW: Breaking Change the
Form (simple)template has been removed, andForm (AJAX)is now the standard template.Form (AJAX)has been the default since v1.4.0 (2018-08-25), so for most people this change will have no effect. However, if you were usingForm (simple), or if you had customized either template, please double check your settings to make sure things look correct. Or, you can reset the settings to get a fresh start. - NEW: Breaking Change in template settings, the variable
%field_html%which previously contained BOTH the field html AND the upload button itself, has been split into separate variables%field_html%and%button_html%. Your template settings will be updated automatically to reflect this. - NEW: image thumbnails will be shown by default. The image feature has existed since v1.4.0 (2018-08-25), but some people didn’t realize this and/or didn’t know they needed to add
%image%into the template to enable it. Now%image%is included in the template by default. If you don’t want this, simply edit your template settings and remove the%image%variable. - NEW: show spinner when processing, and prevent checkout form submission before upload is completed.
- UPDATE: change the way we handle sessions — only start them when needed, not on every page load.
- UPDATE: extensive code refactoring.
- UPDATE: updated some styling and text. For example, progress bars (if enabled) are now green.
- UPDATE: updated .pot file for translations.
1.5.4 – 2020-01-14
- UPDATE: add new filters ‘wpw_checkout_files_upload_form_html’ and ‘wpw_checkout_files_upload_form_ajax_html’.
- UPDATE: wrap checkout page file upload controls in
<
div>.
1.5.3 – 2019-11-22
- UPDATE: bump tested versions
1.5.2 – 2019-11-15
- UPDATE: bump tested versions
1.5.1 – 2019-09-12
- UPDATE: bump tested upto versions
1.5.0 – 2018-10-08
- FIX: php notice
- UPDATE: updated .pot file for translations
1.4.5 – 2018-10-01
- Dev –
[alg_wc_cfu_translate]shortcode added anddo_shortcode()is now applied to each file’s “Labels”.
1.4.4 – 2018-09-13
- Dev – Emails – “Additional Emails Options” subsection added.
- Dev – “Raw” input is now allowed in all textarea admin settings fields.
- Dev – Code refactoring – “Reset” function re-written.
- Dev – Code refactoring –
custom_number_checkout_files_uploadsettings type removed. - Dev – “Your settings have been saved” admin notice added.
1.4.3 – 2018-09-10
- Dev – “Author URI” updated.
1.4.2 – 2018-09-10
- Dev – “Contributors” updated.
1.4.1 – 2018-08-27
- Fix –
%image%in AJAX form fixed on “Thank you” and “My Account” pages. - Dev – “Validate image dimensions” options added for each file.
- Dev – Minor code refactoring.
- Dev – Minor admin settings restyling.
1.4.0 – 2018-08-25
- Fix – User file download fixed on “Thank you” and “My Account” pages.
- Dev –
%image%replaced value added. - Dev – “AJAX form” now is enabled (
yes) in settings by default. - Dev – Code refactoring.
- Dev – Minor admin settings restyling.
- Dev – Plugin URI updated.
1.3.0 – 2018-06-09
- Fix – Case insensitive comparison of the “Accepted file types” options.
- Fix – Default values fixed for all
get_option()calls. - Dev – “AJAX form” options added.
- Dev – “Max file size” options added.
- Dev – Filter rewritten.
- Dev – Admin settings – “Reset settings” section added.
- Dev – Admin settings – Files settings added as separate sections.
- Dev – Admin settings – Minor changes: restyling;
selectoption type changed towc-enhanced-select; settings array saved as main class property.
1.2.0 – 2017-05-10
- Fix –
Call to undefined function is_shop_manager()error fixed. - Dev – WooCommerce v3.x.x compatibility – Order ID – using function instead of accessing property directly.
- Dev –
load_plugin_textdomainmoved to constructor frominithook. - Dev – Plugin link changed from
http://coder.fmtohttps://wpcodefactory.com.
1.1.1 – 2016-12-07
- Dev –
alg_current_filter_priority()modified for compatibility with WordPress since v4.7. - Dev – Language (POT) file updated.
- Dev – Checking for Pro modified.
1.1.0 – 2016-11-28
- Dev – “Form Template Options” settings section added.
- Dev – Language (POT) file added.
- Dev – “Emails Options” settings moved to separate section.
1.0.0 – 2016-09-05
- Initial Release.