Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/hy-vee/lerna-yarn-workspaces-monorepo

πŸ‰ A Monorepo with multiple packages and a shared build, test, and release process.
https://github.com/hy-vee/lerna-yarn-workspaces-monorepo

babel jest lerna monorepo react storybook styled-components yarn-workspaces

Last synced: 6 days ago
JSON representation

πŸ‰ A Monorepo with multiple packages and a shared build, test, and release process.

Awesome Lists containing this project

README

        

# Monorepo with Lerna & Yarn Workspaces

> A Monorepo with multiple packages and a shared build, test, and release process.

View example ➑️ https://storybook-monorepo.now.sh/

![image](https://user-images.githubusercontent.com/9113740/71946241-d9f43a00-318e-11ea-80c4-72c483b88325.png)

- πŸ‰ [Lerna](https://lernajs.io/) β€Š- The Monorepo manager
- πŸ“¦ [Yarn Workspaces](https://yarnpkg.com/lang/en/docs/workspaces/)β€Š - β€ŠSane multi-package management
- πŸš€ [React](https://reactjs.org/)β€Š - β€ŠJavaScript library for user interfaces
- πŸ’… [styled-components](https://www.styled-components.com/)β€Š -β€Š CSS in JS elegance
- πŸ›  [Babel](https://babeljs.io/)β€Š - β€ŠCompiles next-gen JavaScript
- πŸ“– [Storybook](https://storybook.js.org/) - UI Component Environment
- πŸƒ [Jest](https://jestjs.io/)β€Š -β€Š Unit/Snapshot Testing

## Usage

- `yarn dev` - This starts Storybook for viewing all the components locally.
- `yarn bootstrap` - This installs all of the packages and links dependent packages together.
- `yarn build` - This babelfies all of the packages and creates `/lib` folders for each one.
- `yarn test` - Run all linting and unit tests before committing.
- `yarn test -o` - Run only the tests that have changed.
- `yarn test -u` - Update all of the snapshot tests.

## Lerna

- `lerna changed` - Show which packages have changed.
- `lerna diff` - Show specifically what files have cause the packages to change.

## Linking

When linking inside of the Monorepo, everything works as expected. If you are trying to consume packages from this Monorepo _in a different application_ locally, using `npm link` or `yarn link` [does not work as expected](https://github.com/yarnpkg/yarn/issues/5538). However, we have a workaround for the time being.

1. Run `yarn build`
1. Run `yarn dev`
1. Change the `package.json` of the consumer from `$YOUR_PACKAGE_NAME` (which lives inside the monorepo) to `file:./../monorepo/packages/$YOUR_PACKAGE_NAME`
1. Run `rm -rf node_modules && yarn` in the consumer
1. πŸŽ‰

## Contributing

All formatting and linting should be taken care of for you using [stylelint](https://github.com/stylelint/stylelint), [ESLint](https://eslint.org/), and [Prettier](https://prettier.io/). You should also consider installing an extension for CSS syntax highlighting.

- [vscode-styled-components](https://marketplace.visualstudio.com/items?itemName=jpoissonnier.vscode-styled-components)
- [webstorm-styled-components](https://github.com/styled-components/webstorm-styled-components)
- [Other IDEs](https://www.styled-components.com/docs/tooling#syntax-highlighting)

## FAQ

### Why the limitation on yarn versions?

[It's a known issue](https://github.com/yarnpkg/yarn/issues/7807) that yarn workspaces using yarn versions > `1.18.0` can produce the following false positive error message when adding or updating dependencies in packages.

```
error An unexpected error occurred: "expected workspace package to exist for "XXX".
```

To guard against this, we've:

- Changed `package.json` to enforce a yarn version range.
- Added a `.yvmrc` file, so if you're using [yvm](https://yvm.js.org/docs/overview) to manage your yarn versions (like [nvm](https://github.com/nvm-sh/nvm) for node version), it'll pick up the yarn version automatically.