1.33.56 • Published 1 year ago

@atk/mise-ui v1.33.56

Weekly downloads
1,201
License
UNLICENSED
Repository
-
Last release
1 year ago

Mise en place is a French term for having all your ingredients measured, cut, peeled, sliced, grated, etc, before you start cooking. In the same light, Mise UI is a design system and component library for America’s Test Kitchen.

The current state of the master branch can be viewed here: https://mise-ui.netlify.com

To start the app:

Run yarn run storybook and wait for a browser window to open localhost:9009

Storybook

Mise UI is a Storybook app built with React. Storybook is an isolated UI development environment for UI components. Stories are written in Component Story Format (CSF).

Visual review

To review work with others, push your branch to origin/staging. Netlify will build and deploy to http://staging--mise-ui.netlify.com. The master branch is always viewable here: https://mise-ui.netlify.com

Workflow

Create a branch

git checkout -b create-avatar-list-component

Code and commit

git commit -am "Added AvatarList and stories"

Document your code

Add comments to your components which Storybook will use as documentation.

For example:

/**
 * A list of Avatars, ellipsized to at most 3. Supports passing only a subset of the total user count.
 */
export function AvatarList({ loading, users, userCount, size, ...props }) {
}

AvatarList.propTypes = {
  /**
   * Are we loading avatar data from the network?
   */
  loading: PropTypes.bool,
  /**
   * A (sub)-list of the users whose avatars we have data for. Note: only 3 will be displayed.
   */
  users: PropTypes.arrayOf(
    PropTypes.shape({
      id: PropTypes.string.isRequired,
      name: PropTypes.string,
      avatarUrl: PropTypes.string,
    })
  ),
  /**
   * The total number of users, if a subset is passed to `users`.
   */
  userCount: PropTypes.number,
  /**
   * AvatarList comes in four sizes. In most cases, you’ll be fine with `medium`.
   */
  size: PropTypes.oneOf(Object.keys(sizes)),
};

Commit the changes and push to GitHub

git commit -am "Improved AvatarList docs"
git push -u origin `create-avatar-list-component`

Create a PR

Create a Pull Request

The design system’s Storybook is automatically published each pull request to make review dead simple. Scroll down to the PR checks, at the bottom of the PR, to find a link to the deployed Storybook.

You should look for something like deploy/netlify - Deploy preview ready

The online Storybook is a universal reference point for the team. Share the link to AvatarList with other stakeholders to get feedback faster.

Verify changes via tests

  • Chromatic?
  • Snapshots?
  • Unit tests?

Distribute

When tests pass, stakeholders have reviewed and approved and other devs have given thumbs up it's time for the release.

To make sure the release is versioned properly on NPM, you will leverage labels on GitHub. Auto provides a list of labels that will affect whether a new NPM release is a patch, minor or major release. Unsurprisingly, these labels are patch, minor, major. The full list of labels can be found here.

For example: Add the minor label to the PR. This tells Auto to update the minor version of the package on merge.

Labels are located in the right hand column of the PR.

IMPORTANT

Travis has been removed from Github which ran the build to provide the version number to add to associated Repos, such as espresso. This version will need to be generated manually. Before merging to master add 2 labels (patch and release). In the code editor, enter:

yarn build && yarn tsc && npx auto shipit

Wait for the build to complete, and the version number will be available to copy into your package.json.

Next, merge your PR with the two labels and navigate to your package on npm. Hang tight for a few minutes while the package is updated.

Previewing in jarvis, or other ATK repos with yalc

When developing and authoring multiple packages (private or public), you often find yourself in need of using the latest/WIP versions in other projects that you are working on in your local environment without publishing those packages to the remote registry.

See documentation for more info

Install yalc globally

yarn global add yalc

Now run publish, it will copy all the files that should be published in remote NPM registry. Don't forget to update the version number!

yalc publish

With yalc puclished in remote NPM registry, it's already visible to other repos. But if you want to continue the changes in mise-ui run the following

yarn watch

Then add the following to any other ATK repos that would want to see the changes. It will automatically see the changes and update in the application(It might take some seconds)

cd ../jarvis
yalc link @atk/mise-ui

Now just start the repo's development server and it's all set.

When you are done working on mise-ui changes, you might want to 'remove' jarvis.

cd ../jarvis
yalc remove @atk/mise-ui

DEPRECATED - Previewing in jarvis, or other ATK repos

If you are making changes in mise-ui and would like to preview those changes immediately in jarvis, you will need to link your local copy of mise-ui to your local jarvis.

The following commands assume your local repos are stored in /src, adjust the commands to suite the location you have selected on your computer.

-$ cd /src/mise-ui
-$ yarn link
-$ npm link ../jarvis/node_modules/react-instantsearch-dom
-$ npm link ../jarvis/node_modules/react
-$ npm link ../jarvis/node_modules/styled-components
-$ npm link ../jarvis/node_modules/styled-components-breakpoint
-$ cd ../jarvis
-$ yarn link @atk/mise-ui
-$ cd node_modules/styled-components
-$ npm link ../react

Note that two of the above commands use yarn and two use npm. The order of the npm commands is important. Make sure you link react-instantsearch-dom and then react. If you see 'Invalid Hook Call' errors, you might need to re-run these commands with the correct order.

