Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/obsidian-community/obsidian-community-lib
An npm package of commonly used Obsidian plugin utilities.
https://github.com/obsidian-community/obsidian-community-lib
obsidian-plugin obsidianmd
Last synced: 3 months ago
JSON representation
An npm package of commonly used Obsidian plugin utilities.
- Host: GitHub
- URL: https://github.com/obsidian-community/obsidian-community-lib
- Owner: obsidian-community
- License: isc
- Created: 2021-10-24T07:19:19.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-08-29T12:06:20.000Z (over 1 year ago)
- Last Synced: 2024-10-13T11:58:02.866Z (4 months ago)
- Topics: obsidian-plugin, obsidianmd
- Language: TypeScript
- Homepage: https://obsidian-community.github.io/obsidian-community-lib/
- Size: 206 KB
- Stars: 65
- Watchers: 4
- Forks: 4
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Codeowners: CODEOWNERS
Awesome Lists containing this project
- jimsghstars - obsidian-community/obsidian-community-lib - An npm package of commonly used Obsidian plugin utilities. (TypeScript)
README
data:image/s3,"s3://crabby-images/e5c28/e5c28ff9357c3b0da0427ce830a3442b5c70d1cb" alt="npm"
# Obsidian Community Lib
This is a community-maintaned library of commonly used functions when developing Obsidian plugins.
To use the library in your plugin:
1. Install it using `npm i obsidian-community-lib`,
2. Then grab functions out of the library using `import { function } from "obsidian-community-lib"`.**Read more about the included methods [here](https://obsidian-community.github.io/obsidian-community-lib/modules.html).**
## Contributing
> **Disclaimer**: By contributing to this repository, you grant the maintainer an irrevocable license to use the contribution under the license specified in the `LICENSE` file found in the root of this repository.
> The maintainer of this project can choose to change the license, or transfer maintainer status at any time.
> Every contributor must not infringe any copyright in their contribution.This library is very much made for everyone to use and contribute to. If you would like to add a function or edit existing functions, please submit a pull request with your changes.
To add new functions, go to `src/utils.ts` and add your code as an exported function.
You can also add an entirely new file under `src` to better organise everything!Then, go to `src/index.ts` and export your functions from the appropriate file. See `src/index.ts` for examples of how to do this.
### Conventional Commits
In your commit messages, it is highly encouraged for you to use the [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) format. This helps keep everything standardised, and allows us to automatically create a changelog file using the commit messages.
VS Code has a conventional commits extension you can use to make this even easier!
data:image/s3,"s3://crabby-images/9525f/9525fe767c36a050e62647f28f0be768efe76c21" alt=""
### TS Doc
In order to make your functions more useable for others, please consider using [TS Doc](https://tsdoc.org) to document your code in a standardised way.
This will show a nicely formatted description of your function when a user hovers over it:
data:image/s3,"s3://crabby-images/d5453/d54534421622c43119c08c5191c280a324bc2020" alt=""
VS Code has an extension to automate alot of this process based on the type declarations in the function definition:
data:image/s3,"s3://crabby-images/b28b2/b28b28802a370ef162f4be3fb0b70a6dce0edccd" alt="image"