Previews

No matching results.

x
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<select-panel data-interaction-subject="db7ff529579ade9d7699567ac6317276" data-select-variant="multiple" data-fetch-strategy="local" data-open-on-load="false" id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de" anchor-align="start" anchor-side="outside-bottom" data-view-component="true">
<dialog-helper>
<button id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-button" aria-controls="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-dialog" aria-haspopup="dialog" aria-expanded="false" type="button" data-view-component="true" class="Button--secondary Button--medium Button"> <span class="Button-content">
<span class="Button-label">Panel</span>
</span>
</button>
<dialog id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-dialog" aria-labelledby="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-dialog-title" data-target="select-panel.dialog" style="position: absolute;" data-view-component="true" class="Overlay Overlay-whenNarrow Overlay--size-small-portrait">
<div data-view-component="true" class="Overlay-header Overlay-header--divided">
<div class="Overlay-headerContentWrap">
<div class="Overlay-titleWrap">
<h1 class="Overlay-title " id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-dialog-title">
Menu
</h1>
</div>
<div class="Overlay-actionWrap">
<button data-close-dialog-id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-dialog" aria-label="Close" type="button" data-view-component="true" class="close-button Overlay-closeButton"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x">
<path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path>
</svg></button>
</div>
</div>
<div data-view-component="true" class="Overlay-headerFilter">
<div data-target="select-panel.bannerErrorElement" hidden>
<x-banner data-dismiss-scheme="none" data-view-component="true">
<div data-view-component="true" class="Banner flash Banner--error flash-error mb-2">
<div class="Banner-visual">
<svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-stop">
<path d="M4.47.22A.749.749 0 0 1 5 0h6c.199 0 .389.079.53.22l4.25 4.25c.141.14.22.331.22.53v6a.749.749 0 0 1-.22.53l-4.25 4.25A.749.749 0 0 1 11 16H5a.749.749 0 0 1-.53-.22L.22 11.53A.749.749 0 0 1 0 11V5c0-.199.079-.389.22-.53Zm.84 1.28L1.5 5.31v5.38l3.81 3.81h5.38l3.81-3.81V5.31L10.69 1.5ZM8 4a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0v-3.5A.75.75 0 0 1 8 4Zm0 8a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z"></path>
</svg>
</div>
<div data-view-component="true" class="Banner-message">
<p class="Banner-title" data-target="x-banner.titleText">
<h2 class="f6 text-normal">Sorry, something went wrong.</h2>
</p>
</div>
</div>
</x-banner> </div>
<remote-input aria-owns="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-body" data-target="select-panel.remoteInput" data-view-component="true">
<primer-text-field class="FormControl width-full FormControl--fullWidth">
<label for="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-filter" class="sr-only FormControl-label position-absolute sr-only FormControl-label">
Filter
</label>
<div class="FormControl-input-wrap FormControl-input-wrap--leadingVisual">
<span class="FormControl-input-leadingVisualWrap">
<svg data-target="primer-text-field.leadingVisual" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-search FormControl-input-leadingVisual">
<path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path>
</svg>
<span hidden="hidden" data-target="primer-text-field.leadingSpinner" data-view-component="true">
<svg style="box-sizing: content-box; color: var(--color-icon-primary);" width="16" height="16" viewBox="0 0 16 16" fill="none" aria-hidden="true" data-view-component="true" class="anim-rotate">
<circle cx="8" cy="8" r="7" stroke="currentColor" stroke-opacity="0.25" stroke-width="2" vector-effect="non-scaling-stroke" fill="none" />
<path d="M15 8a7.002 7.002 0 00-7-7" stroke="currentColor" stroke-width="2" stroke-linecap="round" vector-effect="non-scaling-stroke" />
</svg> <span class="sr-only">Loading</span>
</span>
</span>
<input id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-filter" type="search" autofocus="autofocus" data-target="primer-text-field.inputElement select-panel.filterInputTextField" aria-describedby="validation-8de24cf2-d199-4248-9a15-c8030d45e7d9" class="FormControl-input FormControl-medium" name="filter" />
</div>
<div class="FormControl-inlineValidation" id="validation-8de24cf2-d199-4248-9a15-c8030d45e7d9" hidden="hidden">
<span class="FormControl-inlineValidation--visual" data-target="primer-text-field.validationSuccessIcon" hidden><svg aria-hidden="true" height="12" viewBox="0 0 12 12" version="1.1" width="12" data-view-component="true" class="octicon octicon-check-circle-fill">
<path d="M6 0a6 6 0 1 1 0 12A6 6 0 0 1 6 0Zm-.705 8.737L9.63 4.403 8.392 3.166 5.295 6.263l-1.7-1.702L2.356 5.8l2.938 2.938Z"></path>
</svg></span>
<span class=" FormControl-inlineValidation--visual" data-target="primer-text-field.validationErrorIcon"><svg aria-hidden="true" height="12" viewBox="0 0 12 12" version="1.1" width="12" data-view-component="true" class="octicon octicon-alert-fill">
<path d="M4.855.708c.5-.896 1.79-.896 2.29 0l4.675 8.351a1.312 1.312 0 0 1-1.146 1.954H1.33A1.313 1.313 0 0 1 .183 9.058ZM7 7V3H5v4Zm-1 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2Z"></path>
</svg></span>
<span></span>
</div>
</primer-text-field>
</remote-input></div>
</div>
<div data-view-component="true" class="Overlay-body mt-0 p-0">
<focus-group direction="vertical" mnemonics retain>
<div class="sr-only" aria-live="polite" aria-atomic="true" data-target="select-panel.ariaLiveContainer"></div>
<div data-fetch-strategy="local" data-target="select-panel.list" data-view-component="true">
<div id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-body">
<action-list>
<div data-view-component="true">
<ul aria-label="Menu options" id="select-panel-2f9b83a6-aba1-4522-9146-7a9cee73b9de-list" role="listbox" data-view-component="true" class="ActionListWrap p-2"></ul>
</div>
</action-list>
</div>
<div data-target="select-panel.noResults" class="pt-2 color-border-muted text-center d-flex flex-items-start flex-justify-center SelectPanel-emptyPanel" hidden>
<h2 class="v-align-middle m-3 f5">No results found</h2>
</div>
</div>
</focus-group>
</div>
<div data-view-component="true" class="Overlay-footer Overlay-footer--alignEnd Overlay-footer--divided"> I'm a footer!
</div>
</dialog> </dialog-helper>
</select-panel>
<script>
function ready(fn) {
if (document.readyState !== 'loading') {
fn()
} else {
document.addEventListener('DOMContentLoaded', fn)
}
}
ready(() => {
const subject = document.querySelector("[data-interaction-subject='db7ff529579ade9d7699567ac6317276']")
if (!subject) return
const fetchStrategy = subject.getAttribute('data-fetch-strategy')
if (fetchStrategy === 'local') {
subject.setAttribute('data-ready', 'true')
return
}
subject.addEventListener('loadend', (event) => {
event.target.setAttribute('data-ready', 'true')
})
})
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<% subject_id = SecureRandom.hex %>
<%= render(Primer::Alpha::SelectPanel.new(
data: { interaction_subject: subject_id },
select_variant: :multiple,
fetch_strategy: :local,
open_on_load: open_on_load
)) do |panel| %>
<% panel.with_show_button { "Panel" } %>
<% panel.with_footer(show_divider: true) do %>
I'm a footer!
<% end %>
<% end %>
<%= render partial: "primer/alpha/select_panel_preview/interaction_subject_js", locals: { subject_id: subject_id } %>
Param Description Input

app/components/primer/alpha/select_panel.css

1
2
3
4
5
6
7
.SelectPanel-loadingPanel {
min-height: min(var(--overlay-height) - 10rem, 100vh - 2rem);
}
.SelectPanel-emptyPanel {
min-height: min(var(--overlay-height) - 10rem, 100vh - 2rem);
}