Skip to content

Commit

Permalink
fix(picker): prevent the Menu opening until required dependencies are…
Browse files Browse the repository at this point in the history
… loaded
  • Loading branch information
Westbrook committed Dec 19, 2023
1 parent ae9fcd2 commit 55e6174
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 2 deletions.
31 changes: 29 additions & 2 deletions packages/picker/src/Picker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -392,12 +392,14 @@ export class PickerBase extends SizedMixin(Focusable, { noDefaultSize: true }) {
};

protected renderOverlay(menu: TemplateResult): TemplateResult {
const container = this.renderContainer(menu);
this.trackDependency('sp-overlay');
import('@spectrum-web-components/overlay/sp-overlay.js');
return html`
<sp-overlay
.triggerElement=${this as HTMLElement}
.offset=${0}
?open=${this.open}
?open=${this.open && this.dependenciesLoaded}
.placement=${this.isMobile.matches ? undefined : this.placement}
.type=${this.isMobile.matches ? 'modal' : 'auto'}
.receivesFocus=${'true'}
Expand All @@ -419,7 +421,7 @@ export class PickerBase extends SizedMixin(Focusable, { noDefaultSize: true }) {
}
}}
>
${this.renderContainer(menu)}
${container}
</sp-overlay>
`;
}
Expand Down Expand Up @@ -521,13 +523,37 @@ export class PickerBase extends SizedMixin(Focusable, { noDefaultSize: true }) {
`;
}

@state()
private dependenciesLoaded = false;
private dependenciesToLoad: Record<string, boolean> = {};

private trackDependency(dependency: string, flag?: boolean): void {
const loaded =
!!customElements.get(dependency) ||
this.dependenciesToLoad[dependency] ||
!!flag;
if (!loaded) {
customElements.whenDefined(dependency).then(() => {
this.trackDependency(dependency, true);
});
}
this.dependenciesToLoad = {
...this.dependenciesToLoad,
[dependency]: loaded,
};
this.dependenciesLoaded = Object.values(this.dependenciesToLoad).every(
(loaded) => loaded
);
}

protected renderContainer(menu: TemplateResult): TemplateResult {
const accessibleMenu = html`
${this.dismissHelper} ${menu} ${this.dismissHelper}
`;
// @todo: test in mobile
/* c8 ignore next 11 */
if (this.isMobile.matches) {
this.trackDependency('sp-tray');
import('@spectrum-web-components/tray/sp-tray.js');
return html`
<sp-tray
Expand All @@ -539,6 +565,7 @@ export class PickerBase extends SizedMixin(Focusable, { noDefaultSize: true }) {
</sp-tray>
`;
}
this.trackDependency('sp-popover');
import('@spectrum-web-components/popover/sp-popover.js');
return html`
<sp-popover
Expand Down
4 changes: 4 additions & 0 deletions packages/picker/src/picker.css
Original file line number Diff line number Diff line change
Expand Up @@ -105,3 +105,7 @@ sp-menu {
width: 1px;
white-space: nowrap;
}

sp-overlay:not(:defined) {
display: none;
}

0 comments on commit 55e6174

Please sign in to comment.