Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DEVDOCS-6016 [new]: MSF International Enhancements, add product images & overrides #545

Merged
merged 19 commits into from
Dec 31, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
368 changes: 368 additions & 0 deletions docs/store-operations/catalog/graphql-admin/product-images.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,368 @@
# Product Images

[_International Enhancements for Multi-Storefront_](/docs/store-operations/catalog/msf-international-enhancements)

<Callout type="info">
This feature is currently in Open Beta.
</Callout>

Using the Catalog features of the Admin API, you can set and query product images.

First [add the image to the product](#add-image-to-product) for the global store and a channel locale.

You can then perform the following:
- [Set product image information](#set-product-image-information) for the catalog. You can create global values and overrides for the product's image in a channel locale.
- [Remove overrides for the product's image in a channel locale](#remove-product-image-information-for-a-locale). A channel then inherits global values.
- [Query product image information](#query-product-image-information), those set at the global level and the overrides.

For a full schema, see the [GraphQL Admin API reference](https://developer.bigcommerce.com/graphql-admin/reference).

## Input fields

Setting or removing information requires that you specify ID fields in the input. For more information on how to specify ID fields, see [Input fields](/docs/store-operations/catalog/msf-international-enhancements#input-fields).

## Product images

### Add image to product

The following example adds images to a product for a channel locale. To add the image to a product for the global store, don't include the `context` field in the `input`.

<Tabs items={['Request', 'Response']}>
<Tab>

```graphql filename="Example mutation: Add image to product" showLineNumbers copy
POST https://api.bigcommerce.com/stores/{{STORE_HASH}}/graphql
X-Auth-Token: {{ACCESS_TOKEN}}
Content-Type: application/json
Accept: application/json

mutation ($input: AddImagesToProductInput!) {
product {
addImagesToProduct(input: $input) {
images {
edges {
node {
id
altText
isThumbnail
sortOrder
urlStandard
urlZoom
bc-andreadao marked this conversation as resolved.
Show resolved Hide resolved
}
}
}
}
}
}
```

```json filename="GraphQL variables" showLineNumbers copy
{
"input": {
"productId": "bc/store/product/111",
"context": {
"channelId": "1",
"locale": "en-US"
},
"ids": ["bc/store/productImage/1", "bc/store/productImage/2"]
}
}
```

</Tab>
<Tab>

```json filename="Example mutation: Add image to product" showLineNumbers copy
{
"data": {
"product": {
"addImagesToProduct": {
"images": {
"edges": [
{
"node": {
"id": "bc/store/productImage/1",
"altText": "Sample alt text for image 1",
"isThumbnail": false,
"sortOrder": 1,
"urlStandard": "https://cdn.example.com/products/111/image1.jpg",
"urlZoom": "https://cdn.example.com/products/111/image1_zoom.jpg"
}
},
{
"node": {
"id": "bc/store/productImage/2",
"altText": "Sample alt text for image 2",
"isThumbnail": true,
"sortOrder": 2,
"urlStandard": "https://cdn.example.com/products/111/image2.jpg",
"urlZoom": "https://cdn.example.com/products/111/image2_zoom.jpg"
}
}
]
}
}
}
}
}
```

</Tab>
</Tabs>


### Remove image from product

The following example removes images to a product for a channel locale. To remove the image to a product for the global store, don't include the `context` field in the `input`.

<Tabs items={['Request', 'Response']}>
<Tab>

```graphql filename="Example mutation: Remove image from product" showLineNumbers copy
POST https://api.bigcommerce.com/stores/{{STORE_HASH}}/graphql
X-Auth-Token: {{ACCESS_TOKEN}}
Content-Type: application/json
Accept: application/json

mutation {
product {
removeImagesFromProduct($input: RemoveImagesFromProductInput!) {
images {
edges {
node {
id
altText
isThumbnail
sortOrder
urlStandard
urlZoom
}
}
}
}
}
}
```

```json filename="GraphQL variables" showLineNumbers copy
{
"input": {
"productId": "bc/store/product/111",
"context": {
"channelId": "1",
"locale": "en-US"
},
"ids": ["bc/store/productImage/1", "bc/store/productImage/2"]
}
}
```

</Tab>
<Tab>

```json filename="Example mutation: Remove image from product" showLineNumbers copy

```

</Tab>
</Tabs>

## Set product image information

The following example sets product image information for the channel locale. These will override global store information.

To set global store information, remove the `overrides` field from the input.
bc-andreadao marked this conversation as resolved.
Show resolved Hide resolved

<Tabs items={['Request', 'Response']}>
<Tab>

```graphql filename="Example mutation: Set global product image information" showLineNumbers copy
POST https://api.bigcommerce.com/stores/{{STORE_HASH}}/graphql
X-Auth-Token: {{ACCESS_TOKEN}}
Content-Type: application/json
Accept: application/json

mutation ($input: $UpdateProductImagePropertiesInput) {
product {
updateProductImageProperties(input: $input) {
images {
edges {
node {
id
altText
isThumbnail
sortOrder
urlStandard
urlZoom
overrides {
context {
channelId
locale
}
altText
isDefault
sortOrder
}
}
}
}
}
}
}
```

```json filename="GraphQL variables" showLineNumbers copy
{
"input": {
"productId": "12345",
"data": [
{
"imageId": "img_001",
"sortOrder": 2,
"altText": "New updated alt text for image 1",
"isDefault": true,

// Overrides for the channel locale
"overrides": [
{
"channelLocaleOverrides": {
"context": {
"channelId": "1",
"locale": "en-US"
},
"data": {
"sortOrder": 1,
"altText": "Channel-specific alt text",
"isDefault": true
}
}
}
]
},
{
"imageId": "img_002",
"sortOrder": 1,
"altText": "Updated alt text for image 2",
"isDefault": false
}
]
}
}
```

</Tab>
<Tab>

```json filename="Example mutation: Set global product image information" showLineNumbers copy

```

</Tab>
</Tabs>


## Remove product image information for a locale

The following example removes product image information for the channel locale.

<Tabs items={['Request', 'Response']}>
<Tab>

```graphql filename="Example mutation: Remove product image information for a locale" showLineNumbers copy
POST https://api.bigcommerce.com/stores/{{STORE_HASH}}/graphql
X-Auth-Token: {{ACCESS_TOKEN}}
Content-Type: application/json
Accept: application/json

mutation removeProductImagePropertiesOverrides($input: RemoveProductImagePropertiesOverridesInput!) {
product {
removeProductImagePropertiesOverrides(input: $input) {
productImage {
id
altText
isThumbnail
sortOrder
urlStandard
urlZoom
}
}
}
}
```
```json filename="GraphQL variables" showLineNumbers copy
{
"input": {
"productId": "bc/store/product/111",
"context": {
"channelId": "1",
"locale": "en-US"
},
"imageIds": ["bc/store/productImage/1", "bc/store/productImage/2"]
}
}
```

</Tab>
<Tab>

```json filename="Example mutation: Remove product image information for a locale" showLineNumbers copy

```

</Tab>
</Tabs>

## Query product image information

The following example retrieves product image information. You can retrieve global information for the store and overrides for the channel locale.

<Tabs items={['Request', 'Response']}>
<Tab>

```graphql filename="Example query: Get product image information" showLineNumbers copy
POST https://api.bigcommerce.com/stores/{{STORE_HASH}}/graphql
X-Auth-Token: {{ACCESS_TOKEN}}
Content-Type: application/json
Accept: application/json

query getProductImageProperties() {
product(id: "bc/store/product/111") {
images {
edges {
node {
id
altText
isThumbnail
sortOrder
urlStandard
urlZoom

# Global store
global: properties {
altText
isThumbnail
sortOrder
}

# Channel locale override
overrides: properties(context: { channelId: "bc/store/channel/2", locale: "uk" }) {
altText
isThumbnail
sortOrder
}
}
}
}
}
}
```
</Tab>
<Tab>

```json filename="Example query: Get product image information" showLineNumbers copy

```

</Tab>
</Tabs>

Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ The following pages provide sample queries:
- [Product URL](/docs/store-operations/catalog/graphql-admin/product-url)
- [Additional product attributes](/docs/store-operations/catalog/graphql-admin/product-attributes)
- [Product custom fields](/docs/store-operations/catalog/graphql-admin/product-custom-fields)
- [Product images](/docs/store-operations/catalog/graphql-admin/product-images)
bc-andreadao marked this conversation as resolved.
Show resolved Hide resolved

You can create webhooks that trigger for the following events:
- [Product updated](/docs/integrations/webhooks/events#products)
Expand Down Expand Up @@ -75,6 +76,7 @@ The following table describes the ID fields that you can use in inputs for mutat
| `valueId` | Variant option value ID | [Get all product variant option values](/docs/rest-catalog/product-variant-options/values#get-all-product-variant-option-values) | Product variant options: `"bc/store/productOptionValue/68"` <br /><br />Shared variant options: `"bc/store/sharedProductOptionValue/123"` |
| | Modifier value ID | [Get all modifier values](/docs/rest-catalog/product-modifiers/values#get-all-modifier-values) | Product modifiers: `"bc/store/productModifierValue/107"` <br /><br />Shared modifiers: `"bc/store/sharedProductModifierValue/107"` |
| `customFieldId` | ID for a product custom field | [Get product custom fields](/docs/rest-catalog/products/custom-fields#get-product-custom-fields) | `"bc/store/productCustomField/1"` |
| `imageId` | Image ID. | [Get all product images](/docs/rest-catalog/products/images#get-all-product-images) | `"bc/store/productImage/1"` |
bc-andreadao marked this conversation as resolved.
Show resolved Hide resolved

## Authentication

Expand Down
Loading