The link commands create symlinks between your local mise-ui and jarvis so that the node_modules folder in jarvis points to your local mise-ui codebase. The npm link commands make it so that jarvis uses its local copies of the packages (react and react-instantsearch-dom) instead of using the versions in the mise-ui/node_modules folder.

Read Invalid Hook Call Warning for more details.

After each change that you make in mise-ui, you will need to compile your code since jarvis looks at the files in ./dist, not in ./src.

-$ yarn run build

You will also need to restart jarvis.

When you are done working on mise-ui changes, you might want to 'unlink' jarvis.

-$ cd /src/jarvis
-$ yarn unlink @atk/mise-ui
-$ yarn add @atk/mise-ui

Your jarvis branch should now be pointing to the lastest NPM version of atk/mise-ui.

Contributors ✨

Thanks goes to these wonderful people (emoji key):

This project follows the all-contributors specification. Contributions of any kind welcome!

1.33.55

1 year ago

1.33.56

1 year ago

1.33.52

1 year ago

1.33.51

2 years ago

1.33.50

2 years ago

1.33.49

2 years ago

1.33.44

2 years ago

1.33.46

2 years ago

1.33.45

2 years ago

1.33.48

2 years ago

1.33.47

2 years ago

1.33.43

2 years ago

1.33.40

2 years ago

1.33.42

2 years ago

1.33.41

2 years ago

1.33.35

2 years ago

1.33.34

2 years ago

1.33.37

2 years ago

1.33.36

2 years ago

1.33.39

2 years ago

1.33.38

2 years ago

1.33.20

3 years ago

1.33.29

2 years ago

1.33.22

3 years ago

1.33.21

3 years ago

1.33.24

3 years ago

1.33.23

3 years ago

1.33.26

3 years ago

1.33.25

3 years ago

1.33.28

2 years ago

1.33.27

3 years ago

1.33.31

2 years ago

1.33.30

2 years ago

1.33.33

2 years ago

1.33.32

2 years ago

1.33.19

3 years ago

1.33.18

3 years ago

1.33.17

3 years ago

1.33.16

3 years ago

1.33.11

3 years ago

1.33.13

3 years ago

1.33.12

3 years ago

1.33.15

3 years ago

1.33.14

3 years ago

1.33.10

3 years ago

1.29.0

3 years ago

1.30.0

3 years ago

1.31.0

3 years ago

1.33.3

3 years ago

1.33.4

3 years ago

1.33.1

3 years ago

1.33.2

3 years ago

1.33.7

3 years ago

1.33.8

3 years ago

1.33.5

3 years ago

1.33.6

3 years ago

1.33.9

3 years ago

1.32.0

3 years ago

1.33.0

3 years ago

1.24.0

3 years ago

1.25.0

3 years ago

1.26.0

3 years ago

1.27.0

3 years ago

1.28.0

3 years ago

1.23.18

3 years ago

1.23.17

3 years ago

1.23.16

3 years ago

1.23.22

3 years ago

1.23.21

3 years ago

1.23.20

3 years ago

1.23.15

3 years ago

1.23.14

3 years ago

1.23.13

3 years ago

1.23.12

3 years ago

1.23.11

3 years ago

1.23.10

3 years ago

1.23.9

3 years ago

1.23.7

3 years ago

1.23.8

3 years ago

1.23.6

3 years ago

1.23.5

3 years ago

1.23.4

3 years ago

1.23.2

3 years ago

1.23.3

3 years ago

1.23.1

3 years ago

1.22.0

3 years ago

1.23.0

3 years ago

1.21.0

3 years ago

1.20.0

3 years ago

1.18.0

3 years ago

1.19.0

3 years ago

1.17.0

3 years ago

1.16.0

4 years ago

1.15.0

4 years ago

1.13.0

4 years ago

1.14.0

4 years ago

1.12.0

4 years ago

1.10.0

4 years ago

1.11.0

4 years ago

1.9.0

4 years ago

1.8.2

4 years ago

1.8.1

4 years ago

1.6.0

4 years ago

1.7.4

4 years ago

1.8.0

4 years ago

1.7.3

4 years ago

1.7.2

4 years ago

1.7.1

4 years ago

1.7.0

4 years ago

1.5.3

4 years ago

1.5.2

4 years ago

1.5.0

4 years ago

1.4.1

4 years ago

1.4.0

4 years ago

1.3.3

4 years ago

1.3.2

4 years ago

1.3.1

4 years ago

1.3.0

4 years ago

1.2.0

4 years ago

1.1.3

4 years ago

1.1.1

4 years ago

1.1.2

4 years ago

1.1.0

4 years ago

1.0.0

4 years ago

0.1.27

4 years ago

0.1.26

4 years ago

0.1.25

5 years ago

0.1.24

5 years ago

0.1.23

5 years ago

0.1.22

5 years ago

0.1.20

5 years ago

0.1.18

5 years ago

0.1.19

5 years ago

0.1.17

5 years ago

0.1.15

5 years ago

0.1.16

5 years ago

0.1.14

5 years ago

0.1.13

5 years ago

0.1.12

5 years ago

0.1.11

5 years ago

0.1.10

5 years ago

0.1.9

5 years ago

0.1.8

5 years ago

0.1.7

5 years ago

0.1.6

5 years ago

0.1.5

5 years ago

0.1.4

5 years ago

0.1.3

5 years ago

0.1.2

5 years ago

0.1.1

5 years ago