Getting started with Avada CLI
Install Avada CLI
Within the scope of this training program, it is recommended that you install this specific version of Avada CLI, which generate a boilerplate app that most of our Shopify apps are having:
npm i -g @avada/console@1.0.7
Every @avada
package is hosted on our private registry at https://registry.avada.io
. To install it, you will need
to use our .npmrc
file to authenticate the installation.
//registry.avada.io/:_authToken="OUujf6Frq8k2UbEfzZDK3QKYR0AmYmPZsYBA89LdnIk="
@avada:registry=https://registry.avada.io
registry=https://registry.npmjs.org/
legacy-peer-deps=true
You can put it in your global .npmrc
or you can use the --userconfig flag npm i -g @avada/console@1.0.7 --userconfig=.npmrc
You should install Yarn and NodeJS version 20.11.0 (exact version for compatibility) to have this to work. If you want to use many NodeJS version, use nvm
: https://github.com/nvm-sh/nvm
npm i -g yarn
Run your commands CLI with Git Bash, not PowerShell, or Windows commands line since this does not support Linux commands. If you are using Mac, or Linux, then it would be no problems.
Init app code
Run this command in your desired folder to initialize Avada project. This command will create a fold with your app name, yarn install
your project dependencies and init a git.
avada app:create app-name
Install dependencies
If you create app using Avada CLI, then the CLI already run the yarn install
command for you. There is no need to run it. Remember that you should always run the yarn install
at the project directory only.
You should never run using npm because our project structure relies on the Yarn Workspace to work.
If you by mistake run install using npm install
then you may find npm run dev
or npm run emulators
failed to work. You need to:
- Remove all
node_modules
folders
find . -name 'node_modules' -type d -prune -exec rm -rf '{}' +
- Install using yarn again
yarn install
Setting env files
You will need to do:
- Create firebase project
- Create Firestore database
- Init Firebase authentication
- Create Shopify app
firebase use
your project- Copy your env files
.env.development
,.runtimeconfig.json
, and download your serviceAccount from Firebase
Here is a snippet in the video that you will need:
function firebaseConfigToEnvFile(config) {
const {apiKey, authDomain, projectId, storageBucket, appId, measurementId} = config;
return `VITE_SHOPIFY_API_KEY=
VITE_FIREBASE_API_KEY-${apiKey}
VITE_FIREBASE_AUTH_DOMAIN=${authDomain}
VITE_FIREBASE_PROJECT_ID=${projectId}
VITE_FIREBASE_STORAGE_BUCKET=${storageBucket}
VITE_FIREBASE_APP_ID=${appId}
VITE_FIREBASE_MEASUREMENT_ID=${measurementId}
`;
}
Start development server
Your will need to run npm run dev
and npm run emulators
, so this video to better understand.
Standalone mode
Besides embed mode, you can setup development flow using standalone mode by simply updating the shopify.web.toml
file. Please see this video:
Using Ngrok
Sometimes the Cloudflare server fail to make the tunnel to our ViteJS server at 5000 via Shopify CLI like the images below:
Instead, you can make use of Ngrok to make a tunnel to 5000 port of your local machine, you will need to install Ngrok first and
then start with ngrok http 5000
.
Then you need to add arguments to your commands (my ngrok link is for example)
npm run dev --tunnel-url=https://e2ab-171-224-181-237.ngrok-free.app:5000