docs | ||
lib | ||
script | ||
src | ||
src-0.18 | ||
styleguide-app | ||
tests/Spec/Nri/Ui | ||
.envrc.nix | ||
.gitattributes | ||
.gitignore | ||
.npmignore | ||
.travis.yml | ||
elm-package.json | ||
elm.json | ||
LICENSE | ||
Makefile | ||
netlify.toml | ||
package-lock.json | ||
package.json | ||
README.md | ||
shell.nix |
noredink-ui
UI widgets we use.
Dual publishing notes
All internal consumers of this repository have been upgrade to Elm 0.19, so we will not be continuing to update the Elm 0.18 source.
Versioning policy
We try to avoid breaking changes and the associated major version bumps in this package. The reason for that is to avoid the following scenario:
|
x 4.6.0: Adding RadioButton widget
|
x 5.0.0: Breaking change in the TextArea widget
|
x 5.0.1: Styling fix in the Checkbox widget
|
Suppose you just released version 5.0.1
, a small styling fix in the checkbox widget, for a story you're working on. If the project you're working in currently pulls in noredink-ui
at version 4.x
, then getting to your styling fix means pulling in a new major version of noredink-ui
. This breaks all TextArea
widgets across the project, so those will need to be fixed before you can do anything else, potentially a big effort.
To prevent these big Yaks from suddenly showing up in seemingly trivial tasks we prefer to avoid breaking changes in the package. Instead when we need to make a breaking change in a widget, we create a new module for it Nri.Ui.MyWidget.VX
. Similarly, when we build custom elements in JavaScript we create a file lib/MyWidget/VX.js
and define a custom element nri-mywidget-vX
.
We should change this process if we feel it's not working for us!
Moving Widgets to noredink-ui
If you are moving in a widget from the monolith:
- Copy the contents of
Nri.SomeModule
and its tests toNri.Ui.SomeModule.V1
innoredink-ui
- Publish!
- If
Nri.Ui.SomeModule.V1
is a direct copy ofNri.SomeModule
, switch over to it everywhere! - If
Nri.Ui.SomeModule.V1
makes changes, renameNri.SomeModule
toNri.DEPRECATEDSomeModule
in the monolith and start usingNri.Ui.SomeModule.V1
where you need it
Phasing out old versions
Our goal is to gradually move to the newest version of each widget, and remove the old versions when they are no longer used.
Currently, noredink-ui
is used by the monolith and by CCS. When neither of these repos use a version of a widget, it can be deleted. (Note: this will be a major version bump, so you may want to batch deletions together.)
When touching code that uses a widget, prefer upgrading to the latest version.
Examples
This repo contains an app showcasing all of these UI widgets.
To see them locally:
script/develop.sh
If you'd like to test your widget in the monolith before publishing, run script/test-elm-package.py ../path_to_this_repo
from the monolith's directory.
Tests
Run tests with
make test
CI (Travis)
Travis will run make ci
to verify everything looks good.
You can run this locally to catch errors before you push!
Deploying
Once your PR is merged, you can publish master
as a new version:
Run the following to bump && publish the version in elm.json
:
elm bump
Commit and push your changes in a PR. Once it's approved and merged, then:
git tag -a 5.10.0 -m "release version 5.10.0"
git push origin 5.10.0
elm publish
You can also add a tag in https://github.com/NoRedInk/noredink-ui/releases/new if you want to add more detail.
Once you've published, you should see the latest version at https://package.elm-lang.org/packages/NoRedInk/noredink-ui/.