| sidebar | auto |
|---|
Thanks for being interested in contributing to this project!
Clone this repo to your local machine and install the dependencies.
yarn installWe use Vitepress for rapid development and documenting. You can start it locally by
yarn devFeel free to enhance the existing functions. Please try not to introduce breaking changes.
There are some notes for adding new functions
- Before you start working, it's better to open an issue to discuss first.
- The implementation should be placed under
packages/coreas a folder and exposing inindex.ts - In the
corepackage, try not to introduce 3-rd party dependencies as this package is aimed to be as lightweight as possible. - If you do want to introduce 3-rd party dependencies, please contribute to add-ons.
- You can found the function template under
packages/core/_template/, details explained in the Function Foloder section.
Please note you don't need to update the
indexes.jsonor packages'index.ts. They are auto generated.
New add-ons are greatly welcome!
- Create a new folder under
packages/, name it as your add-on name. - Add add-on details in
scripts/packages.ts - Create
README.mdunder that folder. - Add functions as you would do to the core package.
- Commit and submit as a PR.
We use monorepo for multiple packages
packages
shared/ - shared utils across packages
core/ - the core package
firebase/ - the Firebase add-on
[...addons]/ - add-ons named
A function folder typicality contains these 4 files:
You can found the template under
packages/core/_template/
index.ts # function source code itself
demo.vue # documentation demo
index.test.ts # jest unit testing
index.md # documentationfor index.ts you should export the function with names.
// DO
export { useMyFunction }
// DON'T
export default useMyFunctionfor index.md the first sentence will be displayed as the short intro in the function list, so try to keep it brief and clear.
# useMyFunction
This will be the intro. The detail descriptions...Don't worry about the code style as long as you install the dev dependencies. Git hooks will format and fix them for you on committing.
Thank you again for being interested in this project! You are awesome!