Skip to main content

Release 1.6

Β· 4 min read
Qian Liu
Maintainer, Key Contributor
Nikita Rokotyan
Creator, Key Contributor
Surya Hanumandla
Maintainer, Key Contributor

Version 1.6 of Unovis is here! This is one of our most feature-packed releases yet, bringing exciting new components, enhanced graph functionality, improved axis customization, and numerous quality of life improvements.

We're excited to welcome our new first-time contributors to the Unovis community: @dennisadriaans, @curran, @50rayn, and @devgru. Thank you for your valuable contributions! πŸŽ‰

Release Highlights​

πŸ“Š New Components: Treemap, Plotline, Plotband & Rolling Pin Legend​

Introducing four new components:

Treemap

  • Hierarchical data visualization with customizable layers
  • Rich styling options including tileColor, tilePadding, tileBorderRadius and lightnessVariationAmount
  • Interactive features with hover states: --vis-treemap-tile-hover-stroke-color, --vis-treemap-tile-hover-stroke-opacity

Plotline - Draw precise reference lines across your charts:

image
  • Support for both X and Y axis orientation
  • Customizable line styles (solid, dashed, dotted)
  • Configurable colors, widths, and positioning
  • Works with all XY components

Plotband - Highlight ranges and areas in your visualizations:

image
  • Create horizontal or vertical bands across chart areas
  • Customizable colors with transparency support
  • Flexible labeling with multiple positioning options

Rolling Pin Legend - Compact legend for displaying color scales:

image
  • Displays color gradients in a horizontal rolling pin format
  • Left and right label support for scale endpoints
  • Customizable font sizes and styling

Check out Plotline's documentation, Plotband's documentation, Treemap's documentation, and Rolling Pin Legend's documentation with examples to learn how to use them.

🎯 Enhanced Crosshair Component​

Allow enforcement of crosshair display at certain position, this can be used to enable synchronized crosshair display

πŸ“ˆ Line Chart Interpolation​

New interpolation feature for handling missing data in line charts:

  • interpolateMissingData property fills data gaps with dashed lines
  • Customizable appearance with CSS variables
    --vis-line-gapfill-stroke-dasharray: 2 3;
--vis-line-gapfill-stroke-opacity: 0.8;
--vis-line-gapfill-stroke-dashoffset: 0;
  • Works seamlessly with fallback values for better data visualization

πŸ”˜ Bullet Legend Enhancements​

Bullet Legend now supports multiple colors per item, enabling more sophisticated legend designs:

image
  • Multiple color arrays for complex legend items

πŸ“ Axis Customization​

New CSS variables for greater axis styling control:

  • --vis-axis-line-stroke-color: Customize axis line color
  • --vis-axis-line-stroke-width: Control axis line thickness
  • Better separation between domain line and tick styling
  • Label Trim and Wrap: Add trim and wrap functionality to axis labels for better text handling
Screenshot 2025-08-13 at 12 36 45β€―PM

⏱️ Timeline Component Enhancements​

Major updates to the Timeline component with new features and improved functionality:

  • Row Icons: Support for enhanced visual categorization with icons alongside row labels
  • Line Icons: Add start and end icons to timeline lines with configurable positioning
  • Arrow Support: Connect related timeline entries with customizable arrows allowing user to create Gantt Charts
  • Hover Styles: Better visual feedback with configurable hover states
  • Animation Control: Configurable animation positions for line enter/exit transitions
  • Label Positioning: Improved label positioning and clipping behavior with dedicated clipPath
  • labelTextAlign: Adds labelTextAlign config option to Timeline component to control label alignment

πŸ”— Graph Component Updates​

Continued improvements to the Graph component:

  • Enhanced panel documentation and examples
  • Configurable node and group spacing in Parallel layouts (doc)

Other Changes​

Enhancements​

  • Component | Graph: Enhanced panel documentation and examples #616
  • Container | XY: Handle edge cases when scaleByDomain is true #588
  • Website | Gallery: New custom nodes graph with tooltips example #603
  • Website | Gallery: New patchy line chart gallery example #558
  • Website | Gallery: New stacked area chart with attributes example #597
  • Website | Docs: Enhanced documentation for multiple components

