Metadata-Version: 2.4
Name: ansys-dynamicreporting-core
Version: 0.10.6
Summary: Python interface to Ansys Dynamic Reporting
Project-URL: homepage, https://github.com/ansys/pydynamicreporting
Project-URL: documentation, https://dynamicreporting.docs.pyansys.com/
Project-URL: changelog, https://github.com/ansys/pydynamicreporting/blob/main/CHANGELOG.md
Project-URL: repository, https://github.com/ansys/pydynamicreporting
Project-URL: bug_tracker, https://github.com/ansys/pydynamicreporting/issues
Project-URL: ci, https://github.com/ansys/pydynamicreporting/actions
Author-email: "ANSYS, Inc." <pyansys.core@ansys.com>, Ansys ADR Team <adrteam@ansys.com>
Maintainer-email: "ANSYS, Inc." <pyansys.core@ansys.com>, Ansys ADR Team <adrteam@ansys.com>
License: MIT
License-File: AUTHORS
License-File: LICENSE
Keywords: ansys,dynamicreporting,pyansys,pydynamicreporting
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: POSIX :: Linux
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: <3.13,>=3.10
Requires-Dist: bleach>=6.2.0
Requires-Dist: django-guardian<3.0.0,>=2.4.0
Requires-Dist: django-weasyprint<2.5.0,>=2.4.0
Requires-Dist: django<5.0,>=4.2.27
Requires-Dist: djangorestframework<3.16.0,>=3.15.2
Requires-Dist: docker>=7.1.0
Requires-Dist: lark<1.3.0,>=1.2.2
Requires-Dist: numpy<2.0.0,>=1.26.4
Requires-Dist: pandas<3.0.0,>=2.2.2
Requires-Dist: pillow>=9.3.0
Requires-Dist: psutil>=6.0.0
Requires-Dist: psycopg[binary]<3.3.0,>=3.2.6
Requires-Dist: pypng>=0.20220715.0
Requires-Dist: python-dateutil>=2.8.0
Requires-Dist: python-pptx<2.0.0,>=1.0.2
Requires-Dist: pytz>=2021.3
Requires-Dist: qtpy<2.5.0,>=2.4.3
Requires-Dist: requests>=2.32
Requires-Dist: statsmodels<0.15.0,>=0.14.2
Requires-Dist: tzlocal<6.0,>=5.3.1
Requires-Dist: urllib3<3.0.0
Provides-Extra: dev
Requires-Dist: black; extra == 'dev'
Requires-Dist: codespell; extra == 'dev'
Requires-Dist: hatch; extra == 'dev'
Requires-Dist: ipdb; extra == 'dev'
Requires-Dist: isort; extra == 'dev'
Requires-Dist: pip; extra == 'dev'
Requires-Dist: pre-commit; extra == 'dev'
Requires-Dist: twine; extra == 'dev'
Requires-Dist: uv; extra == 'dev'
Provides-Extra: doc
Requires-Dist: ansys-sphinx-theme; extra == 'doc'
Requires-Dist: docutils>=0.21; extra == 'doc'
Requires-Dist: numpydoc; extra == 'doc'
Requires-Dist: sphinx; extra == 'doc'
Requires-Dist: sphinx-copybutton; extra == 'doc'
Requires-Dist: sphinx-gallery; extra == 'doc'
Provides-Extra: test
Requires-Dist: ansys-dpf-core==0.14.2; extra == 'test'
Requires-Dist: pytest; extra == 'test'
Requires-Dist: pytest-cov; extra == 'test'
Requires-Dist: pyvista==0.46.4; extra == 'test'
Requires-Dist: vtk==9.5.2; extra == 'test'
Description-Content-Type: text/x-rst

PyDynamicReporting
==================

|pyansys| |python| |pypi| |GH-CI| |cov| |MIT| |black|

