@primer/view-components 0.28.0-rc.bfe86ece → 0.28.0

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.
@@ -20,7 +20,7 @@ export declare class SelectPanelElement extends HTMLElement {
20
20
  ariaLiveContainer: HTMLElement;
21
21
  noResults: HTMLElement;
22
22
  fragmentErrorElement: HTMLElement;
23
- errorBannerElement: HTMLElement;
23
+ bannerErrorElement: HTMLElement;
24
24
  bodySpinner: HTMLElement;
25
25
  filterFn?: FilterFn;
26
26
  get open(): boolean;
@@ -52,8 +52,6 @@ export declare class SelectPanelElement extends HTMLElement {
52
52
  disableItem(item: SelectPanelItem | null): void;
53
53
  enableItem(item: SelectPanelItem | null): void;
54
54
  isItemHidden(item: SelectPanelItem | null): boolean;
55
- hideItem(item: SelectPanelItem | null): void;
56
- showItem(item: SelectPanelItem | null): void;
57
55
  isItemChecked(item: SelectPanelItem | null): boolean;
58
56
  checkItem(item: SelectPanelItem | null): void;
59
57
  uncheckItem(item: SelectPanelItem | null): void;
@@ -15,7 +15,7 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
15
15
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
16
16
  return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
17
17
  };
18
- var _SelectPanelElement_instances, _SelectPanelElement_dialogIntersectionObserver, _SelectPanelElement_abortController, _SelectPanelElement_originalLabel, _SelectPanelElement_inputName, _SelectPanelElement_selectedItems, _SelectPanelElement_loadingDelayTimeoutId, _SelectPanelElement_loadingAnnouncementTimeoutId, _SelectPanelElement_softDisableItems, _SelectPanelElement_updateTabIndices, _SelectPanelElement_potentiallyDisallowActivation, _SelectPanelElement_isAnchorActivationViaSpace, _SelectPanelElement_isActivation, _SelectPanelElement_checkSelectedItems, _SelectPanelElement_addSelectedItem, _SelectPanelElement_removeSelectedItem, _SelectPanelElement_setTextFieldLoadingSpinnerTimer, _SelectPanelElement_handleIncludeFragmentEvent, _SelectPanelElement_toggleIncludeFragmentElements, _SelectPanelElement_handleRemoteInputEvent, _SelectPanelElement_defaultFilterFn, _SelectPanelElement_handleSearchFieldEvent, _SelectPanelElement_updateItemVisibility, _SelectPanelElement_inErrorState, _SelectPanelElement_setErrorState, _SelectPanelElement_clearErrorState, _SelectPanelElement_maybeAnnounce, _SelectPanelElement_fetchStrategy_get, _SelectPanelElement_filterInputTextFieldElement_get, _SelectPanelElement_performFilteringLocally, _SelectPanelElement_handleInvokerActivated, _SelectPanelElement_handleDialogItemActivated, _SelectPanelElement_handleItemActivated, _SelectPanelElement_setDynamicLabel, _SelectPanelElement_updateInput, _SelectPanelElement_firstItem_get, _SelectPanelElement_getItemContent;
18
+ var _SelectPanelElement_instances, _SelectPanelElement_dialogIntersectionObserver, _SelectPanelElement_abortController, _SelectPanelElement_originalLabel, _SelectPanelElement_inputName, _SelectPanelElement_selectedItems, _SelectPanelElement_loadingDelayTimeoutId, _SelectPanelElement_loadingAnnouncementTimeoutId, _SelectPanelElement_waitForCondition, _SelectPanelElement_softDisableItems, _SelectPanelElement_updateTabIndices, _SelectPanelElement_potentiallyDisallowActivation, _SelectPanelElement_isAnchorActivationViaSpace, _SelectPanelElement_isActivation, _SelectPanelElement_checkSelectedItems, _SelectPanelElement_addSelectedItem, _SelectPanelElement_removeSelectedItem, _SelectPanelElement_setTextFieldLoadingSpinnerTimer, _SelectPanelElement_handleIncludeFragmentEvent, _SelectPanelElement_toggleIncludeFragmentElements, _SelectPanelElement_handleRemoteInputEvent, _SelectPanelElement_defaultFilterFn, _SelectPanelElement_handleSearchFieldEvent, _SelectPanelElement_updateItemVisibility, _SelectPanelElement_inErrorState, _SelectPanelElement_setErrorState, _SelectPanelElement_clearErrorState, _SelectPanelElement_maybeAnnounce, _SelectPanelElement_fetchStrategy_get, _SelectPanelElement_filterInputTextFieldElement_get, _SelectPanelElement_performFilteringLocally, _SelectPanelElement_handleInvokerActivated, _SelectPanelElement_handleDialogItemActivated, _SelectPanelElement_handleItemActivated, _SelectPanelElement_setDynamicLabel, _SelectPanelElement_updateInput, _SelectPanelElement_firstItem_get, _SelectPanelElement_hideItem, _SelectPanelElement_showItem, _SelectPanelElement_getItemContent;
19
19
  import { getAnchoredPosition } from '@primer/behaviors';
20
20
  import { controller, target } from '@github/catalyst';
21
21
  import { announceFromElement, announce } from '../aria_live';
@@ -170,64 +170,35 @@ let SelectPanelElement = class SelectPanelElement extends HTMLElement {
170
170
  __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateInput).call(this);
171
171
  __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_softDisableItems).call(this);
