Skip to content

Latest commit

 

History

History
54 lines (36 loc) · 3.49 KB

README.md

File metadata and controls

54 lines (36 loc) · 3.49 KB

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 i command to install dependencies
  3. Run npm run build command to compile error pages and config
  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.tcss file. Custom Tailwind theme settings can be added to theme.tailwind.config.js file located in a root of theme directory. Also Tailwind 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.