Skip to content

Commit

Permalink
Revert "feat(pagination, split-button, dropdown, date-picker) action-…
Browse files Browse the repository at this point in the history
…group): add setFocus method (#6405)"

This reverts commit ceaf532.
  • Loading branch information
benelan committed Feb 6, 2023
1 parent ea9d403 commit 0526ac0
Show file tree
Hide file tree
Showing 11 changed files with 64 additions and 207 deletions.
25 changes: 15 additions & 10 deletions src/components/action-group/action-group.e2e.ts
Original file line number Diff line number Diff line change
@@ -1,26 +1,31 @@
import { accessible, hidden, renders, slots, t9n } from "../../tests/commonTests";
import { newE2EPage } from "@stencil/core/testing";
import { accessible, focusable, hidden, renders, slots, t9n } from "../../tests/commonTests";
import { SLOTS } from "./resources";

const actionGroupHTML = `<calcite-action-group scale="l">
<calcite-action id="plus" slot="menu-actions" text="Add" icon="plus"></calcite-action>
<calcite-action id="banaa" slot="menu-actions" text="Banana" icon="banana"></calcite-action>
</calcite-action-group>`;

describe("calcite-action-group", () => {
it("renders", async () => renders("calcite-action-group", { display: "flex" }));

it("focusable", async () => focusable(actionGroupHTML, { shadowFocusTargetSelector: "calcite-action" }));

it("honors hidden attribute", async () => hidden("calcite-action-group"));

it("should be accessible", async () => accessible(actionGroupHTML));
it("should be accessible", async () =>
accessible(`
<calcite-action-group>
<calcite-action text="Add" icon="plus"></calcite-action>
</calcite-action-group>
`));

it("has slots", () => slots("calcite-action-group", SLOTS));

it("should honor scale of expand icon", async () => {
const page = await newE2EPage({ html: actionGroupHTML });
const page = await newE2EPage({
html: `<calcite-action-group scale="l">
<calcite-action slot="menu-actions" text="Add" icon="plus"></calcite-action>
<calcite-action slot="menu-actions" text="Add" icon="plus"></calcite-action>
</calcite-action-group>`
});

const menu = await page.find(`calcite-action-group >>> calcite-action-menu`);

expect(await menu.getProperty("scale")).toBe("l");
});

Expand Down
30 changes: 3 additions & 27 deletions src/components/action-group/action-group.tsx
Original file line number Diff line number Diff line change
@@ -1,17 +1,12 @@
import { Component, Element, Fragment, h, Method, Prop, State, VNode, Watch } from "@stencil/core";
import { Component, Element, h, Prop, Watch } from "@stencil/core";
import { Fragment, State, VNode } from "@stencil/core/internal";
import { CalciteActionMenuCustomEvent } from "../../components";
import {
ConditionalSlotComponent,
connectConditionalSlotComponent,
disconnectConditionalSlotComponent
} from "../../utils/conditionalSlot";
import { getSlotted } from "../../utils/dom";
import {
componentLoaded,
LoadableComponent,
setComponentLoaded,
setUpLoadableComponent
} from "../../utils/loadable";
import { connectLocalized, disconnectLocalized, LocalizedComponent } from "../../utils/locale";
import {
connectMessages,
Expand All @@ -38,9 +33,7 @@ import { ICONS, SLOTS } from "./resources";
},
assetsDirs: ["assets"]
})
export class ActionGroup
implements ConditionalSlotComponent, LoadableComponent, LocalizedComponent, T9nComponent
{
export class ActionGroup implements ConditionalSlotComponent, LocalizedComponent, T9nComponent {
// --------------------------------------------------------------------------
//
// Properties
Expand Down Expand Up @@ -110,18 +103,6 @@ export class ActionGroup

@State() defaultMessages: ActionGroupMessages;

//--------------------------------------------------------------------------
//
// Public Methods
//
//--------------------------------------------------------------------------

/** Sets focus on the component's first focusable element. */
@Method()
async setFocus(): Promise<void> {
await componentLoaded(this);
this.el.focus();
}
// --------------------------------------------------------------------------
//
// Lifecycle
Expand All @@ -141,14 +122,9 @@ export class ActionGroup
}

async componentWillLoad(): Promise<void> {
setUpLoadableComponent(this);
await setUpMessages(this);
}

componentDidLoad(): void {
setComponentLoaded(this);
}

// --------------------------------------------------------------------------
//
// Component Methods
Expand Down
11 changes: 3 additions & 8 deletions src/components/date-picker/date-picker.e2e.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import { E2EPage, newE2EPage } from "@stencil/core/testing";
import { html } from "../../../support/formatting";
import { defaults, focusable, hidden, renders, t9n } from "../../tests/commonTests";
import { defaults, hidden, renders, t9n } from "../../tests/commonTests";
import { skipAnimations } from "../../tests/utils";
import { dateFromISO } from "../../utils/date";
import { formatTimePart } from "../../utils/time";

describe("calcite-date-picker", () => {
Expand All @@ -17,11 +18,6 @@ describe("calcite-date-picker", () => {
}
]));

it("focusable", async () =>
focusable("<calcite-date-picker></calcite-date-picker>", {
shadowFocusTargetSelector: "calcite-date-picker-month-header"
}));

const animationDurationInMs = 200;

it("fires a calciteDatePickerChange event when changing year in header", async () => {
Expand Down Expand Up @@ -213,8 +209,7 @@ describe("calcite-date-picker", () => {
await page.setContent("<calcite-date-picker value='2000-11-27'></calcite-date-picker>");
const date = await page.find("calcite-date-picker");
const changedEvent = await page.spyOnEvent("calciteDatePickerChange");
date.setProperty("value", "2001-10-28");
await page.waitForChanges();
await date.setProperty("value", "2001-10-28");
expect(changedEvent).toHaveReceivedEventTimes(0);
});

Expand Down
27 changes: 1 addition & 26 deletions src/components/date-picker/date-picker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import {
EventEmitter,
h,
Host,
Method,
Prop,
State,
VNode,
Expand All @@ -20,12 +19,6 @@ import {
HoverRange,
setEndOfDay
} from "../../utils/date";
import {
componentLoaded,
LoadableComponent,
setComponentLoaded,
setUpLoadableComponent
} from "../../utils/loadable";
import {
connectLocalized,
disconnectLocalized,
Expand Down Expand Up @@ -53,7 +46,7 @@ import { DateLocaleData, getLocaleData, getValueAsDateRange } from "./utils";
delegatesFocus: true
}
})
export class DatePicker implements LocalizedComponent, LoadableComponent, T9nComponent {
export class DatePicker implements LocalizedComponent, T9nComponent {
//--------------------------------------------------------------------------
//
// Element
Expand Down Expand Up @@ -195,19 +188,6 @@ export class DatePicker implements LocalizedComponent, LoadableComponent, T9nCom

@State() endAsDate: Date;

//--------------------------------------------------------------------------
//
// Public Methods
//
//--------------------------------------------------------------------------

/** Sets focus on the component's first focusable element. */
@Method()
async setFocus(): Promise<void> {
await componentLoaded(this);
this.el.focus();
}

// --------------------------------------------------------------------------
//
// Lifecycle
Expand Down Expand Up @@ -238,17 +218,12 @@ export class DatePicker implements LocalizedComponent, LoadableComponent, T9nCom
}

async componentWillLoad(): Promise<void> {
setUpLoadableComponent(this);
await this.loadLocaleData();
this.onMinChanged(this.min);
this.onMaxChanged(this.max);
await setUpMessages(this);
}

componentDidLoad(): void {
setComponentLoaded(this);
}

render(): VNode {
const date = dateFromRange(
this.range && Array.isArray(this.valueAsDate) ? this.valueAsDate[0] : this.valueAsDate,
Expand Down
46 changes: 27 additions & 19 deletions src/components/dropdown/dropdown.e2e.ts
Original file line number Diff line number Diff line change
@@ -1,26 +1,23 @@
import { E2EPage, newE2EPage } from "@stencil/core/testing";
import dedent from "dedent";
import { html } from "../../../support/formatting";
import { focusable, accessible, defaults, disabled, floatingUIOwner, hidden, renders } from "../../tests/commonTests";
import { accessible, defaults, disabled, floatingUIOwner, hidden, renders } from "../../tests/commonTests";
import { GlobalTestProps } from "../../tests/utils";
import { CSS } from "./resources";

const simpleDropdownHTML = html`<calcite-dropdown>
<calcite-button slot="trigger">Open dropdown</calcite-button>
<calcite-dropdown-group id="group-1">
<calcite-dropdown-item id="item-1"> Dropdown Item Content </calcite-dropdown-item>
<calcite-dropdown-item id="item-2" selected> Dropdown Item Content </calcite-dropdown-item>
<calcite-dropdown-item id="item-3"> Dropdown Item Content </calcite-dropdown-item>
</calcite-dropdown-group>
</calcite-dropdown>`;

describe("calcite-dropdown", () => {
it("focusable", async () =>
focusable(simpleDropdownHTML, {
focusTargetSelector: '[slot="trigger"]'
}));

it("renders", () => renders(simpleDropdownHTML, { display: "inline-flex" }));
it("renders", () =>
renders(
html`<calcite-dropdown>
<calcite-button slot="trigger">Open dropdown</calcite-button>
<calcite-dropdown-group id="group-1">
<calcite-dropdown-item id="item-1"> Dropdown Item Content </calcite-dropdown-item>
<calcite-dropdown-item id="item-2" selected> Dropdown Item Content </calcite-dropdown-item>
<calcite-dropdown-item id="item-3"> Dropdown Item Content </calcite-dropdown-item>
</calcite-dropdown-group>
</calcite-dropdown>`,
{ display: "inline-flex" }
));

it("honors hidden attribute", async () => hidden("calcite-dropdown"));

Expand All @@ -36,7 +33,18 @@ describe("calcite-dropdown", () => {
}
]));

it("can be disabled", () => disabled(simpleDropdownHTML, { focusTarget: "child" }));
it("can be disabled", () =>
disabled(
html`<calcite-dropdown>
<calcite-button slot="trigger">Open dropdown</calcite-button>
<calcite-dropdown-group id="group-1">
<calcite-dropdown-item id="item-1"> Dropdown Item Content </calcite-dropdown-item>
<calcite-dropdown-item id="item-2" selected> Dropdown Item Content </calcite-dropdown-item>
<calcite-dropdown-item id="item-3"> Dropdown Item Content </calcite-dropdown-item>
</calcite-dropdown-group>
</calcite-dropdown>`,
{ focusTarget: "child" }
));

interface SelectedItemsAssertionOptions {
/**
Expand Down Expand Up @@ -740,7 +748,7 @@ describe("calcite-dropdown", () => {
expect(calciteDropdownOpen).toHaveReceivedEventTimes(1);
expect(calciteDropdownClose).toHaveReceivedEventTimes(0);

await element.callMethod("setFocus");
await trigger.focus();
await page.keyboard.press("Space");
await page.waitForChanges();
expect(await dropdownWrapper.isVisible()).toBe(false);
Expand Down Expand Up @@ -785,7 +793,7 @@ describe("calcite-dropdown", () => {
expect(calciteDropdownOpen).toHaveReceivedEventTimes(1);
expect(calciteDropdownClose).toHaveReceivedEventTimes(0);

await element.callMethod("setFocus");
await trigger.focus();
await page.keyboard.press("Space");
await page.waitForChanges();
expect(await dropdownWrapper.isVisible()).toBe(false);
Expand Down
28 changes: 1 addition & 27 deletions src/components/dropdown/dropdown.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,12 +35,6 @@ import {
import { guid } from "../../utils/guid";
import { InteractiveComponent, updateHostInteraction } from "../../utils/interactive";
import { isActivationKey } from "../../utils/key";
import {
componentLoaded,
LoadableComponent,
setComponentLoaded,
setUpLoadableComponent
} from "../../utils/loadable";
import { createObserver } from "../../utils/observers";
import {
connectOpenCloseComponent,
Expand All @@ -62,9 +56,7 @@ import { SLOTS } from "./resources";
delegatesFocus: true
}
})
export class Dropdown
implements InteractiveComponent, LoadableComponent, OpenCloseComponent, FloatingUIComponent
{
export class Dropdown implements InteractiveComponent, OpenCloseComponent, FloatingUIComponent {
//--------------------------------------------------------------------------
//
// Element
Expand Down Expand Up @@ -193,19 +185,6 @@ export class Dropdown
*/
@Prop({ reflect: true }) width: Scale;

//--------------------------------------------------------------------------
//
// Public Methods
//
//--------------------------------------------------------------------------

/** Sets focus on the component's first focusable element. */
@Method()
async setFocus(): Promise<void> {
await componentLoaded(this);
this.el.focus();
}

//--------------------------------------------------------------------------
//
// Lifecycle
Expand All @@ -222,12 +201,7 @@ export class Dropdown
connectOpenCloseComponent(this);
}

componentWillLoad(): void {
setUpLoadableComponent(this);
}

componentDidLoad(): void {
setComponentLoaded(this);
this.reposition(true);
}

Expand Down
16 changes: 3 additions & 13 deletions src/components/pagination/pagination.e2e.ts
Original file line number Diff line number Diff line change
@@ -1,21 +1,11 @@
import { E2EElement, E2EPage, newE2EPage } from "@stencil/core/testing";
import { html } from "../../../support/formatting";
import { accessible, focusable, hidden, renders, t9n } from "../../tests/commonTests";
import { newE2EPage, E2EElement, E2EPage } from "@stencil/core/testing";
import { accessible, hidden, renders, t9n } from "../../tests/commonTests";
import { CSS } from "./resources";
import { html } from "../../../support/formatting";

describe("calcite-pagination", () => {
it("renders", async () => renders("calcite-pagination", { display: "flex" }));

it("focuses previous button when not on the first page", async () =>
focusable('<calcite-pagination page-size="1" start-item="2" total-items="10"></calcite-pagination>', {
shadowFocusTargetSelector: `.${CSS.previous}`
}));

it("focuses page number 1 when on the first page", async () =>
focusable('<calcite-pagination page-size="1" start-item="1" total-items="10"></calcite-pagination>', {
shadowFocusTargetSelector: `.${CSS.page}`
}));

it("honors hidden attribute", async () => hidden("calcite-pagination"));

it("is accessible", async () => accessible(`<calcite-pagination></calcite-pagination>`));
Expand Down
Loading

0 comments on commit 0526ac0

Please sign in to comment.