172
172
  updateWhenVisible(this);
173
- if (this.remoteInput) {
173
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_waitForCondition).call(this, () => Boolean(this.remoteInput), () => {
174
174
  this.remoteInput.addEventListener('loadstart', this, { signal });
175
175
  this.remoteInput.addEventListener('loadend', this, { signal });
176
- }
177
- else {
178
- const mutationObserver = new MutationObserver(() => {
179
- if (this.remoteInput) {
180
- this.remoteInput.addEventListener('loadstart', this, { signal });
181
- this.remoteInput.addEventListener('loadend', this, { signal });
182
- mutationObserver.disconnect();
183
- }
184
- });
185
- mutationObserver.observe(this, { childList: true, subtree: true });
186
- }
187
- if (this.includeFragment) {
176
+ });
177
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_waitForCondition).call(this, () => Boolean(this.includeFragment), () => {
188
178
  this.includeFragment.addEventListener('include-fragment-replaced', this, { signal });
189
179
  this.includeFragment.addEventListener('error', this, { signal });
190
180
  this.includeFragment.addEventListener('loadend', this, { signal });
191
- }
192
- else {
193
- const mutationObserver = new MutationObserver(() => {
194
- if (this.includeFragment) {
195
- this.includeFragment.addEventListener('include-fragment-replaced', this, { signal });
196
- this.includeFragment.addEventListener('error', this, { signal });
197
- this.includeFragment.addEventListener('loadend', this, { signal });
198
- mutationObserver.disconnect();
199
- }
200
- });
201
- mutationObserver.observe(this, { childList: true, subtree: true });
202
- }
181
+ });
203
182
  __classPrivateFieldSet(this, _SelectPanelElement_dialogIntersectionObserver, new IntersectionObserver(entries => {
204
183
  for (const entry of entries) {
205
184
  const elem = entry.target;
206
185
  if (entry.isIntersecting && elem === this.dialog) {
207
186
  this.updateAnchorPosition();
208
- if (__classPrivateFieldGet(this, _SelectPanelElement_instances, "a", _SelectPanelElement_fetchStrategy_get) === FetchStrategy.LOCAL) {
209
- __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateItemVisibility).call(this);
210
- }
211
187
  }
212
188
  }
213
189
  }), "f");
214
- if (this.dialog) {
190
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_waitForCondition).call(this, () => Boolean(this.dialog), () => {
215
191
  if (this.getAttribute('data-open-on-load') === 'true') {
216
192
  this.show();
217
193
  }
218
194
  __classPrivateFieldGet(this, _SelectPanelElement_dialogIntersectionObserver, "f").observe(this.dialog);
219
- }
220
- else {
221
- const mutationObserver = new MutationObserver(() => {
222
- if (this.dialog) {
223
- if (this.getAttribute('data-open-on-load') === 'true') {
224
- this.show();
225
- }
226
- __classPrivateFieldGet(this, _SelectPanelElement_dialogIntersectionObserver, "f").observe(this.dialog);
227
- mutationObserver.disconnect();
228
- }
195
+ this.dialog.addEventListener('close', this, { signal });
196
+ });
197
+ if (__classPrivateFieldGet(this, _SelectPanelElement_instances, "a", _SelectPanelElement_fetchStrategy_get) === FetchStrategy.LOCAL) {
198
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_waitForCondition).call(this, () => this.items.length > 0, () => {
199
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateItemVisibility).call(this);
200
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateInput).call(this);
229
201
  });
