| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225 | import { createStorefrontApiClient } from '@shopify/storefront-api-client';
import { REACT_APP_ACCESS_TOKEN, REACT_APP_SHOP_NAME } from '../utils/httpCommon';
const client = createStorefrontApiClient({
  storeDomain: `https://${REACT_APP_SHOP_NAME}/api/2024-10/graphql.json`,
  apiVersion: '2024-10',
  publicAccessToken: REACT_APP_ACCESS_TOKEN,
});
// Create a cart
const createCart = async () => {
  const query = `
    mutation CreateCart {
      cartCreate {
        cart {
          id
          createdAt
          updatedAt
        }
      }
    }
  `;
  const { data } = await client.request(query);
  return data.cartCreate.cart;
};
// Add a line item to the cart
const addItemToCart = async (cartId, lines) => {
  const query = `
    mutation($cartId: ID!, $lines: [CartLineInput!]!) {
      cartLinesAdd(cartId: $cartId, lines: $lines) {
        cart {
          id
          createdAt
          updatedAt
          cost {
            totalAmount {
              amount
              currencyCode
            }
            subtotalAmount {
              amount
              currencyCode
            }
            totalTaxAmount {
              amount
              currencyCode
            }
          }
          lines(first: 10) {
            nodes {
              id
              merchandise {
                ... on ProductVariant {
                  id
                  title
                  selectedOptions {
                    name
                    value
                  }
                  image {
                    src
                  }
                  product {
                    title
                    collections(first: 5) {
                      nodes {
                        title
                      }
                    }
                  }
                }
              }
              quantity
              cost {
                totalAmount {
                  amount
                  currencyCode
                }
              }
            }
          }
        }
      }
    }
  `;
  const variables = { cartId, lines };
  const {data, errors, extensions} = await client.request(query,{
    variables: {
      cartId,
      lines
    }
  });
  
  return data.cartLinesAdd.cart;
};
// Get cart details
const getCart = async (cartId) => {
  const query = `
    {
      cart(id: "${cartId}") {
        id
        createdAt
        updatedAt
        cost {
          totalAmount {
            amount
            currencyCode
          }
          subtotalAmount {
            amount
            currencyCode
          }
          totalTaxAmount {
            amount
            currencyCode
          }
        }
        lines(first: 10) {
          nodes {
            id
            merchandise {
              ... on ProductVariant {
                id
                title
                selectedOptions {
                  name
                  value
                }
                image {
                  src
                }
                product {
                  title
                  collections(first: 5) {
                    nodes {
                      title
                    }
                  }
                }
              }
            }
            quantity
            cost {
              totalAmount {
                amount
                currencyCode
              }
            }
          }
        }
      }
        
    }
  `;
  const { data } = await client.request(query);
  return data.cart;
};
// Update a line item's quantity
const updateItemQuantity = async (cartId, lineId, quantity) => {
  const query = `
    mutation UpdateItemQuantity($cartId: ID!, $lines: [CartLineUpdateInput!]!) {
      cartLinesUpdate(cartId: $cartId, lines: $lines) {
        cart {
          id
          lines(first: 10) {
            edges {
              node {
                id
                quantity
                merchandise {
                  ... on ProductVariant {
                    id
                  }
                }
              }
            }
          }
        }
        userErrors {
          field
          message
        }
      }
    }
  `;
  const variables = {
    cartId,
    lines: [{ id: lineId, quantity }],
  };
  const { data } = await client.request(query, variables);
  return data.cartLinesUpdate.cart;
};
// Generate checkout URL
const getCheckoutUrl = async (cartId) => {
  const query = `
    query CheckoutURL($cartId: ID!) {
      cart(id: $cartId) {
        checkoutUrl
      }
    }
  `;
  const variables = { cartId };
  const { data } = await client.request(query, variables);
  return data.cart.checkoutUrl;
};
// Export services
const CartService = {
  createCart,
  addItemToCart,
  getCart,
  updateItemQuantity,
  getCheckoutUrl,
};
export default CartService;
 |