Reveal.js is a free and open-source HTML presentation framework that helps you make a beautiful presentation via a web browser. It uses open web technologies to make a presentation, change styles with CSS, include an external web page using an iframe, and use JavaScript API to add custom behavior.

In this post, we will show you how to install Reveal.js on Fedora.

Step 1 – Install Nodejs and NPM

First, you will need to install Node.js and NPM packages on your server. You can install both packages with the following command.

dnf install nodejs npm -y

Once both packages are installed, you can verify the Node.js version with the following command.

node --version
Output.
v14.19.0

Step 2 – Install Revealjs

First, install the Git package using the following command.

dnf install git

Next, download the latest version of Reveal.js using the following command.

git clone https://github.com/hakimel/reveal.js.git

Next, navigate to the downloaded directory and install all required dependencies using the following command.

cd reveal.js
npm install

Next, run the following command to run the Reveal.js application.

npm start

You will get the following output.

> reveal.js@4.5.0 start /root/reveal.js
> gulp serve

[05:18:41] Using gulpfile ~/reveal.js/gulpfile.js
[05:18:41] Starting 'serve'...
[05:18:41] Starting server...
[05:18:41] Server started http://localhost:8000
[05:18:41] LiveReload started on port 35729
[05:18:41] Running server

Press the CTRL+C to stop the application. We will create a systemd service file to manage the application in the next section.

Step 3 – Create a Systemd Service File for Revealjs

Next, create a systemd unit file to manage the Reveal.js application.

nano /lib/systemd/system/reveal.service

Add the following code.

[Service]
Type=simple
User=root
Restart=on-failure
WorkingDirectory=/root/reveal.js
ExecStart=npm start

Save and close the file, then reload the systemd daemon to apply the changes.

systemctl daemon-reload

Next, start and enable the Reveal service with the following command.

systemctl start reveal
systemctl enable reveal

You can verify the active status of Reveal.js using the following command.

systemctl status reveal

Output.

● reveal.service
     Loaded: loaded (/usr/lib/systemd/system/reveal.service; static)
     Active: active (running) since Sat 2023-05-20 05:19:14 EDT; 4s ago
   Main PID: 12825 (npm)
      Tasks: 22 (limit: 4666)
     Memory: 128.8M
        CPU: 5.232s
     CGroup: /system.slice/reveal.service
             ├─12825 npm
             └─12836 gulp serve

May 20 05:19:14 fedora systemd[1]: Started reveal.service.
May 20 05:19:15 fedora npm[12825]: > reveal.js@4.5.0 start /root/reveal.js
May 20 05:19:15 fedora npm[12825]: > gulp serve
May 20 05:19:18 fedora npm[12836]: [05:19:18] Using gulpfile ~/reveal.js/gulpfile.js
May 20 05:19:18 fedora npm[12836]: [05:19:18] Starting 'serve'...
May 20 05:19:18 fedora npm[12836]: [05:19:18] Starting server...
May 20 05:19:18 fedora npm[12836]: [05:19:18] Server started http://localhost:8000
May 20 05:19:18 fedora npm[12836]: [05:19:18] LiveReload started on port 35729
May 20 05:19:18 fedora npm[12836]: [05:19:18] Running server

Step 4 – Configure Nginx for Revealjs Application

At this point, the Reveal.js application is running and listening on localhost on port 8000, so you will need to configure Nginx as a reverse proxy to access the Reveal.js application from the remote machine.

First, install the Nginx package using the following command.

dnf install nginx

Next, start and enable the Nginx service using the following command.

systemctl start nginx
systemctl enable nginx

Next, create an Nginx virtual host configuration file.

nano /etc/nginx/conf.d/reveal.conf

Add the following configuration.

upstream reveal_backend {
  server localhost:8000;
}

server {
    listen 80;
    server_name reveal.example.com;

    location / {
        proxy_pass http://reveal_backend/;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header Host $http_host;

        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forward-Proto http;
        proxy_set_header X-Nginx-Proxy true;

        proxy_redirect off;
    }
}

Save and close the file, then edit the Nginx main configuration file.

nano /etc/nginx/nginx.conf

Add the following line after http{:

server_names_hash_bucket_size 64;

Save the file, then restart the Nginx service to apply the changes.

systemctl restart nginx

Step 5 – Access Revealjs Web UI

Now, open your web browser and access the Reveal.js presentation using the URL http://reveal.example.com. You should see the Reveal.js default presentation on the following screen.

revealjs dashboard

Conclusion

In this post, we explained how to install the Reveal.js presentation framework on Fedora. We also configured Nginx as a reverse proxy to access Reveal.js on the internet. Try to install Reveal.js on VPS hosting from Atlantic.Net!