.. image:: https://img.shields.io/pypi/v/grafanimate.svg
:target: https://pypi.org/project/grafanimate/
.. image:: https://img.shields.io/pypi/status/grafanimate.svg
:target: https://pypi.org/project/grafanimate/
.. image:: https://codecov.io/gh/grafana-toolbox/grafanimate/branch/main/graph/badge.svg
:target: https://codecov.io/gh/grafana-toolbox/grafanimate
:alt: Code coverage
.. image:: https://img.shields.io/pypi/l/grafanimate.svg
:alt: License
:target: https://pypi.org/project/grafanimate/
.. image:: https://img.shields.io/pypi/dm/grafanimate.svg
:target: https://pypi.org/project/grafanimate/
.. image:: https://img.shields.io/pypi/pyversions/grafanimate.svg
:target: https://pypi.org/project/grafanimate/
.. image:: https://img.shields.io/badge/Grafana-10.x%20--%2011.x-blue.svg
:target: https://github.com/grafana/grafana
:alt: Supported Grafana versions
|
###########
grafanimate
###########
Animate timeseries data with Grafana.
*****
About
*****
``grafanimate`` captures screenshots while animating a Grafana dashboard by
manipulating its `time range control`_, i.e. navigating through time. The
result can be rendered as a sequence of png images, an animated gif file,
and as a video file.
.. attention::
This program can put significant load on your Grafana instance
and the underlying database machinery. Handle with care!
*****
Setup
*****
Prerequisites
=============
This program uses the fine FFmpeg_ program for doing the heavy lifting within
in its postprocessing subsystem.
grafanimate
===========
.. code:: sh
pip install grafanimate
.. note::
We absolutely recommend installing this program into a Python virtualenv::
python3 -m venv .venv
source .venv/bin/activate
pip install grafanimate
*****
Usage
*****
Introduction
============
``grafanimate`` works by operating on animations defined within description
files, written in Python. In cinematography jargon, this is called "exposure
sheet", or "dope sheet".
An exposure sheet (also known variously as "dope sheet", "camera
instruction sheet", or "X-sheet") is a sheet of paper used primarily in
traditional animation to mark out the timing of various actions and
dialogue.
``grafanimate`` offers convenient data types, ``AnimationScenario`` and
``AnimationSequence``, for outlining an animation scenario made of multiple
sequences.
Please have a look at the `scenarios.py`_ file for a full example containing
multiple scenarios.
Synopsis
========
A scenario definition:
.. code:: python
AnimationScenario(
grafana_url="https://play.grafana.org/",
dashboard_uid="000000012",
sequences=[
AnimationSequence(
start="2021-11-15T02:12:05Z",
stop="2021-11-15T02:37:36Z",
every="5min",
mode=SequencingMode.CUMULATIVE,
),
],
)
In order to run a built-in scenario, invoke:
.. code:: sh
grafanimate --scenario=playdemo --output=./animations
To use the headless mode which renders all panels on a dashboard and use panel events instead of waiting a fixed duration run
.. code:: sh
grafanimate --scenario=playdemo --output=./animations--headless --use-panel-events
Details
=======
``grafanimate`` also supports relative timestamps, based on the fine
`pytimeparse2`_ library.
- Within ``every``, you will express a duration.
Help
====
For getting a detailed and descriptive overview about all available command
line options, please invoke:
.. code:: sh
grafanimate --help
Configuration
=============
Firefox Location
----------------
grafanimate will discover a Firefox installation on your system path.
If you need to configure a specific installation location, use the
environment variable ``FIREFOX_BIN`` to point to the Firefox executable
on your system.
Examples
========
Examples for scenario mode. Script your animations in file ``scenarios.py`` or
any other Python module or file.
.. code:: sh
# Use freely accessible `play.grafana.org` for demo purposes.
grafanimate --scenario=playdemo --output=./animations
# Example for generating Luftdaten.info graph & map.
export GRAFANIMATE_OUTPUT=./animations
grafanimate --grafana-url=http://localhost:3000/ --dashboard-uid=1aOmc1sik --scenario=ldi_all
# Use more parameters to control the rendering process.
grafanimate --grafana-url=http://localhost:3000/ --dashboard-uid=acUXbj_mz --scenario=ir_sensor_svg_pixmap \
--header-layout=studio --datetime-format=human-time --panel-id=6
*******************
Usage in Containers
*******************
You can use ``grafanimate`` with Docker and Podman. An OCI image is published
to ``ghcr.io/grafana-toolbox/grafanimate``.
.. code:: sh
docker run --rm -it --volume=$(PWD)/animations:/animations ghcr.io/grafana-toolbox/grafanimate \
--header-layout=no-chrome \
--video-fps=30 --video-framerate=30 \
--scenario=playdemo --output=./animations
*******
Gallery
*******
**Composition**: `The Hiveeyes Project`_. Developing a flexible beehive monitoring infrastructure.
Clicking on an image will take you to the animated version.
.. _The Hiveeyes Project: https://hiveeyes.org/
luftdaten.info coverage
=======================
.. figure:: https://ptrace.hiveeyes.org/2018-12-28_luftdaten-info-coverage.gif
:target: https://ptrace.hiveeyes.org/2018-12-28_luftdaten-info-coverage.mp4
:width: 480px
:height: 306px
:scale: 125%
Coverage of luftdaten.info sensors starting October 2015 across Europe.
- **Data source**: `luftdaten.info`_ (LDI)
- **Production**: `Luftdatenpumpe`_, `LDI data plane v2`_, daily.
- **Development**: `Erneuerung der Luftdatenpumpe`_. All contributions welcome.
Fine dust pollution on New Year's Eve
=====================================
.. figure:: https://ptrace.hiveeyes.org/2019-02-04_M0h7br_ik_2019-01-01T00-15-00.png
:target: https://ptrace.hiveeyes.org/2019-02-03_particulates-on-new-year-s-eve.mp4
:width: 1290px
:height: 824px
:scale: 50%
`Animation of fine dust pollution on New Year's Eve 2018 across Europe <https://community.hiveeyes.org/t/animation-der-feinstaubbelastung-an-silvester-2018-mit-grafanimate/1472>`_.
- **Data source**: `luftdaten.info`_ (LDI)
- **Production**: `Luftdatenpumpe`_, `LDI data plane v2`_, historical.
- **Development**: `Erneuerung der Luftdatenpumpe`_. All contributions welcome.
.. _luftdaten.info: http://luftdaten.info/
.. _Luftdatenpumpe: https://github.com/hiveeyes/luftdatenpumpe
.. _Erneuerung der Luftdatenpumpe: https://community.hiveeyes.org/t/erneuerung-der-luftdatenpumpe/1199
.. _LDI data plane v2: https://community.hiveeyes.org/t/ldi-data-plane-v2/1412
DWD CDC
=======
.. figure:: https://ptrace.hiveeyes.org/2019-02-04_DLOlE_Rmz_2018-03-10T13-00-00.png
:target: https://ptrace.hiveeyes.org/2018-12-28_wetter-dwd-temperatur-sonne-niederschlag-karten-cdc.mp4
:width: 1428px
:height: 829px
:scale: 50%
`Short weather film about temperature, sun and precipitation based on DWD/CDC data in March 2018 <https://community.hiveeyes.org/t/kurzer-wetterfilm-uber-temperatur-sonne-und-niederschlag-auf-basis-der-dwd-cdc-daten-im-marz-2018/1475>`_.
- **Data source**: `DWD Open Data`_ (DWD)
- **Production**: `DWD Climate Data Center (CDC), 10m-Werte: Aktuelle Lufttemperaturen, Sonnenscheindauer & Niederschlag <https://weather.hiveeyes.org/grafana/d/DLOlE_Rmz/temperatur-sonne-and-niederschlag-karten-cdc>`_
- **Development**: <work in progress>
.. _DWD Open Data: https://opendata.dwd.de/
IR-Sensor SVG-Pixmap
====================
.. figure:: https://ptrace.hiveeyes.org/2019-02-04_acUXbj_mz_2018-08-14T03-16-12.png
:target: https://ptrace.hiveeyes.org/2019-02-04_ir-sensor-svg-pixmap.mp4
:width: 666px
:height: 700px
:scale: 50%
IR-Sensor SVG-Pixmap displaying temperature changes inside a beehive.
- **Data source**: `Clemens Gruber`_ (CG)
- **Development**: `How to Visualize 2-Dimensional Temperature Data in Grafana <https://community.hiveeyes.org/t/how-to-visualize-2-dimensional-temperature-data-in-grafana/974/15>`_
.. _Clemens Gruber: https://community.hiveeyes.org/u/clemens
**********************
Background and details
**********************
Introduction
============
Animating things in Grafana_ across the time-axis in the spirit
of the `GeoLoop Panel Plugin`_ hasn't been unlocked for Grafana
in a more general way yet. Challenge accepted!
Time warp
=========
At this programs' core is the code to `set time range in Grafana`_:
.. code:: javascript
__grafanaSceneContext.state.$timeRange.setState({ from: from, to: to});
__grafanaSceneContext.state.$timeRange.onRefresh();
Rendering engine
================
Turtles all the way up, the main rendering work horse is a Firefox Browser
automated through `Marionette Python Client`_ fame:
The Marionette Python client library allows you to remotely control
a Gecko-based browser or device which is running a Marionette server.
Outlook
=======
Neither Playlists_ nor `Scripted Dashboards`_ (now deprecated) offer these
things to the user, but this program can be combined with both in order
to implement more complex animations on top of Grafana.
----
***********
Development
***********
.. code:: sh
# Acquire sources.
git clone https://github.com/grafana-toolbox/grafanimate
cd grafanimate
# Create and activate virtualenv.
uv venv
source .venv/bin/activate
# Install package in "editable" mode.
uv pip install --editable='.[develop,test]'
# Run linters and software tests.
poe check
*******************
Project information
*******************
The code lives on `GitHub <https://github.com/grafana-toolbox/grafanimate>`_ and
the Python package is published to `PyPI <https://pypi.org/project/grafanimate/>`_.
Contributing
============
We are always happy to receive code contributions, ideas, suggestions
and problem reports from the community.
Spend some time taking a look around, locate a bug, design issue or
spelling mistake and then send us a pull request or create an issue.
You can also `discuss grafanimate`_ on our forum, you are welcome to join.
Acknowledgements
================
Thanks to all the contributors who helped to co-create and conceive this
program in one way or another. You know who you are.
Also thanks to all the people working on Python, Grafana, Firefox, FFmpeg,
and the countless other software components this program is based upon.
License
=======
``grafanimate`` is licensed under the terms of the GNU AGPL v3 license.
.. _discuss grafanimate: https://community.panodata.org/t/grafanimate/205
.. _FFmpeg: https://ffmpeg.org/
.. _GeoLoop Panel Plugin: https://grafana.com/plugins/citilogics-geoloop-panel
.. _Grafana: https://grafana.com/
.. _Marionette Python Client: https://marionette-client.readthedocs.io/
.. _Playlists: http://docs.grafana.org/reference/playlist/
.. _pytimeparse2: https://github.com/onegreyonewhite/pytimeparse2
.. _scenarios.py: https://github.com/grafana-toolbox/grafanimate/blob/main/grafanimate/scenarios.py
.. _Scripted Dashboards: http://docs.grafana.org/reference/scripting/
.. _set time range in Grafana: https://stackoverflow.com/questions/48264279/how-to-set-time-range-in-grafana-dashboard-from-text-panels/52492205#52492205
.. _time range control: http://docs.grafana.org/reference/timerange/
Raw data
{
"_id": null,
"home_page": null,
"name": "grafanimate",
"maintainer": null,
"docs_url": null,
"requires_python": "<3.14,>=3.9",
"maintainer_email": null,
"keywords": "animate, animation, automation, gif, grafana, time, video",
"author": "intermittent.energy",
"author_email": "Andreas Motl <andreas.motl@panodata.org>, Florian Maurer <f.maurer@outlook.de>",
"download_url": "https://files.pythonhosted.org/packages/ef/94/071b089da3442fb4ed6349f0ecd98fbcbad8244f8aadb557588e91542613/grafanimate-0.9.0.tar.gz",
"platform": null,
"description": ".. image:: https://img.shields.io/pypi/v/grafanimate.svg\n :target: https://pypi.org/project/grafanimate/\n\n.. image:: https://img.shields.io/pypi/status/grafanimate.svg\n :target: https://pypi.org/project/grafanimate/\n\n.. image:: https://codecov.io/gh/grafana-toolbox/grafanimate/branch/main/graph/badge.svg\n :target: https://codecov.io/gh/grafana-toolbox/grafanimate\n :alt: Code coverage\n\n.. image:: https://img.shields.io/pypi/l/grafanimate.svg\n :alt: License\n :target: https://pypi.org/project/grafanimate/\n\n.. image:: https://img.shields.io/pypi/dm/grafanimate.svg\n :target: https://pypi.org/project/grafanimate/\n\n.. image:: https://img.shields.io/pypi/pyversions/grafanimate.svg\n :target: https://pypi.org/project/grafanimate/\n\n.. image:: https://img.shields.io/badge/Grafana-10.x%20--%2011.x-blue.svg\n :target: https://github.com/grafana/grafana\n :alt: Supported Grafana versions\n\n|\n\n###########\ngrafanimate\n###########\n\nAnimate timeseries data with Grafana.\n\n\n*****\nAbout\n*****\n\n``grafanimate`` captures screenshots while animating a Grafana dashboard by\nmanipulating its `time range control`_, i.e. navigating through time. The\nresult can be rendered as a sequence of png images, an animated gif file,\nand as a video file.\n\n.. attention::\n\n This program can put significant load on your Grafana instance\n and the underlying database machinery. Handle with care!\n\n\n*****\nSetup\n*****\n\nPrerequisites\n=============\n\nThis program uses the fine FFmpeg_ program for doing the heavy lifting within\nin its postprocessing subsystem.\n\n\ngrafanimate\n===========\n\n.. code:: sh\n\n pip install grafanimate\n\n\n.. note::\n\n We absolutely recommend installing this program into a Python virtualenv::\n\n python3 -m venv .venv\n source .venv/bin/activate\n pip install grafanimate\n\n\n*****\nUsage\n*****\n\nIntroduction\n============\n\n``grafanimate`` works by operating on animations defined within description\nfiles, written in Python. In cinematography jargon, this is called \"exposure\nsheet\", or \"dope sheet\".\n\n An exposure sheet (also known variously as \"dope sheet\", \"camera\n instruction sheet\", or \"X-sheet\") is a sheet of paper used primarily in\n traditional animation to mark out the timing of various actions and\n dialogue.\n\n``grafanimate`` offers convenient data types, ``AnimationScenario`` and\n``AnimationSequence``, for outlining an animation scenario made of multiple\nsequences.\n\nPlease have a look at the `scenarios.py`_ file for a full example containing\nmultiple scenarios.\n\nSynopsis\n========\n\nA scenario definition:\n\n.. code:: python\n\n AnimationScenario(\n grafana_url=\"https://play.grafana.org/\",\n dashboard_uid=\"000000012\",\n sequences=[\n AnimationSequence(\n start=\"2021-11-15T02:12:05Z\",\n stop=\"2021-11-15T02:37:36Z\",\n every=\"5min\",\n mode=SequencingMode.CUMULATIVE,\n ),\n ],\n )\n\n\nIn order to run a built-in scenario, invoke:\n\n.. code:: sh\n\n grafanimate --scenario=playdemo --output=./animations\n\nTo use the headless mode which renders all panels on a dashboard and use panel events instead of waiting a fixed duration run\n\n.. code:: sh\n\n grafanimate --scenario=playdemo --output=./animations--headless --use-panel-events\n\nDetails\n=======\n\n``grafanimate`` also supports relative timestamps, based on the fine\n`pytimeparse2`_ library.\n\n- Within ``every``, you will express a duration.\n\nHelp\n====\n\nFor getting a detailed and descriptive overview about all available command\nline options, please invoke:\n\n.. code:: sh\n\n grafanimate --help\n\nConfiguration\n=============\n\nFirefox Location\n----------------\ngrafanimate will discover a Firefox installation on your system path.\nIf you need to configure a specific installation location, use the\nenvironment variable ``FIREFOX_BIN`` to point to the Firefox executable\non your system.\n\nExamples\n========\n\nExamples for scenario mode. Script your animations in file ``scenarios.py`` or\nany other Python module or file.\n\n.. code:: sh\n\n # Use freely accessible `play.grafana.org` for demo purposes.\n grafanimate --scenario=playdemo --output=./animations\n\n # Example for generating Luftdaten.info graph & map.\n export GRAFANIMATE_OUTPUT=./animations\n grafanimate --grafana-url=http://localhost:3000/ --dashboard-uid=1aOmc1sik --scenario=ldi_all\n\n # Use more parameters to control the rendering process.\n grafanimate --grafana-url=http://localhost:3000/ --dashboard-uid=acUXbj_mz --scenario=ir_sensor_svg_pixmap \\\n --header-layout=studio --datetime-format=human-time --panel-id=6\n\n\n*******************\nUsage in Containers\n*******************\n\nYou can use ``grafanimate`` with Docker and Podman. An OCI image is published\nto ``ghcr.io/grafana-toolbox/grafanimate``.\n\n.. code:: sh\n\n docker run --rm -it --volume=$(PWD)/animations:/animations ghcr.io/grafana-toolbox/grafanimate \\\n --header-layout=no-chrome \\\n --video-fps=30 --video-framerate=30 \\\n --scenario=playdemo --output=./animations\n\n\n*******\nGallery\n*******\n\n**Composition**: `The Hiveeyes Project`_. Developing a flexible beehive monitoring infrastructure.\nClicking on an image will take you to the animated version.\n\n.. _The Hiveeyes Project: https://hiveeyes.org/\n\n\nluftdaten.info coverage\n=======================\n.. figure:: https://ptrace.hiveeyes.org/2018-12-28_luftdaten-info-coverage.gif\n :target: https://ptrace.hiveeyes.org/2018-12-28_luftdaten-info-coverage.mp4\n :width: 480px\n :height: 306px\n :scale: 125%\n\n Coverage of luftdaten.info sensors starting October 2015 across Europe.\n\n- **Data source**: `luftdaten.info`_ (LDI)\n- **Production**: `Luftdatenpumpe`_, `LDI data plane v2`_, daily.\n- **Development**: `Erneuerung der Luftdatenpumpe`_. All contributions welcome.\n\n\nFine dust pollution on New Year's Eve\n=====================================\n.. figure:: https://ptrace.hiveeyes.org/2019-02-04_M0h7br_ik_2019-01-01T00-15-00.png\n :target: https://ptrace.hiveeyes.org/2019-02-03_particulates-on-new-year-s-eve.mp4\n :width: 1290px\n :height: 824px\n :scale: 50%\n\n `Animation of fine dust pollution on New Year's Eve 2018 across Europe <https://community.hiveeyes.org/t/animation-der-feinstaubbelastung-an-silvester-2018-mit-grafanimate/1472>`_.\n\n- **Data source**: `luftdaten.info`_ (LDI)\n- **Production**: `Luftdatenpumpe`_, `LDI data plane v2`_, historical.\n- **Development**: `Erneuerung der Luftdatenpumpe`_. All contributions welcome.\n\n.. _luftdaten.info: http://luftdaten.info/\n.. _Luftdatenpumpe: https://github.com/hiveeyes/luftdatenpumpe\n.. _Erneuerung der Luftdatenpumpe: https://community.hiveeyes.org/t/erneuerung-der-luftdatenpumpe/1199\n.. _LDI data plane v2: https://community.hiveeyes.org/t/ldi-data-plane-v2/1412\n\n\nDWD CDC\n=======\n.. figure:: https://ptrace.hiveeyes.org/2019-02-04_DLOlE_Rmz_2018-03-10T13-00-00.png\n :target: https://ptrace.hiveeyes.org/2018-12-28_wetter-dwd-temperatur-sonne-niederschlag-karten-cdc.mp4\n :width: 1428px\n :height: 829px\n :scale: 50%\n\n `Short weather film about temperature, sun and precipitation based on DWD/CDC data in March 2018 <https://community.hiveeyes.org/t/kurzer-wetterfilm-uber-temperatur-sonne-und-niederschlag-auf-basis-der-dwd-cdc-daten-im-marz-2018/1475>`_.\n\n- **Data source**: `DWD Open Data`_ (DWD)\n- **Production**: `DWD Climate Data Center (CDC), 10m-Werte: Aktuelle Lufttemperaturen, Sonnenscheindauer & Niederschlag <https://weather.hiveeyes.org/grafana/d/DLOlE_Rmz/temperatur-sonne-and-niederschlag-karten-cdc>`_\n- **Development**: <work in progress>\n\n.. _DWD Open Data: https://opendata.dwd.de/\n\n\nIR-Sensor SVG-Pixmap\n====================\n.. figure:: https://ptrace.hiveeyes.org/2019-02-04_acUXbj_mz_2018-08-14T03-16-12.png\n :target: https://ptrace.hiveeyes.org/2019-02-04_ir-sensor-svg-pixmap.mp4\n :width: 666px\n :height: 700px\n :scale: 50%\n\n IR-Sensor SVG-Pixmap displaying temperature changes inside a beehive.\n\n- **Data source**: `Clemens Gruber`_ (CG)\n- **Development**: `How to Visualize 2-Dimensional Temperature Data in Grafana <https://community.hiveeyes.org/t/how-to-visualize-2-dimensional-temperature-data-in-grafana/974/15>`_\n\n.. _Clemens Gruber: https://community.hiveeyes.org/u/clemens\n\n\n\n**********************\nBackground and details\n**********************\n\nIntroduction\n============\nAnimating things in Grafana_ across the time-axis in the spirit\nof the `GeoLoop Panel Plugin`_ hasn't been unlocked for Grafana\nin a more general way yet. Challenge accepted!\n\nTime warp\n=========\nAt this programs' core is the code to `set time range in Grafana`_:\n\n.. code:: javascript\n\n __grafanaSceneContext.state.$timeRange.setState({ from: from, to: to});\n __grafanaSceneContext.state.$timeRange.onRefresh();\n\nRendering engine\n================\nTurtles all the way up, the main rendering work horse is a Firefox Browser\nautomated through `Marionette Python Client`_ fame:\n\n The Marionette Python client library allows you to remotely control\n a Gecko-based browser or device which is running a Marionette server.\n\nOutlook\n=======\nNeither Playlists_ nor `Scripted Dashboards`_ (now deprecated) offer these\nthings to the user, but this program can be combined with both in order\nto implement more complex animations on top of Grafana.\n\n\n----\n\n***********\nDevelopment\n***********\n\n.. code:: sh\n\n # Acquire sources.\n git clone https://github.com/grafana-toolbox/grafanimate\n cd grafanimate\n\n # Create and activate virtualenv.\n uv venv\n source .venv/bin/activate\n\n # Install package in \"editable\" mode.\n uv pip install --editable='.[develop,test]'\n\n # Run linters and software tests.\n poe check\n\n\n*******************\nProject information\n*******************\n\nThe code lives on `GitHub <https://github.com/grafana-toolbox/grafanimate>`_ and\nthe Python package is published to `PyPI <https://pypi.org/project/grafanimate/>`_.\n\n\nContributing\n============\nWe are always happy to receive code contributions, ideas, suggestions\nand problem reports from the community.\nSpend some time taking a look around, locate a bug, design issue or\nspelling mistake and then send us a pull request or create an issue.\nYou can also `discuss grafanimate`_ on our forum, you are welcome to join.\n\n\nAcknowledgements\n================\nThanks to all the contributors who helped to co-create and conceive this\nprogram in one way or another. You know who you are.\n\nAlso thanks to all the people working on Python, Grafana, Firefox, FFmpeg,\nand the countless other software components this program is based upon.\n\n\nLicense\n=======\n``grafanimate`` is licensed under the terms of the GNU AGPL v3 license.\n\n\n\n.. _discuss grafanimate: https://community.panodata.org/t/grafanimate/205\n.. _FFmpeg: https://ffmpeg.org/\n.. _GeoLoop Panel Plugin: https://grafana.com/plugins/citilogics-geoloop-panel\n.. _Grafana: https://grafana.com/\n.. _Marionette Python Client: https://marionette-client.readthedocs.io/\n.. _Playlists: http://docs.grafana.org/reference/playlist/\n.. _pytimeparse2: https://github.com/onegreyonewhite/pytimeparse2\n.. _scenarios.py: https://github.com/grafana-toolbox/grafanimate/blob/main/grafanimate/scenarios.py\n.. _Scripted Dashboards: http://docs.grafana.org/reference/scripting/\n.. _set time range in Grafana: https://stackoverflow.com/questions/48264279/how-to-set-time-range-in-grafana-dashboard-from-text-panels/52492205#52492205\n.. _time range control: http://docs.grafana.org/reference/timerange/\n",
"bugtrack_url": null,
"license": "AGPL 3, EUPL 1.2",
"summary": "Animate timeseries data with Grafana",
"version": "0.9.0",
"project_urls": {
"Homepage": "https://github.com/grafana-toolbox/grafanimate",
"Issues": "https://github.com/grafana-toolbox/grafanimate/issues",
"Repository": "https://github.com/grafana-toolbox/grafanimate"
},
"split_keywords": [
"animate",
" animation",
" automation",
" gif",
" grafana",
" time",
" video"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "2a369570b045629bb077665c23b4aa93264ca46e18d7a12831fda7ef8a57fe86",
"md5": "8b1879ae254ffc000de822d5e6c5004c",
"sha256": "b48c3218ba9cd62505df2adb42a3753146aefa7066540a82ba4f6b640bf30cc4"
},
"downloads": -1,
"filename": "grafanimate-0.9.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "8b1879ae254ffc000de822d5e6c5004c",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<3.14,>=3.9",
"size": 47544,
"upload_time": "2024-12-04T21:53:23",
"upload_time_iso_8601": "2024-12-04T21:53:23.972801Z",
"url": "https://files.pythonhosted.org/packages/2a/36/9570b045629bb077665c23b4aa93264ca46e18d7a12831fda7ef8a57fe86/grafanimate-0.9.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "ef94071b089da3442fb4ed6349f0ecd98fbcbad8244f8aadb557588e91542613",
"md5": "3b85686e4f34481f914a134612571778",
"sha256": "c0125e43ed397f54241ad7144cbfde3ca5773f2cfa6c15d14fc4d8a83ffd293b"
},
"downloads": -1,
"filename": "grafanimate-0.9.0.tar.gz",
"has_sig": false,
"md5_digest": "3b85686e4f34481f914a134612571778",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<3.14,>=3.9",
"size": 49920,
"upload_time": "2024-12-04T21:53:26",
"upload_time_iso_8601": "2024-12-04T21:53:26.450823Z",
"url": "https://files.pythonhosted.org/packages/ef/94/071b089da3442fb4ed6349f0ecd98fbcbad8244f8aadb557588e91542613/grafanimate-0.9.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-04 21:53:26",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "grafana-toolbox",
"github_project": "grafanimate",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "grafanimate"
}