npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@bioimagetools/capability-manifest

v0.5.0

Published

Library to determine OME-Zarr viewer compatibility based on capability manifests

Downloads

93

Readme

OME-NGFF Capability Manifests (DRAFT)

During the 2025 OME-NGFF Workflows Hackathon, participants discussed the potential need for a way to programmatically determine OME-NGFF tool capabilities. This repo is a place to experiment with schemas for capability manifests for OME-Zarr-compatible tools.

Background

Current OME-NGFF (i.e. OME-Zarr) tools tend to support different aspects of the specification. Image viewers are purpose built and may only support a subset of possible data features. At the highest level, the specification is still rapidly evolving and any given tool may only support data up to a certain data version (including RFCs). Even when a tool supports a given OME-NGFF version, the specification is complex enough that tool developers may forgo implementing certain aspects of the specification, especially when those aspects are not aligned with the viewer use cases (e.g. an EM-oriented tool may not implement support for HCS plates).

Each tool could optionally publish a "capability manifest" which describes the tool's implementd capabilities with regards to the current and former NGFF Specifications. This manifest could simply live in the tool's Github repo, to be updated whenever relevant changes are made to the code. This manifest can then be interpreted computationally by any platform that wants to launch OME-NGFF tools (OMERO, BFF, Fileglancer, etc.)

Library Usage

This package can be used as a library to determine which OME-Zarr viewers are compatible with a given dataset. The caller provides manifest URLs; the library fetches, parses, and validates them.

Installation

npm install @bioimagetools/capability-manifest

Usage

import {
  loadManifestsFromUrls,
  getCompatibleViewers,
  type OmeZarrMetadata,
} from "@bioimagetools/capability-manifest";

// Load manifests from URLs you control
const manifestMap = await loadManifestsFromUrls([
  "https://example.com/viewers/neuroglancer.yaml",
  "https://example.com/viewers/avivator.yaml",
]);
const manifests = [...manifestMap.values()];

// For each dataset, pass manifests and pre-parsed metadata
const metadata: OmeZarrMetadata = {
  version: "0.4",
  axes: [
    { name: "z", type: "space" },
    { name: "y", type: "space" },
    { name: "x", type: "space" },
  ],
  // ... other metadata
};

// Get list of compatible viewer names
const viewers = getCompatibleViewers(manifests, metadata);
// Returns: ['Avivator', 'Neuroglancer']

API

loadManifestsFromUrls(manifestUrls: string[]): Promise<Map<string, ViewerManifest>>

Fetches and parses capability manifest YAML files from the provided URLs.

  • Parameters:
    • manifestUrls: Array of URLs pointing to capability manifest YAML files
  • Returns: Map keyed by URL to the successfully loaded ViewerManifest
  • Behavior: Uses Promise.allSettled for graceful partial failure. Logs warnings for failed URLs but does not throw. Validates that each manifest has viewer.name (string), viewer.version (string), and capabilities (object).

getCompatibleViewers(manifests: ViewerManifest[], metadata: OmeZarrMetadata): string[]

Returns array of viewer names that are compatible with the given dataset metadata.

  • Parameters:
    • manifests: Array of viewer manifests to check against
    • metadata: Pre-parsed OME-Zarr metadata object (use ome-zarr.js or similar to parse from Zarr stores)
  • Returns: Array of viewer names (e.g., ['Avivator', 'Neuroglancer'])

getCompatibleViewersWithDetails(manifests: ViewerManifest[], metadata: OmeZarrMetadata): Array<{name: string, validation: ValidationResult}>

Returns detailed compatibility information including validation errors and warnings for each compatible viewer. Useful for debugging or displaying why certain viewers work/don't work.

isCompatible(viewer: ViewerManifest, metadata: OmeZarrMetadata): boolean

Returns whether a single viewer is compatible with the given metadata.

validateViewer(viewer: ViewerManifest, metadata: OmeZarrMetadata): ValidationResult

