Create Ignite App Template

This is the official NoA Ignite base template. It's built with Next.js, Storybook, MUI and NoA Ignite packages. If something doesn’t work, please file an issue.

Getting started

npx @noaignite/create-app my-app
cd my-app

Developing with Storybook

yarn storybook

Then open http://localhost:3001/ to see your app in Storybook. If you need to deploy Storybook app to production, create a minified bundle with yarn build-storybook.

Developing with Next.js

yarn dev

Then open http://localhost:3000/ to see your app in Next.js. When you’re ready to deploy your Next.js app to production, create a minified bundle with yarn build.

Creating a release

When going live, an initial release can be created. To do this, run:

yarn release --first-release --skip.changelog

For subsequent releases, run:

yarn release

Developing the App

Inside the newly created directory, the initial project structure will look something like:

my-app
├── .husky
├── .storybook
├── node_modules
├── .eslintrc.js
├── .prettierrc
├── babel.config.js
├── next.config.js
├── package.json
├── public
│   ├── fonts
│   ├── locales
│   ├── media
│   └── favicon.ico
└── src
    ├── api
    ├── blocks
    ├── components
    ├── containers
    ├── contexts
    ├── layouts
    ├── pages
    ├── utils
    └── pages.stories.js

The philosophy behind some of this structure can be read below.

src/api

The place for your api related utilities.

src/api
├── __mock__ (Mock data used for Storybook)
├── centra
├── utils
├── index.js
└── ...

src/blocks

Blocks are top level modules in the application, hierarchically directly below the App layout and typically defined with a section element at it's root. These can also be configured as choosable modules for the admin panel of chosen CMS. When possible, these should be exported from their common exports file (src/blocks/index.js) using next/dynamic. This will ensure that blocks are chunked and not downloaded to the client on a particular page unless rendered.

src/blocks
├── Hero
├── Media
├── index.js
└── ...

src/components

Components found here are meant to be presentational in nature, meaning they are not supposed to be aware of any overlaying structure such as page specific details or API data. Furthermore you will find the theme configuration and MUI/OUI overrides here. A good rule of thumb is to have components not importing project files outside of src/components.

src/components
├── colors (Color palettes)
├── icons (Icon components)
├── internal (MUI & OUI overrides)
├── styles (Theme configuration)
├── index.js
└── ...

src/containers

Container components are "smart" components, they come in various sizes but what unifies them is that they have some understanding of the overlaying structure. This could be page layout, page routing or API data structure. An example of this could be a <ProductCard product={product} /> component that receives complicated data such as a product object as a prop fetched from an API.

src/containers
├── RouterLink (A Next.js wrapped routing component)
├── index.js
└── ...

src/contexts

This is a good place to add app-level providers that should be accessible from all corners of the application. Providers added here should be exported in the api directory's common export file(s). accessing data or helpers from these providers can look like this import { usei18n } from '~/contexts'.

src/contexts
├── Centra (Centra utilities)
├── Global (App state such as menus, cookie bars and such)
├── I18n (Internalization utilities)
├── RemoteConfig (CMS data or other remote settings)
├── index.js
└── ...

src/layouts

this is a good place to add app-level providers that should be accessible from all corners of the application. providers added here should be exported in the api directory's common export file(s). accessing data or helpers from these providers can look like this import { usei18n } from '~/contexts'.

src/layouts
├── AppBase (Contains the necessary modules which should exist on all pages)
├── App (The default layout to be used)
├── index.js
└── ...

src/pages & src/pages.stories.js

The src/pages directory is used by Next.js to configure page routing. Read more about Next.js pages. The src/pages.stories.js file is used to generate your pages for Storybook based on src/api/__mock__/cms/pages.js.

Both Next.js & Storybook pages use the same createRenderBlock helper found under src/utils/createRenderBlock.js to iterate over Block components as described from an API. Using the same setup helps to keep a consistent codebase across both environments. Don't forget to add your newly created Block component to the common exports file!

One template, two entry points

Component
├── Component.js
├── index.js
└── storybook.index.js (Optional)

The index.js file is used as the exports file for it's module. In some cases there is a need to enhance the module with business logic without adding it to the template file directly, this is the place for that. The benefits of doing so is that a separate exports file can be created for Storybook with or without mocked business logic, this is then added to storybook.index.js. Now two different versions of the module can be imported based on the working environment by importing the module from it's directory path; import Component from 'path/to/Component'.

Other good to knows

Favicons

Generate favicons on favicon.io and replace the files under public.

Fonts

Add font files to public/fonts and import them under src/components/internal/MuiCssBaseline.js. For font preloading add them to src/pages/_document.js. We only preload .woff2 files as it's supported by all browsers other than IE11, and adding the media-query wizardry for that doesn't feel worthy of today. Do note that the crossOrigin attribute may need to change if you're using a different domain for CDN, or loading the font from somewhere else.