.. |pyansys| image:: https://img.shields.io/badge/Py-Ansys-ffc107.svg?labelColor=black&logo=data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAIAAACQkWg2AAABDklEQVQ4jWNgoDfg5mD8vE7q/3bpVyskbW0sMRUwofHD7Dh5OBkZGBgW7/3W2tZpa2tLQEOyOzeEsfumlK2tbVpaGj4N6jIs1lpsDAwMJ278sveMY2BgCA0NFRISwqkhyQ1q/Nyd3zg4OBgYGNjZ2ePi4rB5loGBhZnhxTLJ/9ulv26Q4uVk1NXV/f///////69du4Zdg78lx//t0v+3S88rFISInD59GqIH2esIJ8G9O2/XVwhjzpw5EAam1xkkBJn/bJX+v1365hxxuCAfH9+3b9/+////48cPuNehNsS7cDEzMTAwMMzb+Q2u4dOnT2vWrMHu9ZtzxP9vl/69RVpCkBlZ3N7enoDXBwEAAA+YYitOilMVAAAAAElFTkSuQmCC
   :target: https://docs.pyansys.com/
   :alt: PyAnsys

.. |python| image:: https://img.shields.io/pypi/pyversions/ansys-dynamicreporting-core?logo=pypi
   :target: https://pypi.org/project/ansys-dynamicreporting-core/
   :alt: Python

.. |pypi| image:: https://img.shields.io/pypi/v/ansys-dynamicreporting-core.svg?logo=python&logoColor=white
   :target: https://pypi.org/project/ansys-dynamicreporting-core
   :alt: PyPI

.. |GH-CI| image:: https://github.com/ansys/pydynamicreporting/actions/workflows/ci_cd.yml/badge.svg?branch=main
   :target: https://github.com/ansys/pydynamicreporting/actions?query=branch%3Amain
   :alt: GH-CI

.. |cov| image:: https://codecov.io/gh/ansys/pydynamicreporting/graph/badge.svg?token=WCAK7QRLR3
   :target: https://codecov.io/gh/ansys/pydynamicreporting
   :alt: codecov

.. |MIT| image:: https://img.shields.io/badge/License-MIT-yellow.svg
   :target: https://opensource.org/licenses/MIT
   :alt: MIT

.. |black| image:: https://img.shields.io/badge/code%20style-black-000000.svg?style=flat
   :target: https://github.com/psf/black
   :alt: Black

.. _Nexus: https://nexusdemo.ensight.com/docs/html/Nexus.html

Overview
--------
PyDynamicReporting is the Python client library for Ansys Dynamic Reporting,
previously documented as `Nexus`_. Ansys Dynamic Reporting is a service for
pushing items of many types, including images, text, 3D scenes, and tables,
into a database, where you can keep them organized and create dynamic reports
from them. When you use PyDynamicReporting to connect to an instance of
Ansys Dynamic Reporting, you have a Pythonic way of accessing all capabilities
of Ansys Dynamic Reporting.

Documentation and issues
------------------------
Documentation for the latest stable release of PyDynamicReporting is hosted at
`PyDynamicReporting documentation <https://dynamicreporting.docs.pyansys.com/version/stable/>`_.

In the upper right corner of the documentation's title bar, there is an option
for switching from viewing the documentation for the latest stable release
to viewing the documentation for the development version or previously
released versions.

You can also `view <https://cheatsheets.docs.pyansys.com/pydynamicreporting_cheat_sheet.png>`_ or
`download <https://cheatsheets.docs.pyansys.com/pydynamicreporting_cheat_sheet.pdf>`_ the
PyDynamicReporting cheat sheet. This one-page reference provides syntax rules and commands
for using PyDynamicReporting.

On the `PyDynamicReporting Issues <https://github.com/ansys/pydynamicreporting/issues>`_
page, you can create issues to report bugs and request new features. On the `Discussions <https://discuss.ansys.com/>`_
page on the Ansys Developer portal, you can post questions, share ideas, and get community feedback.

