Skip to content

Commit

Permalink
Merge pull request #1749 from dequelabs/release-v6.11.0
Browse files Browse the repository at this point in the history
chore(cauldron): Release 6.11.0
  • Loading branch information
scurker authored Nov 6, 2024
2 parents 66d97c6 + b9ac569 commit 59b79f4
Show file tree
Hide file tree
Showing 37 changed files with 281 additions and 655 deletions.
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,13 @@

All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.

## [6.11.0](https://github.com/dequelabs/cauldron/compare/v6.10.1...v6.11.0) (2024-11-06)


### Features

* upgrade to react 18 ([#1731](https://github.com/dequelabs/cauldron/issues/1731)) ([745aebb](https://github.com/dequelabs/cauldron/commit/745aebb773cb357e50c5e9ff4dcd5bc0a1cd73fb)), closes [#631](https://github.com/dequelabs/cauldron/issues/631) [#1685](https://github.com/dequelabs/cauldron/issues/1685)

### [6.10.1](https://github.com/dequelabs/cauldron/compare/v6.10.0...v6.10.1) (2024-10-25)


Expand Down
2 changes: 1 addition & 1 deletion docs/components/CssParamsTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import { getCssVariablesStartingWith } from '../utils/getCssVariablesStartingWit

interface CssParamsTableProps {
param?: string;
renderExample?: (name: string, value: string) => JSX.Element;
renderExample?: (name: string, value: string) => React.JSX.Element;
formatName?: (name: string) => string;
}

Expand Down
13 changes: 5 additions & 8 deletions docs/index.js
Original file line number Diff line number Diff line change
@@ -1,22 +1,18 @@
import React, { useRef, Fragment, useEffect, useState } from 'react';
import { render } from 'react-dom';
import { createRoot } from 'react-dom/client';
import { BrowserRouter as Router, Route, Link } from 'react-router-dom';
import { Helmet } from 'react-helmet';
import classNames from 'classnames';
import mdxComponents from './mdx-components';
import Footer from './components/Footer';
import ComponentLayout from './components/ComponentLayout';
import Navigation from './components/Navigation';
import {
Code,
Drawer as DrawerComponent,
TopBar,
MenuBar,
TopBarTrigger,
TopBarItem,
Workspace,
SideBar,
SideBarItem,
SkipLink,
OptionsMenuList,
TopBarMenu,
Expand Down Expand Up @@ -276,10 +272,11 @@ const initialTheme =
(window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)')
? 'dark'
: 'light');
const container = document.getElementById('root');
const root = createRoot(container);

render(
root.render(
<ThemeProvider initialTheme={initialTheme}>
<App />
</ThemeProvider>,
document.getElementById('root')
</ThemeProvider>
);
2 changes: 1 addition & 1 deletion docs/mdx-components.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ function Link({
}

interface MDXComponentProps {
[key: string]: (props: unknown) => JSX.Element;
[key: string]: (props: unknown) => React.JSX.Element;
}

const mdxComponents = {
Expand Down
2 changes: 1 addition & 1 deletion docs/pages/components/Combobox.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -337,7 +337,7 @@ When autocomplete is set to "automatic" the listbox will provide a filtered list
},
{
name: 'renderNoResults',
type: ['() => JSX.Element', 'React.Element'],
type: ['() => React.JSX.Element', 'React.Element'],
description: 'Render prop to customize the output when there are no matching results. Useful for localization.'
},
{
Expand Down
12 changes: 6 additions & 6 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "cauldron",
"private": true,
"version": "6.10.1",
"version": "6.11.0",
"license": "MPL-2.0",
"scripts": {
"clean": "rimraf dist docs/dist",
Expand Down Expand Up @@ -61,8 +61,8 @@
"@types/classnames": "^2.2.9",
"@types/express": "^4.17.21",
"@types/node": "^22.1.0",
"@types/react": "^16.9.17",
"@types/react-dom": "^16.9.4",
"@types/react": "^18.3.12",
"@types/react-dom": "^18.3.1",
"@types/react-router-dom": "^5.3.2",
"@types/webpack-env": "^1.18.5",
"@typescript-eslint/eslint-plugin": "^5.59.9",
Expand Down Expand Up @@ -101,9 +101,9 @@
"postcss-loader": "^3.0.0",
"prettier": "^2",
"puppeteer": "^22.12.1",
"react": "^17",
"react-dom": "^17",
"react-helmet": "^5.2.1",
"react": "^18",
"react-dom": "^18",
"react-helmet": "^6.1.0",
"react-router-dom": "^5.3.0",
"remark-frontmatter": "^5.0.0",
"remark-gfm": "^3.0.1",
Expand Down
11 changes: 6 additions & 5 deletions packages/react/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@deque/cauldron-react",
"version": "6.10.1",
"version": "6.11.0",
"license": "MPL-2.0",
"description": "Fully accessible react components library for Deque Cauldron",
"homepage": "https://cauldron.dequelabs.com/",
Expand Down Expand Up @@ -43,8 +43,9 @@
"@rollup/plugin-dynamic-import-vars": "^1.4.2",
"@rollup/plugin-typescript": "^11.1.2",
"@svgr/rollup": "^6.1.2",
"@testing-library/jest-dom": "^6.1.3",
"@testing-library/react": "^12",
"@testing-library/dom": "^10.4.0",
"@testing-library/jest-dom": "^6.6.2",
"@testing-library/react": "^16.0.1",
"@testing-library/user-event": "^14.5.2",
"@types/classnames": "^2.2.10",
"@types/jest": "^29.5.11",
Expand All @@ -66,8 +67,8 @@
"postcss-import": "^12.0.1",
"postcss-loader": "^3.0.0",
"prop-types": "^15.8.1",
"react": "^17",
"react-dom": "^17",
"react": "^18",
"react-dom": "^18",
"rollup": "^2.23.0",
"sinon": "^10.0.0",
"ts-node": "^10.9.2",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import axe from '../../axe';

const CustomLinkComponent = (
props: React.AnchorHTMLAttributes<HTMLAnchorElement>
): JSX.Element => (
): React.JSX.Element => (
// eslint-disable-next-line jsx-a11y/anchor-has-content
<a data-testid="custom" {...props} />
);
Expand Down
6 changes: 4 additions & 2 deletions packages/react/src/components/Checkbox/Checkbox.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -80,16 +80,18 @@ test('should toggle checkbox correctly', async () => {
expect(checkboxIcon).toHaveClass('Icon--checkbox-checked');
});

test('should handle focus correctly', () => {
test('should handle focus correctly', async () => {
const user = userEvent.setup();
const onFocus = spy();
const input = renderCheckbox({ onFocus });
const checkboxIcon = input.parentElement!.querySelector(
'.Checkbox__overlay'
) as HTMLElement;

expect(checkboxIcon).not.toHaveClass('.Checkbox__overlay--focused');
expect(onFocus.notCalled).toBeTruthy();

input.focus();
await user.tab(); // focus on the input
expect(input).toHaveFocus();
expect(checkboxIcon).toHaveClass('Checkbox__overlay--focused');
expect(onFocus.calledOnce).toBeTruthy();
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Checkbox/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(
...other
}: CheckboxProps,
ref
): JSX.Element => {
): React.JSX.Element => {
const [isChecked, setIsChecked] = useState(checked);
const [isIndeterminate, setIsIndeterminate] = useState(indeterminate);
const [focused, setFocused] = useState(false);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ function ClickOutsideListener(
onClickOutside = () => null
}: ClickOutsideListenerProps,
ref: React.ForwardedRef<HTMLElement>
): JSX.Element | null {
): React.JSX.Element | null {
const childElementRef = useRef<HTMLElement>();

const handleEvent = (event: MouseEvent | TouchEvent) => {
Expand Down
6 changes: 4 additions & 2 deletions packages/react/src/components/Combobox/Combobox.test.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import React, { createRef } from 'react';
import { render, screen, fireEvent, createEvent } from '@testing-library/react';
import { within } from '@testing-library/dom';
import userEvent from '@testing-library/user-event';
import { spy } from 'sinon';
import { axe } from 'jest-axe';
import Combobox from './Combobox';
Expand Down Expand Up @@ -379,6 +380,7 @@ test('should close combobox listbox on "blur"', () => {
});

test('should close combobox listbox when selecting option via click', async () => {
const user = userEvent.setup();
render(
<Combobox label="label">
<ComboboxOption>Apple</ComboboxOption>
Expand All @@ -388,9 +390,9 @@ test('should close combobox listbox when selecting option via click', async () =
);

assertListboxIsOpen(false);
screen.getByRole('combobox').focus();
await user.tab();
assertListboxIsOpen(true);
fireEvent.click(screen.getAllByRole('option')[0]);
await user.click(screen.getAllByRole('option')[0]);
assertListboxIsOpen(false);
});

Expand Down
10 changes: 5 additions & 5 deletions packages/react/src/components/Combobox/Combobox.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ interface ComboboxProps
previousValue: ComboboxValue;
}) => void;
onActiveChange?: (option: ListboxOption) => void;
renderNoResults?: (() => JSX.Element) | React.ReactElement;
renderNoResults?: (() => React.JSX.Element) | React.ReactElement;
portal?: React.RefObject<HTMLElement> | HTMLElement;
inputRef?: React.Ref<HTMLInputElement>;
}
Expand All @@ -68,7 +68,7 @@ const ComboboxNoResults = ({
children
}: {
children?: React.ReactNode;
}): JSX.Element => {
}): React.JSX.Element => {
return (
<div className="ComboboxListbox__empty" role="alert" aria-live="polite">
{children || 'No results found.'}
Expand Down Expand Up @@ -103,7 +103,7 @@ const Combobox = forwardRef<HTMLDivElement, ComboboxProps>(
...props
},
ref
): JSX.Element => {
): React.JSX.Element => {
const [value, setValue] = useState<string>(defaultValue || propValue || '');
const [matchingOptions, setMatchingOptions] = useState<
Map<HTMLElement, ComboboxOptionState>
Expand Down Expand Up @@ -469,15 +469,15 @@ const Combobox = forwardRef<HTMLDivElement, ComboboxProps>(
setFormValue={setFormValue}
>
{portal && typeof document !== 'undefined'
? createPortal(
? (createPortal(
comboboxListbox,
// eslint-disable-next-line ssr-friendly/no-dom-globals-in-react-fc
portal instanceof HTMLElement
? portal
: portal.current ||
// eslint-disable-next-line ssr-friendly/no-dom-globals-in-react-fc
/* istanbul ignore next: default fallback value */ document.body
)
) as React.ReactNode)
: comboboxListbox}
</ComboboxProvider>
{hasError && (
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Combobox/ComboboxContext.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ function ComboboxProvider({
setMatchingOptions,
setFormValue,
children
}: ComboboxProvider): JSX.Element {
}: ComboboxProvider): React.JSX.Element {
const { Provider } = ComboboxContext as React.Context<ComboboxContext>;
const contextValue: ComboboxContext = useMemo(
() => ({
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Combobox/ComboboxGroup.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ interface ComboboxGroupProps extends React.HTMLAttributes<HTMLUListElement> {
}

const ComboboxGroup = forwardRef<HTMLUListElement, ComboboxGroupProps>(
({ className, children, label, ...props }, ref): JSX.Element | null => {
({ className, children, label, ...props }, ref): React.JSX.Element | null => {
const { inputValue, autocomplete, matchingOptions } = useComboboxContext();
const comboboxGroupRef = useSharedRef<HTMLUListElement>(ref);

Expand Down
4 changes: 2 additions & 2 deletions packages/react/src/components/Combobox/ComboboxOption.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ const ComboboxMatch = ({
children: text
}: {
children: string;
}): JSX.Element => {
}): React.JSX.Element => {
const { inputValue } = useComboboxContext();

if (!text) {
Expand Down Expand Up @@ -67,7 +67,7 @@ const ComboboxOption = forwardRef<HTMLLIElement, ComboboxOptionProps>(
...props
},
ref
): JSX.Element | null => {
): React.JSX.Element | null => {
const [id] = propId ? [propId] : useId(1, 'combobox-option');
const { selected, active } = useListboxContext();
const { selectedValue, matches, setMatchingOptions, setFormValue } =
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Dialog/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@ export default class Dialog extends React.Component<DialogProps, DialogState> {
return createPortal(
Dialog,
('current' in portal ? portal.current : portal) || document.body
) as JSX.Element;
) as React.JSX.Element;
}

close() {
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Drawer/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -188,7 +188,7 @@ const Drawer = forwardRef<HTMLDivElement, DrawerProps>(
portalElement ||
// eslint-disable-next-line ssr-friendly/no-dom-globals-in-react-fc
document?.body
);
) as React.JSX.Element;
}
);

Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/IconButton/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ const IconButton = forwardRef(
...other
}: IconButtonProps,
ref
): JSX.Element => {
): React.JSX.Element => {
const internalRef = useRef() as MutableRefObject<HTMLElement>;
useImperativeHandle(ref, () => internalRef.current);

Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Listbox/Listbox.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ const Listbox = forwardRef<HTMLElement, ListboxProps>(
...props
},
ref
): JSX.Element => {
): React.JSX.Element => {
const [options, setOptions] = useState<ListboxOption[]>([]);
const [activeOption, setActiveOption] = useState<ListboxOption | null>(
null
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Listbox/ListboxContext.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ function ListboxProvider<T extends ListboxOption>({
setOptions,
onSelect,
children
}: ListboxProvider<T>): JSX.Element {
}: ListboxProvider<T>): React.JSX.Element {
const { Provider } = ListboxContext as unknown as React.Context<
ListboxContext<T>
>;
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Listbox/ListboxGroup.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ const ListboxGroup = forwardRef<HTMLElement, ListboxGroupProps>(
...props
},
ref
): JSX.Element => {
): React.JSX.Element => {
const [id] = propId ? [propId] : useId(1, 'listbox-group-label');
return (
<Component role="group" ref={ref} aria-labelledby={id} {...props}>
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/Listbox/ListboxOption.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ const ListboxOption = forwardRef<HTMLElement, ListboxOptionProps>(
...props
},
ref
): JSX.Element => {
): React.JSX.Element => {
const { active, selected, setOptions, onSelect } = useListboxContext();
const listboxOptionRef = useSharedRef<HTMLElement>(ref);
const [id] = propId ? [propId] : useId(1, 'listbox-option');
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/components/NavBar/NavItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ const NavItem = ({
active,
'aria-current': ariaCurrent = true,
...other
}: NavItemProps): JSX.Element => {
}: NavItemProps): React.JSX.Element => {
const additionalProps = {} as NavItemProps;

if (active) {
Expand Down
6 changes: 2 additions & 4 deletions packages/react/src/components/Popover/index.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -106,14 +106,12 @@ test('should auto-generate id', async () => {
expect(id).toEqual(button.getAttribute('aria-controls'));
});

test('should attach attribute aria-expanded correctly based on shown state', async () => {
test('should attach attribute aria-expanded correctly based on shown state', () => {
const { rerender } = render(<Wrapper />);

expect(
screen.queryByRole('button', {
name: 'Popover button',
hidden: true,
expanded: true
hidden: true
})
).toBeInTheDocument();
rerender(<Wrapper tooltipProps={{ show: false }} />);
Expand Down
Loading

0 comments on commit 59b79f4

Please sign in to comment.