@spectrum-web-components/picker 0.35.0 → 0.35.1-rc.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@spectrum-web-components/picker",
3
- "version": "0.35.0",
3
+ "version": "0.35.1-rc.24+e3649e123",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -65,17 +65,17 @@
65
65
  "lit-html"
66
66
  ],
67
67
  "dependencies": {
68
- "@spectrum-web-components/base": "^0.35.0",
69
- "@spectrum-web-components/button": "^0.35.0",
70
- "@spectrum-web-components/icon": "^0.35.0",
71
- "@spectrum-web-components/icons-ui": "^0.35.0",
72
- "@spectrum-web-components/icons-workflow": "^0.35.0",
73
- "@spectrum-web-components/menu": "^0.35.0",
74
- "@spectrum-web-components/overlay": "^0.35.0",
75
- "@spectrum-web-components/popover": "^0.35.0",
76
- "@spectrum-web-components/reactive-controllers": "^0.35.0",
77
- "@spectrum-web-components/shared": "^0.35.0",
78
- "@spectrum-web-components/tray": "^0.35.0"
68
+ "@spectrum-web-components/base": "^0.35.1-rc.24+e3649e123",
69
+ "@spectrum-web-components/button": "^0.35.1-rc.24+e3649e123",
70
+ "@spectrum-web-components/icon": "^0.35.1-rc.24+e3649e123",
71
+ "@spectrum-web-components/icons-ui": "^0.35.1-rc.24+e3649e123",
72
+ "@spectrum-web-components/icons-workflow": "^0.35.1-rc.24+e3649e123",
73
+ "@spectrum-web-components/menu": "^0.35.1-rc.24+e3649e123",
74
+ "@spectrum-web-components/overlay": "^0.35.1-rc.24+e3649e123",
75
+ "@spectrum-web-components/popover": "^0.35.1-rc.24+e3649e123",
76
+ "@spectrum-web-components/reactive-controllers": "^0.35.1-rc.24+e3649e123",
77
+ "@spectrum-web-components/shared": "^0.35.1-rc.24+e3649e123",
78
+ "@spectrum-web-components/tray": "^0.35.1-rc.24+e3649e123"
79
79
  },
80
80
  "devDependencies": {
81
81
  "@spectrum-css/picker": "^4.0.21"
@@ -88,5 +88,5 @@
88
88
  "./sync/index.js",
89
89
  "./sync/sp-*.js"
90
90
  ],
91
- "gitHead": "1ee5a6c92838cdf48321276d97f61c20f8476ac1"
91
+ "gitHead": "e3649e1230ed727048988a452969c38ced5467ac"
92
92
  }
package/src/Picker.d.ts CHANGED
@@ -1,26 +1,23 @@
1
1
  import { CSSResultArray, PropertyValues, TemplateResult } from '@spectrum-web-components/base';
2
+ import { StyleInfo } from '@spectrum-web-components/base/src/directives.js';
2
3
  import { Focusable } from '@spectrum-web-components/shared/src/focusable.js';
3
4
  import '@spectrum-web-components/icons-ui/icons/sp-icon-chevron100.js';
4
5
  import '@spectrum-web-components/icons-workflow/icons/sp-icon-alert.js';
6
+ import '@spectrum-web-components/overlay/sp-overlay.js';
5
7
  import '@spectrum-web-components/menu/sp-menu.js';
6
- import type { Menu, MenuItem, MenuItemAddedOrUpdatedEvent, MenuItemChildren, MenuItemRemovedEvent } from '@spectrum-web-components/menu';
8
+ import type { Menu, MenuItem, MenuItemChildren } from '@spectrum-web-components/menu';
7
9
  import '@spectrum-web-components/tray/sp-tray.js';
8
10
  import '@spectrum-web-components/popover/sp-popover.js';
9
- import { OverlayOptions, Placement, TriggerInteractions } from '@spectrum-web-components/overlay';
11
+ import { Placement } from '@spectrum-web-components/overlay';
10
12
  import { MatchMediaController } from '@spectrum-web-components/reactive-controllers/src/MatchMedia.js';
11
13
  declare const PickerBase_base: typeof Focusable & {
12
14
  new (...args: any[]): import("@spectrum-web-components/base").SizedElementInterface;
13
15
  prototype: import("@spectrum-web-components/base").SizedElementInterface;
14
16
  };
