Skip to content

Commit

Permalink
Fix merge conflicts
Browse files Browse the repository at this point in the history
  • Loading branch information
jandrade committed Dec 16, 2024
2 parents d067480 + 56d961f commit 9ada939
Show file tree
Hide file tree
Showing 230 changed files with 8,489 additions and 5,912 deletions.
2 changes: 0 additions & 2 deletions .changeset/afraid-buckets-yell.md

This file was deleted.

14 changes: 14 additions & 0 deletions .changeset/light-goats-serve.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
---
"@khanacademy/wonder-blocks-core": major
"@khanacademy/wonder-blocks-search-field": patch
"@khanacademy/wonder-blocks-accordion": patch
"@khanacademy/wonder-blocks-dropdown": patch
"@khanacademy/wonder-blocks-popover": patch
"@khanacademy/wonder-blocks-testing": patch
"@khanacademy/wonder-blocks-tooltip": patch
"@khanacademy/wonder-blocks-switch": patch
"@khanacademy/wonder-blocks-modal": patch
"@khanacademy/wonder-blocks-form": patch
---

Deprecate the ID provider and unique ID utilities
5 changes: 0 additions & 5 deletions .changeset/old-pears-fix.md

This file was deleted.

5 changes: 5 additions & 0 deletions .changeset/thirty-jars-grow.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@khanacademy/wonder-blocks-core": minor
---

- Add the `Id` component for cases where `useId` cannot be used directly
14 changes: 14 additions & 0 deletions .changeset/witty-panthers-shave.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
---
"@khanacademy/wonder-blocks-search-field": major
"@khanacademy/wonder-blocks-accordion": major
"@khanacademy/wonder-blocks-dropdown": major
"@khanacademy/wonder-blocks-popover": major
"@khanacademy/wonder-blocks-testing": major
"@khanacademy/wonder-blocks-tooltip": major
"@khanacademy/wonder-blocks-switch": major
"@khanacademy/wonder-blocks-modal": major
"@khanacademy/wonder-blocks-form": major
"@khanacademy/wonder-blocks-core": patch
---

- Migrate Wonder Blocks components off old id providers and onto new `Id` component
6 changes: 6 additions & 0 deletions .eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,12 @@ module.exports = {
"no-undef": "off",
},
},
{
files: ["**/*.stories.tsx"],
rules: {
"testing-library/no-await-sync-events": "off",
},
},
],
globals: {
// `no-undef` doesn't support `globalThis`, for details see
Expand Down
3 changes: 2 additions & 1 deletion .storybook/preview.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ const parameters = {
},
};