230
- mutationObserver.observe(this, { childList: true, subtree: true });
231
202
  }
232
203
  }
233
204
  disconnectedCallback() {
@@ -262,7 +233,14 @@ let SelectPanelElement = class SelectPanelElement extends HTMLElement {
262
233
  return;
263
234
  }
264
235
  if (targetIsCloseButton && eventIsActivation) {
265
- // #hide will automatically be called by dialog event triggered from `data-close-dialog-id`
236
+ // hide() will automatically be called by dialog event triggered from `data-close-dialog-id`
237
+ return;
238
+ }
239
+ if (event.target === this.dialog && event.type === 'close') {
240
+ this.dispatchEvent(new CustomEvent('panelClosed', {
241
+ detail: { panel: this },
242
+ bubbles: true,
243
+ }));
266
244
  return;
267
245
  }
268
246
  const item = event.target.closest(visibleMenuItemSelectors)?.parentElement;
@@ -315,10 +293,6 @@ let SelectPanelElement = class SelectPanelElement extends HTMLElement {
315
293
  }
316
294
  hide() {
317
295
  this.dialog.close();
318
- this.dispatchEvent(new CustomEvent('panelClosed', {
319
- detail: { panel: this },
320
- bubbles: true,
321
- }));
322
296
  }
323
297
  get visibleItems() {
324
298
  return Array.from(this.querySelectorAll(visibleMenuItemSelectors)).map(element => element.parentElement);
@@ -367,16 +341,6 @@ let SelectPanelElement = class SelectPanelElement extends HTMLElement {
367
341
  return false;
368
342
  }
369
343
  }
370
- hideItem(item) {
371
- if (item) {
372
- item.setAttribute('hidden', 'hidden');
373
- }
374
- }
375
- showItem(item) {
376
- if (item) {
377
- item.removeAttribute('hidden');
378
- }
379
- }
380
344
  isItemChecked(item) {
381
345
  if (item) {
382
346
  return __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_getItemContent).call(this, item).getAttribute(this.ariaSelectionType) === 'true';
@@ -408,6 +372,20 @@ _SelectPanelElement_selectedItems = new WeakMap();
408
372
  _SelectPanelElement_loadingDelayTimeoutId = new WeakMap();
409
373
  _SelectPanelElement_loadingAnnouncementTimeoutId = new WeakMap();
410
374
  _SelectPanelElement_instances = new WeakSet();
375
+ _SelectPanelElement_waitForCondition = function _SelectPanelElement_waitForCondition(condition, body) {
376
+ if (condition()) {
377
+ body();
378
+ }
379
+ else {
380
+ const mutationObserver = new MutationObserver(() => {
381
+ if (condition()) {
382
+ body();
383
+ mutationObserver.disconnect();
384
+ }
385
+ });
386
+ mutationObserver.observe(this, { childList: true, subtree: true });
387
+ }
388
+ };
411
389
  _SelectPanelElement_softDisableItems = function _SelectPanelElement_softDisableItems() {
412
390
  const { signal } = __classPrivateFieldGet(this, _SelectPanelElement_abortController, "f");
413
391
  for (const item of this.querySelectorAll(validSelectors.join(','))) {
@@ -483,23 +461,28 @@ _SelectPanelElement_isActivation = function _SelectPanelElement_isActivation(eve
483
461
  };
484
462
  _SelectPanelElement_checkSelectedItems = function _SelectPanelElement_checkSelectedItems() {
485
463
  for (const item of this.items) {
486
- const value = item.getAttribute('data-value');
464
+ const itemContent = __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_getItemContent).call(this, item);
465
+ if (!itemContent)
466
+ continue;
467
+ const value = itemContent.getAttribute('data-value');
487
468
  if (value) {
488
469
  if (__classPrivateFieldGet(this, _SelectPanelElement_selectedItems, "f").has(value)) {
489
- item.setAttribute(this.ariaSelectionType, 'true');
470
+ itemContent.setAttribute(this.ariaSelectionType, 'true');
490
471
  }
491
472
  }
492
473
  }
493
474
  __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateInput).call(this);
494
475
  };
495
476
  _SelectPanelElement_addSelectedItem = function _SelectPanelElement_addSelectedItem(item) {
496
- const button = item.querySelector('button');
497
- const value = item.getAttribute('data-value');
477
+ const itemContent = __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_getItemContent).call(this, item);
478
+ if (!itemContent)
479
+ return;
480
+ const value = itemContent.getAttribute('data-value');
498
481
  if (value) {
499
482
  __classPrivateFieldGet(this, _SelectPanelElement_selectedItems, "f").set(value, {
500
483
  value,
501
- label: button.querySelector('.ActionListItem-label')?.textContent?.trim(),
502
- inputName: button.getAttribute('data-input-name'),
484
+ label: itemContent.querySelector('.ActionListItem-label')?.textContent?.trim(),
485
+ inputName: itemContent.getAttribute('data-input-name'),
503
486
  element: item,
504
487
  });
505
488
  }
@@ -633,11 +616,11 @@ _SelectPanelElement_updateItemVisibility = function _SelectPanelElement_updateIt
633
616
  const filter = this.filterFn || __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_defaultFilterFn);
634
617
  for (const item of this.items) {
635
618
  if (filter(item, query)) {
636
- this.showItem(item);
619
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_showItem).call(this, item);
637
620
  atLeastOneResult = true;
638
621
  }
639
622
  else {
640
- this.hideItem(item);
623
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_hideItem).call(this, item);
641
624
  }
