Commit Graph

225 Commits

Author SHA1 Message Date
Robin Malfait 7f55847afe update changelog 2021-09-12 18:44:20 +02:00
Robin Malfait 3ad86ad498 ensure we stop the event from propagating 2021-09-12 18:42:20 +02:00
Robin Malfait 452b2c2852 bump version to 1.4.1 2021-08-30 14:23:52 +02:00
Robin Malfait 997f83238b update changelog 2021-08-30 14:23:00 +02:00
Robin Malfait bd3bc6cc42 Merge pull request #713 from tailwindlabs/develop
Next release
2021-08-30 14:20:43 +02:00
Robin Malfait 3f14839c33 Warn instead of error when there are no focusable elements (#775)
* warn instead of error when there are no focusable elements

* update changelog

Co-authored-by: Krystof Rehacek <krystofee@gmail.com>
2021-08-30 13:48:49 +02:00
Robin Malfait b59c091030 Fix broken escape key behaviour (#754)
* fix broken `escape` key behaviour

We've "fixed" an issue when we had nested Dialogs ([#430](https://github.com/tailwindlabs/headlessui/pull/430)).
The `escape` would not close the correct Dialog. The issue here was with
the logic to know whether we were the last Dialog or not. The issue was
_not_ how we implemented the `close` functionality.

To make things easier, we moved the global window event to a scoped div
(the Dialog itself). While that fixed the nested Dialog issue, it
introduced this bug where `escape` would not close if you click on a
non-focusable element like a span in the Dialog.

Since that PR we did a bunch of improvements on how the underlying
"stacking" system worked.
This PR reverts to the "global" window event listener so that we can
still catch all of the `escape` keydown events.

Fixes: #524
Fixes: #693

* update changelog
2021-08-24 11:26:19 +02:00
Robin Malfait d60d2a558f Add Vue emit types (#712)
* Add Vue emit types

* ensure value is a boolean

Even though we only use `false` for now

* add Vue emit types for Tabs component

* update changelog

Co-authored-by: henribru <6639509+henribru@users.noreply.github.com>
2021-08-02 14:37:45 +02:00
Robin Malfait c1117840fd Only add type=button for real buttons (#709)
* add `{type:'button'}` only for buttons

We will try and infer the type based on the passed in `props.as` prop or
the default tag. However, when somebody uses `as={CustomComponent}` then
we don't know what it will render. Therefore we have to pass it a ref
and check if the final result is a button or not. If it is, and it
doesn't have a `type` yet, then we can set the `type` correctly.

* update changelog
2021-08-02 13:57:58 +02:00
Robin Malfait d25f80ae9d bump version to 1.4.0 2021-07-29 12:56:11 +02:00
Robin Malfait a4036d59f2 update changelog 2021-07-29 12:55:12 +02:00
Robin Malfait 819042e9ff Merge pull request #702 from tailwindlabs/develop
Next release
2021-07-29 12:53:17 +02:00
Robin Malfait 4f3c5fa90b update changelog 2021-07-28 14:44:47 +02:00
Robin Malfait 112270d206 Change Tabs api (#698)
* Change Tabs API (React)

| Before        | After        |
| ------------- | ------------ |
| `Tabs`        | `Tab.Group`  |
| `Tabs.List`   | `Tab.List`   |
| `Tabs.Tab`    | `Tab`        |
| `Tabs.Panels` | `Tab.Panels` |
| `Tabs.Panel`  | `Tab.Panel`  |

* Change Tabs API (Vue)

| Before       | After       |
| ------------ | ----------- |
| `Tabs`       | `TabGroup`  |
| `TabsList`   | `TabList`   |
| `TabsTab`    | `Tab`       |
| `TabsPanels` | `TabPanels` |
| `TabsPanel`  | `TabPanel`  |

* change playground example for Tabs (React)

* update changelog
2021-07-28 11:30:34 +02:00
Robin Malfait ba1bd524d1 Expose close functionality via render prop (#697)
* expose a `close` function via the render prop for the `Popover` and `Popover.Panel` components (React)

* expose a `close` function via the render prop for the `Disclosure` and `Disclosure.Panel` components (React)

* expose a `close` function via the render prop for the `Popover` and `PopoverPanel` components (Vue)

* expose a `close` function via the render prop for the `Disclosure` and `DisclosurePanel` components (Vue)
2021-07-26 16:07:47 +02:00
Robin Malfait e8303382dd move manual prop to correct spot in demo 2021-07-15 13:30:18 +02:00
Robin Malfait 0cc9728694 Add aria-orientation to the Listbox component (#683)
* add `aria-orientation` to the Listbox component

By default the `Listbox` will have an orientation of `vertical`. When
you pass the `horizontal` prop to the `Listbox` component then the
`aria-orientation` will be set to `horizontal`.

Additionally, we swap the previous/next keys:

- Vertical: ArrowUp/ArrowDown
- Horizontal: ArrowLeft/ArrowRight

* update changelog
2021-07-13 23:36:15 +02:00
Robin Malfait 10110a928f Add ability to use Disclosure.Button inside a Disclosure.Panel (#682)
* add ability to use `Disclosure.Button` inside a `Disclosure.Panel`

If you do it this way, then the `Disclosure.Button` will function as a
`close` button.

This will make it consistent with the `Popover.Button` inside the
`Popover.Panel` funcitonality.

* update changelog
2021-07-13 19:29:29 +02:00
Robin Malfait 9af04a0a7e add Tabs component (#674)
* add `Tabs` component (React)

* expose `Tabs` component (React)

* add `Tabs` example (React)

* add `Tabs` component (Vue)

* expose `Tabs` component (Vue)

* update changelog
2021-07-13 19:23:55 +02:00
Robin Malfait b961a189d5 improve changelog 2021-06-22 12:29:59 +02:00
Robin Malfait 1ec5e74689 improve changelog 2021-06-22 12:29:39 +02:00
Robin Malfait da314b6b79 bump version to 1.3.0 2021-06-21 11:47:06 +02:00
Robin Malfait 65a7ee1a4b update changelog 2021-06-21 11:46:43 +02:00
Robin Malfait 345f1b6e6b Merge pull request #513 from tailwindlabs/develop
Next release
2021-06-21 11:44:11 +02:00
Robin Malfait e56dd07e16 Improve react peer deps (#622)
* ensure react-dom is also a peer dependency

Co-authored-by: =?UTF-8?q?S=C3=A9bastien=20Vanvelthem?= <belgattitude@gmail.com>

* prepare peer dependencies for React 18

* update changelog

Co-authored-by: =?UTF-8?q?S=C3=A9bastien=20Vanvelthem?= <belgattitude@gmail.com>
2021-06-15 17:48:41 +02:00
Robin Malfait 736f46351c update changelog 2021-06-15 17:33:27 +02:00
Dmitry Ishkov abe3e1b988 Support tree-shaking by enabling preserveModules (#602) 2021-06-15 11:55:13 +02:00
Robin Malfait ece9e87f68 fix failing menu test 2021-06-10 12:15:10 +02:00
Ryan Johnston de6fbd4931 Remove explicit class prop (#608) (#608) 2021-06-10 11:24:12 +02:00
henribru be36684c0d Make Listbox types consistent (#576)
* Make Listbox types consistent

* update changelog

Co-authored-by: Robin Malfait <malfait.robin@gmail.com>
2021-06-09 14:12:52 +02:00
Robin Malfait f73491f4ac remove classname feature (#607)
* change className to class

Co-authored-by: Ryan Johnston <ryan@magic.nz>

* drop className as a function in Vue

* update changelog

Co-authored-by: Ryan Johnston <ryan@magic.nz>
2021-06-09 13:42:00 +02:00
Robin Malfait 045b843f5b Improve aria accessibility (#592)
* encode expected `aria-expanded` behaviour

* ensure `aria-expanded` has the correct value

`aria-expanded` can be in 3 different states:

| Value               | Description                                                                |
| ------------------- | -------------------------------------------------------------------------- |
| false               | The grouping element this element owns or controls is collapsed.           |
| true                | The grouping element this element owns or controls is expanded.            |
| undefined (default) | The element does not own or control a grouping element that is expandable. |

Ref: https://www.w3.org/TR/wai-aria-1.2/#aria-expanded

Fixes: #580

* ensure `disabled` prop in Vue is not rendered when `false`

* update changelog
2021-06-04 20:55:07 +02:00
Robin Malfait 11c461ef1d Fix missing type causing prop check error (#554)
* fix: missing type causing prop check error

* update changelog

Co-authored-by: anzharip <10259593+anzharip@users.noreply.github.com>
2021-05-21 14:18:52 +02:00
Robin Malfait d0e27ff25c Update react peer dependency version range (#544)
* update react peer dependency version range

* update changelog
2021-05-19 12:30:52 +02:00
Robin Malfait e87cf72b61 add aria-disabled to RadioGroup Options (#543)
* add aria-disabled to RadioGroup Options

This will happen when:
- The RadioGroup is disabled
- The RadioGroup Option is disabled

Closes: #515

* update changelog
2021-05-19 12:20:07 +02:00
Robin Malfait 2279cd9213 Improve Vue reactivity & disabled prop (#512)
* only destructure from props inside render

* conditionally ensure that tabindex -1 exists

* reflect `disabled` prop in React as well

* update changelog
2021-05-12 14:18:30 +02:00
Robin Malfait d8e6f73f7e Add entered prop to Transition components (#504)
* introduce `entered` prop on the Transition components

* update Dialog examples to make use of the `entered` prop
2021-05-12 11:31:32 +02:00
Robin Malfait e40c66cec2 Ensure that you can use Transition Child components in more scenario's (#503)
* ensure that you can use Transition Child components

When you are using the implicit variants of the components, for example
when you are using a Transition component inside a Menu component then
it might look weird in Vue.

The Vue code could look like this:

```
<Menu>
  <TransitionRoot>
    <MenuItems>...</MenuItems>
  </TransitionRoot>
<Menu>
```

However, `TransitionRoot` doesn't make much sense here because it sits
in the middle of 2 components, and it is also not controlled by an
explicit `show` prop.

This commit will allows you to use a `TransitionChild` instead (in fact,
both work).

We basically now do a few things, when you are using a TransitionChild:

- Do we have a parent `TransitionRoot`? Yes -> Use it
- Do we have an open closed state? Yes -> Render a TransitionRoot in
  between behind the scenes.
- Throw the error we were throwing before!

* update changelog
2021-05-10 18:36:49 +02:00
Robin Malfait a8bbd0ecee bump versions 2021-05-10 12:08:05 +02:00
Robin Malfait 9303b29abf prepare changelog 2021-05-10 12:07:46 +02:00
Robin Malfait 396f889dc3 Merge pull request #501 from tailwindlabs/develop
Next release
2021-05-10 12:00:38 +02:00
Robin Malfait 084a2497d8 Fix incorrect nested Dialogs behaviour (#489)
* add tests to verify the nested Dialog behaviour

* set mounted to true once rendered once

* cache useWindowEvent listener

We only care about the very last version of the listener function. This
allows us to only change the event listener if the event name (string)
and options (boolean | object) change.

* add/delete messages when mounting/unmounting

We don't require a dedicated hook anymore, so this is a bit of cleanup!

* add comments to the FocusResult enum

* splitup functionality and make it a bit more clear using feature flags

* add getDialogOverlays helper

* simplify the Portal component

We don't need to add the current element to the Stack. We only want to
take care of that in the Dialog component itself.

* drop dom-containers

Currently it is only used in a single spot, so I inlined it into that
file.

* simplify the FocusTrap component, use new API

* improve Dialog component

* update CHANGELOG
2021-05-07 16:29:35 +02:00
Robin Malfait c13e6b7752 Improve dialog and SSR (#477)
* delay initialization of Dialog

We were using a useLayoutEffect, now let's use a useEffect instead. It
still moves focus to the correct element, but that process is now a bit
delayed. This means that users will less-likely be urged to "hack"
around the issue by using fake focusable elements which will result in
worse accessibility.

* add hook to deal with server handoff

This will allow us to delay certain features. For example we can delay
the focus trapping until it is fully hydrated. We can also delay
rendering the Portal to ensure hydration works correctly.

* use server handoff complete hook

* update changelog
2021-05-04 12:18:53 +02:00
Robin Malfait ab92811e13 parallelize GitHub actions (#463) 2021-05-03 13:12:23 +02:00
Robin Malfait 34a10538d6 Open closed state (#466)
* simplify examples by using the implicit open/closed state

* introduce Open/Closed context (React)

* use Open/Closed context in Dialog component (React)

* use Open/Closed context in Disclosure component (React)

* use Open/Closed context in Listbox component (React)

* use Open/Closed context in Menu component (React)

* use Open/Closed context in Popover component (React)

* use Open/Closed context in Transition component (React)

* introduce Open/Closed context (Vue)

* use Open/Closed context in Dialog component (Vue)

* use Open/Closed context in Disclosure component (Vue)

* use Open/Closed context in Listbox component (Vue)

* use Open/Closed context in Menu component (Vue)

* use Open/Closed context in Popover component (Vue)

* use Open/Closed context in Transition component (Vue)

* use a ref in the Description comopnent

This allows us to update the ref and everything should work after that.
Currently we only saw the "current" state.

* add more Vue examples

* update changelog
2021-05-03 13:11:19 +02:00
Robin Malfait 91007b75ef update changelog 2021-04-28 10:35:07 +02:00
Robin Malfait 7d517f6413 bump versions 2021-04-28 10:34:50 +02:00
Robin Malfait 6e404c7d6f Merge pull request #462 from tailwindlabs/develop
Next release
2021-04-28 10:33:05 +02:00
Robin Malfait f385499cbd fix v-model typescript error (#461)
* fix v-model typescript error

* update changelog

Fixes: #368
Fixes: #457
Closes: #459

Co-authored-by: Andrea Nanni <andrea.nanni3@gmail.com>
2021-04-28 10:28:19 +02:00
Robin Malfait cddcd2981d fix clicks and form submissions in Dialog component (#460)
* fix clicks and form submissions in Dialog component

Fixes: #451

* update changelog
2021-04-28 10:25:13 +02:00