export const decorators = [
const decorators = [
(Story, context) => {
const theme = context.globals.theme;
const enableRenderStateRootDecorator =
Expand All @@ -120,6 +120,7 @@ export const decorators = [

const preview: Preview = {
parameters,
decorators,
globalTypes: {
// Allow the user to select a theme from the toolbar.
theme: {
Expand Down
31 changes: 17 additions & 14 deletions __docs__/wonder-blocks-button/button.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import * as React from "react";
import {StyleSheet} from "aphrodite";
import type {Meta, StoryObj} from "@storybook/react";
import {expect, fireEvent, userEvent, within} from "@storybook/test";
import {expect, userEvent, within} from "@storybook/test";

import {MemoryRouter, Route, Switch} from "react-router-dom";

Expand Down Expand Up @@ -103,7 +103,6 @@ export const Tertiary: StoryComponentType = {

// Get HTML elements
const button = canvas.getByRole("button");
const computedStyleButton = getComputedStyle(button);
const innerLabel = canvas.getByTestId("test-button-inner-label");
const computedStyleLabel = getComputedStyle(innerLabel, ":after");

Expand All @@ -116,19 +115,23 @@ export const Tertiary: StoryComponentType = {
await expect(computedStyleLabel.height).toBe("2px");
await expect(computedStyleLabel.color).toBe("rgb(24, 101, 242)");

// TODO(WB-1808, somewhatabstract): This isn't working. I got it passing
// locally by calling `button.focus()` as well, but it was super flaky
// and never passed first time.
// Focus style
await fireEvent.focus(button);
await expect(computedStyleButton.outlineColor).toBe(
"rgb(24, 101, 242)",
);
await expect(computedStyleButton.outlineWidth).toBe("2px");

// Active (mouse down) style
// eslint-disable-next-line testing-library/prefer-user-event
await fireEvent.mouseDown(button);
await expect(innerLabel).toHaveStyle("color: rgb(27, 80, 179)");
await expect(computedStyleLabel.height).toBe("2px");
await expect(computedStyleLabel.color).toBe("rgb(27, 80, 179)");
// const computedStyleButton = getComputedStyle(button);
// await fireEvent.focus(button);
// await expect(computedStyleButton.outlineColor).toBe(
// "rgb(24, 101, 242)",
// );
// await expect(computedStyleButton.outlineWidth).toBe("2px");

// // Active (mouse down) style
// // eslint-disable-next-line testing-library/prefer-user-event
// await fireEvent.mouseDown(button);
// await expect(innerLabel).toHaveStyle("color: rgb(27, 80, 179)");
// await expect(computedStyleLabel.color).toBe("rgb(27, 80, 179)");
// await expect(computedStyleLabel.height).toBe("2px");
},
};

Expand Down
7 changes: 1 addition & 6 deletions __docs__/wonder-blocks-core/exports.use-render-state.mdx
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
import {Meta} from "@storybook/blocks";

<Meta
title="Packages / Core / Exports / useRenderState()"
/>
<Meta title="Packages / Core / Exports / useRenderState()" />

# useRenderState()

Expand All @@ -16,6 +14,3 @@ The `useRenderState` hook will return either:
the initial rehydration render on the client.
- `RenderState.Standard` if the component renders on the client after the initial
rehydration.

NOTE: Although the `RenderState` enum has a third state `Root`, this value is never
returned by `useRenderState`.
1 change: 1 addition & 0 deletions __docs__/wonder-blocks-core/id-provider.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
/* eslint-disable import/no-deprecated */
import * as React from "react";
import type {Meta, StoryObj} from "@storybook/react";

Expand Down
39 changes: 39 additions & 0 deletions __docs__/wonder-blocks-core/id.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
import * as React from "react";
import {Meta, Story, Canvas} from "@storybook/blocks";
import * as IdStories from "./id.stories";

<Meta of={IdStories} />

# Id

`Id` is a component that provides an identifier to its children.

It is useful for situations where the `useId` hook cannot be easily used,
such as in class-based components.

If an `id` prop is provided, that is passed through to the children;
otherwise, a unique identifier is generated.

## Usage

```tsx
import {Id} from "@khanacademy/wonder-blocks-core";

<Id id={maybeId}>{(id) => <div id={id}>Hello, world!</div>}</Id>;
```

## Examples

### 1. Generating an id

An identifier will always be generated if an `id` prop is not provided, or the
provided `id` property is falsy.

<Canvas withSource="open" of={IdStories.GeneratedIdExample} />

### 2. Passthrough an id

If an `id` prop is provided and it is truthy, that value will be passed through
to the children.

<Canvas sourceState="shown" of={IdStories.PassedThroughIdExample} />
46 changes: 46 additions & 0 deletions __docs__/wonder-blocks-core/id.stories.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import * as React from "react";

import {Meta} from "@storybook/react";
import {View, Id} from "@khanacademy/wonder-blocks-core";
import {Body, BodyMonospace} from "@khanacademy/wonder-blocks-typography";
import {Strut} from "@khanacademy/wonder-blocks-layout";
import {spacing} from "@khanacademy/wonder-blocks-tokens";

export default {
title: "Packages / Core / Id",

parameters: {
chromatic: {
// We don't need a snapshot for this.
disableSnapshot: true,
},
},
} as Meta;

export const GeneratedIdExample = () => (
<View>
<Id>
{(id) => (
<View style={{flexDirection: "row"}}>
<Body>Generated identifier: </Body>
<Strut size={spacing.xSmall_8} />
<BodyMonospace>{id}</BodyMonospace>
</View>
)}
</Id>
</View>
);

export const PassedThroughIdExample = () => (
<View>
<Id id="my-identifier">
{(id) => (
<View style={{flexDirection: "row"}}>
<Body>Passed through identifier: </Body>
<Strut size={spacing.xSmall_8} />
<BodyMonospace>{id}</BodyMonospace>
</View>
)}
</Id>
</View>
);
1 change: 1 addition & 0 deletions __docs__/wonder-blocks-core/unique-id-provider.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
/* eslint-disable import/no-deprecated */
import * as React from "react";
import type {Meta, StoryObj} from "@storybook/react";

Expand Down
8 changes: 7 additions & 1 deletion __docs__/wonder-blocks-core/use-unique-id.mdx
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
import {Meta, Story, Canvas} from "@storybook/blocks";
import * as UseUniqueIdStories from './use-unique-id.stories';
import * as UseUniqueIdStories from "./use-unique-id.stories";

<Meta of={UseUniqueIdStories} />

# `useUniqueIdWithoutMock`

DEPRECATED: Will be removed in a future release. Use `useId` from React or
the `Id` component.

This hook is similar to `<UniqueIDProvider mockOnFirstRender={false}>`.
It will return `null` on the initial render and then the same identifier
factory for each subsequent render. The identifier factory is unique to
Expand All @@ -19,6 +22,9 @@ render tree.

# `useUniqueIdWithMock`

DEPRECATED: Will be removed in a future release. Use `useId` from React or
the `Id` component.

This hook is similar to `<UniqueIDProvider mockOnFirstRender={true}>`.
It will return a mock identifier factory on the initial render that doesn'that
guarantee identifier uniqueness. Mock mode can help things appear on the screen
Expand Down
1 change: 1 addition & 0 deletions __docs__/wonder-blocks-core/use-unique-id.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
/* eslint-disable import/no-deprecated */
import * as React from "react";

import {Meta} from "@storybook/react";
Expand Down
42 changes: 41 additions & 1 deletion __docs__/wonder-blocks-dropdown/base-select.argtypes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,53 @@ const argTypes: ArgTypes = {
},

error: {
description: "Whether this component is in an error state.",
description: `Whether this component is in an error state. Use this for
errors that are triggered by something external to the component
(example: an error after form submission).`,
table: {
category: "States",
defaultValue: {summary: "false"},
},
},

required: {
description: `Whether this field is required to to continue, or the
error message to render if the select is left blank. Pass in a
message instead of "true" if possible.`,
table: {
category: "States",
type: {
summary: "boolean | string",
},
},
control: {
type: undefined,
},
},

validate: {
description: `Provide a validation for the selected value. Return a
string error message or null | void for a valid input.
\n Use this for errors that are shown to the user while they are
filling out a form.`,
table: {
category: "States",
type: {
summary: "(value: string) => ?string",
},
},
},

onValidate: {
description: "Called right after the field is validated.",
table: {
category: "Events",
type: {
summary: "(errorMessage: ?string) => mixed",
},
},
},

isFilterable: {
description: `When this is true, the dropdown body shows a search text
input top. The items will be filtered by the input. Selected items
Expand Down
13 changes: 13 additions & 0 deletions __docs__/wonder-blocks-dropdown/multi-select.argtypes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ const argTypes: ArgTypes = {
table: {
type: {summary: "Array<string>"},
},
control: {type: "object"},
},
labels: {
control: {type: "object"},
Expand All @@ -21,6 +22,18 @@ const argTypes: ArgTypes = {
type: {summary: "Labels"},
},
},
showOpenerLabelAsText: {
control: {type: "boolean"},
description: `When false, the SelectOpener can show a Node as a label. When true, the
SelectOpener will use a string as a label. If using custom OptionItems, a
plain text label can be provided with the \`labelAsText\` prop.
Defaults to true.`,

table: {
type: {summary: "boolean"},
defaultValue: {summary: "true"},
},
},
};

export default argTypes;
Loading

0 comments on commit 9ada939

Please sign in to comment.