mirror of
https://github.com/material-components/material-web.git
synced 2024-10-26 21:56:56 +03:00
043bbad6f3
PiperOrigin-RevId: 595540752
79 lines
2.1 KiB
TypeScript
79 lines
2.1 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2023 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import {LitElement} from 'lit';
|
|
|
|
import {FieldHarness} from '../field/harness.js';
|
|
import {Field} from '../field/internal/field.js';
|
|
import {Harness} from '../testing/harness.js';
|
|
|
|
import {Select} from './internal/select.js';
|
|
import {SelectOptionHarness} from './internal/selectoption/harness.js';
|
|
|
|
/**
|
|
* Test harness for menu.
|
|
*/
|
|
export class SelectHarness extends Harness<Select> {
|
|
protected getField() {
|
|
return this.element.renderRoot.querySelector('.field') as Field;
|
|
}
|
|
/**
|
|
* Shows the menu and returns the first list item element.
|
|
*/
|
|
protected override async getInteractiveElement() {
|
|
await this.element.updateComplete;
|
|
return this.getField();
|
|
}
|
|
|
|
override async startHover() {
|
|
const field = await this.getField();
|
|
const element = await new SelectFieldHardness(
|
|
field,
|
|
).getInteractiveElement();
|
|
this.simulateStartHover(element);
|
|
}
|
|
|
|
/** @return ListItem harnesses for the menu's items. */
|
|
getItems() {
|
|
return this.element.options.map(
|
|
(item) => new SelectOptionHarness(item as typeof item & LitElement),
|
|
);
|
|
}
|
|
|
|
async click() {
|
|
const field = await this.getField();
|
|
field.click();
|
|
}
|
|
|
|
async clickOption(index: number) {
|
|
const menu = this.element.renderRoot.querySelector('md-menu')!;
|
|
if (!menu.open) {
|
|
console.warn(
|
|
'Internal menu is not open. Try calling SelectHarness.prototype.click()',
|
|
);
|
|
}
|
|
(await this.getItems()[index].getInteractiveElement()).click();
|
|
}
|
|
|
|
get isOpen() {
|
|
const menu = this.element.renderRoot.querySelector('md-menu')!;
|
|
if (!menu) {
|
|
throw new Error(
|
|
'Internal md-menu is not found. md-select may not have finished rendering when isOpen has been checked',
|
|
);
|
|
}
|
|
return menu.open;
|
|
}
|
|
}
|
|
|
|
// Private class (not exported)
|
|
class SelectFieldHardness extends FieldHarness {
|
|
/* Expose so that we can call it from our internal code in SelectHarness. */
|
|
override getInteractiveElement() {
|
|
return super.getInteractiveElement();
|
|
}
|
|
}
|