mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-05 17:01:17 -05:00
Add contribute file
This commit is contained in:
parent
5aaf0277c1
commit
e6305bbda6
211
CONTRIBUTE.md
Normal file
211
CONTRIBUTE.md
Normal file
@ -0,0 +1,211 @@
|
||||
# Contribute
|
||||
|
||||
This file describes a path to contribute to this project.
|
||||
|
||||
## Bug Reports and Feature Requests
|
||||
|
||||
If you have encountered a problem with QDarkStyle or have an idea for a new
|
||||
feature, please submit it to the
|
||||
[issue tracker](https://github.com/ColinDuquesnoy/QDarkStyleSheet/issues)
|
||||
|
||||
## Contributing to QDarkStyle
|
||||
|
||||
The recommended way for new contributors to submit code to QDarkStyle is to
|
||||
fork the repository on GitHub and then submit a pull request after
|
||||
committing the changes. The pull request will then need to be approved by one
|
||||
of the manteiners before it is merged into the main repository.
|
||||
|
||||
- Check for open issues or open a fresh issue to start a discussion around a
|
||||
feature idea or a bug.
|
||||
- Fork [the repository](https://github.com/ColinDuquesnoy/QDarkStyleSheet)
|
||||
on GitHub to start making your changes to the master branch.
|
||||
- Write a test which shows that the bug was fixed or that the feature works
|
||||
as expected if its a function, or create a screenshot if you are changing
|
||||
the stylesheet evidencing the changes.
|
||||
- Send a pull request and bug the maintainer until it gets merged and
|
||||
published. Make sure to add yourself to
|
||||
[AUTHORS](./AUTHORS.md)
|
||||
and the change(s) to
|
||||
[CHANGES](./CHANGES.md).
|
||||
|
||||
## Getting Started
|
||||
|
||||
These are the basic steps needed to start developing on QDarkStyle.
|
||||
|
||||
- Create an account on GitHub.
|
||||
|
||||
- Fork the main
|
||||
[QDarkStyle repository](https://github.com/ColinDuquesnoy/QDarkStyleSheet)
|
||||
using the GitHub interface.
|
||||
|
||||
- Clone the forked repository to your machine.
|
||||
|
||||
```bash
|
||||
git clone https://github.com/USERNAME/qdarkstyle
|
||||
cd qdarkstyle
|
||||
```
|
||||
|
||||
- Checkout the appropriate branch.
|
||||
|
||||
```bash
|
||||
git checkout master
|
||||
```
|
||||
|
||||
- Setup a virtual environment (not essential, but highly recommended).
|
||||
|
||||
```bash
|
||||
virtualenv ~/.venv
|
||||
. ~/.venv/bin/activate
|
||||
pip install -e .
|
||||
```
|
||||
|
||||
- Create a new working branch. Choose any name you like.
|
||||
|
||||
```bash
|
||||
git checkout -b feature-xyz
|
||||
```
|
||||
|
||||
- Hands on.
|
||||
|
||||
For tips on working with the code, see the Code Guide.
|
||||
|
||||
- Test, test, test.
|
||||
|
||||
Testing is best done through ``tox``, which provides a number of targets and
|
||||
allows testing against multiple different Python environments:
|
||||
|
||||
- Please add a list point to [CHANGES](./CHANGES.md) if the fix or
|
||||
feature is not trivial (small doc updates, typo fixes).
|
||||
|
||||
- Please add you as an author to [AUTHORS](./AUTHORS.md).
|
||||
|
||||
- Add files to commit.
|
||||
|
||||
Add files that are part of your changes, remember that each commit
|
||||
must represent a small but functional change. Remember to add CHANGES.md
|
||||
and AUTHORS.md too. To add all files changed do:
|
||||
```bash
|
||||
git add .
|
||||
```
|
||||
|
||||
- Commiting changes.
|
||||
|
||||
GitHub recognizes certain phrases that can be used to automatically
|
||||
update the issue tracker, so you can commit like this:
|
||||
|
||||
```bash
|
||||
git commit -m "Add useful new feature that does this, close #42"
|
||||
```
|
||||
```bash
|
||||
git commit -m "Fix returning problem for get_style(), fix #78"
|
||||
```
|
||||
|
||||
- Push changes in the branch to your forked repository on GitHub.
|
||||
|
||||
```bash
|
||||
git push origin feature-xyz
|
||||
```
|
||||
|
||||
- Submit a pull request (PR).
|
||||
|
||||
Do it from your branch to the respective branch using the
|
||||
[GitHub PR](https://github.com/ColinDuquesnoy/QDarkStyleSheet/pulls)
|
||||
interface.
|
||||
|
||||
- Wait for mainteiner to review your changes.
|
||||
|
||||
## Logging
|
||||
|
||||
Inside modules we provided a logging that should be used to inform the user.
|
||||
Please, follow the levels bellow.
|
||||
|
||||
- debug: for debug information, high detailed one, directed to programers;
|
||||
- info: something important for common user to know;
|
||||
- warning: something that should not be a big problem or a desicision changed;
|
||||
- error: some error, but not capable of stop program;
|
||||
- critical: something that stops the running program.
|
||||
|
||||
## Guide to QDarkStyle
|
||||
|
||||
Now you can use our example to work on the stylesheet. It has all possible
|
||||
widget provided by Qt - common ones. Feel free to add more to them.
|
||||
|
||||
To simplify the structure, there are separated files in
|
||||
[example.ui](.example/ui/) folder.
|
||||
|
||||
- `dw_buttons.ui`: all types of buttons;
|
||||
- `dw_containers_no_tabs.ui`: all types of containers except for tabs;
|
||||
- `dw_containers_tabs.ui`: all containers tabs;
|
||||
- `dw_displays.ui`: all types of displays;
|
||||
- `dw_inputs_fields.ui`: all types of inputs with fields;
|
||||
- `dw_inputs_no_fields.ui`: all types of inputs without fields;
|
||||
- `dw_views.ui`: all types of views;
|
||||
- `dw_widgets.ui`: all types of widgets;
|
||||
- `mw_menus.ui`: main window with all menus and toolbars.
|
||||
|
||||
*Obs.: `dw` stands for dock widget and `mw` for main window.*
|
||||
|
||||
The entire example is built at runtime, in
|
||||
[example.py](./example/example.py).
|
||||
|
||||
To see more information about it, see its documentation.
|
||||
|
||||
Feel free to modify `.ui` files with Qt Designer and recompile UI using
|
||||
[process_ui.py](./script/process_ui.py) script, inside script folder, using:
|
||||
|
||||
```bash
|
||||
python process_ui.py
|
||||
```
|
||||
|
||||
It will generate all `_ui.py` files for PyQt4, PyQt5, PySide, QtPy, PyQtGraph.
|
||||
|
||||
If you are changing the stylesheet, you will need to recompile the QRC
|
||||
files using [process_qrc.py](./script/process_qrc.py) script, inside
|
||||
script folder.
|
||||
|
||||
```bash
|
||||
python process_qrc.py
|
||||
```
|
||||
|
||||
This generates all `_rc.py` files for PyQt4, PyQt5, PySide, QtPy, PyQtGraph.
|
||||
|
||||
To simplify this process for the developer, if you are changing many things,
|
||||
use the script [run_ui_css_edition.py](./script/run_ui_css_edition.py):
|
||||
|
||||
```bash
|
||||
python run_ui_css_edition.py
|
||||
```
|
||||
|
||||
This creates a loop that restarts the application, process ui and css
|
||||
files. For more information see its documentation.
|
||||
|
||||
For more information about those scripts and their options, see their
|
||||
documentation.
|
||||
|
||||
### Qt, Stylesheets and Palettes
|
||||
|
||||
- [Box model](http://doc.qt.io/qt-5/images/stylesheet-boxmodel.png)
|
||||
- [Box model with height and width](https://www.tutorialrepublic.com/lib/images/css-box-model.jpg)
|
||||
- [Customizing Widgets](http://doc.qt.io/qt-5/stylesheet-customizing.html)
|
||||
- [Window structure](http://doc.qt.io/qt-5/images/mainwindowlayout.png)
|
||||
- [QMainWindow](http://doc.qt.io/qt-5/qmainwindow.html)
|
||||
- [References](http://doc.qt.io/qt-5/stylesheet.html)
|
||||
|
||||
Create good palettes with these tools. For example, on paletton, choose
|
||||
three colors from greyish light (foreground), greyish dark (background)
|
||||
and three more colorfull colors (selection). Greyish colors have a litle
|
||||
bit of the main color, so it is nice to change it if you change the main
|
||||
color.
|
||||
|
||||
- [Paletton](http://paletton.com/)
|
||||
- [Coolors.co](https://coolors.co/)
|
||||
|
||||
## Unit Testing and Fix Preview
|
||||
|
||||
It is a good practice, if you are writing functions to QDarkStyle or fixing
|
||||
something related to those functions (not style), that you provide a test
|
||||
for it. This will keep our implementation stable.
|
||||
|
||||
If you are fixing something about style, please, provide an screenshot
|
||||
before and after the fix to comparison. This could be inserted in the issue
|
||||
tracker, as a message.
|
Loading…
Reference in New Issue
Block a user