Page Kit provides a high quality, well tested, and thoroughly documented set of tools for assembling and delivering FT.com based upon the best industry standards.
Page Kit is not a single part but a set of packages which provide the different pieces required to deliver a reliable production website. The packages can be roughly grouped into 4 categories:
Page Kit provides Webpack and Babel configuration which is capable of transpiling, bundling, and optimising client-side JavaScript code. The config can be configured and extended to suit your requirements and several plugins are provided which enable support for Sass, code splitting, and more.
Page Kit includes several packages which are designed to help assemble and render a Web page. This includes packages for template rendering, utilities to find and load client-side assets, and fetch data needed to render the global UI components.
Page Kit has packages to help make fast loading websites which include all of the metadata and information needed by search engines and social networks. There are packages which provide browser feature detection and script loading, and utilities to format Open Graph and Linked Data.
Page Kit includes a set of packages which provide the markup, behaviour, and styles for rendering global interface components such as the FT.com header, navigation, and footer.
To get started with Page Kit, you'll need to make sure you have the following software tools installed.
- Git
- Node.js (version 12 or higher is required)
- npm
- GNU Parallel (Optional, for running parallel
watch
scripts)
Please note that Page Kit has only been tested in Mac and Linux environments. If you are on a Mac you may find it easiest to install the Command Line Tools package which includes Git.
-
Clone the Page Kit Git repository and change to the new directory that has been created:
git clone [email protected]:Financial-Times/dotcom-page-kit cd dotcom-page-kit
-
Install all of the project dependencies (this may take a few minutes if you are running this for the first time):
npm install
-
Compile all of the packages (again, this may take a while if you are running this for the first time):
npm run build
-
You can now choose to run an example application or start Storybook to view UI component demos. Examples are located in the
examples/
directory and each have their own instructions. To use Storybook you can follow the guide below.
Before writing any new code you may also find it useful to refer to the architecture overview and contribution guide which covers coding standards and expectations.
The repository groups all public packages together in a single packages/
directory. There is also an example/
directory which includes several applications which demonstrate the usage of various packages and provide the basis of the integration and end-to-end tests.
Packages follow a naming convention which broadly denotes their functionality, these are:
dotcom-middleware-*
An Express compatible middlewaredotcom-build-*
A plugin for the Page Kit CLI build taskdotcom-server-*
A generic Node.js moduledotcom-types-*
Shared TypeScript declaration filesdotcom-ui-*
A UI component
If you're interested to know more about our approach of building so many small packages see our architecture overview and design decisions document.
Storybook is a development environment and showcase for UI components. It makes working on and sharing UI components easier by providing a richly configurable environment.
Before starting Storybook you must first run the build script for all packages (if you have not done so already) using this command:
npm run build
Once all of the packages have been built you can run Storybook using the following the command:
npm run storybook
The Storybook interface should then open in your default browser. Storybook has been configured to automatically find stories inside packages with names prefixed with dotcom-ui-
.
The deployment of Storybook to Github Pages is managed by our CircleCI workflow. It is able to deploy to Github Pages by using a personal access token created from the next-team
Github account, stored in the GH_TOKEN
Vault environment variable.
All of the user facing applications that together make up FT.com used to use a package called n-ui
. This package provided:- tools to build and load client-side code; client-side bootstrapping; template loading and configuration; global header, footer, and layout UI; navigation menu data; tracking and analytics setup; ads configuration; global messaging components; and more! Although we relied on this module heavily it was not well understood by the current team and was tightly coupled to technical decisions that were made several years ago.
Page Kit splits all of this functionality into a set of loosely coupled, individually documented, and tested packages. They provide a flexible foundation which teams can build upon rather than prescribing a whole solution.
See the original pitch document for more information.
Page Kit has completely replaced n-ui
on FT.com.
This project does not include any visual changes to the FT.com so the relationship between FT.com and Origami is unchanged.
Page Kit has been designed to work on FT.com applications and should not be used outside this team.