Anchor to productOptionsDeleteproduct
productOptionsDelete
mutation
Requires access scope. Also: The user must have a permission to edit products and delete product variants.
Deletes the specified options.
Anchor to Arguments
Arguments
- Anchor to optionsoptions•[ID!]!required
IDs of the options to delete from the product.
- Anchor to productIdproduct•
Id ID!required ID of the product from which to delete the options.
- Anchor to strategystrategy•Product
Option Default:DEFAULTDelete Strategy The strategy defines which behavior the mutation should observe,such as how to handle a situation where deleting an option would result in duplicate variants.
Was this section helpful?
Anchor to ProductOptionsDeletePayload returnsProductOptionsDeletePayload returns
- Anchor to deletedOptionsIdsdeleted•
Options Ids IDs of the options deleted.
- Anchor to productproduct•
The updated product object.
- Anchor to userErrorsuser•
Errors The list of errors that occurred from executing the mutation.
Was this section helpful?
- Delete an option
- Delete an option with the POSITION delete strategy
- Trying to delete an option with multiple option values linked to variants with no option delete strategy returns an error
- productOptionsDelete reference
Examples
const { admin } = await authenticate.admin(request);
const response = await admin.graphql(
`#graphql
mutation deleteOptions($productId: ID!, $options: [ID!]!, $strategy: ProductOptionDeleteStrategy) {
productOptionsDelete(productId: $productId, options: $options, strategy: $strategy) {
userErrors {
field
message
code
}
deletedOptionsIds
product {
id
options {
id
name
values
position
optionValues {
id
name
hasVariants
}
}
}
}
mutation deleteOptions($productId: ID!, $options: [ID!]!, $strategy: ProductOptionDeleteStrategy) {
productOptionsDelete(productId: $productId, options: $options, strategy: $strategy) {
userErrors {
field
message
code
}
deletedOptionsIds
product {
id
options {
id
name
values
position
optionValues {
id
name
hasVariants
}
}
}
}
}
curl -X POST \
https://your-development-store.myshopify.com/admin/api/2024-04/graphql.json \
-H 'Content-Type: application/json' \
-H 'X-Shopify-Access-Token: {access_token}' \
-d '{
"query": "mutation deleteOptions($productId: ID!, $options: [ID!]!, $strategy: ProductOptionDeleteStrategy) { productOptionsDelete(productId: $productId, options: $options, strategy: $strategy) { userErrors { field message code } deletedOptionsIds product { id options { id name values position optionValues { id name hasVariants } } } } }",
"variables": {
"productId": "gid://shopify/Product/20995642",
"options": [
"gid://shopify/ProductOption/1064576514"
]
}
}'
const { admin } = await authenticate.admin(request);
const response = await admin.graphql(
`#graphql
mutation deleteOptions($productId: ID!, $options: [ID!]!, $strategy: ProductOptionDeleteStrategy) {
productOptionsDelete(productId: $productId, options: $options, strategy: $strategy) {
userErrors {
field
message
code
}
deletedOptionsIds
product {
id
options {
id
name
values
position
optionValues {
id
name
hasVariants
}
}
}
}
}`,
{
variables: {
"productId": "gid://shopify/Product/20995642",
"options": [
"gid://shopify/ProductOption/1064576514"
]
},
},
);
const data = await response.json();
const client = new shopify.clients.Graphql({session});
const data = await client.query({
data: {
"query": `mutation deleteOptions($productId: ID!, $options: [ID!]!, $strategy: ProductOptionDeleteStrategy) {
productOptionsDelete(productId: $productId, options: $options, strategy: $strategy) {
userErrors {
field
message
code
}
deletedOptionsIds
product {
id
options {
id
name
values
position
optionValues {
id
name
hasVariants
}
}
}
}
}`,
"variables": {
"productId": "gid://shopify/Product/20995642",
"options": [
"gid://shopify/ProductOption/1064576514"
]
},
},
});
session = ShopifyAPI::Auth::Session.new(
shop: "your-development-store.myshopify.com",
access_token: access_token
)
client = ShopifyAPI::Clients::Graphql::Admin.new(
session: session
)
query = <<~QUERY
mutation deleteOptions($productId: ID!, $options: [ID!]!, $strategy: ProductOptionDeleteStrategy) {
productOptionsDelete(productId: $productId, options: $options, strategy: $strategy) {
userErrors {
field
message
code
}
deletedOptionsIds
product {
id
options {
id
name
values
position
optionValues {
id
name
hasVariants
}
}
}
}
}
QUERY
variables = {
"productId": "gid://shopify/Product/20995642",
"options": ["gid://shopify/ProductOption/1064576514"]
}
response = client.query(query: query, variables: variables)
Input variables
JSON{
"productId": "gid://shopify/Product/20995642",
"options": [
"gid://shopify/ProductOption/1064576514"
]
}
Response
JSON{
"productOptionsDelete": {
"userErrors": [],
"deletedOptionsIds": [
"gid://shopify/ProductOption/1064576514"
],
"product": {
"id": "gid://shopify/Product/20995642",
"options": [
{
"id": "gid://shopify/ProductOption/328272167",
"name": "Title",
"values": [
"151cm",
"155cm",
"158cm"
],
"position": 1,
"optionValues": [
{
"id": "gid://shopify/ProductOptionValue/141051426",
"name": "151cm",
"hasVariants": true
},
{
"id": "gid://shopify/ProductOptionValue/258076414",