The Human Made Web Style Guide and Pattern Library. Head over to humanmade.github.io/hm-pattern-library to see it in action!
- Matthew Haines-Young, @mattheu
- Samantha Miller, @sambulance
Refer to the documentation for full usage instructions.
PRs merged to the main
branch will be automatically built using CircleCI. Generated assets will be pushed to a main-built
branch by the CI deploy task, and the /dist/
folder from this build will be pushed to the gh-pages
branch.
The gh-pages
branch is the release branch for this project. Release tags should only be created on gh-pages
.
Run these commands to get it running locally
git clone git@github.com:humanmade/hm-pattern-library.git hm-pattern-library
cd hm-pattern-library
nvm use
to select the project's required node version using nvmnpm install
- The sass and html can be compiled by running the command
npm run build
.
The Human Made pattern library generates flat HTML and does not require a web server to be loaded. Once compiled, the HTML can be opened in your browser via the file system. You can simply access the compiled index file directly at …/dist/index.html
All local development should be done against the main
branch. dist
(which contains the compiled files) is ignored from version control and must be created using the gulp
task. Releases are just the content of dist
and nothing else.
All contributions should relate to an issues. If the issue does not exist, open an issue in the original repository, this will give your issue a number.
When creating a branch, name your branch [issue-number]-short-summary
.
Before submitting a pull request, you will need to confirm your sass meets our coding standards by running gulp lint-sass
.
When you push your branch, you will be able to submit a pull request. Travis CI runs on the repository and will need to pass on all pull requests.
If Travis CI fails, you can push further commits to the branch to fix the build.
This project follows the BEM CSS naming convention.
Sub-components are indicated with an __
, variants with a --
block
block__child
block__child--variant
In the styles/components directory, components should be placed in a file named for the component, _component.scss
.
Utilities are prefixed with util-
, for example util-clearfix
. A utility should be placed in the styles/utilities directory in a file named for the utility, _clearfix.scss
.
Class names in vendor files should not be changed, the files should be placed in the styles/vendor directory and included as any other file would be included. These files do not need to meet our linting standards.
- We need the icon file in SVG format. Ping babi if you need a new one as she can make sure they have consistent height and visual weight.
- The source svg file must have black fill. The gulp script will generate red and white icons by doing a search/replace for
fill="#000000"
- Add the icon to this directory:
src/images/icons/
- Add the icon to the list of icons in the SCSS file.
- Add the icon to the list of icons in the icons documentation HTML file.
3.0.0
- New HM brand colors. This changes links to blue for accessibility contrast reasons, and will require manual rework if consuming themes expect links to be red.
2.1.0
- Updated typography styles
2.0.3
- Compatability with Node 16 and M1 Macs.
2.0.2
- Update npm dev dependencies to fix vulnerabilities
- Compatability with Gulp 4
2.0.1
- Mail icon.
2.0
- Big overhaul for the new HMN.MD design. Version 2.0 breaks backwards compatability with older versions.
- New: Labels, Pagination.
- Simplify, removing search and collapsable nav components, and associated JS>
1.0.5
- Labels & Tag cloud styles
- New alternate variant plus/minus icons. Removes need for 'beige' variations.
- New iconSrc helper function.
- Remove animations from nav to fix overflow hidden bug.
- New icon helper mixin. Also new lock and comment icons.
- Fix some bugs in tables
- Refactor links/buttons to break hard dependency.
1.0.4
- Use component colour variables with brand variables as defaults for easier customizing. Props @missjwo
1.0.3
- Better gulp tasks for icons and logos. Note if you are referencing logo file directly, you will need to update your paths.
1.0.2
- Add styles for WordPress galleries
- Make variables defaults
1.0.1
- Prevent images breaking out of container.
1.0.0
- First stable release