Skip to content

Latest commit

 

History

History
152 lines (109 loc) · 3.35 KB

README.md

File metadata and controls

152 lines (109 loc) · 3.35 KB

🍕 JWT Pizza

Coverage badge

A JSON Web Token, or JWT, (pronounced JOT) is a digitally signed transfer of information using JSON notation. Because you can validate the digital signature you can buy JWT pizzas with confidence.

JWT Pizza takes the next stage of digital evolution by allowing you to buy pizzas that you can never actually eat. Not only does JWT exchange bitcoin and give you nothing in return, it also allows for you to be come a franchisee and turn the whole vapor company into an MLM.

You can see a working example of the application at pizza.cs329.click

Running locally

  1. Fork this repository Fork repo

    and then clone the fork from your GitHub account to your development environment.

    git clone https://github.com/youraccountnamehere/jwt-pizza.git
  2. Change to the repo dir and install the dependencies

    cd jwt-pizza
    npm install
  3. Run vite

    npm run dev

Development notes

JWT Pizza uses Vite, React, Tailwind, and Preline. The following contains some notes about how these components were integrated into the project.

Vite

Create the basic Vite app.

npm init -y
npm install vite@latest -D

Modify package.json

  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview"
  },

React

React works out of the box with Vite, but we do need to install the desired React packages. The index.html file loads index.jsx which then loads the app component (src/app.jsx).

npm install react react-dom react-router-dom

Tailwind

To process the Tailwind css we are going to use postcss and autoprefixer.

npm install -D tailwindcss postcss autoprefixer
npx tailwindcss init

Modify tailwind.config.js

/** @type {import('tailwindcss').Config} */
module.exports = {
  content: ['index.html', './src/**/*.{html,js,jsx}'],
  theme: {
    extend: {},
  },
  plugins: [],
};

Create a main.css and add the basic Tailwind directives.

@tailwind base;
@tailwind components;
@tailwind utilities;

Modify index.html to include tailwind output.css.

<head>
  ...
  <link href="./main.css" rel="stylesheet" />
</head>

Now when you run with npm run dev the css will automatically be generated.

Preline

Added the Tailwind Preline component library so that I can use all of their nifty nav, slideshow, containers, and cards.

npm i preline

Updated the tailwind config to use preline.

const defaultTheme = require('tailwindcss/defaultTheme');

module.exports = {
  content: ['index.html', './src/**/*.{html,js,jsx}', './node_modules/preline/preline.js'],
  theme: {
    extend: {
      fontFamily: {
        sans: ['Inter var', ...defaultTheme.fontFamily.sans],
      },
    },
  },
  plugins: [require('preline/plugin')],
};

Import preline into app.jsx.

import 'preline/preline';

Initialize components whenever the page location changes.

import { useLocation, Routes, Route, NavLink } from 'react-router-dom';

export default function App() {
  const location = useLocation();

  useEffect(() => {
    window.HSStaticMethods.autoInit();
  }, [location.pathname]);
  //...

Icons

HeroIcons - MIT license