642
625
  }
643
626
  }
@@ -647,7 +630,10 @@ _SelectPanelElement_updateItemVisibility = function _SelectPanelElement_updateIt
647
630
  __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateTabIndices).call(this);
648
631
  __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_maybeAnnounce).call(this);
649
632
  for (const item of this.items) {
650
- const value = item.getAttribute('data-value');
633
+ const itemContent = __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_getItemContent).call(this, item);
634
+ if (!itemContent)
635
+ continue;
636
+ const value = itemContent.getAttribute('data-value');
651
637
  if (value && !__classPrivateFieldGet(this, _SelectPanelElement_selectedItems, "f").has(value) && this.isItemChecked(item)) {
652
638
  __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_addSelectedItem).call(this, item);
653
639
  }
@@ -672,17 +658,17 @@ _SelectPanelElement_inErrorState = function _SelectPanelElement_inErrorState() {
672
658
  if (this.fragmentErrorElement && !this.fragmentErrorElement.hasAttribute('hidden')) {
673
659
  return true;
674
660
  }
675
- return !this.errorBannerElement.hasAttribute('hidden');
661
+ return !this.bannerErrorElement.hasAttribute('hidden');
676
662
  };
677
663
  _SelectPanelElement_setErrorState = function _SelectPanelElement_setErrorState(type) {
678
664
  let errorElement = this.fragmentErrorElement;
679
665
  if (type === ErrorStateType.BODY) {
680
666
  this.fragmentErrorElement?.removeAttribute('hidden');
681
- this.errorBannerElement.setAttribute('hidden', '');
667
+ this.bannerErrorElement.setAttribute('hidden', '');
682
668
  }
683
669
  else {
684
- errorElement = this.errorBannerElement;
685
- this.errorBannerElement?.removeAttribute('hidden');
670
+ errorElement = this.bannerErrorElement;
671
+ this.bannerErrorElement?.removeAttribute('hidden');
686
672
  this.fragmentErrorElement?.setAttribute('hidden', '');
687
673
  }
688
674
  // check if the errorElement is visible in the dom
@@ -693,7 +679,7 @@ _SelectPanelElement_setErrorState = function _SelectPanelElement_setErrorState(t
693
679
  };
694
680
  _SelectPanelElement_clearErrorState = function _SelectPanelElement_clearErrorState() {
695
681
  this.fragmentErrorElement?.setAttribute('hidden', '');
696
- this.errorBannerElement.setAttribute('hidden', '');
682
+ this.bannerErrorElement.setAttribute('hidden', '');
697
683
  };
698
684
  _SelectPanelElement_maybeAnnounce = function _SelectPanelElement_maybeAnnounce() {
699
685
  if (this.open && this.list) {
@@ -814,6 +800,7 @@ _SelectPanelElement_handleItemActivated = function _SelectPanelElement_handleIte
814
800
  }
815
801
  }
816
802
  __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateInput).call(this);