15
17
  export declare class PickerBase extends PickerBase_base {
16
- /**
17
- * @private
18
- */
19
- static openOverlay: (target: HTMLElement, interaction: TriggerInteractions, content: HTMLElement, options: OverlayOptions) => Promise<() => void>;
20
18
  protected isMobile: MatchMediaController;
21
19
  appliedLabel?: string;
22
20
  button: HTMLButtonElement;
23
- get target(): HTMLButtonElement | this;
24
21
  disabled: boolean;
25
22
  focused: boolean;
26
23
  icons?: 'only' | 'none';
@@ -29,64 +26,59 @@ export declare class PickerBase extends PickerBase_base {
29
26
  open: boolean;
30
27
  readonly: boolean;
31
28
  selects: undefined | 'single';
32
- menuItems: MenuItem[];
33
- private restoreChildren?;
34
- optionsMenu: Menu;
29
+ protected get menuItems(): MenuItem[];
30
+ protected optionsMenu: Menu;
35
31
  /**
36
- * @type {"auto" | "auto-start" | "auto-end" | "top" | "bottom" | "right" | "left" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end" | "none"}
32
+ * @type {"auto" | "auto-start" | "auto-end" | "top" | "bottom" | "right" | "left" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end" }
37
33
  * @attr
38
34
  */
39
35
  placement: Placement;
40
36
  quiet: boolean;
41
37
  value: string;
42
- selectedItem?: MenuItem;
43
- private closeOverlay?;
44
- private popoverEl;
38
+ get selectedItem(): MenuItem | undefined;
39
+ set selectedItem(selectedItem: MenuItem | undefined);
40
+ _selectedItem?: MenuItem;
45
41
  protected listRole: 'listbox' | 'menu';
46
42
  protected itemRole: string;
47
43
  constructor();
48
44
  get focusElement(): HTMLElement;
49
45
  forceFocusVisible(): void;
50
- onButtonBlur(): void;
51
- protected onButtonClick(): void;
46
+ handleButtonBlur(): void;
47
+ private preventNextToggle;
48
+ protected handlePointerdown(): void;
49
+ protected handleButtonClick(): void;
52
50
  focus(options?: FocusOptions): void;
53
- onHelperFocus(): void;
54
- onButtonFocus(): void;
51
+ handleHelperFocus(): void;
55
52
  handleChange(event: Event): void;
56
- protected onKeydown: (event: KeyboardEvent) => void;
57
- setValueFromItem(item: MenuItem, menuChangeEvent?: Event): Promise<void>;
53
+ protected handleKeydown: (event: KeyboardEvent) => void;
54
+ protected setValueFromItem(item: MenuItem, menuChangeEvent?: Event): Promise<void>;
58
55
  protected setMenuItemSelected(item: MenuItem, value: boolean): void;
59
56
  toggle(target?: boolean): void;
60
57
  close(): void;
61
- overlayOpenCallback: () => Promise<void>;
62
- overlayCloseCallback: () => Promise<void>;
63
- private popoverFragment;
64
- private generatePopover;
65
- private openMenu;
66
- protected sizePopover(popover: HTMLElement): void;
67
- private closeMenu;
58
+ protected get containerStyles(): StyleInfo;
68
59
  protected get selectedItemContent(): MenuItemChildren;
60
+ protected set selectedItemContent(selectedItemContent: MenuItemChildren | undefined);
61
+ _selectedItemContent?: MenuItemChildren;
69
62
  protected renderLabelContent(content: Node[]): TemplateResult | Node[];
70
63
  protected get buttonContent(): TemplateResult[];
71
64
  applyFocusElementLabel: (value?: string) => void;
65
+ protected get renderOverlay(): TemplateResult;
72
66
  protected render(): TemplateResult;
73
67
  protected update(changes: PropertyValues<this>): void;
68
+ protected bindButtonKeydownListener(): void;
69
+ protected firstUpdated(changes: PropertyValues<this>): void;
74
70
  protected get dismissHelper(): TemplateResult;
75
- protected get renderPopover(): TemplateResult;
76
- private _willUpdateItems;
77
- protected itemsUpdated: Promise<void>;
78
- /**
79
- * Acquire the available MenuItems in the Picker by
80
- * direct element query or by assuming the list managed
81
- * by the Menu within the open options overlay.
82
- */
83
- protected updateMenuItems(event?: MenuItemAddedOrUpdatedEvent | MenuItemRemovedEvent): void;
71
+ protected get renderContainer(): TemplateResult;
72
+ private willManageSelection;
73
+ protected shouldScheduleManageSelection(event?: Event): void;
74
+ protected shouldManageSelection(): void;
84
75
  protected manageSelection(): Promise<void>;
85
- private menuStatePromise;
86
- private menuStateResolver;
87
76
  private selectionPromise;
88
77
  private selectionResolver;
89
78
  protected getUpdateComplete(): Promise<boolean>;
79
+ private recentlyConnected;
80
+ private enterKeydownOn;
81
+ protected handleEnterKeydown: (event: KeyboardEvent) => void;
90
82
  connectedCallback(): void;
91
83
  disconnectedCallback(): void;
92
84
  }
@@ -101,7 +93,7 @@ export declare class PickerBase extends PickerBase_base {
101
93
  */
102
94
  export declare class Picker extends PickerBase {
103
95
  static get styles(): CSSResultArray;
104
- protected sizePopover(popover: HTMLElement): void;
105
- protected onKeydown: (event: KeyboardEvent) => void;
96
+ protected get containerStyles(): StyleInfo;
97
+ protected handleKeydown: (event: KeyboardEvent) => void;
106
98
  }
107
99
  export {};