Skip to content

Commit

Permalink
Merge pull request #199 from IBM-Watson/develop
Browse files Browse the repository at this point in the history
Release v1.0.0-beta-3
  • Loading branch information
Snugug committed Apr 29, 2015
2 parents 49a91c2 + 0d8617e commit 2a4f3e4
Show file tree
Hide file tree
Showing 151 changed files with 2,577 additions and 100 deletions.
3 changes: 3 additions & 0 deletions .bowerrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"directory": "bower_components/"
}
27 changes: 27 additions & 0 deletions .deploy.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
#!/bin/bash

#########################
## Adapted from https://gist.github.com/domenic/ec8b0fc8ab45f39403dd
#########################
set -e # exit with nonzero exit code if anything fails

if [ "$TRAVIS_BRANCH" = "master" ]
then
# Copy CNAME from .www to www (build folder)
mv .www/CNAME www/CNAME

# Move to build folder and init it
cd www
git init

# Configure Git
git config user.name "Travis CI"
git config user.email "[email protected]"

# Commit all the things into the repo
git add .
git commit -m ":shipit: Deploy to GitHub Pages"

# Force push to gh-pages
git push --force "https://${GH_TOKEN}@${GH_REF}" master:gh-pages > /dev/null 2>&1
fi
8 changes: 8 additions & 0 deletions .runner.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
#! /bin/bash
set -e # exit with nonzero exit code if anything fails

wget https://github.com/IBM-Watson/runner/archive/master.zip
7z x master.zip
rm master.zip
rsync -a -v runner-master/ ./
rm -r runner-master
21 changes: 21 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
language: node_js
node_js:
- '0.10'
before_install:
- sudo apt-get update -qq
- sudo apt-get -y install wget p7zip-full
- sh ./.runner.sh
- npm install -g gulp bower
install:
- bower install
- npm install
script:
- gulp build
- sh ./.deploy.sh
env:
global:
- GH_REF: github.com/IBM-Watson/design-library.git
- secure: "b4znv+qFSwOk51r9bfJgpAX3oZOCM8BSpqCuVw3hgEUDnQQKvnHXavUdy8mWTabvDSkp/ikQsp3UaUStTBgrFKhPQagpSlm3WBVhKCqAMqSt8BvwrwDX7hQhzMC1YVlm4JxDRiKPFtimBxlFguBsc528pB2TjQUIpvO+NGQc3zk="
notifications:
slack:
secure: mN+9lpQZPWm1QdUCreWmJ/MQaGi42yTgHQ1yeZJ3iU7NSVMu5uWdcQ5EXjT2+2ge2cCkfzMQb5EeeAXSw20DLggyC+xOcmIZTeYQY3Y8K0Yrky930z/k/IWpn9h5+yRbzYNp+4jWzcQXKMHNJdswVI25BewE4RpqIcxIsoVHGnw=
1 change: 1 addition & 0 deletions .www/CNAME
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
watsondesign.guide
23 changes: 23 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Watson Design Library Changelog

## v1.0.0-beta.3
*April 28, 2015*

**New**

