Skip to main content

Reusable settings and customization widget for the ndev-kit

Project description

ndev-settings

License BSD-3 PyPI Python Version tests codecov napari hub npe2 Copier

Reusable settings and customization widget for the ndev-kit


This napari plugin was generated with copier using the napari-plugin-template v1.1.0.

Installation

You can install ndev-settings via pip:

pip install ndev-settings

If napari is not already installed, you can install ndev-settings with napari and Qt via:

pip install "ndev-settings[all]"

To install latest development version :

pip install git+https://github.com/ndev-kit/ndev-settings.git

Use with external libraries

External libraries can provide their settings in YAML format with the same structure as your main ndev_settings.yaml.

Step 1: Create a YAML file in the external library (e.g., ndev_settings.yaml):

ndevio_Reader:
  preferred_reader:
    default: bioio-ome-tiff
    dynamic_choices:
      fallback_message: No readers found
      provider: bioio.readers
    tooltip: Preferred reader to use when opening images
    value: bioio-ome-tiff
  scene_handling:
    choices:
    - Open Scene Widget
    - View All Scenes
    - View First Scene Only
    default: Open Scene Widget
    tooltip: How to handle files with multiple scenes
    value: View First Scene Only
  clear_layers_on_new_scene:
    default: false
    tooltip: Whether to clear the viewer when selecting a new scene
    value: false

ndevio_Export:
  canvas_scale:
    default: 1.0
    max: 100.0
    min: 0.1
    tooltip: Scales exported figures and screenshots by this value
    value: 1.0
  override_canvas_size:
    default: false
    tooltip: Whether to override the canvas size when exporting canvas screenshot
    value: false
  canvas_size:
    default: !!python/tuple
    - 1024
    - 1024
    tooltip: Height x width of the canvas when exporting a screenshot
    value: !!python/tuple
    - 1024
    - 1024

Step 2: Register the entry point in pyproject.toml:

[project.entry-points."ndev_settings.manifest"]
ndevio = "ndevio:ndev_settings.yaml"

Step 3: Use the autogenerated widget in napari!

external settings contributed automatically to the ndev-settings widget

Usage Example

from ndev_settings import get_settings

settings = get_settings()

# Access settings from main file
print(settings.Canvas.canvas_scale)

# Access settings from external libraries (if installed)
print(settings.Reader.preferred_reader)  # From ndevio
print(settings.Export.compression_level)  # From ndevio

Contributing

Contributions are very welcome. Tests can be run with tox, please ensure the coverage at least stays the same before you submit a pull request.

License

Distributed under the terms of the BSD-3 license, "ndev-settings" is free and open source software

Issues

If you encounter any problems, please file an issue along with a detailed description.

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

ndev_settings-0.3.0.tar.gz (60.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ndev_settings-0.3.0-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file ndev_settings-0.3.0.tar.gz.

File metadata

  • Download URL: ndev_settings-0.3.0.tar.gz
  • Upload date:
  • Size: 60.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ndev_settings-0.3.0.tar.gz
Algorithm Hash digest
SHA256 12d252bc31a5ea406552b619e2feb489a8491476c41f641433eacea4f046d325
MD5 ae30f71ca21173da8ba37ceedc41a75e
BLAKE2b-256 98ee4c70191d205bfd9bb855e8d69fd8314520a4e38723907edaa0d4c6f780ad

See more details on using hashes here.

Provenance

The following attestation bundles were made for ndev_settings-0.3.0.tar.gz:

Publisher: test_and_deploy.yml on ndev-kit/ndev-settings

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ndev_settings-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: ndev_settings-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 11.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ndev_settings-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e1327d03e5bbd351a1ca6efa90c000e34da85b353f11337a93cd40ce922130e3
MD5 8960cc3bccd28286766a3c13add2c7d0
BLAKE2b-256 e1fb1ce8c15d70464bd9ef2c8710ac7a91589473c7f1d8955e26b39639a4cb17

See more details on using hashes here.

Provenance

The following attestation bundles were made for ndev_settings-0.3.0-py3-none-any.whl:

Publisher: test_and_deploy.yml on ndev-kit/ndev-settings

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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