Hey there! 👋 First off, thanks for taking the time to contribute! ❤️
You can contribute in two main ways:
- Improving the code (like fixing bugs or adding cool new features)
- Adding new code snippets (or improving the existing ones!)
If you spot a bug in the codebase or issues with the documentation, please open up a GitHub issue detailing the problem before creating a PR. Once confirmed with maintainers, you can then create a PR.
If you are interested in proposing new features, please open up a new GitHub discussion with details for the proposed feature.
Please do not create a PR for a new feature without first discussing it with the maintainers. If you create a PR for a new feature without discussing it first, then your PR will be closed.
- Tags must describe the snippet with simple word.
Here's an example:
---
title: Convert Number to Currency
description: Converts a number to a currency format with a specific locale.
author: axorax
tags: number,currency
---
Do not use generic keywords or the language itself as a tag utility
or javascript
!
All snippets should follow the following structure:
- A
code
segment, containing a function with the actual snippet functionnality - An
example
segement, containing one or more examples of use
Example in javascript:
function example(x) {
return x * 2;
}
// Usage:
example(5) // Returns: 10
If your function doesn't return anything just show how to use it. If the result of your function is too complicated to be expressed in a single comment, your snippet is probably too complex to begin with.
To ensure your snippet isn’t refused, consider these questions:
- Does the standard library of my language provide an easy way of doing this ?
- Does that snippet not have a real, and practical use case ?
- Could it be split into separate parts to be better understood ?
If any answer is yes, then your snippet will most likely get rejected.
-
Ensure your snippet match guidelines
-
Navigate to the relevant folder:
- Go to the
/snippets
folder in the root directory. - Locate the folder for the programming language of your snippet, such as
javascript
orpython
.
- Go to the
-
Choose the correct category:
- Within the language folder, find the relevant category folder for your snippet.
- If no suitable category exists, refer to Adding a New Category.
-
Create a markdown file:
- Create a new file with a
.md
extension. - Name the file appropriately, keeping it descriptive and concise.
- Create a new file with a
-
Add your snippet:
- Use the following format to structure your snippet:
---
title: Name of the snippet
description: A short explanation of what the snippet does
tags: tag1, tag2, tag3
author: your-github-username
---
```lang
// Your code here
```
Here’s an example for JavaScript:
---
title: Format Date
description: Formats a date in 'YYYY-MM-DD' format.
author: dostonnabotov
tags: date,format
---
```js
const formatDate = (date) => date.toISOString().split('T')[0];
// Usage:
console.log(formatDate(new Date())); // Output: '2024-12-10'
```
-
Use syntax highlighting:
- Enclose your code with triple backticks (```).
- Specify the language after the first set of backticks for syntax highlighting.
-
Test your snippet:
-
Ensure your code runs as expected.
To test that your snippets are formatted correctly use thesnippets:check
script:$ npm run snippets:check
It will return nothing if they are well formatted, otherwise it will tell you what the error is.
To preview the snippets, start the vite server using:
$ npm run dev
It will use HMR to update the snippets in the
/public
folder, making them available to the frontend.
-
Expected file structure:
/snippets
|- language
|- category-name
|- your-snippet-here.md
Please do NOT add or edit anything in
/public
folder. It will be used for consolidating snippets.
If you’d like to refine or improve an existing snippet:
-
Add a
contributors
field:- Include your GitHub username under the
contributors
field in the metadata section.
- Include your GitHub username under the
---
title: Name of the snippet
description: A short explanation of what the snippet does
tags: tag1, tag2, tag3
author: original-author
contributors: your-github-username
---
```
Updated code here
```
-
Credit all contributors:
- If contributors already exist, add your username separated by a comma
contributors: contributor1, contributor2, your-github-username
-
Document changes:
- Clearly indicate what you updated and why in your pull request description.
We want to make sure that original author and contributor(s) are credited for their work.
If your snippet doesn’t fit into any existing category, you can create a new one! Just make sure it’s unique and doesn’t overlap with others (e.g., don’t create separate categories for “Date” and “Time” when “Date and Time” works).
-
Create a new category folder:
- In the relevant language directory, add a new folder.
- Use a lowercase name with hyphens for separation (e.g.,
file-handling
).
-
Add snippets:
- Follow the Adding a New Snippet instructions.
Example structure:
/snippets
|- python
|- file-handling
|- list-manipulation
|- ....
If you want to introduce a new programming language, here's how to do it:
-
Create a language folder:
- Add a new folder under the
snippets
directory. - Name it after the language in lowercase (e.g.,
go
,ruby
).
- Add a new folder under the
-
Add categories and snippets:
- Follow the Adding a New Snippet and Adding a New Category guidelines.
-
Include an icon:
- Add an
icon.svg
file (50x50px) in the same language folder. - Use tools like Resize SVG to ensure the correct size.
- Add an
-
Double-check your work:
- Verify that everything is structured correctly and displays as intended.
To test that your snippets are formatted correctly use the following script:
$ npm run snippets:check
It will return nothing if they are well formatted, otherwise it will tell you what the error is.
To preview the snippets, you need to consolidate them, use the following script:
$ npm run snippets:consolidate
It will update the snippets in the /public
folder, making them available to the frontend.
Whether you’re fixing a tiny typo, writing a new snippet, or dreaming up big features, every bit counts! 🛠️
If you have any questions or need help, feel free to open a new GitHub discussion.
Happy coding! 💻✨