* :memo: Add the CHANGELOG
* Add `aside`, `detail`, `example`, and `quote` [sub-content](https://github.com/IBM-Watson/design-library/wiki/Content-Models#secondary-content-types) templates (`color` existed previously, `media` is a view of `example` and `detail`)
* :memo: Update to Accessibility guidelines
* :memo: Update to Branding guidelines
* :memo: Add Design principles
* :memo: Add Grid guidelines
* :memo: Add Style guidelines
* :green_heart: Add Travis CI integration
* Add CNAME record

**Changes**

* :memo: Update the Contributing guidelines
* Update `layout` template to use new navigation variables
* :fire: Delete outdated color Wordmark and Logotype SVGs
* :art: Replace updated color Wordmark and Logotype SVGs
104 changes: 95 additions & 9 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,97 @@
## Contributing to the IBM Watson Pattern Library
# Contributing to the IBM Watson Design Library

We love contributors! If you would like to contribute to the IBM Watson Pattern Library, please follow the following guidelines:
The Watson Design Library contains the design and development guidelines and resources for creating cognitive experiences. It's built using Sass and available via Bower, so it's easy to include all or part of it within your own project.

* **DO NOT ISSUE A PULL REQUEST WITHOUT RELATED ISSUE!!** All pull requests must reference an issue in the issue queue and will only be looked at after discussion about that issue has taken place. Any pull request created that does not reference an issue will be closed.
* All pull requests will be tested against our standard test suite through Travis CI. If any of the tests fail, we will ask you to fix your code so that the tests no longer fail. Any new features that are added must have accompanying passing tests before being considered. During a pull request, we may ask for additional tests to be written in order to ensure that what is being changed does not have negative effects elsewhere.
* Styling changes must be done in Sass and compiled into CSS, not solely through CSS
* No patterns may rely upon JavaScript frameworks (jQuery, Dojo, Angular, etc…). Any pattern submissions that do will be asked to be rewritten without said dependencies. Acceptable JavaScript dependencies include core JavaScript that we provide and any current dependencies already included in the project. Any additional external dependencies will need to be approved before they can be used.
* Development is done using [Git Flow](http://nvie.com/posts/a-successful-git-branching-model/). It is recommended you use the [Git Flow Git plugin](http://danielkummer.github.io/git-flow-cheatsheet/) for working with feature branches.
* Development is being done following [North's](http://pointnorth.io/#website-building-blocks) naming conventions and best practices. Any code that does not adhere to North's conventions will be asked to be rewritten.
* If your pull request does not apply cleanly we will ask you to fix that before we will look into pulling it in. We may ask you to update or make changes to the code you've submitted, please don't take this the wrong way. If a pull request smells (such as if a large amount of code is all within a single commit, or the coding standards aren't in line with what currently exists) we may ask you to rewrite your commit.
_**Heads Up!** We love open source, but the Watson Design Library is unlikely to add new guidelines or features that are not in-line with the work we're doing or won't be used at IBM Watson. Inclusion is at the discretion of the Watson Design team. We really love to share, though, so hopefully that means we're still friends :blue_heart:_

## Navigating the Repository

There are three main folders of concern for those interested in contributing: `language`, `library`, and `patterns`.

### Language

The `language` folder contains all of the long-form text available and its related assets, with the exception of documentation for individual UI patterns. All content in here follows our [Guideline](https://github.com/IBM-Watson/design-library/wiki/Content-Models#guideline) content model. Within these, there are a number of [Secondary Content Types](https://github.com/IBM-Watson/design-library/wiki/Content-Models#secondary-content-types) that can be used as sub-content. Assets to be downloaded by a user should go in to `language/assets`, images should go in to `language/images`, and videos should go in to `language/videos`. Within each of those folders, assets should be sorted in to sub-folders based on the sub-folder their related content is sorted into.

### Library

The `library` folder contains all of the items needed to compile the content in the `language` and `patterns` folders into the Watson Design Library website. This includes site-specific Sass, JavaScript, configuration, and templates.

### Patterns

The `patterns` folder contains all of the UI patterns and their documentation. Development is being done following [North's](http://pointnorth.io/#website-building-blocks) naming conventions and best practices. Any code that does not adhere to North's conventions will be asked to be rewritten. The folder is divided in to four parts, [base](https://github.com/IBM-Watson/design-library/tree/develop/patterns/base#base-elements), [components](https://github.com/IBM-Watson/design-library/tree/develop/patterns/components#components), [layouts](https://github.com/IBM-Watson/design-library/tree/develop/patterns/layouts#layouts), and [core](https://github.com/IBM-Watson/design-library/tree/develop/patterns/core#core).

No patterns rely upon JavaScript frameworks (jQuery, Dojo, Angular, etc…). Any pattern submissions that do will be asked to be rewritten without said dependencies. Acceptable JavaScript dependencies include core JavaScript that we provide and any current dependencies already included in the project. Any additional external dependencies will need to be approved before they can be used. Styling should be written without vendor prefixes. Only web standard features that have [moved beyond](http://en.wikipedia.org/wiki/World_Wide_Web_Consortium#Specification_Maturation) the Candidate Recommendation stage (or equivalent for the relevant standards body) will be considered for inclusion.

## Submitting Issues

* Before creating a new issue, perform a [cursory search](https://github.com/issues?utf8=%E2%9C%93&q=is%3Aissue+user%3Aibm-watson+) to see if a similar issue has already been submitted.
* You can create an issue [here](https://github.com/IBM-Watson/design-library/issues). Please include as many details as possible in your report.
* Issue titles should be descriptive, explaining at the high level what it is about, and should be written in the same style as [Git commit messages](#git-commit-messages).
* Please include the version of the Design Library you are using/viewing
* Do not open a [pull request](#pull-requests) to resolve an issue without first receiving feedback from a `collaborator` or `owner` and having them agree on a solution forward.
* Include screenshots and animated GIFs whenever possible; they are immensely helpful.
* When submitting a browser bug, please include the browser, version, operating system, and operating system version.
* When submitting an update to or a new feature, pattern, guideline, etc… we prefer to see user research associated with the suggestion including testing methods, results, and sample size, whenever possible. This allows us to make more user-centered decisions and cut through assumptions and individual preferences.
* Issues that have a number of sub-items that need to be complete should use [task lists](https://github.com/blog/1375%0A-task-lists-in-gfm-issues-pulls-comments) to track the sub-items in the main issue comment.


## Pull Requests

* **DO NOT ISSUE A PULL REQUEST WITHOUT FIRST [SUBMITTING AN ISSUE](#submitting-issues)**
* Pull requests should reference their related issues. If the pull request closes an issue, [please reference its closing in your commit messages](https://help.github.com/articles/closing-issues-via-commit-messages/). Pull requests not referencing any issues will be closed.
* Pull request titles should be descriptive, explaining at the high level what it is doing, and should be written in the same style as [Git commit messages](#git-commit-messages).
* Update the `CHANGELOG` with the changes made by your pull request, making sure to use the proper [Emoji](#emoji-cheatsheet).
* Make sure you have [installed the development environment](https://github.com/IBM-Watson/design-library#installation), [updated your runner to the latest version](https://github.com/IBM-Watson/design-library#updating-the-runner), and have [run the library locally](https://github.com/IBM-Watson/design-library#running-locally) to ensure that your code works properly.
* Follow our JavaScript and CSS styleguides. We have linters set up to catch most of it.
* Ensure that you have [EditorConfig](http://editorconfig.org/) installed in your editor of choice and that it is functioning properly.
* Do not squash or rebase your commits when submitting a Pull Request. It makes it much harder to follow your work and make incremental changes.
* Update the [CHANGELOG](#maintaining-thechangelog) with your changes.
* Ensure no Emoji tags are used in the title of your Pull Request

### Git Commit Messages

* Use the present tense (`"Add feature"` not `"Added Feature"`)
* Use the imperative mood (`"Move cursor to…"` not `"Moves cursor to…"`)
* Limit the first line to 72 characters or less
* Include relevant Emoji from our [Emoji cheatsheet](#emoji-cheatsheet)

### Branching Model

* Branches must be made off of the most current `develop` branch from `[email protected]:IBM-Watson/design-library.git`
* Pull requests must be made into our [develop](https://github.com/IBM-Watson/design-library/tree/develop) branch.
* The following branch prefixes should be used when creating a new branch:
* `hotfix/` - bug fixes that got through and need to be squashed
* `pattern/` - update to or new pattern to be added
* `language/` - update to or new piece of long-form text or assets to go along with it
* `library/` - update to or new code for the site
* `release/` - for releases
* `feature/` - update to or new general feature not covered by other prefixes

## Creating a New Version

Versioning is done through [SEMVER](http://semver.org/). When creating a new version, issue a [pull request](#pull-requests) from `develop` into `master` and create new release branch off of `master` with the version's name, and create a new tag with `v` prefixed with the version's name from that branch.

For instance, if you are creating version `1.1.0`, you would start by merging `develop` into `master`, create a branch `release/1.1.0` from `master`, and create a tag `v1.1.0` from branch `release/1.1.0`.

### Maintaining the Changelog

The Changelog should have a list of changes made for each version. They should be organized so additions come first, changes come second, and deletions come third. Version numbers should be 2nd level headers with the `v` in front (like a tag) and the date of the version's most recent update should be underneath in italics.

Changelog messages do not need to cover each individual commit made, but rather should have individual summaries of the changes made. Changelog messages should be written in the same style as [Git commit messages](#git-commit-messages).

## Emoji Cheatsheet

When creating creating commits or updating the CHANGELOG, please **start** the commit message or update with one of the following applicable Emoji. Emoji should not be used at the start of issue or pull request titles.

* :art: `:art:` when improving the format/structure of the code
* :racehorse: `:racehorse:` when improving performance
* :memo: `:memo:` when writing long-form text (documentation, guidelines, principles, etc…)
* :bug: `:bug:` when fixing a bug
* :fire: `:fire:` when removing code or files
* :green_heart: `:green_heart:` when fixing the CI build
* :white_check_mark: `:white_check_mark:` when adding tests
* :lock: `:lock:` when dealing with security
* :arrow_up: `:arrow_up:` when upgrading dependencies
* :arrow_down: `:arrow_down:` when downgrading dependencies
* :shirt: `:shirt:` when removing linter warnings
* :shipit: `:shipit:` when creating a new release
Loading

0 comments on commit 2a4f3e4

Please sign in to comment.