Back to Top

How to Setup and Install Magento 2 PWA Studio

Updated 31 January 2023

Let’s Learn how to set up PWA Studio Setup and Setup Venia Project on the Production Server

Magento recently introduced PWA(Progressive Web App) Studio project in Magento 2.3 version.
Magento PWA Studio is a suite of tools designed to empower developers to develop online stores as progressive web apps.

What are Progressive Web Apps?

The popularity of PWA is growing at very fast in the field of e-commerce, business,
online news portal and other fields because of its peculiar characteristics listed
below follows:
1. Faster User Interface Support
Web developers can now load an entire website to a browser after just one pageview even on slow networks.
2. Home Screen Shortcut
Mobile users can install the PWA site on their home screen like a Native App.
3. Offline Support
Implementation of service workers makes it able to work offline. The website can now be accessible even to users who lost internet connectivity. PWA sites cache content to ensure that some content can be served when a user is offline.
4. Background Processes
If the user facing poor connectivity or offline, the browser store all the form submission data and requests, When connectivity returns it re-sent all the data in the background.
5. Secure
PWA sites use HTTPS connections for enhanced security.

Let’s back to setup PWA in Magento 2.

PWA Studio project used modern tools and libraries:
Webpack
Webpack’s primary function is to create one or more bundles from the dependencies in your project’s modules.
ReactJs
A JavaScript library for building user interfaces.
Redux
A JavaScript library used for managing state in a web application.
GraphQL
A data query language on the client side and a service layer on the server side.

Searching for an experienced
Magento 2 Company ?
Find out More

PWA Installation 

Let’s start with Magento 2.3 installation.

Note: You must have a version of NodeJS >=10.14.1, and Yarn >=1.13.0. The latest LTS versions of both are recommended.

1. Enter the following command:

composer create-project --repository-url=https://repo.magento.com/ magento/project-community-edition /var/www/html/mage0

/var/www/html/mage0 is a Magento installation directory.

2. Install Magento by Command Line:

php bin/magento setup:install --base-url=http://localhost/mage0 --db-host=localhost --db-name=mahesh_mage0 --db-user=root --db-password=webkul --admin-firstname=John --admin-lastname=Doe [email protected] --admin-user=admin --admin-password=admin123 --backend-frontname=admin_magento --language=en_US --currency=USD --timezone=Asia/Tbilisi --cleanup-database --use-rewrites=1

When you have completed with Magento installation, Now

3. Now clone the PWA Studio repository

 https://github.com/magento-research/pwa-studio.git
git clone https://github.com/magento-research/pwa-studio.git

I have cloned this repository in the Magento root directory ex: /var/www/html/mage0

4. You will see the pwa-studio directory in /var/www/html/mage0.
Enter into this directory:

cd pwa-studio/

5. Run

yarn install

6. Specify the Magento backend server in .env file. you can see the .env.dist file in
/var/www/html/mage0/pwa-studio/packages/venia-concept/ direcoty. If you are not
able see, enable show hidden files. Now create .env file from this env.dist

cp packages/venia-concept/.env.dist packages/venia-concept/.env

7. Open this .env file and find MAGENTO_BACKEND_URL. Here configure your
local Magento 2.3 instance, in my case it is:

MAGENTO_BACKEND_URL="https://magento2-pwa.com/"

7.1 Generate SSL certificate because PWA features require an HTTPS Secure Domain. From the root directory of PWA (/pwa-studio) run the below command:

yarn buildpack create-custom-origin packages/venia-concept

Note: 7.1 Feature requires administrative access.

8. Now let install sample data for venia-theme to make it good-looking.

9. Find the deployVeniaSampleData.sh file in
/var/www/html/mage0/pwa-studio/packages/venia-concept/ directory. and copy this
file in your Magento root directory. Now it must look like
/var/www/html/mage0/deployVeniaSampleData.sh Now run:

bash deployVeniaSampleData.sh

10. After successful installation run:

bin/magento setup:upgrade
bin/magento indexer:reindex
bin/magento cache:flush

Open your Magento instance, you will be able to see the installed sample data like:
pwa-sample-data

11. Now go back to PWA-studio directory /var/www/html/mage0/pwa-studio and
start the Server.

yarn run build

The above command may give the permission error, for that run the above command with sudo.

sudo yarn run build

12. Run server, Use any of the following commands from the project root directory to start
the server:

yarn run watch:venia
yarn run watch:all
yarn run build && yarn run stage:venia

The above commands may give the permission error, for that run the above command with sudo.

you can find more about the above commands from the Venia storefront setup

13. Now browse the application, you will the application URL on the terminal like:

PWA Dev Server ready at https://magento-venia.local.pwadev:8001

OR

Launching staging server…

https://magento-venia.local.pwadev:51828/

Staging server running at the address above.

Note: You might get the issues that the product’s images are not loading on PWA.
To fix this issue, create a virtual host, as I have created https://magento2-pwa.com that must be pointing to your pub directory of Magento instance, not to the root directory of your Magento.

Congratulations! You have set up your development environment for the Venia theme project.

Setup Venia Project on the Production Server

Tested on version: @magento/pwa-buildpack v3.0.0

Note: Make sure HTTPS is enabled for your domain.

Let’s we have a domain https://mahesh.webkul.com we want to set up PWA on this server.

Follow the same steps (as sudo user) as I have explain above.

Enable a port on this server to run Node Server on this port ex (Port: 8724).

  1. Now edit pwa-studio/packages/venia-concept/.env file
  2. Find the Staging server Section.
  3. Remove #(remove comment) and add

STAGING_SERVER_HOST=mahesh.webkul.com

STAGING_SERVER_PORT=8724

Let’s start staging the Venia server.

sudo yarn run build && yarn run stage:venia

You will see that the UPWARD server started, now you can access the URL

http://mahesh.webkul.com:8724/

PWA Studio Setup

Thank you for reading the dev doc article on how Magento 2 PWA Studio setup. If you need any help, please reach out to our team via a support ticket.

Find the complete range of Magento 2 extensions including PWA and Headless PWA.

Current Product Version - pwa-buildpack v3.0.0

Supported Framework Version - Magento 2.0.x, 2.1.x, 2.2.x,2.3.x, 2.4.x

. . .

Leave a Comment

Your email address will not be published. Required fields are marked*


36 comments

  • Tushar
  • Иван Костюк
  • Romain
    • Mahesh Singh (Moderator)
      • Romain
        • Mahesh Singh (Moderator)
          • Romain
          • Mahesh Singh (Moderator)
  • vishal katkar
    • Mahesh Singh (Moderator)
      • vishal katkar
  • Amit Sankhala
    • Mahesh Singh (Moderator)
      • Amit Sankhala
        • Mahesh Singh (Moderator)
  • sakshi lakshkar
    • Mahesh Singh (Moderator)
      • Murali
        • Mahesh Singh (Moderator)
          • Murali
          • Mahesh Singh (Moderator)
  • Milan Chauhan
  • Tri Huynh
  • Joseph Reiner
    • Mahesh Singh (Moderator)
      • Joseph Reiner
        • Mahesh Singh (Moderator)
  • Jignesh Parmar
    • Mahesh Singh (Moderator)
  • Bhavesh Jalondhara
    • Mahesh Singh (Moderator)
  • Rashain
    • Mahesh Singh (Moderator)
  • Solidblack
    • Mahesh Singh (Moderator)
    • govind
  • Back to Top

    Message Sent!

    If you have more details or questions, you can reply to the received confirmation email.

    Back to Home