openproject-primer_view_components 0.38.0 → 0.39.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -0
- data/app/assets/javascripts/primer_view_components.js +1 -1
- data/app/assets/javascripts/primer_view_components.js.map +1 -1
- data/app/components/primer/alpha/select_panel.rb +16 -3
- data/app/components/primer/alpha/select_panel_element.js +3 -0
- data/app/components/primer/alpha/select_panel_element.ts +4 -0
- data/lib/primer/view_components/version.rb +1 -1
- data/previews/primer/alpha/select_panel_preview/playground.html.erb +5 -1
- data/static/arguments.json +22 -0
- data/static/audited_at.json +1 -0
- data/static/constants.json +3 -1
- data/static/info_arch.json +63 -0
- data/static/statuses.json +1 -0
- metadata +1 -1
@@ -250,10 +250,22 @@ module Primer
|
|
250
250
|
# )
|
251
251
|
# ```
|
252
252
|
class SelectPanel < Primer::Component
|
253
|
-
status :alpha
|
254
|
-
|
255
253
|
# The component that should be used to render the list of items in the body of a SelectPanel.
|
256
|
-
ItemList
|
254
|
+
class ItemList < Primer::Alpha::ActionList
|
255
|
+
# @param system_arguments [Hash] The arguments accepted by <%= link_to_component(Primer::Alpha::ActionList) %>.
|
256
|
+
def initialize(**system_arguments)
|
257
|
+
select_variant = system_arguments[:select_variant] || Primer::Alpha::ActionList::DEFAULT_SELECT_VARIANT
|
258
|
+
|
259
|
+
super(
|
260
|
+
p: 2,
|
261
|
+
role: "listbox",
|
262
|
+
aria_selection_variant: select_variant == :single ? :selected : :checked,
|
263
|
+
**system_arguments
|
264
|
+
)
|
265
|
+
end
|
266
|
+
end
|
267
|
+
|
268
|
+
status :alpha
|
257
269
|
|
258
270
|
DEFAULT_PRELOAD = false
|
259
271
|
|
@@ -328,6 +340,7 @@ module Primer
|
|
328
340
|
# @param open_on_load [Boolean] Open the panel when the page loads.
|
329
341
|
# @param anchor_align [Symbol] The anchor alignment of the Overlay. <%= one_of(Primer::Alpha::Overlay::ANCHOR_ALIGN_OPTIONS) %>
|
330
342
|
# @param anchor_side [Symbol] The side to anchor the Overlay to. <%= one_of(Primer::Alpha::Overlay::ANCHOR_SIDE_OPTIONS) %>
|
343
|
+
# @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
|
331
344
|
def initialize(
|
332
345
|
src: nil,
|
333
346
|
title: "Menu",
|
@@ -184,6 +184,9 @@ let SelectPanelElement = class SelectPanelElement extends HTMLElement {
|
|
184
184
|
const elem = entry.target;
|
185
185
|
if (entry.isIntersecting && elem === this.dialog) {
|
186
186
|
this.updateAnchorPosition();
|
187
|
+
if (__classPrivateFieldGet(this, _SelectPanelElement_instances, "a", _SelectPanelElement_fetchStrategy_get) === FetchStrategy.LOCAL) {
|
188
|
+
__classPrivateFieldGet(this, _SelectPanelElement_instances, "m", _SelectPanelElement_updateItemVisibility).call(this);
|
189
|
+
}
|
187
190
|
}
|
188
191
|
}
|
189
192
|
}), "f");
|
@@ -216,6 +216,10 @@ export class SelectPanelElement extends HTMLElement {
|
|
216
216
|
const elem = entry.target
|
217
217
|
if (entry.isIntersecting && elem === this.dialog) {
|
218
218
|
this.updateAnchorPosition()
|
219
|
+
|
220
|
+
if (this.#fetchStrategy === FetchStrategy.LOCAL) {
|
221
|
+
this.#updateItemVisibility()
|
222
|
+
}
|
219
223
|
}
|
220
224
|
}
|
221
225
|
})
|
@@ -5,7 +5,11 @@
|
|
5
5
|
|
6
6
|
<%= render(Primer::Alpha::SelectPanel.new(
|
7
7
|
data: { interaction_subject: subject_id },
|
8
|
-
src: select_panel_items_path(
|
8
|
+
src: select_panel_items_path(
|
9
|
+
select_variant: :single,
|
10
|
+
show_results: !simulate_no_results,
|
11
|
+
fail: simulate_failure
|
12
|
+
),
|
9
13
|
select_variant: :single,
|
10
14
|
fetch_strategy: :remote,
|
11
15
|
**system_arguments
|
data/static/arguments.json
CHANGED
@@ -2467,6 +2467,28 @@
|
|
2467
2467
|
"type": "Symbol",
|
2468
2468
|
"default": "`:outside_bottom`",
|
2469
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
|
+
"name": "system_arguments",
|
2473
|
+
"type": "Hash",
|
2474
|
+
"default": "N/A",
|
2475
|
+
"description": "[System arguments](/system-arguments)"
|
2476
|
+
}
|
2477
|
+
]
|
2478
|
+
},
|
2479
|
+
{
|
2480
|
+
"component": "SelectPanel::ItemList",
|
2481
|
+
"status": "alpha",
|
2482
|
+
"a11y_reviewed": true,
|
2483
|
+
"short_name": "SelectPanelItemList",
|
2484
|
+
"source": "https://github.com/primer/view_components/tree/main/app/components/primer/alpha/select_panel/item_list.rb",
|
2485
|
+
"lookbook": "https://primer.style/view-components/lookbook/inspect/primer/alpha/select_panel/item_list/default/",
|
2486
|
+
"parameters": [
|
2487
|
+
{
|
2488
|
+
"name": "system_arguments",
|
2489
|
+
"type": "Hash",
|
2490
|
+
"default": "N/A",
|
2491
|
+
"description": "The arguments accepted by [ActionList](/components/alpha/actionlist)."
|
2470
2492
|
}
|
2471
2493
|
]
|
2472
2494
|
},
|
data/static/audited_at.json
CHANGED
@@ -53,6 +53,7 @@
|
|
53
53
|
"Primer::Alpha::SegmentedControl::Item": "2023-02-01",
|
54
54
|
"Primer::Alpha::Select": "",
|
55
55
|
"Primer::Alpha::SelectPanel": "",
|
56
|
+
"Primer::Alpha::SelectPanel::ItemList": "2023-07-10",
|
56
57
|
"Primer::Alpha::SubmitButton": "",
|
57
58
|
"Primer::Alpha::TabContainer": "",
|
58
59
|
"Primer::Alpha::TabNav": "",
|
data/static/constants.json
CHANGED
@@ -606,13 +606,15 @@
|
|
606
606
|
"eventually_local",
|
607
607
|
"local"
|
608
608
|
],
|
609
|
-
"ItemList": "Primer::Alpha::
|
609
|
+
"ItemList": "Primer::Alpha::SelectPanel::ItemList",
|
610
610
|
"SELECT_VARIANT_OPTIONS": [
|
611
611
|
"single",
|
612
612
|
"multiple",
|
613
613
|
"none"
|
614
614
|
]
|
615
615
|
},
|
616
|
+
"Primer::Alpha::SelectPanel::ItemList": {
|
617
|
+
},
|
616
618
|
"Primer::Alpha::SubmitButton": {
|
617
619
|
},
|
618
620
|
"Primer::Alpha::TabContainer": {
|
data/static/info_arch.json
CHANGED
@@ -7630,6 +7630,12 @@
|
|
7630
7630
|
"type": "Symbol",
|
7631
7631
|
"default": "`:outside_bottom`",
|
7632
7632
|
"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`."
|
7633
|
+
},
|
7634
|
+
{
|
7635
|
+
"name": "system_arguments",
|
7636
|
+
"type": "Hash",
|
7637
|
+
"default": "N/A",
|
7638
|
+
"description": "{{link_to_system_arguments_docs}}"
|
7633
7639
|
}
|
7634
7640
|
],
|
7635
7641
|
"slots": [
|
@@ -8080,7 +8086,64 @@
|
|
8080
8086
|
}
|
8081
8087
|
],
|
8082
8088
|
"subcomponents": [
|
8089
|
+
{
|
8090
|
+
"fully_qualified_name": "Primer::Alpha::SelectPanel::ItemList",
|
8091
|
+
"description": "The component that should be used to render the list of items in the body of a SelectPanel.",
|
8092
|
+
"accessibility_docs": null,
|
8093
|
+
"is_form_component": false,
|
8094
|
+
"is_published": true,
|
8095
|
+
"requires_js": true,
|
8096
|
+
"component": "SelectPanel::ItemList",
|
8097
|
+
"status": "alpha",
|
8098
|
+
"a11y_reviewed": true,
|
8099
|
+
"short_name": "SelectPanelItemList",
|
8100
|
+
"source": "https://github.com/primer/view_components/tree/main/app/components/primer/alpha/select_panel/item_list.rb",
|
8101
|
+
"lookbook": "https://primer.style/view-components/lookbook/inspect/primer/alpha/select_panel/item_list/default/",
|
8102
|
+
"parameters": [
|
8103
|
+
{
|
8104
|
+
"name": "system_arguments",
|
8105
|
+
"type": "Hash",
|
8106
|
+
"default": "N/A",
|
8107
|
+
"description": "The arguments accepted by {{#link_to_component}}Primer::Alpha::ActionList{{/link_to_component}}."
|
8108
|
+
}
|
8109
|
+
],
|
8110
|
+
"slots": [
|
8111
|
+
{
|
8112
|
+
"name": "heading",
|
8113
|
+
"description": "Heading text rendered above the list of items.",
|
8114
|
+
"parameters": [
|
8115
|
+
{
|
8116
|
+
"name": "component_klass",
|
8117
|
+
"type": "Class",
|
8118
|
+
"default": "N/A",
|
8119
|
+
"description": "The class to use instead of the default {{#link_to_component}}Primer::Alpha::ActionList::Heading{{/link_to_component}}."
|
8120
|
+
},
|
8121
|
+
{
|
8122
|
+
"name": "system_arguments",
|
8123
|
+
"type": "Hash",
|
8124
|
+
"default": "N/A",
|
8125
|
+
"description": "The arguments accepted by `component_klass`."
|
8126
|
+
}
|
8127
|
+
]
|
8128
|
+
},
|
8129
|
+
{
|
8130
|
+
"name": "items",
|
8131
|
+
"description": "Items. Items can be individual items, avatar items, or dividers. See the documentation for `#with_item`, `#with_divider`, and `#with_avatar_item` respectively for more information.",
|
8132
|
+
"parameters": [
|
8133
|
+
|
8134
|
+
]
|
8135
|
+
}
|
8136
|
+
],
|
8137
|
+
"methods": [
|
8138
|
+
|
8139
|
+
],
|
8140
|
+
"previews": [
|
8083
8141
|
|
8142
|
+
],
|
8143
|
+
"subcomponents": [
|
8144
|
+
|
8145
|
+
]
|
8146
|
+
}
|
8084
8147
|
]
|
8085
8148
|
},
|
8086
8149
|
{
|
data/static/statuses.json
CHANGED
@@ -53,6 +53,7 @@
|
|
53
53
|
"Primer::Alpha::SegmentedControl::Item": "alpha",
|
54
54
|
"Primer::Alpha::Select": "alpha",
|
55
55
|
"Primer::Alpha::SelectPanel": "alpha",
|
56
|
+
"Primer::Alpha::SelectPanel::ItemList": "alpha",
|
56
57
|
"Primer::Alpha::SubmitButton": "alpha",
|
57
58
|
"Primer::Alpha::TabContainer": "alpha",
|
58
59
|
"Primer::Alpha::TabNav": "alpha",
|