The content in this repository is temporary, we are making new web design for WebX DAO. If you want to help, please message us on Discord
Make sure to read our contributing guidelines
git clone https://github.com/WebXDAO/WebXDAO.github.io.git
cd WebXDAO.github.io
npm install
This step is only required the very first time.
npm run build
npm run start
- Netlify CMS (Currently WIP 🚧):
Netlify CMS is used to handle the CMS part of this static website. It uses Git as backend, so there is no need to maintain a different server. Maintained by the awesome folks of Netlify.
Eleventy is a simpler static site generator using JavaScript. Eleventy will compile all of our files and generate a static output where we can host it anywhere.
Alpine JS is a minimal framework to provide JavaScript behavior in our markup. Think it as a lite version of React & Vue. We use Alpine JS to add JavaScript components like Dropdown, Toggle etc.
Tailwind CSS is a utility first CSS Framework. It has a set of preset utility classes to style anything without touching CSS file.
Root /
folder of our project contains all configuration files like tailwind.config.js
, .eleventy.js
etc..
/src
folder contains all of our site contents and data. Before configuring anything, you go to the /src
folder and make some changes to see if its working.
Go to the /src
folder and open index.html
file. Now make any changes and save it to see if the changes are reloading or not. If it's reloading with your changes, then it means it's working perfectly. If you have any issues, comment here or raise an issue at GitHub.
- This is the new folder structure :
src
│ index.html
│
└───__data
│ │ navigation.yaml
│ │ settings.yaml
│
└───__includes
│ │ default.html
│ │
│ └───partials
│ │ navbar.html
│ │ footer.html
│
└───static
│ │
│ └───css
│ │
│ └───img
.eleventy.js
.eleventyignore
.gitignore
.nojekyll
CODE_OF_CONDUCT.md
LICENSE
package.json
package-lock.json
postscss.config.js
tailwind.config.js
README.md
Writing code with NEAT Stack is fun because of Nunjucks. Eleventy supports Nunjucks Templating language by default. So that you can split HTML Code and avoid writing repetitive code like a boss.
Including a part of HTML is easy. Go to src/_includes/partials/navbar.html
and make some changes there. Now we can include the navbar anywhere we wanted using {% include ..}
Another great feature of Nunjucks is the Loops. Suppose you have a card block repeating over 10 times, using Nunjucks, just write it once and loop it. That means you will be able to modify easily by changing in one place. The data should be separated here and it will be handled seamlessly by our Eleventy.
Example Nunjucks loop :
_data/navigation.yaml
:
---
items:
- text: HOME
url: "/"
- text: LEARN
url: "/learn"
- text: BLOG
url: "/blog"
- text: ABOUT
url: "/about"
- text: PROJECTS
url: "/projects"
navbar.html
:
<ul>
{% for item in navigation.items %}
<li class="nav__item">
<a href="{{ item.url }}">{{ item.text }}</a>
</li>
{% endfor %}
</ul>
That's it. Adding classes or modifying layout is now easier since Eleventy & Nunjucks combined do all the magic for us.
Since we talked about the _data
above. If you enter the data as raw text inside a page, it means you cannot edit that text using CMS. So it's important to plan initially according to your needs. Make a list on which data you need to change later and which is not.
By default, Eleventy looks for a folder called _data/
and get the data from the files inside. They accept json, yaml, js etc. So you can write data in any format you like. If you have to fetch a data from a different server, you can create .js file which returns the data.
The
_data
folder name can be changed using Eleventy configuration
Its really simple to create pages or sections in Eleventy. Just create an HTML file in the /src folder and it will automatically build it as a page. If you are writing a blog, you can even use Markdown (.md
file type) as well.
- Create a file called
blog.html
---
title: Our Blog
layout: default
path: blog
---
<div class="container max-w-3xl mt-6 px-6">
<h1 class="font-bold text-5xl">{{title}}</h1>
{{ content | safe }}
</div>
- Access it to localhost:8080/blog/
Adding interactivity is easy using Alpine JS. You can learn more about from the docs. Here's how a simple Toggle works with Alpine JS.
<nav x-data="{ isOpen: false }" @keydown.escape="isOpen = false">
<button @click="isOpen = !isOpen"">Menu </button>
<div :class="{ 'block': isOpen, 'hidden': !isOpen }" @click.away="isOpen = false" x-show.transition="true">
... menu
</div>
</nav>
Here you can see the initial data is created for isOpen
and its set to false
and it changes the data on button click. Based on the Value, we just toggle the div
visibility. Wasn't it easy compared to jQuery? We didn't even created a js
file.