forked from crowetic/commerce
* Moved everything * Figuring out how to make imports work * Updated exports * Added missing exports * Added @vercel/commerce-local to `site` * Updated commerce config * Updated exports and commerce config * Updated commerce hoc * Fixed exports in local * Added publish config * Updated imports in site * It's actually working * Don't use debugger in dev for better speeds * Improved DX when editing packages * Set up eslint with husky * Updated prettier config * Added prettier setup to every package * Moved bigcommerce * Moved Bigcommerce to src and package updates * Updated setup of bigcommerce * Moved definitions script * Moved commercejs * Move to src * Fixed types in commercejs * Moved kibocommerce * Moved kibocommerce to src * Added package/tsconfig to kibocommerce * Fixed imports and other things * Moved ordercloud * Moved ordercloud to src * Fixed imports * Added missing prettier files * Moved Saleor * Moved Saleor to src * Fixed imports * Replaced all imports to @commerce * Added prettierignore/rc to all providers * Moved shopify to src * Build shopify in packages * Moved Spree * Moved spree to src * Updated spree * Moved swell * Moved swell to src * Fixed type imports in swell * Moved Vendure to packages * Moved vendure to src * Fixed imports in vendure * Added codegen to saleor * Updated codegen setup for shopify * Added codegen to vendure * Added codegen to kibocommerce * Added all packages to site's deps * Updated codegen setup in bigcommerce * Minor fixes * Updated providers' names in site * Updated packages based on Bel's changes * Updated turbo to latest * Fixed ts complains * Set npm engine in root * New lockfile install * remove engines * Regen lockfile * Switched from npm to yarn * Updated typesVersions in all packages * Moved dep * Updated SWR to the just released 1.2.0 * Removed "isolatedModules" from packages * Updated list of providers and default * Updated swell declaration * Removed next import from kibocommerce * Added COMMERCE_PROVIDER log * Added another log * Updated turbo config * Updated docs * Removed test logs Co-authored-by: Jared Palmer <jared@jaredpalmer.com>
136 lines
3.2 KiB
Markdown
136 lines
3.2 KiB
Markdown
## Shopify Provider
|
|
|
|
**Demo:** https://shopify.demo.vercel.store/
|
|
|
|
Before getting started, a [Shopify](https://www.shopify.com/) account and store is required before using the provider.
|
|
|
|
Next, copy the `.env.template` file in this directory to `.env.local` in the main directory (which will be ignored by Git):
|
|
|
|
```bash
|
|
cp packages/shopify/.env.template .env.local
|
|
```
|
|
|
|
Then, set the environment variables in `.env.local` to match the ones from your store.
|
|
|
|
## Contribute
|
|
|
|
Our commitment to Open Source can be found [here](https://vercel.com/oss).
|
|
|
|
If you find an issue with the provider or want a new feature, feel free to open a PR or [create a new issue](https://github.com/vercel/commerce/issues).
|
|
|
|
## Modifications
|
|
|
|
These modifications are temporarily until contributions are made to remove them.
|
|
|
|
### Adding item to Cart
|
|
|
|
```js
|
|
// components/product/ProductView/ProductView.tsx
|
|
const ProductView: FC<Props> = ({ product }) => {
|
|
const addToCart = async () => {
|
|
setLoading(true)
|
|
try {
|
|
await addItem({
|
|
productId: product.id,
|
|
variantId: variant ? variant.id : product.variants[0].id,
|
|
})
|
|
openSidebar()
|
|
setLoading(false)
|
|
} catch (err) {
|
|
setLoading(false)
|
|
}
|
|
}
|
|
}
|
|
```
|
|
|
|
### Proceed to Checkout
|
|
|
|
```js
|
|
// components/cart/CartSidebarView/CartSidebarView.tsx
|
|
import { useCommerce } from '@framework'
|
|
|
|
const CartSidebarView: FC = () => {
|
|
const { checkout } = useCommerce()
|
|
return (
|
|
<Button href={checkout.webUrl} Component="a" width="100%">
|
|
Proceed to Checkout
|
|
</Button>
|
|
)
|
|
}
|
|
```
|
|
|
|
## APIs
|
|
|
|
Collections of APIs to fetch data from a Shopify store.
|
|
|
|
The data is fetched using the [Shopify JavaScript Buy SDK](https://github.com/Shopify/js-buy-sdk#readme). Read the [Shopify Storefront API reference](https://shopify.dev/docs/storefront-api/reference) for more information.
|
|
|
|
### getProduct
|
|
|
|
Get a single product by its `handle`.
|
|
|
|
```js
|
|
import getProduct from '@framework/product/get-product'
|
|
import { getConfig } from '@framework/api'
|
|
|
|
const config = getConfig()
|
|
|
|
const product = await getProduct({
|
|
variables: { slug },
|
|
config,
|
|
})
|
|
```
|
|
|
|
### getAllProducts
|
|
|
|
```js
|
|
import getAllProducts from '@framework/product/get-all-products'
|
|
import { getConfig } from '@framework/api'
|
|
|
|
const config = getConfig()
|
|
|
|
const { products } = await getAllProducts({
|
|
variables: { first: 12 },
|
|
config,
|
|
})
|
|
```
|
|
|
|
### getAllCollections
|
|
|
|
```js
|
|
import getAllCollections from '@framework/product/get-all-collections'
|
|
import { getConfig } from '@framework/api'
|
|
|
|
const config = getConfig()
|
|
|
|
const collections = await getAllCollections({
|
|
config,
|
|
})
|
|
```
|
|
|
|
### getAllPages
|
|
|
|
```js
|
|
import getAllPages from '@framework/common/get-all-pages'
|
|
import { getConfig } from '@framework/api'
|
|
|
|
const config = getConfig()
|
|
|
|
const pages = await getAllPages({
|
|
variables: { first: 12 },
|
|
config,
|
|
})
|
|
```
|
|
|
|
## Code generation
|
|
|
|
This provider makes use of GraphQL code generation. The [schema.graphql](./schema.graphql) and [schema.d.ts](./schema.d.ts) files contain the generated types & schema introspection results.
|
|
|
|
When developing the provider, changes to any GraphQL operations should be followed by re-generation of the types and schema files:
|
|
|
|
From the project root dir, run:
|
|
|
|
```sh
|
|
yarn generate:shopify
|
|
```
|