Welcome to the Administer Contribution Guide! We are happy to have your interest in our project. This document oulines the guidelines for contributing to our projects, ensuring an enjoyable experience for everyone and ensure our maintainers are able to quickly and efficiently address your issues and merge requests.
We are committed to providing a welcoming and inclusive environment. By participating, you agree to abide by our Code of Conduct. Please read it before contributing.
If you encounter bugs, glitches or other issues please:
- Check the issue tracker to see if it's already reported.
- Open a new issue, providing:
- A clear, descriptive title.
- Steps to reproduce the issue.
- Expected vs. actual behavior.
- Relevant logs, screenshots, or code snippets of applicable.
If you believe it is a bug with Roblox rather than Administer please report it to them, we cannot do anything about it.
Have an idea for the Administer ecosystem? Share it with us by:
- Searching the issue tracker first to see if it has already been suggested.
- Opening a feature request issue, describing:
- The problem your feature solves.
- Your proposed solution.
- Any alternative approaches considered.
Alternatively, you can open a ticket in our Discord server.
- Fork the Repository: Click the "Fork" button at the top of the repository page.
- Clone Your Fork:
git clone https://github.com/your-username/repository-name.git cd repository-name
- Create a Branch: Use a descriptive name (for example,
fix-typo-in-readme
orcreate-notification-card
)git checkout -b branch-name
- Make Changes: Make sure to follow our development guidelines.
- Push Your Changes:
git push origin branch-name
- Submit a Pull Request: Open a PR on the original repository, linking it to the issue it addresses (if applicable).
You can help by correcting typos, improving clarity or adding examples. The process for contributing documentation is the same as contributing code.
We welcome changes or additions to translations or other localization. We do not have a system such as weblate but you are welcome to add or modify changes to the translation folder. Please do not contribue if you do not natively understand the target language, do not use automated translators (Google Translate, Apple Translate app, Yandex, ...) to push translations.
- Follow the style of existing code in the project.
- Write clear, maintainable, and self-descriptive code. Use comments if necessary.
- Use the standard variable naming convention for languages (PascalCase in Lua, camelCase in Java/TypeScript, snake_case in Python)
-
Use clear, concise messages.
-
Structure:
<type>(<optional scope>): <description> [Optional body] [Optional footer]
-
Commit Types:
feat
Adds or removes a featurefix
Fixes one or more bugs/issuesrefacor
Rewrite or restructure a piece of code without changing behaviorperf
A variant ofrefactor
that improves performancedocs
Changes documentationimprovement
Improves an existing feature with better UX or alikestyle
Improving the code style (white-space, formatting, etc)
-
Scopes:
- Optional, used to provide more context
- Tailored to each repo
- Don't use issue identifiers as scopes
-
Breaking Changes Indicator
- Indicate breaking changes with a
[!!]
before the:
in the subject line. - Example:
feat(button) [!!]: remove events
- Indicate breaking changes with a
-
Description
- Mandatory part of the format
- Use imperative, present tense "change" not "changed" or "changes"
- Don't capitalize the first letter
- No period (
.
) at the end
-
Body
- Optional, used to describe motivation
- Use imperative, present tense "change" not "changed" or "changes"
- This is where issue identifiers and their relations are put
-
Footer
- Optional, include any information about breaking changes
- Optionally reference an issue with its identifier (ex.
Fixes #2
) - Breaking changes should start with
BREAKING CHANGE:
followed by a space, the rest of the commit message is then used for breaking changes
Examples:
-
feat: add new button properties
-
feat(api): add new endpoint for monitoring statistics
-
feat [!!]: remove button events addresses #33 BREAKING CHANGE: buttons no longer fire callbacks.
-
fix(button): fix wrong anchor point
-
refactor(prompt): change how buttons are parented
- Reference relevant issues in your PR description (as described above).
- Ensure your branch is up-to-date with the
main
branch:git fetch origin git checkout main git merge origin/main
- Write a detailed PR description.
- Be responsive to feedback during the review process
- We will review it in a couple of days usually, please do not try to mention maintainers or otherwise annoy/pester us.
If you have questions, need guidance, or want to discuss contributions:
- Join our Discord server.
- Post on our Discussion board.
By contributing, you agree that your contributions will be licensed under the same license as the project (generally GNU AGPL 3.0). Refer to the LICENSE file in the repository for details.
We're excited to collaborate with you! Thanks for contributing to Administer.