From 051f33235b302e1f5d41ac8d8e8a52ec0a20b6c2 Mon Sep 17 00:00:00 2001 From: JC Franco Date: Tue, 7 Nov 2023 13:19:52 -0800 Subject: [PATCH] fix(split-button): fix width layout (#8133) **Related Issue:** #7692 ## Summary This fixes an issue where styles related to `width` were being applied internally and had no impact on the component. --- .../src/components/split-button/resources.ts | 6 +-- .../split-button/split-button.e2e.ts | 19 -------- .../components/split-button/split-button.scss | 46 +++++++++---------- .../split-button/split-button.stories.ts | 35 ++++++++++++++ .../components/split-button/split-button.tsx | 8 +--- 5 files changed, 61 insertions(+), 53 deletions(-) diff --git a/packages/calcite-components/src/components/split-button/resources.ts b/packages/calcite-components/src/components/split-button/resources.ts index 27c46e3541d..106aed5f1c4 100644 --- a/packages/calcite-components/src/components/split-button/resources.ts +++ b/packages/calcite-components/src/components/split-button/resources.ts @@ -1,7 +1,7 @@ export const CSS = { - container: "split-button__container", - dividerContainer: "split-button__divider-container", - divider: "split-button__divider", + container: "container", + dividerContainer: "divider-container", + divider: "divider", widthAuto: "width-auto", widthHalf: "width-half", widthFull: "width-full", diff --git a/packages/calcite-components/src/components/split-button/split-button.e2e.ts b/packages/calcite-components/src/components/split-button/split-button.e2e.ts index 7e344a1c29a..19a1e7415e4 100644 --- a/packages/calcite-components/src/components/split-button/split-button.e2e.ts +++ b/packages/calcite-components/src/components/split-button/split-button.e2e.ts @@ -1,7 +1,6 @@ import { newE2EPage } from "@stencil/core/testing"; import { html } from "../../../support/formatting"; import { accessible, defaults, disabled, focusable, hidden, renders } from "../../tests/commonTests"; -import { CSS } from "./resources"; describe("calcite-split-button", () => { describe("defaults", () => { @@ -212,24 +211,6 @@ describe("calcite-split-button", () => { expect(dropdownButton).toEqualAttribute("split-child", "secondary"); }); - it("adds the relevant CSS class based on the width attribute", async () => { - const page = await newE2EPage(); - await page.setContent(``); - - const element = await page.find(`calcite-split-button`); - const container = await page.find(`calcite-split-button >>> .${CSS.widthAuto}`); - expect(container).not.toBeNull(); - expect(container).toHaveClass(CSS.widthAuto); - - element.setAttribute("width", "half"); - await page.waitForChanges(); - expect(container).toHaveClass(CSS.widthHalf); - - element.setAttribute("width", "full"); - await page.waitForChanges(); - expect(container).toHaveClass(CSS.widthFull); - }); - it("should support dropdown item keyboard navigation", async () => { const page = await newE2EPage(); await page.setContent(` diff --git a/packages/calcite-components/src/components/split-button/split-button.scss b/packages/calcite-components/src/components/split-button/split-button.scss index 4ae15eae7cf..c6e9a3b94ae 100644 --- a/packages/calcite-components/src/components/split-button/split-button.scss +++ b/packages/calcite-components/src/components/split-button/split-button.scss @@ -2,13 +2,16 @@ @apply inline-block; } -:host { - .split-button__container { - @apply flex items-stretch; - > calcite-dropdown > calcite-button { - @apply h-full align-top; - } - } +:host([width="auto"]) { + @apply w-auto; +} + +:host([width="half"]) { + @apply w-2/4; +} + +:host([width="full"]) { + @apply w-full; } :host { @@ -74,41 +77,36 @@ } } -.width-auto { - @apply w-auto; -} - -.width-half { - @apply w-1/2; -} - -.width-full { - @apply w-full; +.container { + @apply flex items-stretch; + > calcite-dropdown > calcite-button { + @apply h-full align-top; + } } -.split-button__divider-container { +.divider-container { @apply transition-default flex w-px items-stretch; background-color: var(--calcite-split-button-background); } -.split-button__divider { +.divider { @apply my-1 inline-block w-px; background-color: var(--calcite-split-button-divider); } :host([appearance="outline-fill"]), :host([appearance="outline"]) { - .split-button__divider-container { + .divider-container { border-block: 1px solid var(--calcite-split-button-divider); } - &:hover .split-button__divider-container { + &:hover .divider-container { background-color: var(--calcite-split-button-divider); } } :host([appearance="outline-fill"]:hover), :host([appearance="outline"]:hover) { - .split-button__divider-container { + .divider-container { background-color: var(--calcite-split-button-divider); } } @@ -121,13 +119,13 @@ &:host([kind="danger"]) { --calcite-split-button-divider: theme("colors.danger-press"); } - .split-button__divider-container { + .divider-container { background-color: var(--calcite-split-button-divider); } } @include disabled() { - .split-button__divider-container { + .divider-container { @apply opacity-disabled; } diff --git a/packages/calcite-components/src/components/split-button/split-button.stories.ts b/packages/calcite-components/src/components/split-button/split-button.stories.ts index 0fad58fcf40..45653547fef 100644 --- a/packages/calcite-components/src/components/split-button/split-button.stories.ts +++ b/packages/calcite-components/src/components/split-button/split-button.stories.ts @@ -37,6 +37,41 @@ export const simple = (): string => html` `; +export const allWidths_TestOnly = (): string => html` +
+ + + Pea + Parsnip + Radish + Tomato + Rutabaga + Bean + + + + + Pea + Parsnip + Radish + Tomato + Rutabaga + Bean + + + + + Pea + Parsnip + Radish + Tomato + Rutabaga + Bean + + +
+`; + export const iconEnd_TestOnly = (): string => html`
+