mirror of
https://github.com/inventree/inventree-website.git
synced 2025-04-27 21:16:45 +00:00
90 lines
4.1 KiB
Markdown
90 lines
4.1 KiB
Markdown
# InvenTree website
|
|
This project contains the source for InvenTree's website.
|
|
It is built on Jekyll and GitHub pages for backend / hosting, tailwindcss for design and Netlify for preview builds.
|
|
|
|
[](https://app.netlify.com/sites/inventree-org-preview/deploys)
|
|
|
|
## Adding a plugin to the list
|
|
|
|
Any maintainer of a plugin can add their plugin to the list. The plugin will be listed on the website, we might provide a mechanism to discover plugins from within InvenTree in the future.
|
|
|
|
To add a plugin the following steps are required:
|
|
- Fork the repository
|
|
- Create a new branch. We recommend `plugin/<plugin-name>` as the branch name.
|
|
- Create a new file in `_repo`. We recommend using the package name as the file name.
|
|
- Copy the content from `_repo/template.md` into the new file.
|
|
- Fill out the details. Please make sure to use the correct format for the fields.
|
|
- If this is your first contribution to the list, please add yourself to the `_publishers` folder.
|
|
- Use your GitHub username as the file name.
|
|
- Copy the content from `_publishers/_template.md` into the new file.
|
|
- Fill out the details. Please make sure to use the correct format for the fields.
|
|
- Commit your changes and create a pull request. We recommend using the title `[REPO] Add plugin <plugin-name>`.
|
|
|
|
Please note that the plugin list is moderated as we see fit and we reserve the right to reject plugins that do not meet basic quality standards. We will try to provide feedback in the pull request if that is the case.
|
|
|
|
As a maintainer of a plugin we count on you to keep the information up to date. If you want to update the information, please create a pull request.
|
|
The plugin list is just getting started as a static collection, we might enhance the features in the future. If we need more information or make significant changes to the list, we will ping the maintainers via their GitHub handle - so please keep your main GitHub handle up to date in your publisher file.
|
|
|
|
## Architecture and development
|
|
|
|
The website consists of content, layouts and assets. Jekyll runs and builds out of these files static html files - that are then hosted on GitHub pages.
|
|
|
|
### Folders and files
|
|
Folders with an underscore prefixed are internal folders for Jekyll, folders without are rendered as subdirectories in the output.
|
|
|
|
Structure:
|
|
`_data` contains data that is references on pages
|
|
`_drafts` contains drafts for blog pages and news items
|
|
`_news` contains news entries
|
|
`_posts` contains blog entries
|
|
`_publishers` contains authors/publishers of blog entries, news items and plugins
|
|
`_repo` contains plugin repo entries
|
|
|
|
Layouts:
|
|
`_includes` contains partials that can be used in layouts
|
|
`_layouts` contains the page definitions
|
|
|
|
Assets:
|
|
`assets` contains static assets for the pages
|
|
|
|
The site configuration is saved in `config.yaml`, required gems in `Gemfile` and npm packages in `package.json`.
|
|
|
|
The CSS stylesheet uses tailwindcss and is built with postcss on demand. NodeJs is needed for this. The main css file is located in `assets/index.css`. Rebuilds are handled by the workflows automatically.
|
|
|
|
### Preview builds
|
|
|
|
Once a PR is created, a preview build is created on Netlify. The preview build is available at `https://<pr-number>-inventree-org-preview.netlify.app/`. The preview build is automatically updated when the PR is updated.
|
|
A bot will comment on the PR with the link to the preview build.
|
|
|
|
|
|
### Common commands for local development
|
|
Install packages for ruby and nodejs.
|
|
|
|
```bash
|
|
sudo apt-get install rubygems ruby-dev nodejs npm
|
|
npm install
|
|
sudo gem install bundler
|
|
bundle install
|
|
```
|
|
|
|
Build site locally
|
|
|
|
```bash
|
|
bundle exec jekyll build
|
|
```
|
|
|
|
Run debug server that automatically updates. This does not recompile the tailwindcss stylesheet. If you change something in the css file, you need to build the site fully with the command above.
|
|
|
|
```bash
|
|
bundle exec jekyll serve --incremental
|
|
```
|
|
|
|
### Update dependencies
|
|
|
|
If the above commands fail, you may have outdated ruby gems, or node packages. Update with the following commands:
|
|
|
|
```bash
|
|
bundle update
|
|
ncu -u
|
|
```
|