Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gil--/gatsby-starter-shopifypwa
💚:shopping_cart:💚 Bodega is a Shopify PWA using Gatsby JS + Netlify CMS
https://github.com/gil--/gatsby-starter-shopifypwa
gatsby-starter gatsbyjs graphql pwa reactjs shopify shopify-pwa styled-components
Last synced: 2 days ago
JSON representation
💚:shopping_cart:💚 Bodega is a Shopify PWA using Gatsby JS + Netlify CMS
- Host: GitHub
- URL: https://github.com/gil--/gatsby-starter-shopifypwa
- Owner: gil--
- License: mit
- Archived: true
- Created: 2018-06-06T00:53:43.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-01-07T21:52:20.000Z (about 6 years ago)
- Last Synced: 2024-12-15T05:46:20.022Z (about 1 month ago)
- Topics: gatsby-starter, gatsbyjs, graphql, pwa, reactjs, shopify, shopify-pwa, styled-components
- Language: JavaScript
- Homepage: https://bodega.netlify.com
- Size: 704 KB
- Stars: 102
- Watchers: 14
- Forks: 9
- Open Issues: 33
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Bodega Cloud
A Gatsby Shopify starter
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com)
[![Edit gatsby-starter-shopify](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/98rxxwxj1w)
## Bodega Cloud powered by Gatsby, Netlify, & Shopify
This will be a POC Shopify PWA using the Storefront API & GatsbyJS.
## High Level Project Goals
### Speed
Should be as fast but ideally, faster than a normal Shopify experience - especially for slower connection due to service worker.
### Highly Customizable Theme and Settings
There should be a number of ways to customize the theme without touching the code such as colors, typography, and settings (show breadcrumbs?, etc.)
### Accessible
Out-of-box, the site should be WCAG 2.0 accessible. This means aria tags where needed, AA color contrast, and keyboard accessible navigation with focus styling. This includes things like the gallery.
### Code Complete with regular Shopify themes
Should strive to offer the same features as a normal Shopify theme such as easy homepage section content, all the normal content types. See [this list of issues](https://github.com/gil--/gatsby-starter-shopifypwa/issues/4) which might prevent code complete.
## Install
### ENV
Copy .env.sample to .env.development and change the items to match your store. Make sure to add all .env keys and values in Netlify
### Emails
#### Customer Active
When sending a customer an active email (invite email), the template utilizes a url pattern that does not currently work with Shopify PWA. To simplify setup, change the following items in the *Customer account invite* email notification template (**Settings > Notifications > Customer Account > Customer account invite** or https://YOUR_STORE_NAME.myshopify.com/admin/email_templates/customer_account_activate/edit):
```diff
-Activate your account
+{% assign url_parts = customer.account_activation_url | split: '/' %}
+Activate your account
```#### Password Reset
Shopify Password Resets urls do not currently work with the Storefront API and are also presented in a sturcture that requires custom Server-Side Routing. To simplify setup, change the following items in the *Customer account password reset* email notification template (**Settings > Notifications > Customer Account > Customer account password reset** or https://YOUR_STORE_NAME.myshopify.com/admin/email_templates/customer_account_reset/edit):
```diff
-Reset your password
+{% assign url_parts = customer.reset_password_url | split: '/' %}
+Reset your password
```We're basically splitting the reset password url into URL parameters which will make it MUCH easier for Gatsby to understand.
### Webhooks
Setup webhooks with Netlify to auto-deploy after product creation, update, and deletion.
1. Got to https://app.netlify.com/sites/MY_NETLIFY_APP/settings/deploys
2. Scroll down to **Build Hooks** and click the *Add build hook* button.
3. Create a new Build Hook such as **Shopify Product Update**.
4. Go to `https://YOUR_STORE_NAME.myshopify.com/admin/settings/notifications` and scroll down to Webhooks. Select **Create webhook** and for Event select *Product update* for example.
5. For the URL, enter the one Netlify gave you in step 3.
6. You can test the Webhook by clicking the **Send test notification** link and you should see a new build begin in Netlify.
7. Repeat steps 1 through 6 for any additional Shopify Events that should trigger a new build.## Deploy
[![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/gil--/gatsby-starter-shopifypwa)
### Instructions
1. Have your Shopify store name (If it's https://shopifypwa.myshopify.com, the store name would be **shopifypwa**) and [access token ready](https://www.shopify.com/partners/blog/17056443-how-to-generate-a-shopify-api-token). Enter those as the environment variables after clicking the deploy button above.
2. Enable Netlify Identity in order to enable the Admin CMS. Go to `https://app.netlify.com/sites/YOURAPPNAME/identity` and click **Enable Identity**.## Features (WIP)
The following are planned features. Many of these are not planned for the initial release.
- ✅ Works Offline (Service Workers)
- ✅ Registration & Logic
- ✅ Shopify Product Pages
- ✅ Shopify Collection Pages
- [ ] Native-Like Homepage Sections
- [ ] Page Builder (Easily Build CMS Pages & Category Landing Pages)
- [ ] Theme Customizer (Colors, Typography, Basic Theme Features On/Off)
- [ ] Excellent SEO
- [ ] Rich-Media Cards (Twitter, Facebook)
- [ ] OOB Analytics Support (GA Ecommerce, GTM)
- [ ] WCAG AA Accessible
- [ ] PWA Functionality (Offline, Notifications, Manifest)
- [ ] Advanced Search (3rd Party Integration)
- [ ] WebPayments API Support? Shopify Dynamic Checkout?
- [ ] AR Product Support
- [ ] Advance Related Products
- [ ] 3rd Party Reviews Support
- [ ] 3rd Party Chat Support
- [ ] Mega Menu
- [ ] Login/Registration (My Orders)
- [ ] Order Status Lookup
- [ ] FAQ Page Template (w/ Typeahead search)