Component Library package & Component Catalog app code
Go to file
2018-12-18 16:47:08 -06:00
docs Reviews go through Teambot 2018-10-16 10:40:20 +01:00
lib Direct class compatibility (#146) 2018-10-30 16:26:27 -07:00
scripts Prep for 0.19 dual-publish (#163) 2018-11-12 15:38:19 -08:00
src Only show scrollbar when needed 2018-12-17 10:21:03 -08:00
src-0.18 Fix checkbox (#175) 2018-11-15 22:30:40 -08:00
styleguide-app Merge remote-tracking branch 'origin/master' into update-checkbox-text 2018-12-17 11:03:27 +00:00
tests/Spec/Nri/Ui Add Checkbox.V4/PremiumCheckbox.V3 with correct text styling 2018-12-14 12:18:49 +00:00
.envrc add the simplest possible .envrc 2018-12-18 16:47:08 -06:00
.gitattributes Only store images in git lfs 2018-05-04 13:44:30 +02:00
.gitignore ignore documentation.json 2018-12-18 16:42:57 -06:00
.npmignore Updates to TextArea (#70) 2018-06-11 11:08:49 -07:00
.travis.yml dont cache sysconfcpus 2018-12-12 16:30:13 -08:00
elm-package.json Add Checkbox.V4/PremiumCheckbox.V3 with correct text styling 2018-12-14 12:18:49 +00:00
elm.json Add Checkbox.V4/PremiumCheckbox.V3 with correct text styling 2018-12-14 12:18:49 +00:00
LICENSE Initial commit 2017-11-14 16:24:25 -08:00
Makefile use npx for everything 2018-12-18 16:46:32 -06:00
package-lock.json use HTTPS for all source locations 2018-12-18 16:45:43 -06:00
package.json fix test ci script 2018-12-11 21:57:06 +01:00
README.md fix local running instructions in readme 2018-12-11 21:57:06 +01:00
shell.nix version Elm stuff with npm instead 2018-12-18 16:46:07 -06:00

noredink-ui

UI widgets we use.

Dual publishing notes

This package is published for both 0.18 and 0.19! The 0.18 source code is in src-0.18. While we still have codebases that utilize either version we'll need to make updates to any version after 6.0.0 in both src and src-0.18. Eventually, everything will be updated to 0.19 at which point we will delete src-0.18 and stop publishing for Elm 0.18.

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 Nri.Ui.SomeModule.V1 is a direct copy of Nri.SomeModule, switch over to it everywhere!
  • If Nri.Ui.SomeModule.V1 makes changes, 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.

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:

make styleguide-app

If you'd like to test your widget in the monolith before publishing, check out the helpful tips here.

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-packages.json:

elm-package bump
git tag -a 5.10.0 -m "release version 5.10.0"
git push origin master --tags
elm-package 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 the top of https://dmy.github.io/elm-0.18-packages/.