Skip to main content

Sphinx extension for plausible.io analytics

Project description

Sphinx extension for plausible.io

This extension adds the https://plausible.io script to a Sphinx project by using standard Sphinx javascript insertion tools. It doesn't change the template, and it should work with any template (that uses the standard Sphinx javascript insertion, which seems to be most of them).

This is a relatively new project (but being used), so please verify it does the correct thing in your case and suggest improvements.

Plausible without this extension

Actually, this extension isn't needed, you can directly add a script with the required tags by doing the following. This uses the same insertion mechanism as this extension, and thus should work with any well-designed theme with no modifications:

html_js_files = [
    ('https://plausible.io/js/script.js', {"data-domain": "yourdomain.com", "defer": "defer"}),
]

Installation

Install the Python package: on PyPI it is sphinx-plausible:

pip install sphinx-plausible

Usage

Add sphinx_plausible to extensions. Example config:

extensions = [
    "sphinx_plausible",
]

plausible_domain = "my.domain.org"

If you want Plausible to only be enabled when your site is deployed by Github Actions on the main branch in your own repository (remember to update organization/repo-name):

import os
plausible_enabled = (
    'GITHUB_ACTION' in os.environ
    and os.environ.get('GITHUB_REPOSITORY', '').lower() == 'organization-name/repo-name'
    and os.environ.get('GITHUB_REF') == 'refs/heads/main'
    )

Configuration options:

  • plausible_domain (required): The domain name, like my.domain.org. Can be a list which will be joined by commas.

  • plausible_script (default https://plausible.io/js/script.js): The URL to the script to load. If you want to use embed the script, download the script and put it in html_static_path and add the filename (relative to html_static_path) here instead of a URL.

  • plausible_enabled (default True): Should plausible be active? You might want to disable it on all you test deployments and so on, so you can add some logic to enable/disable as needed.

Status and development

Beta but works as of 2022 - improvements and feature requests are still welcome! I would be happy for a group maintenance home for this.

See also

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-plausible-0.1.2.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

sphinx_plausible-0.1.2-py3-none-any.whl (4.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: sphinx-plausible-0.1.2.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.28.1

File hashes

Hashes for sphinx-plausible-0.1.2.tar.gz
Algorithm Hash digest
SHA256 052ff1828cd64f0ee7909b7bc29d2450d70cf87e2bb32baca3b9acbd36b25b65
MD5 3dda3abec6355fe1a3802dc14902a2a2
BLAKE2b-256 ec3eee77a5a6ccd686618f82975d6a0975b1a099c31618837ecfffae9dba9206

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for sphinx_plausible-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 11110f2e60c4024506d39eb389096890b37d03ca7f9b9c1293eef5a494c7d1dd
MD5 10a33119aefb140a451f21576ed1f200
BLAKE2b-256 2916d2cfee69a898d5bd970736bfdf29a14049318244463c33deaa18afed0163

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