Skip to content

We are starting to implement the design to code (Unofficial content)

License

Notifications You must be signed in to change notification settings

hyomiTheTech/WebXDAO.github.io

Repository files navigation

Web 3 Community


Web3 Community is an Open Source Community that focuses on Web 3.0 and Blockchain technologies 🚀

We are currently implementing the design from Figma to code. If you want to help, please check the issue regarding about that. Any suggestions for our website, you can submit an issue here.


Getting Started

Deploy to Netlify

Make sure to read our contributing guidelines

  1. Skip all of the steps below by using Gitpod, which would automatically do all of that for you: Open in Gitpod

2. Clone this Repository

git clone https://github.com/web3community/web3community.github.io.git

3. Navigate to the directory

cd web3community.github.io

4. Install dependencies

npm install

5. Build the project to generate the first CSS

This step is only required the very first time.

npm run build

6. Run Eleventy

npm run start

7. ✨ Enjoy

Technologies used

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.

Folder Structure

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.

Make Changes

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

Nunjucks

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.

Eleventy Data

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

Writing HTML

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.

Example to create a blog page

  1. 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>
  1. Access it to localhost:8080/blog/

Alpine JS

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.

About

We are starting to implement the design to code (Unofficial content)

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 97.5%
  • CSS 2.5%