Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zouhangwithsweet/vue-components-lib-seed
:seedling: a vue3.0 components library template. Vue3.0 组件库的次佳实践.
https://github.com/zouhangwithsweet/vue-components-lib-seed
ts-morph vite vue3
Last synced: 7 days ago
JSON representation
:seedling: a vue3.0 components library template. Vue3.0 组件库的次佳实践.
- Host: GitHub
- URL: https://github.com/zouhangwithsweet/vue-components-lib-seed
- Owner: zouhangwithsweet
- License: mit
- Created: 2021-07-11T13:33:37.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-02-16T01:40:42.000Z (almost 2 years ago)
- Last Synced: 2025-01-10T06:36:47.656Z (14 days ago)
- Topics: ts-morph, vite, vue3
- Language: TypeScript
- Homepage: https://vuecomponent-seed.vercel.app
- Size: 2.46 MB
- Stars: 210
- Watchers: 5
- Forks: 31
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# A Vue3 UI library template
[![GitHub stars](https://img.shields.io/github/stars/zouhangwithsweet/vue-components-lib-seed)](https://github.com/zouhangwithsweet/vue-components-lib-seed/stargazers)
[中文文档](https://github.com/zouhangwithsweet/vue-components-lib-seed/blob/master/README.zh-CN.md)
Help you quickly create a component library.
- :rocket: dev with `Vite`
- :airplane: build with `esbuild`
- :helicopter: generate types with `ts-morph`## Docs
power by vitepress
- [doc example](https://vuecomponent-seed.vercel.app/)
## Feature
- :rainbow: Speedy dev & build
- :fireworks: Customize friendly
- :pencil: More beautiful doc, support `Chinese` and `English`. Support `Dark Mode` by [vueuse](https://github.com/vueuse/vueuse)
- :lollipop: Rich scripts, inspired by [esbuild-plugin-vue](https://github.com/egoist/esbuild-plugin-vue) & [vue-dts-gen](https://github.com/egoist/vue-dts-gen)
- :yum: Type friendly
- :truck: `ESM` & `CJS` product## How to use
[Generate a repository by vue-components-lib-seed](https://github.com/zouhangwithsweet/vue-components-lib-seed/generate)
### Checklist
- [ ] Replace all `my-lib` words with your libary name. Just search `my-lib` and replace them in VScode
- `.gitignore`
- `package.json`
- `vite.config.ts`
- `.vitepress`
- `scripts` ...### Install
```bash
yarn
```### Dev
> Benefited from [`vite-plugin-pages`](https://github.com/hannoeru/vite-plugin-pages), the `src/pages/index.vue` is the entry page for development. You can visit `/[component-name]/demo` to check component, like `http://localhost:3000/#/button/demo`.
```bash
yarn dev
```### Build
```bash
yarn build
```### Test
```bash
yarn test
```### Generate entry point
> The entry file is the `input` option for rollup.
```bash
yarn gen-entry
```### Generate Component
> A component's name is required for this command.
```bash
yarn gen [component\'s name]
```### Generate dts
```bash
npx esno ./scripts/gen-dts.ts
```### Release
> This command will add git tag、generate changelog. You can test your lib with argument `--dry`
```bash
yarn release [--dry]
```## Build Docs
> :exclamation: Noted: you should run `yarn build:lib` before run this command. Because the docs need the build bundle.
### Docs dev
```bash
yarn docs:dev
```### Docs build
```bash
yarn docs:build
```### Docs deploy
Here is a git [action](https://github.com/zouhangwithsweet/vue-components-lib-seed/blob/master/.github/workflows/build.yml). When you push the code to the `master` branch, the document will be automatically deployed on `gh-pages` branch.
Then you can set the Github Pages's source on the `gh-pages` branch.### Use demo code in doc
Take button as an example.
In `button.md`, insert the following code
```markdown
:::demo
src/packages/button/demo/demo0.vue
:::
- or
:::demo
src/packages/button/demo/demo*.vue
:::
```~~There is a global component [`Demos`](https://github.com/zouhangwithsweet/fisand-doc/blob/feat_fisand_doc/src/client/app/components/Demos.vue) to display all demos.
This is currently the only way to show demo. [More info](https://github.com/zouhangwithsweet/fisand-doc/blob/feat_fisand_doc/src/node/markdown/plugins/demo.ts).~~### Custom doc style
You can add the `class` in frontmatter, then the `` would inherit the `class`. Of course, the `unocss` can be used here.
```markdown
---
class: 'custom-class'
---
```## Recommended IDE Setup
[VSCode](https://code.visualstudio.com/) + [Volar](https://github.com/johnsoncodehk/volar).
### If Using ``
[`<script setup>`](https://github.com/vuejs/rfcs/pull/227) is a feature that is currently in RFC stage. To get proper IDE support for the syntax, use [Volar](https://marketplace.visualstudio.com/items?itemName=johnsoncodehk.volar) instead of Vetur (and disable Vetur).
## Credits
- [unplugin-vue](https://github.com/sxzz/unplugin-vue)
- [esbuild-plugin-vue](https://github.com/egoist/esbuild-plugin-vue)
- [vue-dts-gen](https://github.com/egoist/vue-dts-gen)
- [vueuse](https://github.com/vueuse/vueuse)
- [vitepress-for-component](https://github.com/dewfall123/vitepress-for-component)
- [unocss](https://github.com/unocss/unocss)
- [Element Plus](https://github.com/element-plus/element-plus)## Thanks
| [<img src="https://avatars.githubusercontent.com/u/73626725?v=4" width="75px;"/><br/>eeeeelle<br/> <sub>:writing_hand:release-script</sub>](https://github.com/eeeeelle) |
| :---: |