AdminTaxRatesResource
This class is used to send requests to Admin Tax Rate API Routes. All its method
are available in the JS Client under the medusa.admin.taxRates
property.
All methods in this class require user authentication.
Each region has at least a default tax rate. Admins can create and manage additional tax rates that can be applied for certain conditions, such as for specific product types.
Related Guide: How to manage tax rates.
Methods
addProductTypes
Add product types to a tax rate.
Example
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.taxRates
.addProductTypes(taxRateId, {
product_types: [productTypeId],
})
.then(({ tax_rate }) => {
console.log(tax_rate.id)
})
Parameters
id
stringRequiredThe product types to add to the tax rate.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
addProducts
Add products to a tax rate.
Example
Parameters
id
stringRequiredThe products to add to the tax rate.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
addShippingOptions
Add shipping options to a tax rate.
Example
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.taxRates
.addShippingOptions(taxRateId, {
shipping_options: [shippingOptionId],
})
.then(({ tax_rate }) => {
console.log(tax_rate.id)
})
Parameters
id
stringRequiredThe shipping options to add to the tax rate.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
create
Create a tax rate.
Example
Parameters
The tax rate to create.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
delete
Delete a tax rate. Resources associated with the tax rate, such as products or product types, are not deleted.
Example
Parameters
id
stringRequiredcustomHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the deletion operation's details.
list
Retrieve a list of tax rates. The tax rates can be filtered by fields such as name
or rate
passed in the query
parameter. The tax rates can also be paginated.
Example
To list tax rates:
To specify relations that should be retrieved within the tax rates:
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.taxRates
.list({
expand: "shipping_options",
})
.then(({ tax_rates, limit, offset, count }) => {
console.log(tax_rates.length)
})
By default, only the first 50
records are retrieved. You can control pagination by specifying the limit
and offset
properties:
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.taxRates
.list({
expand: "shipping_options",
limit,
offset,
})
.then(({ tax_rates, limit, offset, count }) => {
console.log(tax_rates.length)
})
Parameters
Filters and pagination configurations applied to the retrieved tax rates.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the list of tax rates with pagination fields.
removeProductTypes
Remove product types from a tax rate. This only removes the association between the product types and the tax rate. It does not delete the product types.
Example
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.taxRates
.removeProductTypes(taxRateId, {
product_types: [productTypeId],
})
.then(({ tax_rate }) => {
console.log(tax_rate.id)
})
Parameters
id
stringRequiredThe product types to remove from the tax rate.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
removeProducts
Remove products from a tax rate. This only removes the association between the products and the tax rate. It does not delete the products.
Example
Parameters
id
stringRequiredThe products to remove from the tax rate.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
removeShippingOptions
Remove shipping options from a tax rate. This only removes the association between the shipping options and the tax rate. It does not delete the shipping options.
Example
import Medusa from "@medusajs/medusa-js"
const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
// must be previously logged in or use api token
medusa.admin.taxRates
.removeShippingOptions(taxRateId, {
shipping_options: [shippingOptionId],
})
.then(({ tax_rate }) => {
console.log(tax_rate.id)
})
Parameters
id
stringRequiredThe shipping options to remove from the tax rate.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
retrieve
Retrieve a tax rate's details.
Example
A simple example that retrieves a tax rate by its ID:
To specify relations that should be retrieved:
Parameters
id
stringRequiredConfigurations to apply on retrieved tax rates.
customHeaders
Record<string, any>RequiredDefault: {}
Returns
Resolves to the tax rate's details.
update
Update a tax rate's details.
Example
Parameters
id
stringRequiredThe attributes to update in the tax rate.
Configurations to apply on the retrieved tax rate.
customHeaders
Record<string, any>RequiredDefault: {}