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

@ankhorage/paradox

v0.1.7

Published

Deterministic documentation generator for TypeScript packages.

Readme

@ankhorage/paradox

license: MIT npm: v0.1.6 runtime: bun typescript: strict eslint: checked prettier: checked build: checked tests: checked docs: paradox

Deterministic documentation generator for TypeScript packages.

Installation

bunx @ankhorage/paradox

CLI

Runs the Paradox CLI.

The command discovers the nearest Paradox config, resolves the package and output roots, analyzes the package, builds the documentation model, renders all documentation artifacts, and writes them to the configured output directory.

bunx @ankhorage/paradox

Diagram: paradox sequence

sequenceDiagram
  participant participant_analyze as analyze
  participant participant_buildModel as buildModel
  participant participant_dirname as dirname
  participant participant_findParadoxConfigFile as findParadoxConfigFile
  participant participant_loadParadoxConfig as loadParadoxConfig
  participant participant_main as main
  participant participant_render as render
  participant participant_resolveOutputRoot as resolveOutputRoot
  participant participant_resolvePackageRoot as resolvePackageRoot
  participant participant_write as write
  participant_main->>participant_findParadoxConfigFile: findParadoxConfigFile()
  participant_findParadoxConfigFile-->>participant_main: return
  participant_main->>participant_dirname: dirname()
  participant_dirname-->>participant_main: return
  participant_main->>participant_loadParadoxConfig: loadParadoxConfig()
  participant_loadParadoxConfig-->>participant_main: return
  participant_main->>participant_resolvePackageRoot: resolvePackageRoot()
  participant_resolvePackageRoot-->>participant_main: return
  participant_main->>participant_resolveOutputRoot: resolveOutputRoot()
  participant_resolveOutputRoot-->>participant_main: return
  participant_main->>participant_analyze: analyze()
  participant_analyze-->>participant_main: return
  participant_main->>participant_buildModel: buildModel()
  participant_buildModel-->>participant_main: return
  participant_main->>participant_render: render()
  participant_render-->>participant_main: return
  participant_main->>participant_write: write()
  participant_write-->>participant_main: return

Configuration

Create a paradox.config.ts file:

import { defineParadoxConfig } from '@ankhorage/paradox';

export default defineParadoxConfig({
  // ...
});

| Field | Type | Required | Default | Description | | ------- | --------------------------------------------------------- | -------- | ------- | ----------- | | mode | 'safe' \| 'write' \| undefined | no | — | | | docs | { title?: string; description?: string; } \| undefined | no | — | | | package | { root?: string; entrypoints?: string[]; } \| undefined | no | — | | | output | { dir?: string; } \| undefined | no | — | |

Generated documentation

Architecture preview