Returns full validation details (dataCompatible, dataFeaturesSupported, errors, warnings) for a single viewer against the given metadata.

Types

The library exports TypeScript types for all data structures:

  • ViewerManifest - Structure of viewer capability manifests
  • OmeZarrMetadata - Structure of OME-Zarr metadata
  • ValidationResult - Validation outcome with errors/warnings
  • ValidationError, ValidationWarning - Detailed validation messages
  • AxisMetadata, MultiscaleMetadata - Nested metadata types

Icons

Icons for canonical viewers are hosted in the public/icons/ directory and served via GitHub Pages at:

https://raw.githubusercontent.com/bioimagetools/capability-manifest/host-manifests-and-docs/public/icons/{slug}.png

where {slug} is the viewer name lowercased with spaces replaced by hyphens (e.g. "OME-Zarr Validator"ome-zarr-validator.png). Consumers can derive this URL automatically and fall back to a local placeholder when the icon is unavailable.

The logo field in the viewer section is an optional override for cases where this convention does not apply.

Canonical Manifests

This repository hosts canonical capability manifests for well-known OME-Zarr viewers in the manifests/ directory:

| Manifest | Viewer | OME-Zarr Versions | | --- | --- | --- | | neuroglancer.yaml | Neuroglancer | 0.4, 0.5 | | avivator.yaml | Avivator (Viv) | 0.4 | | validator.yaml | OME-Zarr Validator | 0.4, 0.5 | | vole.yaml | Vol-E | 0.4, 0.5 |

Consumers can load these manifests by URL directly from GitHub (raw content URLs) or host copies on their own infrastructure.

Viewer developers are encouraged to maintain their own manifests and submit PRs to update the canonical versions here when capabilities change.

Manifest Schema (DRAFT)

A capability manifest is a YAML file with two top-level sections: viewer and capabilities.

viewer Section

Identifies the tool and provides a URL template for launching it.

| Field | Type | Required | Description | | --- | --- | --- | --- | | name | string | yes | Human-readable name of the viewer | | version | string | yes | Version of the viewer these capabilities describe | | repo | string | no | URL of the source code repository | | logo | string | no | URL to a logo image for the viewer. Optional override — consumers may derive a logo URL by convention (see Icons). Omit if the conventional path applies. | | template_url | string | no | URL template for opening a dataset. Use {DATA_URL} as a placeholder for the dataset URL — consumers replace it at runtime with the actual OME-Zarr location |

Example:

viewer:
  name: "Neuroglancer"
  version: "2.41.2"
  repo: "https://github.com/google/neuroglancer"
  template_url: https://neuroglancer-demo.appspot.com/#!{"layers":[{"name":"image","source":"{DATA_URL}","type":"image"}]}

capabilities Section

Describes which OME-Zarr features the tool supports. All fields are optional — omitting a field means the capability is unknown/undeclared.

| Field | Type | Description | | --- | --- | --- | | ome_zarr_versions | number[] | OME-NGFF specification versions the tool can load (e.g. [0.4, 0.5]). When a dataset's multiscales metadata contains a version listed here, the tool should be able to open it. | | compression_codecs | string[] | Compression codecs the tool can decode (e.g. ["blosc", "zstd", "gzip"]). An empty array [] means the tool does not declare codec support — compatibility is unknown rather than unsupported. | | rfcs_supported | number[] | RFC numbers implemented on top of the released OME-NGFF versions. Given test data for a listed RFC, the tool should handle it. | | axes | boolean | Whether axis names and units from the metadata are respected | | scale | boolean | Whether scaling factors on multiscale datasets are respected | | translation | boolean | Whether translation offsets (including subpixel offsets for lower scale levels) are respected | | channels | boolean | Whether the tool supports datasets with multiple channels (c axis) | | timepoints | boolean | Whether the tool supports datasets with multiple timepoints (t axis) | | labels | boolean | Whether pixel-annotation metadata in the "labels" group is loaded | | hcs_plates | boolean | Whether high content screening datasets in the "plate" group are loaded | | bioformats2raw_layout | boolean | Whether the tool can open Zarr stores using the bioformats2raw transitional layout | | omero_metadata | boolean | Whether the tool uses OMERO metadata (e.g. to set default channel colors) |

