import { composeStories } from "@storybook/react" import { fireEvent, screen } from "@testing-library/react" import { userEvent } from "@testing-library/user-event" import React from "react" import { expect, describe, test } from "vitest" import { render } from "../../../tests/render" import * as stories from "./SideSheet.stories" const { Uncontrolled, Controlled } = composeStories(stories) describe("", () => { test("Uncontrolled", async () => { render() await userEvent.click(screen.getByText("Open sheet")) expect(await screen.findByRole("dialog")).toBeInTheDocument() expect(screen.getByText("Title content")).toBeInTheDocument() expect(screen.getByText("Body content")).toBeInTheDocument() }) test("closes on overlay click", async () => { render() await userEvent.click(screen.getByText("Open sheet")) expect(await screen.findByRole("dialog")).toBeInTheDocument() expect(screen.getByText("Title content")).toBeInTheDocument() await userEvent.click(screen.getByTestId("Overlay")) expect(screen.getByRole("dialog")).toHaveAttribute("data-state", "closed") }) test("closes on close icon click", async () => { render() await userEvent.click(screen.getByText("Open sheet")) expect(await screen.findByRole("dialog")).toBeInTheDocument() expect(screen.getByText("Title content")).toBeInTheDocument() await fireEvent.click(screen.getByRole("button", { name: "Close" })) expect(screen.getByRole("dialog")).toHaveAttribute("data-state", "closed") }) test("Controlled", async () => { render() await userEvent.click(screen.getByText("Open sheet")) expect(await screen.findByRole("dialog")).toBeInTheDocument() expect(screen.getByText("Title content")).toBeInTheDocument() await userEvent.click(screen.getByTestId("Overlay")) expect(screen.getByRole("dialog")).toHaveAttribute("data-state", "closed") }) })