graph TD
  package__ankhorage_paradox["@ankhorage/paradox"]
  entrypoint_src_index_ts["src/index.ts"]
  package__ankhorage_paradox --> entrypoint_src_index_ts
  module_src_analyze_analyze_ts["src/analyze/analyze.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_analyze_ts
  module_src_analyze_analyze_ts --> module_src_analyze_badges_ts
  module_src_analyze_analyze_ts --> module_src_analyze_components_ts
  module_src_analyze_analyze_ts --> module_src_analyze_exports_ts
  module_src_analyze_analyze_ts --> module_src_analyze_modules_ts
  module_src_analyze_analyze_ts --> module_src_analyze_project_ts
  module_src_analyze_analyze_ts --> module_src_analyze_semantic_createTypeScriptProgram_ts
  module_src_analyze_analyze_ts --> module_src_analyze_semantic_exports_ts
  module_src_analyze_analyze_ts --> module_src_analyze_semantic_graphs_ts
  module_src_analyze_analyze_ts --> module_src_analyze_sequenceScenarios_ts
  module_src_analyze_analyze_ts --> module_src_analyze_sourceFunctions_ts
  module_src_analyze_analyze_ts --> module_src_analyze_types_ts
  module_src_analyze_analyze_ts --> module_src_analyze_usage_ts
  module_src_analyze_analyze_ts --> module_src_config_types_ts
  module_src_analyze_badges_ts["src/analyze/badges.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_badges_ts
  module_src_analyze_badges_ts --> module_src_analyze_types_ts
  module_src_analyze_badges_ts --> module_src_analyze_usage_ts
  module_src_analyze_components_ts["src/analyze/components.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_components_ts
  module_src_analyze_components_ts --> module_src_analyze_semantic_exports_ts
  module_src_analyze_components_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_components_ts --> module_src_analyze_types_ts
  module_src_analyze_components_ts --> module_src_analyze_utils_getComponentPropsType_ts
  module_src_analyze_components_ts --> module_src_analyze_utils_getPropsFromType_ts
  module_src_analyze_components_ts --> module_src_analyze_utils_isReactComponent_ts
  module_src_analyze_exports_ts["src/analyze/exports.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_exports_ts
  module_src_analyze_exports_ts --> module_src_analyze_types_ts
  module_src_analyze_exports_ts --> module_src_analyze_utils_getExportMetadata_ts
  module_src_analyze_exports_ts --> module_src_analyze_utils_getParadoxComment_ts
  module_src_analyze_exports_ts --> module_src_analyze_utils_parseParadoxComment_ts
  module_src_analyze_exports_ts --> module_src_analyze_utils_resolveExportSymbol_ts
  module_src_analyze_modules_ts["src/analyze/modules.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_modules_ts
  module_src_analyze_modules_ts --> module_src_analyze_types_ts
  module_src_analyze_project_ts["src/analyze/project.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_project_ts
  module_src_analyze_semantic_analyzeProject_ts["src/analyze/semantic/analyzeProject.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_analyzeProject_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_associateDocBlocksWithSymbols_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_collectSourceFiles_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_createTypeScriptProgram_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_docBlocks_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_exports_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_graphs_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_analyzeProject_ts --> module_src_analyze_semantic_tagRegistry_ts
  module_src_analyze_semantic_associateDocBlocksWithSymbols_ts["src/analyze/semantic/associateDocBlocksWithSymbols.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_associateDocBlocksWithSymbols_ts
  module_src_analyze_semantic_associateDocBlocksWithSymbols_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_associateDocBlocksWithSymbols_ts --> module_src_analyze_semantic_utils_ts
  module_src_analyze_semantic_collectSourceFiles_ts["src/analyze/semantic/collectSourceFiles.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_collectSourceFiles_ts
  module_src_analyze_semantic_collectSourceFiles_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_collectSourceFiles_ts --> module_src_analyze_semantic_utils_ts
  module_src_analyze_semantic_createTypeScriptProgram_ts["src/analyze/semantic/createTypeScriptProgram.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_createTypeScriptProgram_ts
  module_src_analyze_semantic_createTypeScriptProgram_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_createTypeScriptProgram_ts --> module_src_analyze_semantic_utils_ts
  module_src_analyze_semantic_docBlocks_ts["src/analyze/semantic/docBlocks.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_docBlocks_ts
  module_src_analyze_semantic_docBlocks_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_docBlocks_ts --> module_src_analyze_semantic_tagRegistry_ts
  module_src_analyze_semantic_docBlocks_ts --> module_src_analyze_semantic_utils_ts
  module_src_analyze_semantic_exports_ts["src/analyze/semantic/exports.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_exports_ts
  module_src_analyze_semantic_exports_ts --> module_src_analyze_semantic_isReactComponent_ts
  module_src_analyze_semantic_exports_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_exports_ts --> module_src_analyze_semantic_paradoxComment_ts
  module_src_analyze_semantic_exports_ts --> module_src_analyze_semantic_utils_ts
  module_src_analyze_semantic_graphs_ts["src/analyze/semantic/graphs.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_graphs_ts
  module_src_analyze_semantic_graphs_ts --> module_src_analyze_semantic_exports_ts
  module_src_analyze_semantic_graphs_ts --> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_graphs_ts --> module_src_analyze_semantic_utils_ts
  module_src_analyze_semantic_isReactComponent_ts["src/analyze/semantic/isReactComponent.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_isReactComponent_ts
  module_src_analyze_semantic_model_ts["src/analyze/semantic/model.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_model_ts
  module_src_analyze_semantic_paradoxComment_ts["src/analyze/semantic/paradoxComment.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_paradoxComment_ts
  module_src_analyze_semantic_tagRegistry_ts["src/analyze/semantic/tagRegistry.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_tagRegistry_ts
  module_src_analyze_semantic_utils_ts["src/analyze/semantic/utils.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_semantic_utils_ts
  module_src_analyze_sequenceScenarios_ts["src/analyze/sequenceScenarios.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_sequenceScenarios_ts
  module_src_analyze_sequenceScenarios_ts --> module_src_analyze_semantic_utils_ts
  module_src_analyze_sequenceScenarios_ts --> module_src_analyze_types_ts
  module_src_analyze_sequenceScenarios_ts --> module_src_analyze_usage_ts
  module_src_analyze_sequenceScenarios_ts --> module_src_analyze_utils_getParadoxComment_ts
  module_src_analyze_sequenceScenarios_ts --> module_src_analyze_utils_parseParadoxComment_ts
  module_src_analyze_sourceFunctions_ts["src/analyze/sourceFunctions.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_sourceFunctions_ts
  module_src_analyze_sourceFunctions_ts --> module_src_analyze_types_ts
  module_src_analyze_sourceFunctions_ts --> module_src_analyze_utils_getParadoxComment_ts
  module_src_analyze_sourceFunctions_ts --> module_src_analyze_utils_parseParadoxComment_ts
  module_src_analyze_types_ts["src/analyze/types.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_types_ts
  module_src_analyze_usage_ts["src/analyze/usage.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_usage_ts
  module_src_analyze_usage_ts --> module_src_analyze_types_ts
  module_src_analyze_utils_getComponentPropsType_ts["src/analyze/utils/getComponentPropsType.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_utils_getComponentPropsType_ts
  module_src_analyze_utils_getExportMetadata_ts["src/analyze/utils/getExportMetadata.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_utils_getExportMetadata_ts
  module_src_analyze_utils_getExportMetadata_ts --> module_src_analyze_types_ts
  module_src_analyze_utils_getExportMetadata_ts --> module_src_analyze_utils_getParadoxComment_ts
  module_src_analyze_utils_getExportMetadata_ts --> module_src_analyze_utils_parseParadoxComment_ts
  module_src_analyze_utils_getParadoxComment_ts["src/analyze/utils/getParadoxComment.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_utils_getParadoxComment_ts
  module_src_analyze_utils_getPropsFromType_ts["src/analyze/utils/getPropsFromType.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_utils_getPropsFromType_ts
  module_src_analyze_utils_getPropsFromType_ts --> module_src_analyze_types_ts
  module_src_analyze_utils_getPropsFromType_ts --> module_src_analyze_utils_getParadoxComment_ts
  module_src_analyze_utils_getPropsFromType_ts --> module_src_analyze_utils_parseParadoxComment_ts
  module_src_analyze_utils_isReactComponent_ts["src/analyze/utils/isReactComponent.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_utils_isReactComponent_ts
  module_src_analyze_utils_parseParadoxComment_ts["src/analyze/utils/parseParadoxComment.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_utils_parseParadoxComment_ts
  module_src_analyze_utils_resolveExportSymbol_ts["src/analyze/utils/resolveExportSymbol.ts"]
  package__ankhorage_paradox -.-> module_src_analyze_utils_resolveExportSymbol_ts
  module_src_cli_ts["src/cli.ts"]
  package__ankhorage_paradox -.-> module_src_cli_ts
  module_src_cli_ts --> module_src_analyze_analyze_ts
  module_src_cli_ts --> module_src_model_buildModel_ts
  module_src_cli_ts --> module_src_paths_policy_ts
  module_src_cli_ts --> module_src_render_render_ts
  module_src_cli_ts --> module_src_write_write_ts
  module_src_config_defineParadoxConfig_ts["src/config/defineParadoxConfig.ts"]
  package__ankhorage_paradox -.-> module_src_config_defineParadoxConfig_ts
  module_src_config_defineParadoxConfig_ts --> module_src_config_types_ts
  module_src_config_types_ts["src/config/types.ts"]
  package__ankhorage_paradox -.-> module_src_config_types_ts
  module_src_doc_tags_registry_ts["src/doc-tags/registry.ts"]
  package__ankhorage_paradox -.-> module_src_doc_tags_registry_ts
  module_src_index_ts["src/index.ts"]
  module_src_model_buildModel_ts["src/model/buildModel.ts"]
  package__ankhorage_paradox -.-> module_src_model_buildModel_ts
  module_src_model_buildModel_ts --> module_src_model_types_ts
  module_src_model_types_ts["src/model/types.ts"]
  package__ankhorage_paradox -.-> module_src_model_types_ts
  module_src_paths_policy_ts["src/paths/policy.ts"]
  package__ankhorage_paradox -.-> module_src_paths_policy_ts
  module_src_paths_policy_ts --> module_src_config_types_ts
  module_src_render_render_ts["src/render/render.ts"]
  package__ankhorage_paradox -.-> module_src_render_render_ts
  module_src_render_render_ts --> module_src_model_types_ts
  module_src_render_render_ts --> module_src_render_renderers_badges_ts
  module_src_render_render_ts --> module_src_render_renderers_diagrams_ts
  module_src_render_render_ts --> module_src_render_renderers_html_ts
  module_src_render_render_ts --> module_src_render_renderers_markdown_ts
  module_src_render_render_ts --> module_src_render_types_ts
  module_src_render_renderers_badges_ts["src/render/renderers/badges.ts"]
  package__ankhorage_paradox -.-> module_src_render_renderers_badges_ts
  module_src_render_renderers_badges_ts --> module_src_model_types_ts
  module_src_render_renderers_badges_ts --> module_src_render_types_ts
  module_src_render_renderers_diagrams_ts["src/render/renderers/diagrams.ts"]
  package__ankhorage_paradox -.-> module_src_render_renderers_diagrams_ts
  module_src_render_renderers_diagrams_ts --> module_src_model_types_ts
  module_src_render_renderers_diagrams_ts --> module_src_render_types_ts
  module_src_render_renderers_html_ts["src/render/renderers/html.ts"]
  package__ankhorage_paradox -.-> module_src_render_renderers_html_ts
  module_src_render_renderers_html_ts --> module_src_model_types_ts
  module_src_render_renderers_html_ts --> module_src_render_types_ts
  module_src_render_renderers_markdown_ts["src/render/renderers/markdown.ts"]
  package__ankhorage_paradox -.-> module_src_render_renderers_markdown_ts
  module_src_render_renderers_markdown_ts --> module_src_model_types_ts
  module_src_render_renderers_markdown_ts --> module_src_render_types_ts
  module_src_render_types_ts["src/render/types.ts"]
  package__ankhorage_paradox -.-> module_src_render_types_ts
  module_src_render_types_ts --> module_src_model_types_ts
  module_src_write_write_ts["src/write/write.ts"]
  package__ankhorage_paradox -.-> module_src_write_write_ts
  module_src_write_write_ts --> module_src_config_types_ts
  module_src_write_write_ts --> module_src_render_types_ts

Public API

Config

defineParadoxConfig(config: ParadoxConfig) => ParadoxConfig

Defines a Paradox configuration object without changing its shape.

Module: src/config/defineParadoxConfig.ts Source: src/config/defineParadoxConfig.ts:8:1 Related symbols: ParadoxConfig

Configuration for running Paradox.

Module: src/config/types.ts Source: src/config/types.ts:7:1

Documentation

Supported Paradox documentation tags.

Paradox supports doc tags inside triple-star documentation comments.

| name | syntax | description | applies to | repeatable | handler | | --------- | ---------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------- | ---------- | -------------- | | readme | @readme | Includes a documentation block or exported symbol in README output. | block, symbol | no | markReadme | | config | @config | Marks a type or interface as part of the Paradox configuration model. @config alone does not imply README inclusion; use @config plus @readme for README output. | interface, type | no | markConfig | | example | @example | Adds a titled fenced code example to the generated documentation for a symbol. | symbol | yes | parseExample |

Module: src/doc-tags/registry.ts Source: src/doc-tags/registry.ts:8:14