HugoPerard / standup-app

App for Bearstudio standups
standup-app.vercel.app
MIT License
9 stars 4 forks source link

Start UI

Opinionated UI starter with

πŸ‘‰ Technology Choices

ℹ️ API calls are mapped on a JHipster backend application.

Installation

yarn install
yarn build

Setup

Go to the Firebase Console and create a project. Get all the credentials and put them in the .env file. An example is available in the .env.example file.

Development

yarn dev

Setup VS code

Create or edit your .vscode/settings.json file with the following code

{
  "i18n-ally.localesPaths": "src/locales"
}

Storybook

yarn storybook

Development with MirageJS (mock)

This is the default behavior.

Do not set the NEXT_PUBLIC_API_BASE_URL variable in the .env file at the root of the project.

Development with a JHipster backend

Create a .env file at the root of the project with the following content:

NEXT_PUBLIC_API_BASE_URL=http://localhost:8080/api

Show hint on development environments

Setup the NEXT_PUBLIC_DEV_ENV_NAME env variable with the name of the environment.

NEXT_PUBLIC_DEV_ENV_NAME=staging
NEXT_PUBLIC_DEV_ENV_COLOR_SCHEME=teal

API Documentation

API documentation is accessible by admins in the app with Swagger-UI.

yarn docs:build

This will build the json documentation from the main file /src/mocks/openapi/openapi.yaml.

Production

NodeJS (recommended)

yarn storybook:build # Optional: Will expose the Storybook at `/storybook`
yarn build
yarn start

Static files

yarn storybook:build # Optional: Will expose the Storybook at `/storybook/index.html`
yarn static:build

Then expose the /out folder.

πŸ’‘ You will need to setup your server to rewrite all /app/* urls to serve the app.html file.


Technology Choices

React

React is a JavaScript library created in 2013 to build reactive user interfaces. At the time of writing, React is probably the front end library the most used to create new projects and has a huge community which is beneficial for the maintainability of the project in terms of developers and online resources.

GitHub Β· License MIT

Next.js

Next.js gives you the best developer experience with all the features you need for production: hybrid static & server rendering, TypeScript support, smart bundling, route pre-fetching, and more. No config needed.

GitHub Β· License MIT

React Router

Next.js is bundled with its own router, but at the time of writing those lines, it does not allow nested routes using a shared layout.

GitHub Β· License MIT

TypeScript

JavaScript is a not typed language. TypeScript is here to help add static type definition. TypeScript helps a lot when it comes to types, interfaces and define contract between functions which helps a lot for a reliable documentation. No worry, the TypeScript adoption is incremental and writing in TypeScript is not mandatory to use Start UI, but it is a good practice to do so to avoid bugs in the future.

GitHub Β· License Apache 2.0

React Query

React Query is a powerful tool to do efficient data synchronization for React. No need of Redux or another global state manager anymore. Usable with fetch, axios, or graphql-request, React Query will do the work and is agnostic of the method you will use.

GitHub Β· License MIT

Storybook

Storybook is an Open Source tool to help you develop framework agnostic components in isolation and document them.

GitHub Β· License MIT

Chakra UI

Chakra UI is a simple, modular, composable and accessible component library that is highly customizable.

GitHub Β· License MIT

Formiz

To create React forms, there is a lot of libraries out there. Formiz will help you create React forms with ease! Composable, headless & with built-in multi steps.

GitHub Β· License MIT