Bug Fixes​

  • Component | Tooltip: Fix dynamic config retrieval for mousemove handler #606
  • Component | Graph: Fix link flow group dot issue #575
  • Component | Graph: Fix link flow animation update #577
  • Component | Timeline: Fix icon data binding, ordinal scale domain, and arrow exit transition #536
  • Solid | Bug: Component destroy method #602
  • Core | Types: Making fontSize optional in UnovisText #585

Quality of Life Improvements​

  • TS: Replace deprecated JSX.Element with React.ReactNode #545
  • Testing: Continued improvements to visual testing infrastructure

Release 1.5

Β· 3 min read
Qian Liu
Maintainer, Key Contributor
Nikita Rokotyan
Creator, Key Contributor
Rebecca Bol
Maintainer, Key Contributor

Version 1.5 of Unovis has arrived! This release is packed with enhancements, including full support for Solid; compatibility with React 19 and Angular 19; many Graph component tweaks; exciting new features; and numerous bug fixes.

Release Highlights​

πŸŽ‰ Solid Support​

Unovis now works with Solid β€” one of the most performant JSX frameworks. Thanks to @hngngn for this amazing contribution!

🎊 React 19 and Angular 19​

Unovis now also support Angular 19 and React 19.
Calling for Svelte 5 support contribution (discussion)! Huge thanks to @pingu-codes for your incredible help with Svelte support! πŸš€.

πŸ”— Graph​

A ton of new features were added to Graph:

  • Provide your own functions to render nodes allowing you to highly customize how the graph looks (docs).

  • Post-Layout (docs) and Post-Render Customization (docs) allowing you to modify the layout of the graph on the fly and render additional layers with D3.

  • Provide custom SVG icon to link labels (docs).

  • Zoom start/end and node dragging callbacks (docs).

  • Fit view to specific nodes by providing an array of node ids.

  • Multiple node selection (docs).

  • Enable Graph nodes to accept precalculated layout data (docs).

πŸͺ§ Tooltip​

Tooltip now can be anchored to the target element, can be hovered over, and supports dynamic content (updates if the content changes) (docs).

πŸ“ Axis​

Axis now automatically hides overlapping labels (docs) and supports label rotation (docs).

πŸ”΅ Bullet Legend​

You can set the orientation of Bullet Legend to 'vertical' (docs).

πŸ’¬ Discord​

Unovis now has a Discord channel! Join us to say hi, ask questions, and stay updated with the latest news.

Other changes​

Enhancements​

  • Testing | Add Cypress and Percy for visual testing #419
  • Component | Brush: Additional styling options via CSS variables #392
  • Website | Upgrade to Docusaurus V3 #486
  • Website | Gallery: Range plot #390
  • Website | Gallery: Scatter Plot with Varied Shape #370
  • Website | Gallery: Donut Example #367
  • Website | Add new composite chart section and dual axis chart #383

Bug Fixes​

  • Component | Scatter: MakesizeScale immutable to prevent sizeRange collisions #411
  • Component | Scatter: Label rendering fixes #413
  • Component | TopoJSON Map: Various fixes #425
  • Core | Bug: XY-container size rendering fix #431

Release 1.4

Β· 2 min read
Rebecca Bol
Maintainer, Key Contributor

Version 1.4.0 of Unovis is finally here! This update is packed full with enhancements including the new Annotations component, expanded Graph features, and a number of bug fixes to improve overall stability of the library.

Release Highlights​

πŸ“ New component: Annotations​

Introducing Annotations, a versatile new component that enables you to overlay customized, stylized text on top of your visualizations. Whether you want to highlight points of interest, annotate trends, or simply add text labels to your charts or graphs, Annotations is designed to integrate smoothly with any Unovis component.

Check out Annotations's documentation and gallery example to learn how to use it.

annotations

