- Server Side
- Client Side
- Tips and Tricks
- The boilerplate is based off off Shopify's tech stack and follows their baseline practices to ensure easy migration between templates. One major difference is we're not treating the server side as a module, so you cannot use
import
statements, instead you're usingrequire
. - The template uses MongoDB (
mongoose
) as it's database. MongoDB is starter friendly since a lot of tutorials on the internet are based on the MERN stack, it's easier for newbies to understand the structure of the project and working with basic APIs and understand how auth works.
- The repo comes with all middlewares setup and ready to go to pass auth and ensure things work in accordance to guidelines published by Shopify for app devs.
- A basic router is setup at
server/routes/index.js
so you can create your routes and combine them there without having to worry about figuring out where to add in the routers.
- Using a new package
raviger
to add in navigation and routing. I've found it to be much easier to work with, since there's no unnecessary need to use Switches and other boilerpate code. - Add all your routes to
src/GlobalRoutes.jsx
and then you can usenavigate("/path")
to navigate around, just like Next.js' good ol'router.push("/path")
- You can refer to raviger documentation, and a quickstart guide to understand how it works, passing props and other good stuff.
- In
src/pages/RecurringSubscriptions.jsx
, thereturnUrl
can also be replaced withconst returnUrl =
https://${shopOrigin}/admin/apps/${process.env.SHOPIFY_API_KEY};`.- The reason I personally don't prefer this is because Shopify will be moving the admin URL from
store-name.myshopify.com/admin
toadmin.shopify.com
and this specific implementation could break things in the future. Re-running the auth workflow means the redirection would be handled by Shopify and would take us to the right URL directly. - Also I find this super interesting on how the API Key can be used as an alternative to redirect the user to the app.
- The reason I personally don't prefer this is because Shopify will be moving the admin URL from
This section is a collection of tips and tricks I use to speed up my workflow. If you have any, please feel free to add 'em. I use macOS
so if you're on Windows, this may/may not work.
- If you're running this project on GitHub Codespaces and want to run MongoDB on the platform, run the following command in terminal:
wget -qO - https://www.mongodb.org/static/pgp/server-5.0.asc | sudo apt-key add -;sudo apt-get install gnupg;wget -qO - https://www.mongodb.org/static/pgp/server-5.0.asc | sudo apt-key add -;echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu bionic/mongodb-org/5.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-5.0.list;sudo apt-get update
- The above code will install MongoDB. Alternatively, you can follow the official installation guide available here
- MongoDB won't run with
mongod --dbpath mongo/
without root permissions. Runsudo mongod --dbpath mongo/
instead and it'll work as intended.
"env": "cp -R .env.example .env"
: This is to copy the.env.example
and create a.env
file (or overwrite it). I usually jump between apps to test functionality or have to switch out variables and this comes really handy in resetting.env
files."mongo": "rm -rf mongo/; mkdir mongo; mongod --dbpath mongo/"
: This is to remove themongo/
directory if it exists, create a newmongo
directory and start a MongoDB server in themongo/
directory. Comes really handy when you want to start over or test out scenarios like app reinstall, or you just want to start afresh and crash your app to see how it can be improved. You can also break the command into two parts, one to delete and create themongo/
directory and the other to start themongod
server."pregit": "clear; npm run pretty; git add ."
: This is really handy to prettify code and adding all files for staging into agit commit
. Also if you've made any mistakes,prettier
usually throws an error (if you missed them somewhere) and comes really handy to ensure, yet again, that the code is running and has been prettified.
clear; npm run dev
: Dev instance.clear; npm run ngrok
: Tunnel localhost to https server.mongod --dbpath mongo/
: Local mongo server that runs locally in themongo/
directory.clear; npm run pretty
: This is usually a spare window that is open depending on what stage of dev I'm in. I like to write the whole code and format for that specific section to be isolated with extra new lines and spaces so it's in focus, then a quick prettify to bring it all together.
I like to be very clear on how I am building my apps. This is my workflow:
- Use pen and paper to sketch out the app UI, with Shopify Polaris Components open.
- Design in Figma.
- Use the Shopify Polaris Playground repo I built to see how the UI feels like.
- Drop in the UI (without the
App.jsx
file) directly into my repo and then start writing my backend / frontend code.
About using a design tool, don't feel forced to use a tool like Figma, Adobe XD, etc. Your tool's job is to give you freedom and sometimes it's not software, but a white board or pen and paper. Do what makes you feel like you have the freedom to build and you can directly skip making a design set in a tool and code it in with your sketches open.
- Shopify.dev has a Graphiql interface available where you can build your queries and mutations. I personally like to build my queries and mutations here because of how easy it is to test things out and the explore section makes it really easy to build the queries.
- If you want to access queries or mutations, just type in
query
ormutation
and click on Explore, and it'll open up the latest version of end points available. Build your query, prettify and paste in your repo. Also make sure you have the right scopes added in or you're going to run into errors that you may / may not spend an entire day figuring out.