All notable changes to this project will be documented in this file.
See the Changesets for the latest changes.
0.49.0 - 2024-04-26
-
Store, React
- Fix issue where multiple versions of
@zag-js/store
could lead to "proxy state is not iterable" errors
- Fix issue where multiple versions of
-
Collapsible
- Fix issue where initial height animation can sometimes run
-
DatePicker
- Fix issue where date picker content doesn't register as a dismissable when lazy mounted
- Fix issue where changing focused value doesn't update the date picker's visible range
-
Splitter
- Fix issue where
onResize
was not called
- Fix issue where
-
TagsInput
- Fix issue where editing a tag and clearing it's value leaves an empty tag. Now, empty tags will be deleted
- Fix issue where deleting a tag with pointer and navigating with keyboard doesn't work
-
Presence
- Add
api.unmount
to programmatically unmount the component - Add
api.skip
to skip initial animation
- Add
0.48.0 - 2024-04-22
This release marks the journey to a more stable and consistent API across all components. We've made significant changes.
-
Collapsible
- Resolve an issue that sometimes the collapsible height was not measured correctly
-
Toast
- Fix an issue where toast hide immediately after updating
- Fix an issue that the height was not exactly measured
-
Select, Combobox
- Fix issue where
value
is unintentionally sorted when highlighting item
- Fix issue where
-
Checkbox, RadioGroup, Switch
- Add support for
readOnly
prop to prevent user interaction from changing the checkbox state
- Add support for
-
Combobox
- Add support for controlling the open state of the combobox via
open
andonOpenChange
- Add new
openOnChange
property to automatically open the combobox when the value changes. Value can be a boolean or a function that returns a boolean.
const [state, send] = useMachine( combobox.machine({ openOnChange: ({ inputValue }) => inputValue.length > 2, }), )
- Add new
openOnKeypress
property to automatically open the combobox when the arrow keys (up and down) are pressed. - Add
persistFocus
to the item props to determine whether to clear the highlighted item on pointer leave.
- Add support for controlling the open state of the combobox via
-
All machines
- Rename all api to return consistent boolean properties. This means going from
is<X>
to<x>
. For example,isDisabled
->disabled
,isFocused
->focused
,isOpen
->open
, etc. - Rename
open()
,close()
methods tosetOpen(true|false)
- Remove
selectOnBlur
to prevent accidental selection of options. Prefer explicit selection by user via click or enter key.
- Rename all api to return consistent boolean properties. This means going from
-
Accordion
- Rename
getItemState
propertiesisOpen
->expanded
isDisabled
->disabled
isFocused
->focused
- Rename
-
Avatar
- Rename
api.isLoaded
toapi.loaded
- Remove
api.showFallback
since it's equivalent to!api.loaded
- Rename
-
Carousel
- Rename
isCurrent
tocurrent
- Rename
isNext
andisPrevious
tonext
andprevious
respectively - Rename
isPrevious
toprevious
- Rename
-
Clipboard
- Rename
api.isCopied
toapi.copied
- Rename
-
File Upload
- Rename
api.open()
->api.openFilePicker()
- Rename
-
Menu
- Menu now focuses the first tabbable element when it opens. This allows for composition with combobox
- Rename
loop
toloopFocus
to better reflect its purpose
-
TagsInput
- Rename
allowTagEdit
toeditable
- Add
onInputValueChange
to machine context
- Rename
0.47.0 - 2024-04-19
- Select
- Prevent tab key interaction when the select is open. This keeps focus within the select and ensures keyboard interactions work consistently
-
Toast [BREAKING]:
- Simplify toast api methods
<ToastContext.Provider value={api}> - {Object.entries(api.getToastsByPlacement()).map(([placement, toasts]) => ( + {api.getPlacements().map((placement) => ( <div key={placement} {...api.getGroupProps({ placement })}> - {toasts.map((toast) => ( + {api.getToastsByPlacement(placement).map((toast) => ( <Toast key={toast.id} actor={toast} /> ))} </div> ))} {children} </ToastContext.Provider>
- Fix issue where toast closes when you update the same toast type
0.46.0 - 2024-04-12
-
Checkbox, Switch
- Fix issue where
data-active
doesn't get removed when pointer is release outside the element
- Fix issue where
-
Toast
- Fix issue where toast closes when updated without
type
orduration
- Fix issue where toast closes when updated without
-
Signature Pad [NEW]
- Add new signature pad machine to allow capturing user signature
-
Svelte
- Add support for
useActor
hook to be consistent with other frameworks
- Add support for
-
Avatar [Breaking]
- Change
onLoadingStatusChange
toonStatusChange
to match naming convention across machines
- Change
-
Clipboard [Breaking]
- Change
onCopyStatusChange
toonStatusChange
to match naming convention across machines
- Change
-
Toasts [Breaking]
- Add support for overlapping toasts by setting
overlap: true
in thetoast.group
machine context - Remove
pauseOnInteraction
in favor of always pausing on hover. This is required for accessibility reasons (there should always be a way to pause the widgets with time-based interactions) - Remove
onOpen
,onClose
andonClosing
in favor ofonStatusChange
which reports the lifecycle status of the toast - Impose new required styling for toast to work as designed. Here's a quick example of the required styling:
[data-scope="toast"][data-part="root"] { translate: var(--x) var(--y); scale: var(--scale); z-index: var(--z-index); height: var(--height); opacity: var(--opacity); will-change: translate, opacity, scale; transition: translate 400ms, scale 400ms, opacity 400ms; } [data-scope="toast"][data-state="closed"] { transition: translate 400ms, scale 400ms, opacity 200ms; }
- Require new
ghostBeforeProps
andghostAfterProps
props to ensure the hover interaction works as expected
- Add support for overlapping toasts by setting
0.45.0 - 2024-04-04
- Solid: Rewrite
mergeProps
to prevent issues with children that read from context, and ensure props are always up-to-date.
0.44.0 - 2024-04-03
- Tags Input: Support for
RegExp
in delimiter
- Avatar: Remove hardcoded
style
to allow more flexible styling
0.43.0 - 2024-04-02
-
Menu [Breaking]
- Rename
getOptionItemIndicatorProps
togetItemIndicatorProps
- Rename
getOptionItemTextProps
togetItemTextProps
- Changed
data-part
to match new anatomyoption-item
->item
option-item-indicator
->item-indicator
option-item-text
->item-text
- Rename
-
File Upload [Breaking]
-
Remove
files
form user defined context. File upload, just like<input type=file>
, is largely a readonly operation that can't be set by the user.Consider using the
onFileChange
event to handle file changes. -
Rename
api.files
toapi.acceptedFiles
-
Rename
onFilesChange
toonFileChange
-
0.42.0 - 2024-04-01
- File Upload
- Add support selecting directories via
directory
prop - Add support for
capture
property that specifies which camera to use for capture of image or video
- Add support selecting directories via
- Menu [Breaking]
- Removed
value
andonValueChange
in favor of using explicit state to manage option items, and passingchecked
andonCheckedChange
to thegetOptionItemProps
callback. - Prefer
value
overid
ingetItemProps
andgetOptionItemProps
for consistency with other machine. onSelect
now providesvalue
notid
in its details.
- Removed
0.41.0 - 2024-04-01
- Select
- Fix issue where select doesn't work in forms when
readOnly: true
is set - Fix issue where initial value was not synced with hidden select element
- Fix issue where select doesn't work in forms when
-
Dialog: Sync
zIndex
of content with positioner and backdrop via--z-index
css variable. This helps with stacking order when using multiple dialogs. -
Dismissable: Improve interaction outside logic when layer rendering is deferred (via Portals or unmounted)
-
Utilities: Add support for
formatDate
andformatList
functions that use the underlyingIntl.*
implementations
- Tooltip: Set tooltip
interactive
tofalse
by default
0.40.0 - 2024-03-26
- Circular Progress: Fix issue where circular progress circle diameter doesn't get calculated correctly
- Combobox:
- Fix issue where input doesn't clear when
selectionBehavior
is set toclear
- Fix issue where input doesn't show initially selected
value
- Fix issue where empty input was replaced by selected value string when typing
- Fix issue where input doesn't clear when
- [NEW] Introduce new floating panel machine for draggable and resizable panels
- Select
- Add
data-placement
to the select content to make it easier to style - Add support for
scrollToIndexFn
to be used with virtualization libraries - Add support for
highlightedIndex
in theonHighlightChange
callback
- Add
- Svelte: Unify API for
useService
anduseMachine
with other frameworks
0.39.0 - 2024-03-19
- Select: Fix issue where multiple select doesn't work correctly in forms.
- DatePicker: Remove unused
parse
function - TagsInput: Fix issue where setting
addOnPaste
tofalse
and pasting text prevents subsequent tags from being added - Progress: Fix issue where progress throws when value is initially set to
null
- Popper: Fix issue where
crossAxis
positioning property doesn't work in some cases. - Combobox: Fix issue where clear trigger remains hidden when initial value is set.
- Slider: Add support for custom
name
attribute on the thumb element - Splitter: Add
data-orientation
attribute to splitter panel - Menu: Expose
onEscapeKeyDown
event handler
💥 Breaking changes
- Tabs: Rename
api.tablistProps
toapi.listProps
to match naming convention - Dismissable: Use capture phase for escape keydown handling
0.38.1 - 2024-03-08
-
DatePicker
- Fix issue where next and previous had the wrong aria labels
- Fix an issue wher close on click outside does not get called when conditionally rendered
-
FileUpload: Fix an issue where
onFileReject
would not be called -
Switch: Fix accessibility issue where
aria-readonly
was incorrectly set on the wrong element.
0.38.0 - 2024-02-26
- Collapsible: Add
onExitComplete
to listen for exit animation completion.
0.37.2 - 2024-02-25
- Collapsible: Fix issue where collapsible doesn't work when content is initially unmounted, or no animation is attached.
0.37.1 - 2024-02-24
- Collapsible: Fix issue where collapsible doesn't work when content is initially unmounted, or no animation is attached.
0.37.0 - 2024-02-21
- Tour: Add new
Tour
component to guide users through a series of steps in an application. - Expose all machine context properties as array to improve DX of building design system components.
- TreeView: Add missing
getBranchIndicator
function and other minor fixes.
0.36.3 - 2024-02-16
- Collapsible: Export missing types for clipboard machine
- Tooltip: Fix issue where disabled tooltip flashes when hovering and clicking the trigger
0.36.2 - 2024-02-13
- Clipboard: Export missing types for clipboard machine
0.36.1 - 2024-02-13
- HoverCard: Remove superfluous log message when card was hovered
0.36.0 - 2024-02-13
- Refactor scroll utilities to safely handle null element values in test environment
- Dialog: Prevent calling interaction outside logic when scrollbar is clicked
- TreeView: Extend anatomy to include tree item text and indicator parts.
- Clipboard: Add
api.copy()
to copy text to clipboard
0.35.0 - 2024-02-11
-
All components
- Improve runtime performance when using watchers by subscribing to context once.
- Fix issue where restoring scroll causes a smooth scroll transition back to the initial scroll point.
-
Fix issue where scrolling into view could result in scrolling the body element.
Affected components: Select, Menu, Combobox
-
Select:
- Fix issue where item group's label id pointed to the wrong element
- Fix issue where select uses the incorrect id for
aria-activedecesendant
field
-
DatePicker: Fix issue where date picker does not show correct number of weeks when
startOfWeek
is set
-
[NEW] Clipboard: Add Clipboard machine for copying text to clipboard.
-
[NEW] Collapsible: Add Collapsible machine for interactive component which expands/collapses a panel.
-
Add support for open.controlled in the machine context as a way to fully control the machine's open state programmatically.
Affected components: Dialog, HoverCard, Popover, ColorPicker, DatePicker, Tooltip, Menu, HoverCard, and Combobox.
-
Combobox: Expose api.collection for better control over the collection of items in combobox.
- DatePicker
- [BREAKING] Change date picker from
api.inputProps
toapi.getInputProps(...)
to support multiple inputs. - Added a new prop
getPresetTriggerProps
to support custom trigger for common date presets (e.g. Last 7 days, Last 30 days, etc.)
- [BREAKING] Change date picker from
0.34.0 - 2024-01-19
- All components: Fix issue where positioning doesn't work as expected when combined with entry/exit animations in the presence component
- Radio, Tabs: Make it possible to override indicator's transition duration by setting the
--transition-duration
css variable.
0.33.2 - 2024-01-26
- React: Fix context reactivity issue where updates were not sent to the machine
0.33.1 - 2024-01-26
= Core: Fix issue where context mutation updates were missed due to the underlying proxy-compare
regression.
- TreeView: Fix issue where tree view machine types were not exported.
- Select: Add
data-disabled
,data-invalid
, anddata-readonly
to indicator props
0.33.0 - 2024-01-23
- All Machines:
- Improve runtime performance by only creating a machine instance once, and updating the context with
setContext(...)
instead ofwithContext(...)
. - Fix issue on touch devices where selecting an item within combobox, menu, select triggers click event on element behind the portalled content.
- Improve runtime performance by only creating a machine instance once, and updating the context with
PinInput: Fix an issue where paste in pin input would fill the input with all pasted characters instead of 1 per input
-
TreeView: Add new
TreeView
component to render a tree view of items. This component is useful for rendering nested data structures like a file system.This component is still in beta and is subject to change.
- TagsInput:Improve
TagsInput
component design by introducing a newitem-preview
part. See the diff below for more details.
<div {...api.rootProps}>
{api.value.map((value, index) => (
- <span key={index}>
+ <span key={index} {...api.getItemProps({ index, value })}>
- <div {...api.getItemProps({ index, value })}>
+ <div {...api.getItemPreviewProps({ index, value })}>
<span>{value} </span>
<button {...api.getItemDeleteTriggerProps({ index, value })}>✕</button>
</div>
<input {...api.getItemInputProps({ index, value })} />
</span>
))}
<input placeholder="Add tag..." {...api.inputProps} />
</div>
- Progress: Rename indicator part to view to better communicate the purpose of the part.
0.32.1 - 2024-01-10
- ColorPicker: Fix issue where some change details typings were no exported
- Combobox:
- Fix an issue that breaks the combobox when clicking on the input while the menu is open
- Fix issue where some change details typings were no exported
0.31.1 - 2023-12-01
- NumberInput: Fix issue where formatting on blur doesn't work as expected
0.31.0 - 2023-11-27
-
ColorPicker: Fix issue where swatch indicator had incorrect data attributes
-
NumberInput:
- Fix issue when value updates due to intl formatting does not trigger
onValueChange
- Fix issue where increment and decrement buttons doesn't respect locales (esp. when locales uses decimal commas and not decimal points)
- Fix issue when value updates due to intl formatting does not trigger
-
Menu: Fix issue in non-portalled, nested menus where keyboard interactions within submenu bubble to parent menu
- FileUpload
- Add support for
onFileAccept
andonFileReject
callbacks. - Add support customizing
ids
and aria labels usingmessages
context property. - Add item preview image part
- Breaking: Update file error types
TOO_MANY_FILES_REJECTION
>TOO_MANY_FILES
TOO_LARGE
>FILE_TOO_LARGE
TOO_SMALL
>FILE_TOO_SMALL
- Add support for
- DatePicker: Rename
messages
context property totranslations
. This property was previously unused
0.30.0 - 2023-11-14
- RadioGroup: Fix issue where indicator isn't positioned relative to the root
-
ColorPicker:
- Add support for setting the desired output format. This format will be used in the
details.valueAsString
foronValueChange
callback - Add support for format trigger and select parts to help control the format of the output value
- Add
onFormatChange
callback to listen for format changes - Add
closeOnSelect
prop to control whether the color picker should close when a swatch color is selected
- Add support for setting the desired output format. This format will be used in the
-
Toast: Add generic support to toast types to support framework-specific types.
0.28.1 - 2023-11-09
-
Dialog: Fix issue where dialog positioner applied the
hidden
attribute when closed leading to pre-mature exit of css animations applied to the dialog content.Only the backdrop and content should use the
hidden
attribute. -
Combobox: Fix a case where item highlight was looping even though loop property was false
0.28.0 - 2023-11-08
- Menu: Fix issue issue where link is not clickable on mobile
- Accordion: Fix issue where
onValueChange
is not called whenmultiple
is set totrue
- NumberInput
- Fix issue where "." cannot be entered due to virtual dom timing between frameworks
- Fix issue where decrement and increment triggers don't work for touch devices
- ColorPicker, DatePicker: Fix issue where
aria-controls
was not added to trigger - Combobox: Fix autocomplete input behavior not working in Vue.js
- Select: Fix issue where the
loop
property is not respected - Slider: Fix issue where slider thumb throws if index is not provided. We now set
0
as the default index.
- Menu: Add support for controlling menu's open state via the
open
context property
0.27.0 - 2023-10-30
- ColorPicker:
- Fix issue where entering empty value in alpha sets value to
NaN
. Now, it reverts back to the previous alpha value - Fix issue where channel inputs within control and content have similar ids, violating the accessibility tree
- Fix issue where entering empty value in alpha sets value to
- Select: Fix issue where
collection
is not returned in theapi
- React: Refactor types to reference react
use
directly - DatePicker: Fix issue where
api.isOpen
returnedundefined
in some cases
- RadioGroup: Set default orientation to
vertical
- Slider: Rename
output
part tovalueText
to match naming convention - DatePicker
- Remove support for
inline
in datepicker and replace withcloseOnSelect
for API consistency. - Add
data-placement
to trigger and content parts for position-aware styling.
- Remove support for
0.25.0 - 2023-10-17
-
ColorPicker
- Fix issue where channel inputs within control doesn't get synced
- Fix issue where area selection doesn't work when the value is not
hsl
- Add default
12px
size for transparency grid
-
RadioGroup: Fix issue where indicator stays visibile when the value is
null
-
Combobox: Fix issue where combobox positioner is
hidden
when combobox is not open
-
Toast: Redesign toast render apis to allow for framework control.
defaultOptions
can now be passed directly to thetoast.group
machine context.- You can now pass the default
render
function to thetoast.group
machine context. - Removed
api.render
in favor of userland control. This eliminates the bug in Solid.js for custom toasts.
-
Carousel: Rename
onSlideChange
toonIndexChange
-
Slider, RangeSlider: Merge the slider and range slider machines into one to prevent logic duplication.
value
andonValueChange
type has been updated to benumber[]
- Update
api.getThumbProps(index)
toapi.getThumbProps({ index })
-
Dialog: Rename dialog container to dialog positioner for better API consistency. This means
api.containerProps
is nowapi.positionerProps
0.24.0 - 2023-10-12
- FileUpload: Issue where
api.setFiles
andapi.clearFiles
does not work - NumberInput: Fix issue where before input gets called with incorrect event data
- Popover: Fix issue where popover shows a
DOMException
warning when third party iframes are present
- DatePickcer: Add new table head component to allow for customizing the table head
💥 Breaking changes
-
Combobox, Select, HoverCard: Rename
api.setPositioning(...)
toapi.reposition(...)
-
Carousel: Refactor components to ensure consistent naming convention
slideGroupProps
->itemGroupProps
getSlideProps
->getItemProps
nextSlideTrigger
->nextTrigger
prevSlideTrigger
->prevTrigger
-
ColorPicker:
- Redesigned components to ensure consistent naming convention
- Added support for trigger and content parts to control the open/close behavior
- Add new
api.getChannelValue
API to get the value of a specific color channel
-
Pagination: Rename component anatomy and parts
getPageTriggerProps
=>getTriggerProps
getNextPageTriggerProps
=>getNextTriggerProps
getPrevPageTriggerProps
=>getPrevTriggerProps
0.23.0 - 2023-10-02
- All Machines: Ensure
dir
is applied to all positioner elements - FileUpload: Fix reopening the system file picker in file-upload on browsers other than Chrome
- PinInput: Fix issue where multiple values can be entered in a single input
💥 Breaking changes
-
FileUpload:
- Redesign the file-upload component to include new parts:
Item
: The element that represents a fileItemSizeText
: The element that represents the size of a fileItemName
: The element that represents the name of a fileItemDeleteTrigger
: The buttonelement used to delete a file
- Added new
api.getFileSize
method to get the size of a file in a human readable format
- Redesign the file-upload component to include new parts:
-
RatingGroup:
- Rename
api.sizeArray
toapi.items
- Rename
max
tocount
- Rename
0.22.0 - 2023-09-26
- All machines: Ensure the
dir
attribute is applied consistently across all component parts. - ColorPicker:
- Fix issue where color area changes format when you type custom hex values
- Fix issue where alpha channel input resets to 1 after blurring hex channel input
- Dialog:
- Fix issue where focusing outside closes the dialog despite
closeOnInteractOutside
being set tofalse
- Fix issue where focusing outside closes the dialog despite
- Editable:
- Fix issue where the input value doesn't get synced correctly when controlled
- Combobox: Add support for
api.setPositioning(...)
to allow for repositioning the combobox content - Menu:
- Add new
optionItemIndicator
andoptionItemText
part - Add
api.optionItemIndicatorProps(...)
,api.optionItemTextProps(...)
support - Add api.getOptionItemState and
api.getItemState
- Export
OptionItemState
andItemState
types
- Add new
- ColorPicker: Add support for entering native color names (e.g. red, blue, green, etc.)
- Menu:
- Removed
api.isOptionChecked
in favor ofapi.getOptionItemState
- Removed
- NumberInput:
- Refactor number input machine to handle number parsing correctly
- Fix issue where value doesn't listen to form reset events
- BREAKING: Removed the following context properties in favor of the new
formatOptions
:validateCharacter
,parse
,format
,minFractionDigits
,maxFractionDigits
- Dialog:
- Fix issue where
modal: false
doesn't disable focus trap - Rename
closeOnEsc
tocloseOnEscapeKeyDown
- Rename
onEsc
toonEscapeKeyDown
- Rename
closeOnOutsideClick
tocloseOnInteractOutside
- Fix issue where
- Editable:
- Hide submit and cancel trigger when not in editing mode
- Hide edit trigger when in editing mode
0.21.0 - 2023-09-19
- ToggleGroup: Fix issue where anatomy was not exported
- Pagination: Fix bug where pagination returns inconsistent pages
- Select, Combobox: Fix issue where
readonly
items could not be used in the collection - Focus Visible: Fix issue where focus visible was not working when clicked inside element with
tabindex
attribute - Toast: Fix accessibility issue where toast placement region labels were not unique
- Menu: Fix issue where menu does not scroll highlighted item into view
- Add indicator part to some components for ease of styling. Added
AccordionItemIndicator
,SelectIndicator
,MenuIndicator
,PopoverIndicator
- Popper: Ensure positioner uses the same
zIndex
as the content element
💥 Breaking changes
-
Refactor component anatomy to use consistent naming convention across all machines.
-
Accordion
getTriggerProps
=>getItemTriggerProps
getContentProps
=>getItemContentProps
-
Radio
getRadioProps
=>getItemProps
getRadioControlProps
=>getItemControlProps
getRadioLabelProps
=>getItemTextProps
getRadioHiddenInputProps
=>getItemHiddenInputProps
getRatingState
=>getItemState
getRatingProps
=>getItemProps
-
TagsInput
getTagProps
=>getItemProps
getTagDeleteTriggerProps
=>getItemDeleteTriggerProps
getTagInputProps
=>getItemInputProps
-
Toggle Group
getToggleProps
=>getItemProps
-
-
ToggleGroup: Allow deselecting item when
multiple
isfalse
.
0.20.0 - 2023-09-14
- Pagination: Fix issue where change callback does not get called when clicking the page button.
- DatePicker: Add
onOpenChange
callback to listen for changes in the open state - [New]: Add
@zag-js/file-utils
package to help with file related operations - Editable: Autofocus the editable input element when
startsWithEditView
is set totrue
- Tabs: Add
api.getTriggerState(...)
to get the current state of the tab trigger
💥 Breaking changes
-
All machines: Unify all callbacks to follow a consistent naming convention
onOpen
andonClose
=>onOpenChange
onChange
=>onValueChange
onFocus
=>onFocusChange
onHighlight
=>onHighlightChange
onLoad
andonError
=>onLoadingStatusChange
onInputChange
=>onInputValueChange
-
Remove toggle machine in favor of userland implementation. For more advanced toggle functionality, use the
ToggleGroup
machine. -
RadioGroup: Remove
api.blur()
from radio group machine. Prefer to usedocument.activeElement.blur()
instead. -
FileUpload
- Rename
api.setValue
toapi.setFiles
- Rename
api.clearValue
toapi.clearFiles
- Rename
-
Tabs: Changed
api.setIndicatorRect(id)
toapi.setIndicatorRect(value)
for better userland control
0.19.1 - 2023-09-11
- All machines: Fix issue where onChange callbacks could be executed excessively when no value changed.
- Combobox, Select:
- Fix issue where clear trigger was incorrectly shown when value is empty
- Export
CollectionItem
type - Ensure consistent usage of generics across the
connect
andmachine
functions
0.19.0 - 2023-09-07
-
Popper: Fix issue where passing the
offset
positioning option to popper-related components causes undesired placement in each render cycle. -
RadioGroup: Fix issue where change event doesn't get dispatched when value changes programmatically.
- Combobox, Selected
- Add
control
androot
parts to select and combobox components
- Add
-
Combobox, Select
- Loosen the collection item types to allow string item
- Add generic to select and combobox context and api
- Use dismissable layer to better manage layering when used in a popover or dialog
-
Checkbox, Switch: Dispatch change event when checked state is set programmatically to get it working in Solid.js form libraries
0.18.0 - 2023-09-05
- DatePicker
- Fix issue where datepicker value
onChange
returned a proxy array - Fix issue where clearing the date picker value prevent selecting a new date when
inline: true
is set
- Fix issue where datepicker value
- Menu: Fix issue where
closeOnSelect
on menu item props isn't respected in machine - NumberInput: Fix issue where number input goes into infinite update cycles due to additional input event
- React: Export
PropTypes
from react package for consistency - Select, Combobox: Add support for selecting multiple items
- Combobox: Add support for
closeOnSelect
- RadioGroup: Remove unsupported
readOnly
property from types
💥 Breaking changes
Redesign select and combobox API to allow passing value as string
and collection
Prior to this change, Zag computes the label and value from the DOM element. While this worked, it makes it challenging
to manage complex objects that don't match the label
and value
convention.
// Create the collection
const collection = select.collection({
items: [],
itemToString(item) {
return item.label
},
itemToValue(item) {
return item.value
},
})
// Pass the collection to the select machine
const [state, send] = useMachine(
select.machine({
collection,
id: useId(),
}),
)
0.17.0 - 2023-08-26
-
React: Fix issue where spreading props on a
forwardRef
element show aLegacyRef
error -
Slider: Fix issue where slider marks are not aligned to the thumb position in "contain" alignment mode
-
TagsInput: Ignore key during composition in
onKeyDown
event -
Combobox, Select, Menu
- Fix issue where select clicks underlying element on mobile.
- Fix issue where combobox and menu option item triggers double click.
-
Form Elements: Re-enable the input after removing
disabled
attribute from the parent fieldset
- Slider: Add support for passing the
thumbSize
in the machine context to avoid first-render flicker due to DOM measurement.
💥 Breaking changes
- All machines: Rename exported
PublicApi
toApi
- Combobox: Remove
selectInputOnFocus
option in favor of userland control - Accordion: Remove support for passing
value
asstring
. Thevalue
property must be an array of stringsstring[]
- Tabs
- Rename
onHighlight
toonFocusChange
- Remove
onTagUpdate
, useonChange
instead
- Rename
0.16.0 - 2023-08-13
- Select: Fix issue where interaction outside and positioning does not work when select content is conditionally rendered
- Pressable: Remove
id
usage for better composition - Radio: Rename
getRadioInputProps
togetRadioHiddenInputProps
- Tabs: Rename
tablist
part tolist
to match naming convention
0.15.0 - 2023-08-08
- Checkbox: Rename
inputProps
tohiddenInputProps
- All machines: Remove
hiddenInput
from machine anatomy - Combobox: Add
optionGroupLabel
part to Combobox - Tabs: Remove content group part
0.14.0 - 2023-08-07
- Dialog: Improve outside interaction logic to avoiding closing when interacting with browser extensions like grammarly or 1password.
- File Upload
- Rename
minSize
andmaxSize
tominFileSize
andmaxFileSize
respectively - Rename
api.openFilePicker
toapi.open
- Rename
💥 Breaking changes
- Carousel: Rename
nextTrigger
,prevTrigger
tonextSlideTrigger
andprevSlideTrigger
parts - DatePicker: Add positioner part to allow dynamic positioning
- Combobox, Editable, Menu, Select, TagsInput: Provide interaction event handlers (
onPointerdownOutside
,onFocusOutside
andonInteractOutside
) to better manage outside interaction
0.13.0 - 2023-07-25
- ColorPicker
- Fix issue where
isEqual
doesn't consider alpha channel. - Fix keyboard navigation in Color Picker between area and channel slider thumb.
- Fix issue where
- Popper Components
- Fix issue in Combobox, Select, Menu, Hover Card where
sameWidth
doesn't work consistently during re-render.
- Fix issue in Combobox, Select, Menu, Hover Card where
- File Upload: Add
data-disabled
to all element parts - NumberInput: Add
data-focus
to all element parts - Popover: Set
portalled
attribute to betrue
by default - RadioGroup:
- Add
data-orientation
to all parts - Remove unimplemented
setPreviousValue
action
- Add
-
Core: Add support for transforming context before settings it in the machine's context. This is useful when some values need to passed to
ref
function -
Toast: Add option to set toast default options like
placement
,removeDelay
,duration
, etc
- New ToggleGroup machine
0.12.0 - 2023-07-16
- Avatar: Fix issue where avatar doesn't show fallback when image src is initially empty
- ColorPicker: Fix issue where focusing on area thumb doesn't transition to focused state, making keyboard navigation not work.
- Checkbox, Switch: Fix issue where
api.setChecked
does not work
💥 Breaking changes
-
All machines:
-
Add
data-state
attribute to allow styling the open/closed state or checked/unchecked states -
We replaced
data-expanded
ordata-checked
todata-state
attributedata-expanded
maps todata-state="open"
ordata-state="closed"
data-checked
maps todata-state="checked"
ordata-state="unchecked"
data-indeterminate
maps todata-state="indeterminate"
data-open
maps todata-state="open"
-
0.11.2 - 2023-07-13
- All machines: Fix issue where machine types were not being properly inferred
0.11.1 - 2023-07-12
- Carousel: Expose the types and add
onClick
to carousel indicator - ColorPicker: Fix types exports
0.11.0 - 2023-07-11
- Editable: Fix issue where initially cancelling the value by pressing the escape key doesn't work
- Tooltip: Fix issue where it re-opens after clicking the trigger and moving the cursor slightly
- Tooling: Revert build tooling from
vite
totsup
- New presense machine to manage mount/unmount animation.
0.10.5 - 2023-07-06
- All machines: Fix an issue where type declarations aren't inferred correctly
0.10.4 - 2023-07-05
- RadioGroup: Fix issue where indicator part does not transition its size and position after first render
0.10.3 - 2023-06-30
- All machines: Improve DOM detection code to rely on
document
instead ofwindow
- Popper: Fix issue where
offset
is ignored from default gutter
0.10.2 - 2023-06-01
- Avatar: Fix issue where anatomy was not exported
- Splitter: Set the panel's default
minSize
to0
0.10.1 - 2023-05-31
- Splitter: Fix issue where
api
for controlling panel sizes wasn't implemented
0.10.0 - 2023-05-31
- Checkbox, Switch: Fix issue where root element emits
onClick
twice when parent element is clicked - Combobox
- Fix issue where entering value in between input character moves cursor to the end
- Fix issue where non-ascii characters could not be entered
- DatePicker, Dialog
- Fix scroll hijacking issue during initial and return focus
- Upgrade
focus-trap
package to ensure that trap works when the active element within the content is removed - Fix scroll hijacking issue during initial and return focus
- Pressable: Ensure consistent behavior between space and enter key
- Anatomy: Update
createAnatomy
to return an array of the anatomy instance's part names
- New Avatar machine
0.9.2 - 2023-05-18
- All machines: Fix issue where event point calculation is incorrect when the page is scrolled
- Dialog: Fix issue where
setReturnFocus
used infocus-trap
throws a console error - PinInput: Fix issue where
defaultValue
is always overriden with an array with empty strings when mounted
0.9.0 - 2023-05-16
- DatePicker: Fix inconsistencies in api methods and naming conventions
- Switch: Remove unused attributes and make it consistent with checkbox
- Tabs
- Remove unneeded style property in the indicator (depending on orientation)
- Fix bug where keyboard navigation doesn't work in manual activation mode
- Anatomy: Add support for renaming component scope/name
0.7.0 - 2023-05-03
- All machines:
Ensure ids of underlying elements can customized based on
ids` context property. - Editable: Fix issue where focus is hijacked on blur when interacting outside on a focusable element
- Core: Refactor regex for
mergeProps
in zag core. - Solid.js: Improve reactivity of
mergeProps
function - Carousel: Improve support for spacing and slides per view
- ColorPicker: Export types for color channel and swatch parts
- Popover, Menu, Tooltip, HoverCard
- Update the
setPositioning
api method to allow empty arguments
- Update the
- Slider, RangeSlider: Ensure consistent props for marker
- Splitter: Export types for panel and resize trigger props
- Editable: Add
finalFocusEl
to allow for better return focus management - Pagination: Add
type
property to the pagination's context to control properties used in trigger element
0.6.0 - 2023-04-15
- Vue: Fix issue where
defaultValue
does not get applied to input element - Checkbox: Fix issue where checkbox
toggleChecked
was not defined - DatePicker
- Fix issue where
focusedValue
was not synced withvalue
property - Fix issue where input value was not updated when
locale
andvalue
changed
- Fix issue where
- RatingGroup, Splitter
- Update point calculations based on changes in
getRelativePointPercent
output
- Update point calculations based on changes in
- Rename HoverCard and Popover
onOpenChange
toonOpen
andonClose
- New ColorPicker machine
- All machines: Ensure all packages are versioned together
- Checkbox: Remove the
defaultChecked
property in favor of thechecked
property that can now be controlled.
// the checkbox will be checked initially
const [state, send] = useMachine(
checkbox.machine({
id: "1",
checked: true,
}),
)
// this will update the checkbox when the `checked` value changes
const [state, send] = useMachine(checkbox.machine({ id: "1" }), {
context: {
// when this value changes, the checkbox will be checked/unchecked
checked: true,
},
})
- Dialog: Remove the
defaultOpen
property in favor of theopen
property that can now be controlled.
// this is will open the dialog initially
const [state, send] = useMachine(dialog.machine({ id: "1", open: true }))
// this will open the dialog when the `open` value changes
const [state, send] = useMachine(dialog.machine({ id: "1" }), {
context: {
// when this value changes, the dialog will open/close
open: true,
},
})
- HoverCard: Remove the
defaultOpen
property in favor of theopen
property that can now be controlled.
// this is will open the hoverCard initially
const [state, send] = useMachine(hoverCard.machine({ id: "1", open: true }))
// this will open the hoverCard when the `open` value changes
const [state, send] = useMachine(hoverCard.machine({ id: "1" }), {
context: {
// when this value changes, the hoverCard will open/close
open: true,
},
})
- Popover: Remove the
defaultOpen
property in favor of theopen
property that can now be controlled.
// this is will open the popover initially
const [state, send] = useMachine(popover.machine({ id: "1", open: true }))
// this will open the popover when the `open` value changes
const [state, send] = useMachine(popover.machine({ id: "1" }), {
context: {
// when this value changes, the popover will open/close
open: true,
},
})
- Switch: Remove the
defaultChecked
property in favor of thechecked
property that can now be controlled.
// the switch will be checked initially
const [state, send] = useMachine(
switch.machine({
id: "1",
checked: true,
}),
)
// this will update the switch when the `checked` value changes
const [state, send] = useMachine(switch.machine({ id: "1" }), {
context: {
// when this value changes, the switch will be checked/unchecked
checked: true,
},
})
- Tooltip: Remove
defaultOpen
property in favor of theopen
property that can now be controlled.
// this is will open the tooltip initially
const [state, send] = useMachine(tooltip.machine({ id: "1", open: true }))
// this will open the tooltip when the `open` value changes
const [state, send] = useMachine(tooltip.machine({ id: "1" }), {
context: {
// when this value changes, the tooltip will open/close
open: true,
},
})