Example:

capabilities:
  ome_zarr_versions: [0.4, 0.5]
  compression_codecs: ["blosc", "zstd", "gzip"]
  rfcs_supported: []
  axes: true
  scale: true
  translation: true
  channels: true
  timepoints: true
  labels: false
  hcs_plates: false
  bioformats2raw_layout: false
  omero_metadata: true

How validateViewer() Uses the Manifest

The validateViewer() function checks a manifest's declared capabilities against a dataset's OmeZarrMetadata and returns a ValidationResult:

interface ValidationResult {
  dataCompatible: boolean;        // true if no errors (viewer can open the data)
  dataFeaturesSupported: boolean; // true if no warnings (viewer fully supports all data features)
  errors: ValidationError[];      // hard failures — data will not load
  warnings: ValidationWarning[];  // soft issues — data loads but features may be missing
}

Capabilities fall into two levels:

  • Data compatibility (errors): Hard requirements. If unmet, the viewer cannot open or render the data at all — it should not be shown.
  • Data support (warnings): Soft requirements. If unmet, the viewer can still open the data but may not display certain features — it should still be shown, with warnings logged or surfaced to the user.

The checks performed, in order:

| Check | Metadata field | Manifest field | Level | Result if mismatch | | --- | --- | --- | --- | --- | | OME-Zarr version | version or multiscales[0].version | ome_zarr_versions | Compatibility | Error — viewer cannot load this version | | Compression codec | compressor.id | compression_codecs | Compatibility | Error if codec not listed; Warning if viewer declares no codecs (unknown support) | | Axes metadata | axes | axes | Support | Warning — axis names/units may be ignored | | Channel support | axes contains c/channel | channels | Support | Warning — multi-channel data may not render correctly | | Timepoint support | axes contains t/time | timepoints | Support | Warning — time-series data may not render correctly | | Labels | labels array non-empty | labels | Support | Warning — labels won't be displayed | | HCS plates | plate present | hcs_plates | Support | Warning — plate layout won't be shown | | OMERO metadata | omero present | omero_metadata | Support | Warning — channel colors etc. won't be applied | | Scale transforms | multiscales[].datasets[].coordinateTransformations type scale | scale | Support | Warning — scaling factors may be ignored | | Translation offsets | multiscales[].datasets[].coordinateTransformations type translation | translation | Support | Warning — coordinate offsets may be ignored | | bioformats2raw layout | bioformats2raw_layout | bioformats2raw_layout | Support | Warning — layout may not be traversed correctly |

Note on rfcs_supported: Although rfcs_supported is a hard compatibility requirement (it determines whether a viewer can parse RFC-mandated metadata structures), no validation check is currently implemented. OME-NGFF metadata does not yet expose which RFCs a dataset requires — this is a spec-level gap. When the spec defines a rfcs_required field, the validator will compare it against viewer.capabilities.rfcs_supported and produce an error on mismatch.

A viewer is considered data-compatible (dataCompatible: true) when there are zero errors — it should be shown to the user. dataFeaturesSupported is false when there are warnings, indicating the viewer can open the data but may not display all features.

Prototype

There is a prototype in this repo which implements a basic compatibility matrix by fetching the individual viewer manifests.

Releasing to npm

To publish a new version to npm manually:

# 1. Run tests
npm test

# 2. Clean and build the library (compiles TypeScript to dist/)
rm -rf dist && npm run build:lib

# 3. Bump the version in package.json (patch, minor, or major)
# Using this command automatically makes a commit with the
# updated package.json and package-lock.json
npm version patch   # e.g. 0.3.1 -> 0.3.2

# 4. Login to npm (if not already) and publish
# (uses "publishConfig": {"access": "public"} from package.json)
npm login
npm publish

# 5. Push the version commit
git push

Other links