Skip to main content

Interactive charts, graphs and figures for Sphinx HTML docs.

Project description

PyPI version codecov Documentation Status pre-commit black

Sphinx Charts

Interactive charts, graphs and figures for sphinx using plotly v2.8.3 and D3.

Documentation is here.

Quick start

See the documentation above for more, but in an nutshell, add the extension to your conf.py:

extensions = [
    ...
    'sphinx_charts.charts'
]

Paste the following into a new file <your_docs_src_directory>/charts/test.json:

{
  "data": [
    {
      "x": [1, 2, 3, 4, 5],
      "y": [1, 2, 4, 8, 16]
    }
  ],
  "layout": {
    "margin": {"t": 15, "b": 30, "r": 15, "l": 35}
  }
}

Include the following directive in your *.rst file:

.. chart:: charts/test.json

    This is the caption of the chart

... and away you go!

Developer notes

Note: You don't need to pay attention to the following unless you plan to develop sphinx_charts itself.

Getting started

  1. Click 'use this template' to the top right, and away you go.
  2. Search for {{ in your new repository. Do search and replace for the various terms - it's obvious what they are, like replace {{github_username}} with your github username!
  3. Set up the license you need in LICENSE.
  4. If you need to deploy to pypi, you have to do the first deploy manually - travis can't do that for you. See the packaging instructions.

Pre-Commit

You need to install pre-commit to get the hooks working. Do:

pip install pre-commit
pre-commit install

Once that's done, each time you make a commit, the following checks are made:

  • valid github repo and files
  • code style
  • import order
  • PEP8 compliance
  • documentation build

Upon failure, the commit will halt. Re-running the commit will automatically fix most issues except:

  • The flake8 checks... hopefully over time Black (which fixes most things automatically already) will negate need for it.
  • You'll have to fix documentation yourself prior to a successful commit (there's no auto fix for that!!).

You can run pre-commit hooks without making a commit, too, like:

pre-commit run black --all-files

or

# -v gives verbose output, useful for figuring out why docs won't build
pre-commit run build-docs -v

Contributing

  • Please raise an issue on the board (or add your $0.02 to an existing issue) so the maintainers know what's happening and can advise / steer you.

  • Create a fork of {{library_name}}, undertake your changes on a new branch, (see .pre-commit-config.yaml for branch naming conventions). To run tests and make commits, you'll need to do something like:

git clone <your_forked_repo_address>    # fetches the repo to your local machine
cd sphinx_charts                     # move into the repo directory
pyenv virtualenv 3.6.9 myenv            # Makes a virtual environment for you to install the dev tools into. Use any python >= 3.6
pyend activate myenv                    # Activates the virtual environment so you don't screw up other installations
pip install -r requirements-dev.txt     # Installs the testing and code formatting utilities
pre-commit install                      # Installs the pre-commit code formatting hooks in the git repo
tox                                     # Runs the tests with coverage. NB you can also just set up pycharm or vscode to run these.
  • Adopt a Test Driven Development approach to implementing new features or fixing bugs.

  • Ask the sphinx_charts maintainers where to make your pull request. We'll create a version branch, according to the roadmap, into which you can make your PR. We'll help review the changes and improve the PR.

  • Once checks have passed, test coverage of the new code is >=95%, documentation is updated and the Review is passed, we'll merge into the version branch.

  • Once all the roadmapped features for that version are done, we'll release.

Release process

The process for creating a new release is as follows:

  1. Check out a branch for the next version, called vX.Y.Z
  2. Create a Pull Request into the master branch.
  3. Undertake your changes, committing and pushing to branch vX.Y.Z
  4. Ensure that documentation is updated to match changes, and increment the changelog. Pull requests which do not update documentation will be refused.
  5. Ensure that test coverage is sufficient. Pull requests that decrease test coverage will be refused.
  6. Ensure code meets style guidelines (pre-commit scripts and flake8 tests will fail otherwise)
  7. Address Review Comments on the PR
  8. Ensure the version in setup.py is correct and matches the branch version.
  9. Merge to master. Successful test, doc build, flake8 and a new version number will automatically create the release on pypi.
  10. Go to code > releases and create a new release on GitHub at the same SHA.

Documents

Building documents automatically

The documentation will build automatically in a pre-configured environment when you make a commit.

In fact, the way pre-commit works, you won't be allowed to make the commit unless the documentation builds, this way we avoid getting broken documentation pushed to the main repository on any commit sha, so we can rely on builds working.

Building documents manually

If you did need to build the documentation

Install doxgen. On a mac, that's brew install doxygen; other systems may differ.

Install sphinx and other requirements for building the docs:

pip install -r docs/requirements.txt

Run the build process:

sphinx-build -b html docs/source docs/build

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sphinx-charts-0.1.2.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

sphinx_charts-0.1.2-py3-none-any.whl (1.1 MB view details)

Uploaded Python 3

File details

Details for the file sphinx-charts-0.1.2.tar.gz.

File metadata

  • Download URL: sphinx-charts-0.1.2.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.9.7 Linux/5.11.0-1028-azure

File hashes

Hashes for sphinx-charts-0.1.2.tar.gz
Algorithm Hash digest
SHA256 18992663217b1677213a53fcb551e6c71ea10194aeba4777dea995b3a2cfe11f
MD5 5e9ea66b341c2cdecd9ee3dc22f16093
BLAKE2b-256 6291d4d47b49076deef43e02393ba5801b9c86876a9260f2c8e6688d4dbc4b05

See more details on using hashes here.

File details

Details for the file sphinx_charts-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: sphinx_charts-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 1.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.9.7 Linux/5.11.0-1028-azure

File hashes

Hashes for sphinx_charts-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e440553fea46e2fd90501cb94a247090f7211cf1eb153624efaf8b381b0c408e
MD5 c010a1865c91b7ecd9df8b8784a74a0d
BLAKE2b-256 45f964026bfcb93cc778049361a244345414576257bf4511416ae19110ca8e24

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page