Component Library package & Component Catalog app code
Go to file
Juan Edi 2b976abc03
Merge pull request #340 from NoRedInk/lab/readme--replace-old-usages
Suggestions to replace usages of old versions
2019-08-13 09:28:42 -03:00
docs Reviews go through Teambot 2018-10-16 10:40:20 +01:00
lib Export CustomElement 2019-01-16 17:44:22 -08:00
script update debugging instructions now that the report isn't a file 2019-07-29 14:30:43 -05:00
src Adds href 2019-08-09 16:37:34 -07:00
styleguide-app Merge branch 'master' into tessa/password-supporting-input 2019-08-05 13:01:58 -07:00
tests Verify Modal.V6 example code. 2019-07-30 23:03:59 +02:00
.envrc.nix use absolute path for node binaries 2019-02-14 10:12:31 +01:00
.gitattributes Only store images in git lfs 2018-05-04 13:44:30 +02:00
.gitignore stop hiding bad exit status from axe report 2019-07-29 13:55:00 -05:00
.npmignore Updates to TextArea (#70) 2018-06-11 11:08:49 -07:00
.travis.yml Use node 10 for now on CI 2019-05-02 16:44:31 -07:00
elm.json Bump 2019-08-12 09:09:42 -07:00
LICENSE Initial commit 2017-11-14 16:24:25 -08:00
Makefile Verify Modal.V6 example code. 2019-07-30 23:03:59 +02:00
netlify.toml fix key name in netlify.toml 2019-04-03 05:56:38 -05:00
package-lock.json Verify Modal.V6 example code. 2019-07-30 23:03:59 +02:00
package.json Verify Modal.V6 example code. 2019-07-30 23:03:59 +02:00
README.md Typo 2019-08-13 09:23:12 -03:00
shell.nix add entr 2019-04-02 15:07:26 -05:00

noredink-ui

UI widgets we use.

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 to Nri.Ui.SomeModule.V1 in noredink-ui
  • Publish!
  • If you feel confident upgrading pre-existing usages of the widget, switch over to it everywhere!
  • If the new version introduces big changes and you'd rather keep the old one around for now, rename Nri.SomeModule to Nri.DEPRECATEDSomeModule in the monolith and start using Nri.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.

This means:

  • We should avoid introducing new references to old versions of a widget
  • When touching code that uses a widget, prefer upgrading to the latest version
  • If you introduce a new version of a widget, please consider taking the time to upgrade all previous usages
    • If for some reason this isn't feasible, create a story in your team's backlog so that you can prioritize it separately without disrupting your current work
  • You can delete an old version of a widget when there are no usages left
    • Currently, noredink-ui is used by the monolith, CCS and tutorials
    • Note: this will be a major version bump, so you may want to batch deletions together

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/.