803
+ __classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateTabIndices).call(this);
817
804
  this.dispatchEvent(new CustomEvent('itemActivated', {
818
805
  bubbles: true,
819
806
  detail: { item, checked },
@@ -884,6 +871,16 @@ _SelectPanelElement_updateInput = function _SelectPanelElement_updateInput() {
884
871
  _SelectPanelElement_firstItem_get = function _SelectPanelElement_firstItem_get() {
885
872
  return (this.querySelector(visibleMenuItemSelectors)?.parentElement || null);
886
873
  };
874
+ _SelectPanelElement_hideItem = function _SelectPanelElement_hideItem(item) {
875
+ if (item) {
876
+ item.setAttribute('hidden', 'hidden');
877
+ }
878
+ };
879
+ _SelectPanelElement_showItem = function _SelectPanelElement_showItem(item) {
880
+ if (item) {
881
+ item.removeAttribute('hidden');
882
+ }
883
+ };
887
884
  _SelectPanelElement_getItemContent = function _SelectPanelElement_getItemContent(item) {
888
885
  return item.querySelector('.ActionListContent');
889
886
  };
@@ -913,7 +910,7 @@ __decorate([
913
910
  ], SelectPanelElement.prototype, "fragmentErrorElement", void 0);
914
911
  __decorate([
915
912
  target
916
- ], SelectPanelElement.prototype, "errorBannerElement", void 0);
913
+ ], SelectPanelElement.prototype, "bannerErrorElement", void 0);
917
914
  __decorate([
918
915
  target
919
916
  ], SelectPanelElement.prototype, "bodySpinner", void 0);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@primer/view-components",
3
- "version": "0.28.0-rc.bfe86ece",
3
+ "version": "0.28.0",
4
4
  "description": "ViewComponents for the Primer Design System",
5
5
  "main": "app/assets/javascripts/primer_view_components.js",
6
6
  "module": "app/components/primer/primer.js",
@@ -2352,6 +2352,124 @@
2352
2352
  }
2353
2353
  ]
2354
2354
  },