A number of features were added to Graph in this PR, including link curvature configuration, the ability to use custom SVGs as node icons, and support for longer link labels. Check out the docs for a deep dive into the latest enhancements or to explore the breadth of features Graph has to offer.

SCR-20240105-motu

🧩 Bullet Legend Shapes​

Bullet Legend now supports a variety of shapes on the component level and for individual legend items. Perfect for when you want to pair a legend with a combination chart or shaped scatter plot.

Other changes​

Enhancements​

  • React: Exporting component selectors to allow for easier import #325
  • Component | Crosshair | Configurable stroke and strokeWidth #353
  • Vue | export selector, docs: update #358

Bug Fixes​

  • Component | Donut | Fix: sortFunction type error #308
  • XYContainer | Fix: Crosshair accessors #309
  • Component | Timeline | Fix: Color rendering on enter #310
  • Component | Chord Diagram | Fixes, enhancements, and refactoring #318
  • Website | Releases: Fix url image preview #323
  • Core Component and Tooltip event handling tweaks #330
  • Svelte | Package: Add missing exports condition for Svelte #334
  • Angular | Build: Removing shared from peer dependencies #349
  • React | Fixing ref initialization #344
  • XY Container | Fix: scaleByDomain produces inconsistent behavior among XY charts #348
  • Component | XYLabels | Fix clustering config not taking effect #351
  • Component | Crosshair | Fix: crosshair with multiple area issue #356

Release 1.3

Β· One min read
Nikita Rokotyan
Creator, Key Contributor
Rebecca Bol
Maintainer, Key Contributor

Unovis 1.3 introduces Vue support and a new pattern theme to further improve our support for accessibility features.

Release Highlights​

πŸŽ‰ Vue 3 support​

Long-awaited support for Vue, the third most popular front-end UI framework. Kudos to our community member @zernonia for this amazing contribution!

πŸ‘¨β€πŸŽ¨ Patterns​

A new theme with pattern fills that can be enabled by adding the theme-patterns class to the body element of your document. See the documentation and this pull request for more details.

unovis-patterns unovis-patterns

Other changes​

Other changes were aimed at improving the overall stability of the library making the codebase more robust to future changes

  • Refactoring: From Config Classes to Objects #279
  • Refactoring: No Implicit Any #290
  • Component | Tooltip | Fix: Prevent container overflow when viewport size is reduced #292
  • Component | NestedDonut | Fix: TS errors #296
  • Svelte: Fixing SingleContainer props and adding support for class property #294
  • Theme | Patterns: Adjust injected SVG style #298

Release 1.2

Β· 2 min read
Nikita Rokotyan
Creator, Key Contributor
Rebecca Bol
Maintainer, Key Contributor

A new version of Unovis is waiting for you on NPM! This update introduces a new component: Nested Donut (aka Sunburst). It also adds better support for accessibility features, allows you to apply additional styles to axes, and much more.

Release Highlights​

🍩 New component: Nested Donut​

Nested Donut is a captivating graphical representation that displays hierarchical data in a circular format. Its nested design allows for multiple concentric rings, each representing a different level of data, enabling users to explore relationships and proportions effortlessly.

Check out Nested Donut's documentation and example to learn how to use it.

SCR-20230616-iwvk nested-donut-2

πŸ‘“ Accessibility: Supporting ARIA tags​

You can now set the aria-label attribute for your visualization by providing the ariaLabel config property to the container you use. Unovis will automatically apply role="figure" attribute to the container element, making it accessible to assistive technologies.

Image showing aria-label support in Unovis

πŸ”  New CSS variables for styling Axis​

If you want to customize the width of your tick and grid lines, you can do so using the new --vis-axis-tick-line-width and --vis-axis-grid-line-width variables.

The color of the domain line by default equals the tick color (that can be specified with --vis-axis-tick-color), but Unovis 1.2 allows you to explicitly set it via --vis-axis-domain-color.

Additionally you can apply custom cursor and text-decoration to your tick labels with --vis-axis-tick-label-cursor and --vis-axis-tick-label-text-decoration variables.

image

Other changes​

