Releases: TypeStrong/typedoc
Releases · TypeStrong/typedoc
v0.26.2
Features
- Added a
--suppressCommentWarningsInDeclarationFilesoption to disable warnings from
parsing comments in declaration files, #2611. - Improved comment discovery to more closely match TypeScript's discovery when getting comments
for members of interfaces/classes, #2084, #2545.
Bug Fixes
- The
textnon-highlighted language no longer causes warnings when rendering, #2610. - If a comment on a method is inherited from a parent class, and the child class does not
use an@paramtag from the parent, TypeDoc will no longer warn about the@paramtag.
v0.26.1
Features
- Improved Korean translation coverage, #2602.
Bug Fixes
- Added
@authorto the default list of recognized tags, #2603. - Anchor links are no longer incorrectly checked for relative paths, #2604.
- Fixed an issue where line numbers reported in error messages could be incorrect, #2605.
- Fixed relative link detection for markdown links containing code in their label, #2606.
- Fixed an issue with packages mode where TypeDoc would use (much) more memory than required, #2607.
- TypeDoc will no longer crash when asked to render highlighted code for an unsupported language, #2609.
- Fixed an issue where relatively-linked files would not be copied to the output directory in packages mode.
- Fixed an issue where modifier tags were not applied to top level modules in packages mode.
- Fixed an issue where excluded tags were not removed from top level modules in packages mode.
.jsoncconfiguration files are now properly read as JSONC, rather than being passed torequire.
Thanks!
- @KNU-K
v0.26.0
Breaking Changes
- Drop support for Node 16.
- Moved from
markedtomarkdown-itfor parsing as marked has moved to an async model which supporting would significantly complicate TypeDoc's rendering code.
This means that any projects settingmarkedOptionsneeds to be updated to usemarkdownItOptions.
Unlikemarked@4,markdown-itpushes lots of functionality to plugins. To use plugins, a JavaScript config file must be used with themarkdownItLoaderoption. - Updated Shiki from 0.14 to 1.x. This should mostly be a transparent update which adds another 23 supported languages and 13 supported themes.
As Shiki adds additional languages, the time it takes to load the highlighter increases linearly. To avoid rendering taking longer than necessary,
TypeDoc now only loads a few common languages. Additional languages can be loaded by setting the--highlightLanguagesoption. - Changed default of
--excludePrivatetotrue. - Renamed
--sitemapBaseUrlto--hostedBaseUrlto reflect that it can be used for more than just the sitemap. - Removed deprecated
navigation.fullTreeoption. - Removed
--mediaoption, TypeDoc will now detect image links within your comments and markdown documents and automatically copy them to the site. - Removed
--includesoption, use the@documenttag instead. - Removed
--stripYamlFrontmatteroption, TypeDoc will always do this now. - Renamed the
--htmlLangoption to--lang. - Removed the
--gaIdoption for Google Analytics integration and correspondinganalyticstheme member, #2600. - All function-likes may now have comments directly attached to them. This is a change from previous versions of TypeDoc where functions comments
were always moved down to the signature level. This mostly worked, but caused problems with type aliases, so was partially changed in 0.25.13.
This change was extended to apply not only to type aliases, but also other function-likes declared with variables and callable properties.
As a part of this change, comments on the implementation signature of overloaded functions will now be added to the function reflection, and will
not be inherited by signatures of that function, #2521. - API: TypeDoc now uses a typed event emitter to provide improved type safety, this found a bug where
Converter.EVENT_CREATE_DECLARATION
was emitted forProjectReflectionin some circumstances. - API:
MapOptionDeclaration.mapErrorhas been removed. - API: Deprecated
BindOptiondecorator has been removed. - API:
DeclarationReflection.indexSignaturehas been renamed toDeclarationReflection.indexSignatures.
Note: This also affects JSON serialization. TypeDoc will support JSON output from 0.25 through at least 0.26. - API:
JSONOutput.SignatureReflection.typeParameterhas been renamed totypeParametersto match the JS API. - API:
DefaultThemeRenderContext.iconsCachehas been removed as it is no longer needed. - API:
DefaultThemeRenderContext.hookmust now be passedcontextif required by the hook.
Features
- Added support for TypeScript 5.5.
- Added new
--projectDocumentsoption to specify additional Markdown documents to be included in the generated site #247, #1870, #2288, #2565. - TypeDoc now has the architecture in place to support localization. No languages besides English
are currently shipped in the package, but it is now possible to add support for additional languages, #2475. - Added support for a
packageOptionsobject which specifies options that should be applied to each entry point when running with--entryPointStrategy packages, #2523. --hostedBaseUrlwill now be used to generate a<link rel="canonical">element in the project root page, #2550.- Added support for documenting individual elements of a union type, #2585.
Note: This feature is only available on type aliases directly containing unions. - TypeDoc will now log the number of errors/warnings errors encountered, if any, after a run, #2581.
- New option,
--customFooterHtmlto add custom HTML to the generated page footer, #2559. - TypeDoc will now copy modifier tags to children if specified in the
--cascadedModifierTagsoption, #2056. - TypeDoc will now warn if mutually exclusive modifier tags are specified for a comment (e.g. both
@alphaand@beta), #2056. - Groups and categories can now be collapsed in the page body, #2330.
- Added support for JSDoc
@hideconstructortag.
This tag should only be used to work around TypeScript#58653, prefer the more general@hidden/@ignoretag to hide members normally, #2577. - Added
--useHostedBaseUrlForAbsoluteLinksoption to use the--hostedBaseUrloption to produce absolute links to pages on a site, #940. - Tag headers now generate permalinks in the default theme, #2308.
- TypeDoc now attempts to use the "most likely name" for a symbol if the symbol is not present in the documentation, #2574.
- Fixed an issue where the "On This Page" section would include markdown if the page contained headings which contained markdown.
- TypeDoc will now warn if a block tag is used which is not defined by the
--blockTagsoption. - Added three new sort strategies
documents-first,documents-last, andalphabetical-ignoring-documentsto order markdown documents. - Added new
--alwaysCreateEntryPointModuleoption. When set, TypeDoc will always create aModulefor entry points, even if only one is provided.
If--projectDocumentsis used to add documents, this option defaults totrue, otherwise, defaults tofalse. - Added new
--highlightLanguagesoption to control what Shiki language packages are loaded. - TypeDoc will now render union elements on new lines if there are more than 3 items in the union.
- TypeDoc will now only render the "Type Declaration" section if it will provide additional information not already presented in the page.
This results in significantly smaller documentation pages in many cases where that section would just repeat what has already been presented in the rendered type. - Added
comment.beforeTagsandcomment.afterTagshooks for plugin use.
Combined withCommentTag.skipRenderingthis can be used to provide custom tag handling at render time.
Bug Fixes
- TypeDoc now supports objects with multiple index signatures, #2470.
- Header anchor links in rendered markdown are now more consistent with headers generated by TypeDoc, #2546.
- Types rendered in the
Returnsheader are now properly colored, #2546. - Links added with the
navigationLinksoption are now moved into the pull out navigation on mobile displays, #2548. @licenseand@importcomments will be ignored at the top of files, #2552.- Fixed issue in documentation validation where constructor signatures where improperly considered not documented, #2553.
- Keyboard focus is now visible on dropdowns and checkboxes in the default theme, #2556.
- The color theme label in the default theme now has an accessible name, #2557.
- Fixed issue where search results could not be navigated while Windows Narrator was on, #2563.
charsetis now correctly cased in<meta>tag generated by the default theme, #2568.- Fixed very slow conversion on Windows where Msys git was used by typedoc to discover repository links, #2586.
- Validation will now be run in watch mode, #2584.
- Fixed an issue where custom themes which added dependencies in the
<head>element could result in broken icons, #2589. @defaultand@defaultValueblocks are now recognized as regular blocks if they include inline tags, #2601.- Navigation folders sharing a name will no longer be saved with a shared key to
localStorage. - The
--hideParameterTypesInTitleoption no longer applies when rendering function types. - Broken
@linktags in readme files will now cause a warning when link validation is enabled. - Fixed
externalSymbolLinkMappingsoption's support for meanings in declaration references. - Buttons to copy code now have the
type=buttonattribute set to avoid being treated as submit buttons. --hostedBaseUrlwill now implicitly add a trailing slash to the generated URL.
Thanks!
Unreleased
v0.25.13
Features
- Added
gitRevision:shortplaceholder option to--sourceLinkTemplateoption, #2529.
Links generated by TypeDoc will now default to using the non-short git revision. - Moved "Generated by TypeDoc" footer into a
<footer>tag, addedfooter.beginandfooter.end
render hooks for use by custom plugins, #2532.
Bug Fixes
- Fixed conversion of
NoInfermissing type parameter reference, #2539. - Linking to a member on a page no longer incorrectly claims that
"This member is normally hidden due to your filter settings" for every member.
Thanks!
v0.25.12
v0.25.11
v0.25.10
Bug Fixes
- Constructed references to enum types will be properly linked with
@interface, #2508. - Comments on property-methods will no longer be duplicated in generated documentation, #2509.
- Reduced rendered docs size by writing icons to a referenced SVG asset, #2505.
For TypeDoc's docs, this reduced the rendered documentation size by ~30%. - The HTML docs now attempt to reduce repaints caused by dynamically loading the navigation, #2491.
- When navigating to a link that contains an anchor, the page will now be properly highlighted in the page navigation.
v0.25.9
Features
- Literal numeric unions will now be sorted during conversion, #2502.
Bug Fixes
- Module readmes will now be included in JSON output, #2500.
- Fixed crash when
--excludeNotDocumentedwas used and the project contained a reference to a removed signature, #2496. - Fixed crash when converting an infinitely recursive type via a new
--maxTypeConversionDepthoption, #2507. - Type links in "Parameters" and "Type Parameters" sections of the page will now be correctly colored.
Thanks!
v0.25.8
Features
- Added a new
--sitemapBaseUrloption. When specified, TypeDoc will generate asitemap.xmlin your output folder that describes the site, #2480. - Added support for the
@classtag. When added to a comment on a variable or function, TypeDoc will convert the member as a class, #2479.
Note: This should only be used on symbols which actually represent a class, but are not declared as a class for some reason. - Added support for
@groupDescriptionand@categoryDescriptionto provide a description of groups and categories, #2494. - API: Exposed
Context.getNodeCommentfor plugin use, #2498.
Bug Fixes
- Fixed an issue where a namespace would not be created for merged function-namespaces which are declared as variables, #2478.
- A class which implements itself will no longer cause a crash when rendering HTML, #2495.
- Variable functions which have construct signatures will no longer be converted as functions, ignoring the construct signatures.
- The class hierarchy page will now include classes whose base class is not included in the documentation, #2486.
- Fixed an issue where, if the index section was collapsed when loading the page, all content within it would be hidden until expanded, and a member visibility checkbox was changed.
- API:
Context.programswill no longer contain duplicates, #2498.