Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coreproject-moe/monorepo
JS monorepo for @coreproject-moe
https://github.com/coreproject-moe/monorepo
coreproject icons stencil stencil-components stencil-js stenciljs stenciljs-components
Last synced: 10 days ago
JSON representation
JS monorepo for @coreproject-moe
- Host: GitHub
- URL: https://github.com/coreproject-moe/monorepo
- Owner: coreproject-moe
- Created: 2024-05-17T03:04:43.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-10-19T00:56:40.000Z (3 months ago)
- Last Synced: 2024-10-19T10:31:32.705Z (3 months ago)
- Topics: coreproject, icons, stencil, stencil-components, stencil-js, stenciljs, stenciljs-components
- Language: TypeScript
- Homepage: https://coreproject-moe.github.io
- Size: 2.55 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Turborepo Design System starter with Changesets
This is an official React design system starter powered by Turborepo. Versioning and package publishing is handled by [Changesets](https://github.com/changesets/changesets) and fully automated with GitHub Actions.
## Using this example
Run the following command:
```sh
npx create-turbo@latest -e with-changesets
```## What's inside?
This Turborepo includes the following:
### Apps and Packages
- `docs`: A placeholder documentation site powered by [Next.js](https://nextjs.org/)
- `@acme/core`: core React components
- `@acme/utils`: shared React utilities
- `@acme/tsconfig`: shared `tsconfig.json`s used throughout the monorepo
- `@acme/eslint-config`: ESLint presetEach package and app is 100% [TypeScript](https://www.typescriptlang.org/).
### Utilities
This Turborepo has some additional tools already setup for you:
- [TypeScript](https://www.typescriptlang.org/) for static type checking
- [ESLint](https://eslint.org/) for code linting
- [Prettier](https://prettier.io) for code formatting### Useful commands
- `yarn build` - Build all packages and the docs site
- `yarn dev` - Develop all packages and the docs site
- `yarn lint` - Lint all packages
- `yarn changeset` - Generate a changeset
- `yarn clean` - Clean up all `node_modules` and `dist` folders (runs each package's clean script)### Changing the npm organization scope
The npm organization scope for this design system starter is `@acme`. To change this, it's a bit manual at the moment, but you'll need to do the following:
- Rename folders in `packages/*` to replace `acme` with your desired scope
- Search and replace `acme` with your desired scope
- Re-run `yarn install`## Versioning and Publishing packages
Package publishing has been configured using [Changesets](https://github.com/changesets/changesets). Please review their [documentation](https://github.com/changesets/changesets#documentation) to familiarize yourself with the workflow.
This example comes with automated npm releases setup in a [GitHub Action](https://github.com/changesets/action). To get this working, you will need to create an `NPM_TOKEN` and `GITHUB_TOKEN` in your repository settings. You should also install the [Changesets bot](https://github.com/apps/changeset-bot) on your GitHub repository as well.
For more information about this automation, refer to the official [changesets documentation](https://github.com/changesets/changesets/blob/main/docs/automating-changesets.md)
### npm
If you want to publish package to the public npm registry and make them publicly available, this is already setup.
To publish packages to a private npm organization scope, **remove** the following from each of the `package.json`'s
```diff
- "publishConfig": {
- "access": "public"
- },
```### GitHub Package Registry
See [Working with the npm registry](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-npm-registry#publishing-a-package-using-publishconfig-in-the-packagejson-file)