--- title: cartGiftCardCodesUpdateDefault description: >- Creates a function that accepts an array of strings and adds the gift card codes to a cart api_version: 2024-07 api_name: hydrogen source_url: html: >- https://shopify.dev/docs/api/hydrogen/2024-07/utilities/cart/cartgiftcardcodesupdatedefault md: >- https://shopify.dev/docs/api/hydrogen/2024-07/utilities/cart/cartgiftcardcodesupdatedefault.md --- # cart​Gift​Card​Codes​Update​Defaultutility Creates a function that accepts an array of strings and adds the gift card codes to a cart ## cart​Gift​Card​Codes​Update​Default([options](#cartgiftcardcodesupdatedefault-propertydetail-options)​) ### Parameters * options CartQueryOptions required ### Returns * CartGiftCardCodesUpdateFunction ### CartGiftCardCodesUpdateFunction * export type CartGiftCardCodesUpdateFunction = ( giftCardCodes: string[], optionalParams?: CartOptionalInput, ) => Promise; ### CartQueryOptions * cartFragment The cart fragment to override the one used in this query. ```ts string ``` * customerAccount The customer account instance created by \[\`createCustomerAccount\`]\(docs/api/hydrogen/latest/customer/createcustomeraccount). ```ts CustomerAccount ``` * getCartId A function that returns the cart ID. ```ts () => string ``` * storefront The storefront client instance created by \[\`createStorefrontClient\`]\(docs/api/hydrogen/latest/utilities/createstorefrontclient). ```ts Storefront ``` ```ts { /** * The storefront client instance created by [`createStorefrontClient`](docs/api/hydrogen/latest/utilities/createstorefrontclient). */ storefront: Storefront; /** * A function that returns the cart ID. */ getCartId: () => string | undefined; /** * The cart fragment to override the one used in this query. */ cartFragment?: string; /** * The customer account instance created by [`createCustomerAccount`](docs/api/hydrogen/latest/customer/createcustomeraccount). */ customerAccount?: CustomerAccount; } ``` ### CustomerAccount * authorize On successful login, the customer redirects back to your app. This function validates the OAuth response and exchanges the authorization code for an access token and refresh token. It also persists the tokens on your session. This function should be called and returned from the Remix loader configured as the redirect URI within the Customer Account API settings in admin. ```ts () => Promise ``` * getAccessToken Returns CustomerAccessToken if the customer is logged in. It also run a expiry check and does a token refresh if needed. ```ts () => Promise ``` * getApiUrl Creates the fully-qualified URL to your store's GraphQL endpoint. ```ts () => string ``` * handleAuthStatus Check for a not logged in customer and redirect customer to login page. The redirect can be overwritten with \`customAuthStatusHandler\` option. ```ts () => void | DataFunctionValue ``` * isLoggedIn Returns if the customer is logged in. It also checks if the access token is expired and refreshes it if needed. ```ts () => Promise ``` * login Start the OAuth login flow. This function should be called and returned from a Remix action. It redirects the customer to a Shopify login domain. It also defined the final path the customer lands on at the end of the oAuth flow with the value of the \`return\_to\` query param. (This is automatically setup unless \`customAuthStatusHandler\` option is in use) ```ts (options?: LoginOptions) => Promise ``` * logout Logout the customer by clearing the session and redirecting to the login domain. It should be called and returned from a Remix action. The path app should redirect to after logout can be setup in Customer Account API settings in admin. ```ts (options?: LogoutOptions) => Promise ``` * mutate Execute a GraphQL mutation against the Customer Account API. This method execute \`handleAuthStatus()\` ahead of mutation. ```ts (mutation: RawGqlString, ...options: IsOptionalVariables> extends true ? [({} & ClientVariables>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountMutations[RawGqlString]["variables"] as Filter>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof CustomerAccountMutations[RawGqlString]["variables"] as Filter>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountMutations[RawGqlString]["variables"] as Filter>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>)?] : [{} & ClientVariables>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountMutations[RawGqlString]["variables"] as Filter>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof CustomerAccountMutations[RawGqlString]["variables"] as Filter>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountMutations[RawGqlString]["variables"] as Filter>]: CustomerAccountMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>]) => Promise>, "errors"> & { errors?: Pick[]; }> ``` * query Execute a GraphQL query against the Customer Account API. This method execute \`handleAuthStatus()\` ahead of query. ```ts (query: RawGqlString, ...options: IsOptionalVariables> extends true ? [({} & ClientVariables>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountQueries[RawGqlString]["variables"] as Filter>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof CustomerAccountQueries[RawGqlString]["variables"] as Filter>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountQueries[RawGqlString]["variables"] as Filter>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>)?] : [{} & ClientVariables>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountQueries[RawGqlString]["variables"] as Filter>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof CustomerAccountQueries[RawGqlString]["variables"] as Filter>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof CustomerAccountQueries[RawGqlString]["variables"] as Filter>]: CustomerAccountQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>]) => Promise>, "errors"> & { errors?: Pick[]; }> ``` * UNSTABLE\_getBuyer UNSTABLE feature. Get buyer token and company location id from session. ```ts () => Promise> ``` * UNSTABLE\_setBuyer UNSTABLE feature. Set buyer information into session. ```ts (buyer: Partial) => void ``` ```ts { /** Start the OAuth login flow. This function should be called and returned from a Remix action. * It redirects the customer to a Shopify login domain. It also defined the final path the customer * lands on at the end of the oAuth flow with the value of the `return_to` query param. (This is * automatically setup unless `customAuthStatusHandler` option is in use) * * @param options.uiLocales - The displayed language of the login page. Only support for the following languages: * `en`, `fr`, `cs`, `da`, `de`, `es`, `fi`, `it`, `ja`, `ko`, `nb`, `nl`, `pl`, `pt-BR`, `pt-PT`, * `sv`, `th`, `tr`, `vi`, `zh-CN`, `zh-TW`. If supplied any other language code, it will default to `en`. * */ login: (options?: LoginOptions) => Promise; /** On successful login, the customer redirects back to your app. This function validates the OAuth response and exchanges the authorization code for an access token and refresh token. It also persists the tokens on your session. This function should be called and returned from the Remix loader configured as the redirect URI within the Customer Account API settings in admin. */ authorize: () => Promise; /** Returns if the customer is logged in. It also checks if the access token is expired and refreshes it if needed. */ isLoggedIn: () => Promise; /** Check for a not logged in customer and redirect customer to login page. The redirect can be overwritten with `customAuthStatusHandler` option. */ handleAuthStatus: () => void | DataFunctionValue; /** Returns CustomerAccessToken if the customer is logged in. It also run a expiry check and does a token refresh if needed. */ getAccessToken: () => Promise; /** Creates the fully-qualified URL to your store's GraphQL endpoint.*/ getApiUrl: () => string; /** Logout the customer by clearing the session and redirecting to the login domain. It should be called and returned from a Remix action. The path app should redirect to after logout can be setup in Customer Account API settings in admin. * * @param options.postLogoutRedirectUri - The url to redirect customer to after logout, should be a relative URL. This url will need to included in Customer Account API's application setup for logout URI. The default value is current app origin, which is automatically setup in admin when using `--customer-account-push` flag with dev. * */ logout: (options?: LogoutOptions) => Promise; /** Execute a GraphQL query against the Customer Account API. This method execute `handleAuthStatus()` ahead of query. */ query: < OverrideReturnType extends any = never, RawGqlString extends string = string, >( query: RawGqlString, ...options: ClientVariablesInRestParams< CustomerAccountQueries, RawGqlString > ) => Promise< Omit< CustomerAPIResponse< ClientReturn >, 'errors' > & {errors?: JsonGraphQLError[]} >; /** Execute a GraphQL mutation against the Customer Account API. This method execute `handleAuthStatus()` ahead of mutation. */ mutate: < OverrideReturnType extends any = never, RawGqlString extends string = string, >( mutation: RawGqlString, ...options: ClientVariablesInRestParams< CustomerAccountMutations, RawGqlString > ) => Promise< Omit< CustomerAPIResponse< ClientReturn >, 'errors' > & {errors?: JsonGraphQLError[]} >; /** UNSTABLE feature. Set buyer information into session.*/ UNSTABLE_setBuyer: (buyer: Buyer) => void; /** UNSTABLE feature. Get buyer token and company location id from session.*/ UNSTABLE_getBuyer: () => Promise; } ``` ### DataFunctionValue ```ts Response | NonNullable | null ``` ### LoginOptions * uiLocales ```ts LanguageCode ``` ```ts { uiLocales?: LanguageCode; } ``` ### LogoutOptions * postLogoutRedirectUri ```ts string ``` ```ts { postLogoutRedirectUri?: string; } ``` ### CustomerAccountMutations ```ts export interface CustomerAccountMutations { // Example of how a generated mutation type looks like: // '#graphql mutation m1 {...}': {return: M1Mutation; variables: M1MutationVariables}; } ``` ### CustomerAPIResponse * data ```ts ReturnType ``` * errors ```ts Array<{ message: string; locations?: Array<{line: number; column: number}>; path?: Array; extensions: {code: string}; }> ``` * extensions ```ts { cost: { requestQueryCost: number; actualQueryCakes: number; throttleStatus: { maximumAvailable: number; currentAvailable: number; restoreRate: number; }; }; } ``` ```ts { data: ReturnType; errors: Array<{ message: string; locations?: Array<{line: number; column: number}>; path?: Array; extensions: {code: string}; }>; extensions: { cost: { requestQueryCost: number; actualQueryCakes: number; throttleStatus: { maximumAvailable: number; currentAvailable: number; restoreRate: number; }; }; }; } ``` ### GraphQLError * locations If an error can be associated to a particular point in the requested GraphQL document, it should contain a list of locations. ```ts { line: number; column: number; }[] ``` * path If an error can be associated to a particular field in the GraphQL result, it \_must\_ contain an entry with the key \`path\` that details the path of the response field which experienced the error. This allows clients to identify whether a null result is intentional or caused by a runtime error. ```ts (string | number)[] ``` * extensions Reserved for implementors to extend the protocol however they see fit, and hence there are no additional restrictions on its contents. ```ts { [key: string]: unknown; } ``` * toString Note: \`toString()\` is internally used by \`console.log(...)\` / \`console.error(...)\` when ingesting logs in Oxygen production. Therefore, we want to make sure that the error message is as informative as possible instead of \`\[object Object]\`. ```ts () => string ``` * toJSON Note: toJSON\` is internally used by \`JSON.stringify(...)\`. The most common scenario when this error instance is going to be stringified is when it's passed to Remix' \`json\` and \`defer\` functions: e.g. \`defer({promise: storefront.query(...)})\`. In this situation, we don't want to expose private error information to the browser so we only do it in development. ```ts () => Pick ``` * \_\_@toStringTag\@690 ```ts string ``` * name ```ts string ``` * message ```ts string ``` * stack ```ts string ``` ```ts export class GraphQLError extends Error { /** * If an error can be associated to a particular point in the requested * GraphQL document, it should contain a list of locations. */ locations?: Array<{line: number; column: number}>; /** * If an error can be associated to a particular field in the GraphQL result, * it _must_ contain an entry with the key `path` that details the path of * the response field which experienced the error. This allows clients to * identify whether a null result is intentional or caused by a runtime error. */ path?: Array; /** * Reserved for implementors to extend the protocol however they see fit, * and hence there are no additional restrictions on its contents. */ extensions?: {[key: string]: unknown}; constructor( message?: string, options: Pick< GraphQLError, 'locations' | 'path' | 'extensions' | 'stack' | 'cause' > & { query?: string; queryVariables?: GenericVariables; requestId?: string | null; clientOperation?: string; } = {}, ) { const h2Prefix = options.clientOperation ? `[h2:error:${options.clientOperation}] ` : ''; const enhancedMessage = h2Prefix + message + (options.requestId ? ` - Request ID: ${options.requestId}` : ''); super(enhancedMessage); this.name = 'GraphQLError'; this.extensions = options.extensions; this.locations = options.locations; this.path = options.path; this.stack = options.stack || undefined; try { this.cause = JSON.stringify({ ...(typeof options.cause === 'object' ? options.cause : {}), requestId: options.requestId, ...(process.env.NODE_ENV === 'development' && { path: options.path, extensions: options.extensions, graphql: h2Prefix && options.query && { query: options.query, variables: JSON.stringify(options.queryVariables), }, }), }); } catch { if (options.cause) this.cause = options.cause; } } get [Symbol.toStringTag]() { return this.name; } /** * Note: `toString()` is internally used by `console.log(...)` / `console.error(...)` * when ingesting logs in Oxygen production. Therefore, we want to make sure that * the error message is as informative as possible instead of `[object Object]`. */ override toString() { let result = `${this.name}: ${this.message}`; if (this.path) { try { result += ` | path: ${JSON.stringify(this.path)}`; } catch {} } if (this.extensions) { try { result += ` | extensions: ${JSON.stringify(this.extensions)}`; } catch {} } result += '\n'; if (this.stack) { // Remove the message line from the stack. result += `${this.stack.slice(this.stack.indexOf('\n') + 1)}\n`; } return result; } /** * Note: toJSON` is internally used by `JSON.stringify(...)`. * The most common scenario when this error instance is going to be stringified is * when it's passed to Remix' `json` and `defer` functions: e.g. `defer({promise: storefront.query(...)})`. * In this situation, we don't want to expose private error information to the browser so we only * do it in development. */ toJSON() { const formatted: Pick< GraphQLError, 'name' | 'message' | 'path' | 'extensions' | 'locations' | 'stack' > = {name: 'Error', message: ''}; if (process.env.NODE_ENV === 'development') { formatted.name = this.name; formatted.message = 'Development: ' + this.message; if (this.path) formatted.path = this.path; if (this.locations) formatted.locations = this.locations; if (this.extensions) formatted.extensions = this.extensions; // Skip stack on purpose because we don't want to expose it to the browser. } return formatted; } } ``` ### CustomerAccountQueries ```ts export interface CustomerAccountQueries { // Example of how a generated query type looks like: // '#graphql query q1 {...}': {return: Q1Query; variables: Q1QueryVariables}; } ``` ### Storefront Interface to interact with the Storefront API. * cache ```ts Cache ``` * CacheCustom ```ts (overrideOptions: AllCacheOptions) => AllCacheOptions ``` * CacheLong ```ts (overrideOptions?: AllCacheOptions) => AllCacheOptions ``` * CacheNone ```ts () => NoStoreStrategy ``` * CacheShort ```ts (overrideOptions?: AllCacheOptions) => AllCacheOptions ``` * generateCacheControlHeader ```ts (cacheOptions: AllCacheOptions) => string ``` * getApiUrl ```ts (props?: Partial>) => string ``` * getPrivateTokenHeaders ```ts (props?: Partial> & Pick & { buyerIp?: string; }) => Record ``` * getPublicTokenHeaders ```ts (props?: Partial> & Pick) => Record ``` * getShopifyDomain ```ts (props?: Partial>) => string ``` * i18n ```ts TI18n ``` * mutate ```ts (mutation: RawGqlString, ...options: IsOptionalVariables> extends true ? [(StorefrontCommonExtraParams & ClientVariables>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontMutations[RawGqlString]["variables"] as Filter>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof StorefrontMutations[RawGqlString]["variables"] as Filter>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontMutations[RawGqlString]["variables"] as Filter>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>)?] : [StorefrontCommonExtraParams & ClientVariables>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontMutations[RawGqlString]["variables"] as Filter>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof StorefrontMutations[RawGqlString]["variables"] as Filter>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontMutations[RawGqlString]["variables"] as Filter>]: StorefrontMutations[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>]) => Promise & StorefrontError> ``` * query ```ts (query: RawGqlString, ...options: IsOptionalVariables> extends true ? [(StorefrontCommonExtraParams & Pick & ClientVariables>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontQueries[RawGqlString]["variables"] as Filter>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof StorefrontQueries[RawGqlString]["variables"] as Filter>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontQueries[RawGqlString]["variables"] as Filter>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>)?] : [StorefrontCommonExtraParams & Pick & ClientVariables>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontQueries[RawGqlString]["variables"] as Filter>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }, Record<"variables", RawGqlString extends never ? { [KeyType in keyof ({ [KeyType in keyof StorefrontQueries[RawGqlString]["variables"] as Filter>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)]: ({ [KeyType in keyof StorefrontQueries[RawGqlString]["variables"] as Filter>]: StorefrontQueries[RawGqlString]["variables"][KeyType]; } & Partial>>)[KeyType]; } : { readonly [variable: string]: unknown; }>>]) => Promise & StorefrontError> ``` ```ts { query: < OverrideReturnType extends any = never, RawGqlString extends string = string, >( query: RawGqlString, ...options: ClientVariablesInRestParams< StorefrontQueries, RawGqlString, StorefrontCommonExtraParams & Pick, AutoAddedVariableNames > ) => Promise< ClientReturn & StorefrontError >; mutate: < OverrideReturnType extends any = never, RawGqlString extends string = string, >( mutation: RawGqlString, ...options: ClientVariablesInRestParams< StorefrontMutations, RawGqlString, StorefrontCommonExtraParams, AutoAddedVariableNames > ) => Promise< ClientReturn & StorefrontError >; cache?: Cache; CacheNone: typeof CacheNone; CacheLong: typeof CacheLong; CacheShort: typeof CacheShort; CacheCustom: typeof CacheCustom; generateCacheControlHeader: typeof generateCacheControlHeader; getPublicTokenHeaders: ReturnType< typeof createStorefrontUtilities >['getPublicTokenHeaders']; getPrivateTokenHeaders: ReturnType< typeof createStorefrontUtilities >['getPrivateTokenHeaders']; getShopifyDomain: ReturnType< typeof createStorefrontUtilities >['getShopifyDomain']; getApiUrl: ReturnType< typeof createStorefrontUtilities >['getStorefrontApiUrl']; i18n: TI18n; } ``` ### AllCacheOptions Override options for a cache strategy. * maxAge The maximum amount of time in seconds that a resource will be considered fresh. See \`max-age\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#:\~:text=Response%20Directives-,max%2Dage,-The%20max%2Dage). ```ts number ``` * mode The caching mode, generally \`public\`, \`private\`, or \`no-store\`. ```ts string ``` * sMaxAge Similar to \`maxAge\` but specific to shared caches. See \`s-maxage\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#s-maxage). ```ts number ``` * staleIfError Indicate that the cache should serve the stale response if an error occurs while revalidating the cache. See \`stale-if-error\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#stale-if-error). ```ts number ``` * staleWhileRevalidate Indicate that the cache should serve the stale response in the background while revalidating the cache. See \`stale-while-revalidate\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#stale-while-revalidate). ```ts number ``` ```ts export interface AllCacheOptions { /** * The caching mode, generally `public`, `private`, or `no-store`. */ mode?: string; /** * The maximum amount of time in seconds that a resource will be considered fresh. See `max-age` in the [MDN docs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#:~:text=Response%20Directives-,max%2Dage,-The%20max%2Dage). */ maxAge?: number; /** * Indicate that the cache should serve the stale response in the background while revalidating the cache. See `stale-while-revalidate` in the [MDN docs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#stale-while-revalidate). */ staleWhileRevalidate?: number; /** * Similar to `maxAge` but specific to shared caches. See `s-maxage` in the [MDN docs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#s-maxage). */ sMaxAge?: number; /** * Indicate that the cache should serve the stale response if an error occurs while revalidating the cache. See `stale-if-error` in the [MDN docs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#stale-if-error). */ staleIfError?: number; } ``` ### NoStoreStrategy * mode ```ts string ``` ```ts { mode: string; } ``` ### StorefrontMutations Maps all the mutations found in the project to variables and return types. ```ts export interface StorefrontMutations { // Example of how a generated mutation type looks like: // '#graphql mutation m1 {...}': {return: M1Mutation; variables: M1MutationVariables}; } ``` ### AutoAddedVariableNames ```ts 'country' | 'language' ``` ### StorefrontCommonExtraParams * displayName ```ts string ``` * headers ```ts HeadersInit ``` * storefrontApiVersion ```ts string ``` ```ts { headers?: HeadersInit; storefrontApiVersion?: string; displayName?: string; } ``` ### StorefrontError * errors ```ts StorefrontApiErrors ``` ```ts { errors?: StorefrontApiErrors; } ``` ### StorefrontApiErrors ```ts JsonGraphQLError[] | undefined ``` ### JsonGraphQLError ```ts ReturnType ``` ### StorefrontQueries Maps all the queries found in the project to variables and return types. ```ts export interface StorefrontQueries { // Example of how a generated query type looks like: // '#graphql query q1 {...}': {return: Q1Query; variables: Q1QueryVariables}; } ``` ### StorefrontQueryOptions ```ts StorefrontCommonExtraParams & { query: string; mutation?: never; cache?: CachingStrategy; } ``` ### CachingStrategy Use the \`CachingStrategy\` to define a custom caching mechanism for your data. Or use one of the pre-defined caching strategies: CacheNone, CacheShort, CacheLong. * maxAge The maximum amount of time in seconds that a resource will be considered fresh. See \`max-age\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#:\~:text=Response%20Directives-,max%2Dage,-The%20max%2Dage). ```ts number ``` * mode The caching mode, generally \`public\`, \`private\`, or \`no-store\`. ```ts string ``` * sMaxAge Similar to \`maxAge\` but specific to shared caches. See \`s-maxage\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#s-maxage). ```ts number ``` * staleIfError Indicate that the cache should serve the stale response if an error occurs while revalidating the cache. See \`stale-if-error\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#stale-if-error). ```ts number ``` * staleWhileRevalidate Indicate that the cache should serve the stale response in the background while revalidating the cache. See \`stale-while-revalidate\` in the \[MDN docs]\(https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#stale-while-revalidate). ```ts number ``` ```ts AllCacheOptions ``` ### CartGiftCardCodesUpdateFunction * giftCardCodes ```ts string[] ``` * optionalParams ```ts CartOptionalInput ``` Promise\ ```ts Promise ``` ```ts export type CartGiftCardCodesUpdateFunction = ( giftCardCodes: string[], optionalParams?: CartOptionalInput, ) => Promise; ``` ### CartOptionalInput * cartId The cart id. ```ts string ``` * country The country code. ```ts CountryCode ``` * language The language code. ```ts LanguageCode ``` ```ts { /** * The cart id. * @default cart.getCartId(); */ cartId?: Scalars['ID']['input']; /** * The country code. * @default storefront.i18n.country */ country?: CountryCode; /** * The language code. * @default storefront.i18n.language */ language?: LanguageCode; } ``` ### CartQueryDataReturn ```ts CartQueryData & { errors?: StorefrontApiErrors; } ``` ### CartQueryData * cart ```ts Cart ``` * userErrors ```ts | CartUserError[] | MetafieldsSetUserError[] | MetafieldDeleteUserError[] ``` ```ts { cart: Cart; userErrors?: | CartUserError[] | MetafieldsSetUserError[] | MetafieldDeleteUserError[]; } ``` ### Cart ```ts Cart ``` ### CartUserError ```ts CartUserError ``` ### MetafieldsSetUserError ```ts MetafieldsSetUserError ``` ### MetafieldDeleteUserError ```ts MetafieldDeleteUserError ``` ### Examples * #### example ##### Description This is the default example ##### JavaScript ```js import {cartGiftCardCodesUpdateDefault} from '@shopify/hydrogen'; const cartGiftCardCodes = cartGiftCardCodesUpdateDefault({ storefront, getCartId, }); const result = await cartGiftCardCodes(['GIFT_CARD_CODE_123']); ```