Enhancements​

  • Component | LeafletMap: Adding getExpandedCluster public method #205
  • Component | Line: Better enter transition for broken lines #227
  • Component | Scatter: Fixing the missing points issue #227
  • Component | Scatter: Stroke color and width support #232

Bug Fixes​

  • Container | XY: Calling render right after initialization if there are axes or components with data #212
  • @unovis/svelte: Updating component lifecycles to prevent DOM related errors with SvelteKt (SSR) #216

Other​

  • Core: Using native ResizeObserver when available #209
  • Dependencies: Updating Dagre packages to work with Angular 16 #210

Release 1.1

Β· 2 min read
Nikita Rokotyan
Creator, Key Contributor
Rebecca Bol
Maintainer, Key Contributor

We're excited to announce the release of Unovis 1.1.0! This update brings new features, enhancements, and bug fixes that improve the overall user experience and stability of the library.

Release Highlights​

🦌 ELK support for Graph​

We've added ELK integration to our Graph component. Now you can render complex hierarchical graphs ELK is famous for! SCR-20230405-ngtd

πŸ₯¨ New component: Multi-Level Chord Diagram​

Multi-Level Chord Diagram can display hierarchical relationships and interactions between multiple entities, often used to visualize complex systems or networks. It showcases the flow of data or connections between different levels, allowing users to understand the intricacies of interconnected components and their relative importance within the system. SCR-20230419-lhbu

πŸ‘‹ Goodbye lodash​

Unovis doesn't have lodash as it's dependency anymore saving precious 90KB (unzipped) of your app bundle! SCR-20230419-llma

Changelog​

New Features​

  • Component | Graph: ELK Support by @rokotyan #161
  • Chord Diagram: Refactoring, Docs, Examples by @reb-dev #105

Enhancements​

  • Goodbye lodash by @rokotyan #100
  • Component | Timeline: Fixing odd rows fill color by @rokotyan #145
  • Component | LeafletMap: Calling fitView and fitToPoints in the next frame by @rokotyan #148
  • Code Quality: Enabling strictFunctionTypes by @rokotyan #158
  • React | Tweaks: Supporting style and className; Removing @emotion/css dependency by @rokotyan #162
  • Component | LeafletMap | Styles: Updating MapLibreArcticLight style by @rokotyan #165
  • Component | LeafletMap: Configurable inner label color by @rokotyan #156
  • Component | Chord Diagram: Better accessor support for non-leaf nodes by @reb-dev #160
  • Website: Updating Docusaurus and fixing editUrl by @rokotyan #175
  • Container | Core, Single: Setting SVG size in render() by @rokotyan #174

Bug Fixes​

  • Component | Graph | Link fixes by @reb-dev #151
  • React: Fixing double-render on component initialization by @rokotyan #154
  • React: Fixing component initialization flow by @rokotyan #164
  • Component | Chord Diagram: Fixing invisible nodes by @reb-dev #169

Other​

  • Misc tweaks and fixes by @rokotyan #168

Announcing Unovis 1.0

Β· One min read
Nikita Rokotyan
Creator, Key Contributor
Rebecca Bol
Maintainer, Key Contributor

We’re excited to announce Unovis 1.0 - a modular data visualization framework for React, Angular, Svelte, and vanilla TypeScript or JavaScript!​

After more than 3 years in development, Unovis finally goes open source. Unovis can draw charts, maps and network graphs, no matter what UI framework you use. We’ve been using it extensively at F5 with Angular and React apps, and it now empowers user interfaces of F5 Distributed Cloud console and NGINX Controller.

Why Unovis?​

  • πŸ— Integrates nicely with the UI framework of your choice, making it very easy to use;
  • πŸ—Ί Supports various charts, simple and detailed maps, network graphs and diagrams;
  • πŸ’‡ Highly customizable, thanks to the extensive use of CSS variables;
  • πŸ“– Extensive documentation and growing gallery of examples.

Want to give it try?​

Go to unovis.dev, check out the docs, explore the gallery, or jump right into development with our Quick Start guide.