WooPayments’ multi-currency feature lets you to show product prices to customers in various currencies. It also allows your customers to select their preferred currency from a list you define and then purchase their goods in that currency.
This document shows how you can configure multi-currency settings, the various places where multiple currencies are used, and answers some common questions.
For a list of all the currencies that WooPayments supports, see this page.
NOTE: Enabling multi-currency only changes how prices are shown to your customers. It does not mean you can accept payouts in multiple currencies. See our payout currencies document for more information on doing that.
Enabling multi-currency
↑ Back to topTo enable the multi-currency feature, if it’s not already:
- Go to Payments > Settings in your WordPress dashboard.
- Scroll down to the bottom and click on Advanced settings.
- Check the Enable Multi-Currency box.
- Click Save changes at the bottom.
Configuring multi-currency
↑ Back to topOnce WooPayments multi-currency has been enabled, a tab for it’s settings will be added to the WooCommerce > Settings page.
Initially, the Enabled currencies list will only show your default store currency.
Enabled currencies
↑ Back to topClicking the Add/remove currencies button will show a list of supported currencies.
From this list, you can select all the currencies that you want to allow your customers to view prices in. After selecting any additional currencies you’d like to add to your store, click Update selected to save that list. Afterward, the Enabled currencies list will reflect those changes.
Currencies can also be removed by unchecking them and click Update selected.
Store settings
↑ Back to topBelow the enabled currencies list will be some options relating to how customer currencies can be switched from one to another.
Automatically switching currencies
Checking the Automatically switch customers to their local currency box will attempt to geolocate your customers when they visit your site — regardless of the “Default customer location” setting under WooCommerce > Settings > General. If your customer is in a country where their currency has been enabled, pricing will automatically change to be in that currency.
NOTE: Geolocation is not always 100% accurate and can be incorrect due to customer use of VPNs and other such factors.
Add a currency switcher
If you have our Storefront theme active, you’ll see a second option: Add a currency switcher to the Storefront theme. Enabling this setting will put a small currency switcher widget in the breadcrumbs section of Storefront, or any child theme of Storefront.
Managing currencies
↑ Back to topYou can manage individual currencies in the Enabled currencies list by clicking the Manage link next to the one you want to manage settings for.
Exchange rate
↑ Back to topBy default, exchange rates are regularly retrieved from the WooPayments server. The last update time shown under the Fetch rates automatically option.
If needed, you can force WooPayments to pull fresh exchange rates by temporarily switching your WooCommerce store currency (under WooCommerce > Settings > General), and then switching it back to the original setting.
NOTE: Exchange rates are not accurate to the minute and may differ slightly from historical exchange rate listings on third-party services.
If you wish, you can also switch to a manually-defined exchange rate. If and while set, these will be used at all times and not automatically updated.
Price rounding
↑ Back to topSetting Price rounding to anything besides “None” will round up a product’s converted price to the nearest amount selected. Selecting “None” rounds converted prices to the nearest number of decimal places conventionally used for that currency.
In other words, “None” provides the most exact product price conversion, but this is likely to result in odd-looking prices. For this reason, most currencies default to 1.00
, while zero-decimal currencies (e.g. JPY) default to 100
.
As an example, if a product price in the default currency is converted to 5.134863
, the price rounding setting would work as shown below.
Price Rounding | Resulting Price |
---|---|
None | 5.13 |
0.25 | 5.25 |
0.50 | 5.50 |
1.00 | 6.00 |
5.00 | 10.00 |
10.00 | 10.00 |
NOTE: Price rounding also affects taxes, shipping, and other order fees.
Charm pricing
↑ Back to topCharm pricing (also called psychological pricing) can optionally reduce the converted product price by either 0.01
or 0.05
. For example, if the converted product price is 20.00
, you can use charm pricing to reduce that to either 19.99
or 19.95
.
Charm pricing is set to None by default.
If you’d like to enable charm pricing, we suggest ensuring that price rounding is also enabled. Otherwise, enabling charm pricing will likely not have the intended effect.
NOTE: Charm pricing only affects product prices. To apply charm pricing to shipping, fees, etc. as well, you can use the filter shown here.
Previewing converted prices
↑ Back to topYou can use the Preview section to see how prices in your default currency will be converted to the customer currency that you’re currently editing the settings for. It will use the exchange rate and formatting rules you’ve set above.
Currency switching
↑ Back to topIf you’d like your customers to be able to choose their currency from the frontend of your site and you are not using a theme that supports this by default, you will need to use the currency switcher block or widget.
NOTE: Although our currency switching block and widget should look fine with most themes, you may want to customize them to fit your site’s styles, colors, and so on. Unfortunately, we are unable to help with customizations such as this under our Support Policy. If you need assistance, we suggest engaging with Codeable or a Certified WooExpert for help.
Block
↑ Back to topTo add the currency switcher block, edit any post, page, or (more commonly) widget area. Insert the block wherever it works best for your theme. It’s likely that this will be in a widget area such as a sidebar, header, or footer.
Once the block has been added, your customers can use it to switch the currency on their account quickly.
Widget
↑ Back to topTo add the currency switcher widget, go to Appearance > Widgets and look for the “Currency Switcher” widget and add it to the best location in your theme.
In the widget setting, choose if you want the widget to display currency symbols and flags next to the currency name.
Customer default currency
↑ Back to topLastly, your customers can choose their preferred currency on the My Account > Account Details page.
Refunds and currencies
↑ Back to topIf you refund a currency-converted payment, the amount deducted from your balance is converted to the customer currency using the exchange rate at the time you issued the refund. Since exchange rates can vary over time, the amount deducted from your balance may be more or less than the original payment.
Put another way: the customer will always be refunded the exact amount that they paid and in the currency that they paid in, regardless of any rate fluctuations between the time of the transaction and the time of the refund.
For example, if your payout currency is EUR and you receive a 60 USD order when the exchange rate is 0.88 EUR per 1 USD, the converted amount is 52.80 EUR (excluding fees). If the exchange rate is 0.86 EUR per 1 USD when you refund the order, the amount deducted from your balance is only 51.60 EUR.
Analytics
↑ Back to topAll data in your site’s Analytics menu will be converted into your store’s default currency.
If you want a list of orders placed with a certain currency, you can find that under Analytics > Orders. Use the filter at the top to select the currency you’re interested in.
We’ve also added a Customer currency column to the orders list, though you may need to enable it by clicking the three dots menu in the upper-right of the orders list first.
Support for other themes
↑ Back to topNOTE: This is a developer-level section. If you are unfamiliar with code, templates, and resolving potential conflicts, contact a WooExpert for assistance. We are unable to provide support for customizations under our support policy.
If you are not using the Storefront theme or one of the many child themes based on it, you can add the currency switcher to your theme using the following PHP snippet:
if ( function_exists( 'wc_get_currency_switcher_markup' ) ) {
$instance = [
'symbol' => true,
'flag' => false,
];
$args = [];
echo wc_get_currency_switcher_markup( $instance, $args );
}
$instance
lets you enable or disable the symbol and flags, and $args
accepts the same arguments as WordPress core’s the_widget.