To reach the project support team, email `pyansys.core@ansys.com <pyansys.core@ansys.com>`_.

Installation
------------
The ``pydynamicreporting`` package supports Python 3.10 through 3.12 on
Windows and Linux. It is currently available on the PyPi
`repository <https://pypi.org/project/ansys-dynamicreporting-core/>`_.

To install the package, simply run

.. code::

   pip install ansys-dynamicreporting-core

Developer installation
^^^^^^^^^^^^^^^^^^^^^^
To clone and install the ``pydynamicreporting`` package in development mode,
run this code:

.. code::

   git clone https://github.com/ansys/pydynamicreporting
   cd pydynamicreporting
   pip install virtualenv
   virtualenv venv  # create virtual environment
   source venv/bin/activate  # (.\venv\Scripts\activate for Windows shell)
   make install-dev  # install pydynamicreporting in editable mode

The preceding code creates an "editable" installation that lets you develop and test
PyDynamicReporting at the same time.

To build and create a production-like installation on Windows (not required on other OSes),
first install `chocolatey <https://chocolatey.org/install>`_. Then:

.. code::

   choco install make  # install make on Windows
   make clean  # clean
   make build   # build
   # this replaces the editable installation done previously. If you don't want to replace,
   # switch your virtual environments to test the new install separately.
   make install
   # you can skip the steps above and just do 'make all'
   make smoketest  # test import

Local GitHub Actions
^^^^^^^^^^^^^^^^^^^^
To run GitHub Actions on your local desktop (recommended), install the
`act <https://github.com/nektos/act#readme>`_ package.

.. code::

   choco install act-cli

To run a job, such as the ``style`` job from the ``ci_cd.yml`` file, use
this command, where ``style`` is the job name:

.. code::

   act -W '.github/workflows/ci_cd.yml' -j style --bind


Deploy and upload steps **must always** be ignored. If they are not ignored,
before running GitHub Actions locally, add ``if: ${{ !env.ACT }}`` to the
workflow step and commit this change if required.

Creating a Release
------------------

This project now uses **tag-driven releases** and **dynamic versions** powered by ``hatch-timestamp-version`` (based on ``hatch-vcs``). Stable releases are cut from **Git tags** (``vX.Y.Z``). Development builds use **UTC timestamped** versions derived from the most recent tag.
**Release branches are no longer needed**; the version is always derived from tags.

Versioning model
^^^^^^^^^^^^^^^^
- **Stable releases**: The version is the exact **Git tag** (for example, ``v0.10.0`` → package version ``0.10.0``).
- **Development builds**: Version is computed from the latest tag **plus a timestamp**, e.g. ``0.10.1.devYYYYMMDDHHMMSS``.
- No manual editing of ``pyproject.toml`` for versions — ``[tool.hatch.version]`` drives everything.

What the automation does
^^^^^^^^^^^^^^^^^^^^^^^^
- **Create Draft Release** (on tag push): builds wheels/sdist and opens a **draft GitHub Release** attaching artifacts.
- **Publish Release** (when the GitHub Release is **published**): uploads artifacts to **PyPI** via Trusted Publisher, then builds & deploys **stable docs**.
- **Failure notifications**: posts to Microsoft Teams on workflow failure.

Prerequisites
^^^^^^^^^^^^^
- Ensure ``CHANGELOG.md`` has a section for the release **dated today** (the helper script validates this).
- Working tree must be **clean** (no uncommitted changes).
- CI secrets for publishing and docs deploy are configured in GitHub.

Cutting a Stable Release
^^^^^^^^^^^^^^^^^^^^^^^^
1) Make sure your ``CHANGELOG.md`` entry for the version is dated **today**
   (this check runs automatically from ``make tag``).

2) Create and push the release tag:

   .. code-block:: bash

      make tag

   This runs all safety checks, validates the changelog date, and pushes the Git tag (for example, ``v0.10.0``).

