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;
|