2355
+ {
2356
+ "component": "SelectPanel",
2357
+ "status": "alpha",
2358
+ "a11y_reviewed": false,
2359
+ "short_name": "SelectPanel",
2360
+ "source": "https://github.com/primer/view_components/tree/main/app/components/primer/alpha/select_panel.rb",
2361
+ "lookbook": "https://primer.style/view-components/lookbook/inspect/primer/alpha/select_panel/default/",
2362
+ "parameters": [
2363
+ {
2364
+ "name": "src",
2365
+ "type": "String",
2366
+ "default": "`nil`",
2367
+ "description": "The URL to fetch search results from."
2368
+ },
2369
+ {
2370
+ "name": "title",
2371
+ "type": "String",
2372
+ "default": "`\"Menu\"`",
2373
+ "description": "The title that appears at the top of the panel."
2374
+ },
2375
+ {
2376
+ "name": "id",
2377
+ "type": "String",
2378
+ "default": "`self.class.generate_id`",
2379
+ "description": "The unique ID of the panel."
2380
+ },
2381
+ {
2382
+ "name": "size",
2383
+ "type": "Symbol",
2384
+ "default": "`:small`",
2385
+ "description": "The size of the panel. One of `:auto`, `:large`, `:medium`, `:medium_portrait`, `:small`, or `:xlarge`."
2386
+ },
2387
+ {
2388
+ "name": "select_variant",
2389
+ "type": "Symbol",
2390
+ "default": "`:single`",
2391
+ "description": "One of `:multiple`, `:multiple_checkbox`, `:none`, or `:single`."
2392
+ },
2393
+ {
2394
+ "name": "fetch_strategy",
2395
+ "type": "Symbol",
2396
+ "default": "`:remote`",
2397
+ "description": "One of `:eventually_local`, `:local`, or `:remote`."
2398
+ },
2399
+ {
2400
+ "name": "no_results_label",
2401
+ "type": "String",
2402
+ "default": "`\"No results found\"`",
2403
+ "description": "The label to display when no results are found."
2404
+ },
2405
+ {
2406
+ "name": "preload",
2407
+ "type": "Boolean",
2408
+ "default": "`false`",
2409
+ "description": "Whether to preload search results when the page loads. If this option is false, results are loaded when the panel is opened."
2410
+ },
2411
+ {
2412
+ "name": "dynamic_label",
2413
+ "type": "Boolean",
2414
+ "default": "`false`",
2415
+ "description": "Whether or not to display the text of the currently selected item in the show button."
2416
+ },
2417
+ {
2418
+ "name": "dynamic_label_prefix",
2419
+ "type": "String",
2420
+ "default": "`nil`",
2421
+ "description": "If provided, the prefix is prepended to the dynamic label and displayed in the show button."
2422
+ },
2423
+ {
2424
+ "name": "dynamic_aria_label_prefix",
2425
+ "type": "String",
2426
+ "default": "`nil`",
2427
+ "description": "If provided, the prefix is prepended to the dynamic label and set as the value of the `aria-label` attribute on the show button."
2428
+ },
2429
+ {
2430
+ "name": "body_id",
2431
+ "type": "String",
2432
+ "default": "`nil`",
2433
+ "description": "The unique ID of the panel body. If not provided, the body ID will be set to the panel ID with a \"-body\" suffix."
2434
+ },
2435
+ {
2436
+ "name": "list_arguments",
2437
+ "type": "Hash",
2438
+ "default": "`{}`",
2439
+ "description": "Arguments to pass to the underlying [ActionList](/components/alpha/actionlist) component. Only has an effect for the local fetch strategy."
2440
+ },
2441
+ {
2442
+ "name": "form_arguments",
2443
+ "type": "Hash",
2444
+ "default": "`{}`",
2445
+ "description": "Form arguments to pass to the underlying [ActionList](/components/alpha/actionlist) component. Only has an effect for the local fetch strategy."
2446
+ },
2447
+ {
2448
+ "name": "show_filter",
2449
+ "type": "Boolean",
2450
+ "default": "`true`",
2451
+ "description": "Whether or not to show the filter input."
2452
+ },
2453
+ {
2454
+ "name": "open_on_load",
2455
+ "type": "Boolean",
2456
+ "default": "`false`",
2457
+ "description": "Open the panel when the page loads."
2458
+ },
2459
+ {
2460
+ "name": "anchor_align",
2461
+ "type": "Symbol",
2462
+ "default": "`:start`",
2463
+ "description": "The anchor alignment of the Overlay. One of `:center`, `:end`, or `:start`."
2464
+ },
2465
+ {
2466
+ "name": "anchor_side",
2467
+ "type": "Symbol",
2468
+ "default": "`:outside_bottom`",
2469
+ "description": "The side to anchor the Overlay to. One of `:inside_bottom`, `:inside_center`, `:inside_left`, `:inside_right`, `:inside_top`, `:outside_bottom`, `:outside_left`, `:outside_right`, or `:outside_top`."
2470
+ }
2471
+ ]
2472
+ },
2355
2473
  {
2356
2474
  "component": "SubmitButton",
2357
2475
  "status": "alpha",
@@ -52,6 +52,7 @@
52
52
  "Primer::Alpha::SegmentedControl": "2023-02-01",
53
53
  "Primer::Alpha::SegmentedControl::Item": "2023-02-01",
54
54
  "Primer::Alpha::Select": "",
55
+ "Primer::Alpha::SelectPanel": "",
55
56
  "Primer::Alpha::SubmitButton": "",
56
57
  "Primer::Alpha::TabContainer": "",
57
58
  "Primer::Alpha::TabNav": "",
@@ -597,6 +597,22 @@
597
597
  },
598
598
  "Primer::Alpha::Select": {
599
599
  },
600
+ "Primer::Alpha::SelectPanel": {
601
+ "DEFAULT_FETCH_STRATEGY": "remote",
602
+ "DEFAULT_PRELOAD": false,
603
+ "DEFAULT_SELECT_VARIANT": "single",
604
+ "FETCH_STRATEGIES": [
605
+ "remote",
606
+ "eventually_local",
607
+ "local"
608
+ ],
609
+ "ItemList": "Primer::Alpha::ActionList",
610
+ "SELECT_VARIANT_OPTIONS": [
611
+ "single",
612
+ "multiple",
613
+ "none"
614
+ ]
615
+ },
600
616
  "Primer::Alpha::SubmitButton": {
601
617
  },
602
618
  "Primer::Alpha::TabContainer": {