3) Once the tag is pushed:
   - The **Create Draft Release** workflow builds the package and opens a **draft GitHub Release** with artifacts.
   - After reviewing and finalizing notes, **publish** the GitHub Release.

4) Publishing the release automatically triggers the **Release** workflow, which:
   - Uploads artifacts to **PyPI** using Trusted Publisher.
   - Builds and deploys the **stable documentation**.

Patch releases
^^^^^^^^^^^^^^
- For a patch, update the changelog, ensure the working tree is clean, then run ``make tag`` again (which tags the next patch version determined by ``hatch version`` from your last tag).
- No separate “release branch” is required; the version is derived from tags.

Local dry-runs (optional)
^^^^^^^^^^^^^^^^^^^^^^^^^
You can use ``act`` to exercise non-publishing parts locally. Steps that publish or deploy are already guarded in workflows (e.g., with ``if: ${{ !env.ACT }}``). Build and validation steps still run:

.. code-block:: bash

   act -W '.github/workflows/release.yml' -j release --bind

CI workflows (reference)
^^^^^^^^^^^^^^^^^^^^^^^^
- **.github/workflows/create_draft_release.yml**
  - Triggers on: tag push ``v*``, or manual dispatch.
  - Builds artifacts and opens a **draft** GitHub Release attaching ``dist/*``.

- **.github/workflows/release.yml**
  - Triggers on: **published** GitHub Release, or manual dispatch.
  - Rebuilds/validates, downloads artifacts, **publishes to PyPI**, builds docs, and **deploys stable docs**.

CLI helpers
^^^^^^^^^^^
- Print the resolved version (dev or stable):

  .. code-block:: bash

     make version

- Build locally (sdist + wheel):

  .. code-block:: bash

     make build
     make check-dist

- Clean:

  .. code-block:: bash

     make clean

Changelog guards
^^^^^^^^^^^^^^^^
Releases are blocked if today’s dated entry is missing:

.. code-block:: text

   ❌ ERROR: CHANGELOG.md is not ready for release.
      Expected line: ## [0.10.0] - YYYY-MM-DD
      Tip: Check if it's still marked as '[Unreleased]' and update it to today's date.

Troubleshooting
^^^^^^^^^^^^^^^
- **“No Git tag found” during checks**: Create a tag via ``make tag`` (or ``git tag vX.Y.Z && git push origin vX.Y.Z``).
- **Draft already exists**: The draft release is unique per tag. Delete or publish the existing one, or bump the tag properly.
- **Version mismatch**: ``hatch version`` determines the version from the last tag; ensure you pushed the intended tag and your clone has all tags (``git fetch --tags``).


Dependencies
------------
To use PyDynamicReporting, you must have a locally installed and licensed copy
of Ansys 2023 R2 or later.

To use PyDynamicReporting Serverless (ansys.dynamicreporting.core.serverless),
you must have a locally installed and licensed copy of Ansys 2025 R1 or later.

Basic usage
-----------
This code shows how to start the simplest PyDynamicReporting session:

.. code:: pycon

    >>> import ansys.dynamicreporting.core as adr
    >>> adr_service = adr.Service(ansys_installation=r"C:\Program Files\ANSYS Inc\v232")
    >>> ret = adr_service.connect()
    >>> my_img = adr_service.create_item()
    >>> my_img.item_image = "image.png"
    >>> adr_service.visualize_report()


License and acknowledgements
----------------------------
PyDynamicReporting is licensed under the MIT license.

PyDynamicReporting makes no commercial claim over Ansys whatsoever.
This library extends the functionality of Ansys Dynamic Reporting by
adding a Python interface to Ansys Dynamic Reporting without changing
the core behavior or license of the original software. The use of
PyDynamicReporting requires a legally licensed copy of an Ansys product
that supports Ansys Dynamic Reporting.

To get a copy of Ansys, visit the `Ansys <https://www.ansys.com/>`_ website.