Skip to content

A lightweight tool for creating static custom HTTP Error Pages featuring a minimalistic, adaptive, and accessible design, along with support for customization and localization.

License

Notifications You must be signed in to change notification settings

sapachev/error-pages

Repository files navigation

Custom HTTP Error Pages

Lightweight tool to create static HTTP Error Pages in minimalistic adaptive and accessible design with customization and localization support.

Features

  • Static pages with simple and responsive design
  • Lightweight and fast running
  • Extensibility
  • Customization
  • Localization (i18n)
  • Accessibility (a11y)
  • Built-in web server config generator (Nginx)

Screenshot

Demo

How to use

Requirements: installed Node.js 11+

  1. Checkout this repository to your local machine
  2. Run npm install --production command to install dependencies
  3. Run npm run build command to compile error pages and web server configs
  4. Copy static html files from dist directory to your server
  5. Copy and apply config snippet from dist to your web server configuration (see details below).

Nginx

Nginx config located in /dist/<locale>/nginx-error-pages.conf file and can be copied to /etc/nginx/snippets/ directory. According to this config file, all html pages and their assets must be placed to /usr/share/nginx/html/error-pages directory. After copying all files you have to update your server configuration with include /etc/nginx/snippets/nginx-error-pages.conf; line.

How to improve default pages

  • Extensibility A new pages can be added by adding new json files in scr/<locale> directory. The page name must follow to format <HTTP code>.json (<HTTP code> is Number, related to specific HTTP status code). You can put any additional data to json files, that you want to display on a page. In case of common variables, you can use common.json file to define them.
  • Customization By editing default theme you can add anything you want. In case if you want to have own page design, you can create a new theme and apply it by editing config.json file. All assets (images, fonts, etc) must be placed to @assets directory (note: the @assets name is used to avoid a naming collision with default assets directory name in common cases). By default the mustache.js is used as a template engine and Tailwind as a CSS framework. Entry point of Tailwind styles must be located in themes/<name>/@assets/css/main.twnd.css file. Custom Tailwind theme settings can be added to theme.tailwind.config.js file located in a root of theme directory. If you don't want to use Tailwind builder, then it can be disabled by editing tailwind option in config.js.
  • Localization If you need to change default text messages, then you can simply edit existing files insrc/<locale> directory according to your needs. If you want to create your own localization, just simply add new locale directory and create set of source files. After new locale adding, change locale property in config.json file, located in a root.

Contributing

You are very welcome to contribute into this project with improvements, localizations, bug fixes and so on.

About

A lightweight tool for creating static custom HTTP Error Pages featuring a minimalistic, adaptive, and accessible design, along with support for customization and localization.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published