Thanks for considering to contribute!
GitHub's API for Discussions is currently only available through the GraphQL API, which currently requires authentication for all requests. With the way giscus works, you'll need to create a GitHub App in order to get it running on your machine. Follow the self-hosting guide to get it running.
To contribute to giscus, follow these steps:
- Fork the repository to your GitHub account.
- Clone the repository to your device (or use something like Codespaces).
- Create a new branch in the repository.
- Make your modifications.
- Commit your modifications and push the branch.
- Create a PR from the branch in your fork to giscus'
main
branch.
This project is built with Next.js and yarn
as the package manager.
Here are some commands that you can use:
yarn
: install dependenciesyarn dev
: compile and hot-reload for developmentyarn build
: compile and minify for productionyarn lint
: lint and fix filesyarn start
: serve the compiled build in production mode
If you want to submit your custom theme to giscus, create a new file in
styles/themes
. The file name (without .css
) will be the
theme's key. You can use the other theme files as reference (see
custom_example.css
). Once you've added the theme file, add the key
and name to Theme
in lib/variables.ts
to register it. Please
also update the config.json
in each localization in the locales
directory to include a theme=your_theme_key
key.
If you want to customize the syntax themes, you can change the CSS variables
that start with the --color-prettylights-syntax-
prefix. See the
custom_example.css
file for more details.
To support both light and dark mode based on the user's system preferences, you
can use the @media (prefers-color-scheme: dark)
query. For more details, see
the preferred_color_scheme
theme file.
Several classes prefixed with gsc-
are used in the HTML
generated by giscus. You can take advantage of this to further customize your
theme. Note that the classes and HTML structure are subject to change, as
updates to giscus may require modifications to the HTML. You'll need to make
sure that your theme is up-to-date.
If you want to use a custom theme without submitting it to giscus, you can do
so by using a custom theme URL. Note that you cannot
@import
a syntax theme and must inline it in your CSS. That said, if you
create a nice theme, I'd appreciate it if you create a PR instead so others can
use it easily.
If your language is not yet supported by giscus, please contribute a localization! Follow these steps to add a new localization:
- Copy one of the directories in locales and rename the new directory into your language's code.
- Open
common.json
andconfig.json
inside the directory. - Start translating the strings. Make sure to follow your language's
plural rules for translation keys with an object as the value
(e.g. those that require
{{ count }}
). - Copy one of the README files and name it
README.[code].md
, e.g.README.id.md
and translate the content. Add your language to the new README and all the existing READMEs, ordered by the language code. - Edit
i18n.tsx
and update the following variables:availableLanguages
: include your language code and name.rtlLanguages
: include your language code if it is a right-to-left language.dateFormatters
,shortDateFormatters
,shortDateYearFormatters
, andrelativeTimeFormatters
: include new objects with your language code, following the existing languages.
- Edit
i18n.js
and include your language. - In all of the aforementioned files, make sure that the language list is sorted by the language code.
- Create a PR with your localization updates.