Skip to content

zuhairtaha/hackyourfuture.dk

 
 

Repository files navigation

HackYourFuture.dk

content

this is a fork from Keven repo

to preview on Heroku hosting https://hyf-dk.herokuapp.com/

Why Next.js

nodejs is react server-rendering universal-rendering. It is a framework that most notably allows you to write server-rendered React apps easily – amongst other cool things. Also one of the most important features is SEO-friendly.

project structure refs

The project is depend on Next.js & Express.js, and here is a tutorial about the same structure using both next.js and express.js

Website Fonts

there is two basic fonts: Space Mono, and Work Sans

 @import url('https://fonts.googleapis.com/css?family=Space+Mono|Work+Sans');
 //font-family: 'Space Mono', monospace;
 //font-family: 'Work Sans', sans-serif;

UI components

Many components are coming from Material UI

Note

When we navigate between website urls under development, some porplems appears with navbar and some other places, so we need to restart the server manually with npm start dev The same issue if we added a new module

project structure:

structure

  • server.js is the entry point for this project, which is node.js server based on express.js
  • the backend folder contains express.js routes where we can connect the database later and create our API
  • static folder contains the assets like: images, fonts, icons...
  • pages folder contains the next.js files. Each one of the represent a route or a link at the website. For example: about.js file on the root of this folder represents hackyourfuture.dk/about and so on. We can also make sub-folders contains files to create links like hackyourfuture/folder-name/file-name
  • components folder contains our react components. we are importing these components at pages files.

pages content

most of pages content is comming from components/content/... content is stored in these files as variables. and at pages we are importing them marked module is used to convert the content from markup to html and the component <content> is the wrapper div for them example:

content

Many components are using data coming from json files. You can find these files in the same component folder.

Note: These files are temporary, and the real date will come later from database

JSX styling

the default way to add css for components with next.js is jsx at the components we can add something like:

<style jsx>{`
  body {
    font-size : 16px;
  }
`}
</style>

Navbar

content

components/navbar

This component is a Material-UI component. you can read more about it here.

the content exists at links.json file at the same component folder. Some menus has sub menus which are Material UI Menus component

When is screen is small you will see hamburger icon, which opens left menu, which is Drawer Material UI component

content

Members card

card-memeber

This component is exists under team/card-member and it is responsible for viewing each of:

  • team components/team/index.js
  • core team components/core-team/index.js
  • alumni components/hire/index.js at hire page

Icons

icons

At static/social-icons/font there is an icons font contains some social icons. These icons collected from flaticon.com

Usage example: <i className="flaticon-twitter-logo" />

Hire page

hire

alumni.json file contains temporary list of alumni. At components/hire/index.js we view them with a drop-down menu for filtering them according to there skills. The current options at this list are coming from tags at alumni array.

About

The official website for HackYourFuture Copenhagen

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 90.3%
  • CSS 9.7%