playbook_ui_docs 14.21.2 → 14.22.0.pre.alpha.PLAY2132phonenumberinputvalidationtooaggressive8863
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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_sort.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_subrow_headers.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.jsx +51 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.md +7 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers.jsx +77 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers_rails.html.erb +63 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers_rails.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.html.erb +38 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.md +7 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_custom_sort.jsx +65 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_custom_sort.md +5 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_infinite_scroll.md +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_loading.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pinned_rows.jsx +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pinned_rows_react.md +5 -3
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_row_styling.jsx +64 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_row_styling.md +7 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions.jsx +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions_rails.html.erb +3 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header.jsx +69 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +8 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +6 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_colors.jsx +33 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_default.jsx +33 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_height.jsx +52 -22
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_height.md +3 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_horizontal.jsx +12 -16
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend.jsx +31 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend_non_clickable.jsx +39 -16
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend_position.jsx +86 -38
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_negative_numbers.jsx +32 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_secondary_y_axis.jsx +72 -22
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_secondary_y_axis.md +1 -1
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_spline.jsx +31 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_stacked.jsx +37 -16
- data/app/pb_kits/playbook/pb_bar_graph/docs/_description.md +1 -3
- data/app/pb_kits/playbook/pb_bar_graph/docs/example.yml +1 -3
- data/app/pb_kits/playbook/pb_bar_graph/docs/index.js +0 -2
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_block.jsx +71 -26
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_colors.jsx +29 -16
- data/app/pb_kits/playbook/pb_circle_chart/docs/{_circle_chart_colors.md → _circle_chart_colors_rails.md} +1 -1
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_colors_react.md +2 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_custom_tooltip.jsx +28 -16
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_custom_tooltip.md +4 -2
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_default.jsx +23 -15
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_inner_sizes.jsx +81 -51
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_legend_position.jsx +103 -75
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_legend_position.md +3 -6
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_live_data.jsx +19 -13
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_rounded.jsx +30 -17
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_with_labels.jsx +34 -20
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_with_legend_kit.jsx +29 -20
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_with_title.jsx +28 -20
- data/app/pb_kits/playbook/pb_circle_chart/docs/_description.md +1 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/example.yml +0 -1
- data/app/pb_kits/playbook/pb_circle_chart/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_blank_selection.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_blank_selection.jsx +7 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_clear_selection.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_value.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_value.jsx +7 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.jsx +7 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select.jsx +19 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display.jsx +19 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display_rails.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_rails.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.jsx +20 -11
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.jsx +8 -8
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.jsx +23 -14
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_separators_hidden.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_separators_hidden.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subtle_variant.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subtle_variant.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.html.erb +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.jsx +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options.html.erb +52 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options.jsx +99 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options_rails.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options_react.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options.html.erb +28 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options.jsx +47 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options_rails.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options_react.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_external_control.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +4 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/index.js +3 -1
- data/app/pb_kits/playbook/pb_filter/docs/_filter_sidebar.jsx +224 -0
- data/app/pb_kits/playbook/pb_filter/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_filter/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.html.erb +8 -8
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.jsx +8 -8
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_rails.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_react.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.html.erb +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.jsx +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md +2 -2
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_react.md +3 -3
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.html.erb +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.jsx +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_rails.md +2 -2
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_react.md +3 -3
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open.html.erb +14 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open.jsx +25 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open_rails.md +1 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open_react.md +1 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input.html.erb +18 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input_rails.md +1 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +1 -0
- data/dist/playbook-doc.js +3 -3
- metadata +37 -28
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.jsx +0 -72
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.md +0 -6
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_pb_styles.jsx +0 -64
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_pb_styles.md +0 -1
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_pb_styles.jsx +0 -38
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_pb_styles.md +0 -1
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_description.md +0 -5
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_colors.html.erb +0 -37
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_colors.jsx +0 -48
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_colors.md +0 -2
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_default.html.erb +0 -37
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_default.jsx +0 -47
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_default.md +0 -3
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_drillable.html.erb +0 -79
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_drillable.jsx +0 -90
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_drillable.md +0 -1
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_grouped_data.html.erb +0 -54
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_grouped_data.jsx +0 -65
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_grouped_data.md +0 -3
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_tooltip.html.erb +0 -37
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_tooltip.jsx +0 -48
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_tooltip.md +0 -3
- data/app/pb_kits/playbook/pb_treemap_chart/docs/example.yml +0 -15
- data/app/pb_kits/playbook/pb_treemap_chart/docs/index.js +0 -5
- /data/app/pb_kits/playbook/pb_typeahead/docs/{_typeahead_preserve_input.md → _typeahead_preserve_input_react.md} +0 -0
@@ -2,21 +2,21 @@
|
|
2
2
|
options = [
|
3
3
|
{
|
4
4
|
label: "United States",
|
5
|
-
value: "
|
5
|
+
value: "unitedStates",
|
6
6
|
areaCode: "+1",
|
7
7
|
icon: "🇺🇸",
|
8
8
|
id: "us"
|
9
9
|
},
|
10
10
|
{
|
11
11
|
label: "Canada",
|
12
|
-
value: "
|
12
|
+
value: "canada",
|
13
13
|
areaCode: "+1",
|
14
14
|
icon: "🇨🇦",
|
15
15
|
id: "ca"
|
16
16
|
},
|
17
17
|
{
|
18
18
|
label: "Pakistan",
|
19
|
-
value: "
|
19
|
+
value: "pakistan",
|
20
20
|
areaCode: "+92",
|
21
21
|
icon: "🇵🇰",
|
22
22
|
id: "pk"
|
@@ -1,8 +1,8 @@
|
|
1
1
|
<%
|
2
2
|
options = [
|
3
|
-
{ label: 'United States', value: '
|
4
|
-
{ label: 'Canada', value: '
|
5
|
-
{ label: 'Pakistan', value: '
|
3
|
+
{ label: 'United States', value: 'unitedStates', id: 'us' },
|
4
|
+
{ label: 'Canada', value: 'canada', id: 'ca' },
|
5
|
+
{ label: 'Pakistan', value: 'pakistan', id: 'pk' },
|
6
6
|
]
|
7
7
|
|
8
8
|
%>
|
@@ -6,21 +6,21 @@ const DropdownWithCustomPadding = (props) => {
|
|
6
6
|
const options = [
|
7
7
|
{
|
8
8
|
label: "United States",
|
9
|
-
value: "
|
9
|
+
value: "unitedStates",
|
10
10
|
areaCode: "+1",
|
11
11
|
icon: "🇺🇸",
|
12
12
|
id: "United-states"
|
13
13
|
},
|
14
14
|
{
|
15
15
|
label: "Canada",
|
16
|
-
value: "
|
16
|
+
value: "canada",
|
17
17
|
areaCode: "+1",
|
18
18
|
icon: "🇨🇦",
|
19
19
|
id: "canada"
|
20
20
|
},
|
21
21
|
{
|
22
22
|
label: "Pakistan",
|
23
|
-
value: "
|
23
|
+
value: "pakistan",
|
24
24
|
areaCode: "+92",
|
25
25
|
icon: "🇵🇰",
|
26
26
|
id: "pakistan"
|
@@ -0,0 +1,28 @@
|
|
1
|
+
<%
|
2
|
+
options = [
|
3
|
+
{ label: "Item 1", value: "item-1", id: "1" },
|
4
|
+
{ label: "Item 2", value: "item-2", id: "2" },
|
5
|
+
{ label: "Item 3", value: "item-3", id: "3" }
|
6
|
+
]
|
7
|
+
|
8
|
+
selected_value = params[:selected_value]
|
9
|
+
%>
|
10
|
+
|
11
|
+
<%= pb_rails("dropdown", props: { label: "Choose Item", options: options }) do %>
|
12
|
+
<%= pb_rails("dropdown/dropdown_trigger") %>
|
13
|
+
<%= pb_rails("dropdown/dropdown_container") do %>
|
14
|
+
<% options.each do |option| %>
|
15
|
+
<% checked = (option[:value] == selected_value) %>
|
16
|
+
<%= pb_rails("dropdown/dropdown_option", props: { option: option }) do %>
|
17
|
+
<%= pb_rails("flex", props: { align: "center" }) do %>
|
18
|
+
<%= pb_rails("radio", props: {
|
19
|
+
text: option[:label],
|
20
|
+
name: "dropdown_radio",
|
21
|
+
value: option[:value],
|
22
|
+
checked: checked,
|
23
|
+
}) %>
|
24
|
+
<% end %>
|
25
|
+
<% end %>
|
26
|
+
<% end %>
|
27
|
+
<% end %>
|
28
|
+
<% end %>
|
@@ -0,0 +1,47 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import Dropdown from '../_dropdown'
|
3
|
+
|
4
|
+
import Body from '../../pb_body/_body'
|
5
|
+
import Flex from '../../pb_flex/_flex'
|
6
|
+
import Radio from '../../pb_radio/_radio'
|
7
|
+
|
8
|
+
const DropdownCustomRadioOptions = (props) => {
|
9
|
+
const [selectedValue, setSelectedValue] = useState(null)
|
10
|
+
|
11
|
+
const options = [
|
12
|
+
{ label: "Item 1", value: "item-1", id: "1" },
|
13
|
+
{ label: "Item 2", value: "item-2", id: "2" },
|
14
|
+
{ label: "Item 3", value: "item-3", id: "3" },
|
15
|
+
]
|
16
|
+
|
17
|
+
|
18
|
+
return (
|
19
|
+
<div>
|
20
|
+
<Dropdown
|
21
|
+
label="Select Item"
|
22
|
+
onSelect={(selectedItem) => setSelectedValue(selectedItem?.value)}
|
23
|
+
options={options}
|
24
|
+
{...props}
|
25
|
+
>
|
26
|
+
{options.map((option) => {
|
27
|
+
return (
|
28
|
+
<Dropdown.Option key={option.id}
|
29
|
+
option={option}
|
30
|
+
>
|
31
|
+
<Flex align="center">
|
32
|
+
<Radio
|
33
|
+
checked={selectedValue === option.value}
|
34
|
+
name="dropdown_radio"
|
35
|
+
value={option.value}
|
36
|
+
/>
|
37
|
+
<Body text={option.label} />
|
38
|
+
</Flex>
|
39
|
+
</Dropdown.Option>
|
40
|
+
)
|
41
|
+
})}
|
42
|
+
</Dropdown>
|
43
|
+
</div>
|
44
|
+
)
|
45
|
+
}
|
46
|
+
|
47
|
+
export default DropdownCustomRadioOptions
|
@@ -0,0 +1 @@
|
|
1
|
+
Radio inputs can be used inside `dropdown/dropdown_option` for a custom layout that mimics form-like selection within a dropdown.
|
@@ -0,0 +1 @@
|
|
1
|
+
Radio inputs can be used inside `Dropdown.Option` for a custom layout that mimics form-like selection within a dropdown.
|
@@ -14,21 +14,21 @@ const [selectedOption, setSelectedOption] = useState();
|
|
14
14
|
const options = [
|
15
15
|
{
|
16
16
|
label: "United States",
|
17
|
-
value: "
|
17
|
+
value: "unitedStates",
|
18
18
|
areaCode: "+1",
|
19
19
|
icon: "🇺🇸",
|
20
20
|
id: "United-states"
|
21
21
|
},
|
22
22
|
{
|
23
23
|
label: "Canada",
|
24
|
-
value: "
|
24
|
+
value: "canada",
|
25
25
|
areaCode: "+1",
|
26
26
|
icon: "🇨🇦",
|
27
27
|
id: "canada"
|
28
28
|
},
|
29
29
|
{
|
30
30
|
label: "Pakistan",
|
31
|
-
value: "
|
31
|
+
value: "pakistan",
|
32
32
|
areaCode: "+92",
|
33
33
|
icon: "🇵🇰",
|
34
34
|
id: "pakistan"
|
@@ -2,21 +2,21 @@
|
|
2
2
|
options = [
|
3
3
|
{
|
4
4
|
label: "United States",
|
5
|
-
value: "
|
5
|
+
value: "unitedStates",
|
6
6
|
areaCode: "+1",
|
7
7
|
icon: "🇺🇸",
|
8
8
|
id: "us"
|
9
9
|
},
|
10
10
|
{
|
11
11
|
label: "Canada",
|
12
|
-
value: "
|
12
|
+
value: "canada",
|
13
13
|
areaCode: "+1",
|
14
14
|
icon: "🇨🇦",
|
15
15
|
id: "ca"
|
16
16
|
},
|
17
17
|
{
|
18
18
|
label: "Pakistan",
|
19
|
-
value: "
|
19
|
+
value: "pakistan",
|
20
20
|
areaCode: "+92",
|
21
21
|
icon: "🇵🇰",
|
22
22
|
id: "pk"
|
@@ -11,21 +11,21 @@ const [isDropDownClosed, setIsDropdownClosed] = useDropdown(true);
|
|
11
11
|
const options = [
|
12
12
|
{
|
13
13
|
label: "United States",
|
14
|
-
value: "
|
14
|
+
value: "unitedStates",
|
15
15
|
areaCode: "+1",
|
16
16
|
icon: "🇺🇸",
|
17
17
|
id: "United-states"
|
18
18
|
},
|
19
19
|
{
|
20
20
|
label: "Canada",
|
21
|
-
value: "
|
21
|
+
value: "canada",
|
22
22
|
areaCode: "+1",
|
23
23
|
icon: "🇨🇦",
|
24
24
|
id: "canada"
|
25
25
|
},
|
26
26
|
{
|
27
27
|
label: "Pakistan",
|
28
|
-
value: "
|
28
|
+
value: "pakistan",
|
29
29
|
areaCode: "+92",
|
30
30
|
icon: "🇵🇰",
|
31
31
|
id: "pakistan"
|
@@ -1,8 +1,8 @@
|
|
1
1
|
<%
|
2
2
|
options = [
|
3
|
-
{ label: 'United States', value: '
|
4
|
-
{ label: 'Canada', value: '
|
5
|
-
{ label: 'Pakistan', value: '
|
3
|
+
{ label: 'United States', value: 'unitedStates', id: 'us' },
|
4
|
+
{ label: 'Canada', value: 'canada', id: 'ca' },
|
5
|
+
{ label: 'Pakistan', value: 'pakistan', id: 'pk' },
|
6
6
|
]
|
7
7
|
|
8
8
|
%>
|
@@ -6,15 +6,18 @@ const DropdownDefault = (props) => {
|
|
6
6
|
const options = [
|
7
7
|
{
|
8
8
|
label: "United States",
|
9
|
-
value: "
|
9
|
+
value: "unitedStates",
|
10
|
+
id: "us"
|
10
11
|
},
|
11
12
|
{
|
12
13
|
label: "Canada",
|
13
|
-
value: "
|
14
|
+
value: "canada",
|
15
|
+
id: "ca"
|
14
16
|
},
|
15
17
|
{
|
16
18
|
label: "Pakistan",
|
17
|
-
value: "
|
19
|
+
value: "pakistan",
|
20
|
+
id: "pk"
|
18
21
|
}
|
19
22
|
];
|
20
23
|
|
@@ -8,20 +8,20 @@ const [selectedOption, setSelectedOption] = useState();
|
|
8
8
|
const options = [
|
9
9
|
{
|
10
10
|
label: "United States",
|
11
|
-
value: "
|
11
|
+
value: "unitedStates",
|
12
12
|
icon: "🇺🇸",
|
13
13
|
id: "United-states"
|
14
14
|
|
15
15
|
},
|
16
16
|
{
|
17
17
|
label: "United Kingdom",
|
18
|
-
value: "
|
18
|
+
value: "unitedKingdom",
|
19
19
|
icon: "🇬🇧",
|
20
20
|
id: "united-kingdom"
|
21
21
|
},
|
22
22
|
{
|
23
23
|
label: "Pakistan",
|
24
|
-
value: "
|
24
|
+
value: "pakistan",
|
25
25
|
icon: "🇵🇰",
|
26
26
|
id: "pakistan"
|
27
27
|
}
|
@@ -2,21 +2,21 @@
|
|
2
2
|
options = [
|
3
3
|
{
|
4
4
|
label: "United States",
|
5
|
-
value: "
|
5
|
+
value: "unitedStates",
|
6
6
|
areaCode: "+1",
|
7
7
|
icon: "🇺🇸",
|
8
8
|
id: "us"
|
9
9
|
},
|
10
10
|
{
|
11
11
|
label: "United Kingdom",
|
12
|
-
value: "
|
12
|
+
value: "unitedKingdom",
|
13
13
|
areaCode: "+44",
|
14
14
|
icon: "🇬🇧",
|
15
15
|
id: "gb"
|
16
16
|
},
|
17
17
|
{
|
18
18
|
label: "Pakistan",
|
19
|
-
value: "
|
19
|
+
value: "pakistan",
|
20
20
|
areaCode: "+92",
|
21
21
|
icon: "🇵🇰",
|
22
22
|
id: "pk"
|
@@ -15,6 +15,8 @@ examples:
|
|
15
15
|
- dropdown_with_custom_trigger_rails: Custom Trigger
|
16
16
|
- dropdown_with_search_rails: Custom Trigger Dropdown with Search
|
17
17
|
- dropdown_with_custom_padding: Custom Option Padding
|
18
|
+
- dropdown_with_custom_icon_options: Custom Icon Options
|
19
|
+
# - dropdown_with_custom_radio_options: Custom Radio Options # TODO: Update and publish doc ex in [PLAY-2146](https://runway.powerhrg.com/backlog_items/PLAY-2146) (remove this comment afterwards)
|
18
20
|
- dropdown_error: Dropdown with Error
|
19
21
|
- dropdown_default_value: Default Value
|
20
22
|
- dropdown_multi_select_with_default: Multi Select Default Value
|
@@ -37,6 +39,8 @@ examples:
|
|
37
39
|
- dropdown_with_custom_trigger: Custom Trigger
|
38
40
|
- dropdown_with_search: Custom Trigger Dropdown with Search
|
39
41
|
- dropdown_with_custom_padding: Custom Option Padding
|
42
|
+
- dropdown_with_custom_icon_options: Custom Icon Options
|
43
|
+
# - dropdown_with_custom_radio_options: Custom Radio Options # TODO: Update and publish doc ex in [PLAY-2146](https://runway.powerhrg.com/backlog_items/PLAY-2146) (remove this comment afterwards)
|
40
44
|
- dropdown_error: Dropdown with Error
|
41
45
|
- dropdown_default_value: Default Value
|
42
46
|
- dropdown_multi_select_with_default: Multi Select Default Value
|
@@ -19,4 +19,6 @@ export { default as DropdownMultiSelect } from './_dropdown_multi_select.jsx'
|
|
19
19
|
export { default as DropdownMultiSelectDisplay } from './_dropdown_multi_select_display.jsx'
|
20
20
|
export { default as DropdownMultiSelectWithAutocomplete } from './_dropdown_multi_select_with_autocomplete.jsx'
|
21
21
|
export { default as DropdownMultiSelectWithDefault } from './_dropdown_multi_select_with_default.jsx'
|
22
|
-
export { default as DropdownMultiSelectWithCustomOptions } from './_dropdown_multi_select_with_custom_options.jsx'
|
22
|
+
export { default as DropdownMultiSelectWithCustomOptions } from './_dropdown_multi_select_with_custom_options.jsx'
|
23
|
+
export {default as DropdownWithCustomIconOptions} from './_dropdown_with_custom_icon_options.jsx'
|
24
|
+
export {default as DropdownWithCustomRadioOptions} from './_dropdown_with_custom_radio_options.jsx'
|
@@ -0,0 +1,224 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
|
3
|
+
import Filter from '../../pb_filter/_filter'
|
4
|
+
import Select from '../../pb_select/_select'
|
5
|
+
import TextInput from '../../pb_text_input/_text_input'
|
6
|
+
import useCollapsible from '../../pb_collapsible/useCollapsible'
|
7
|
+
import SectionSeparator from '../../pb_section_separator/_section_separator'
|
8
|
+
import Checkbox from '../../pb_checkbox/_checkbox'
|
9
|
+
import Flex from '../../pb_flex/_flex'
|
10
|
+
import Table from '../../pb_table/_table'
|
11
|
+
import Caption from '../../pb_caption/_caption'
|
12
|
+
import Icon from '../../pb_icon/_icon'
|
13
|
+
|
14
|
+
const people = [
|
15
|
+
{ name: 'Hera Syndulla', territory: 'A galaxy far far away, like really far away...', products: ['Insulation'] },
|
16
|
+
{ name: 'Kanan Jarrus', territory: 'USA', products: ['Siding', 'Roofing', 'Gutters'] },
|
17
|
+
{ name: 'C1-10P', territory: 'USA', products: ['Roofing'] },
|
18
|
+
{ name: 'Anakin Skywalker', territory: 'A galaxy far far away, like really far away...', products: ['Doors', 'Windows', 'Solar'] },
|
19
|
+
{ name: 'Leia Organa', territory: 'Canada', products: ['Windows', 'Doors'] },
|
20
|
+
{ name: 'Luke Skywalker', territory: 'Brazil', products: ['Solar', 'Roofing'] },
|
21
|
+
{ name: 'Padmé Amidala', territory: 'Philippines', products: ['Siding', 'Gutters'] },
|
22
|
+
{ name: 'Obi-Wan Kenobi', territory: 'USA', products: ['Windows', 'Siding'] },
|
23
|
+
{ name: 'Ahsoka Tano', territory: 'Canada', products: ['Insulation', 'Solar'] },
|
24
|
+
{ name: 'Boba Fett', territory: 'Brazil', products: ['Roofing', 'Gutters'] },
|
25
|
+
{ name: 'Mace Windu', territory: 'Philippines', products: ['Doors', 'Siding'] },
|
26
|
+
{ name: 'Grogu', territory: 'A galaxy far far away, like really far away...', products: ['Insulation'] },
|
27
|
+
{ name: 'Sabine Wren', territory: 'Canada', products: ['Solar', 'Doors'] },
|
28
|
+
{ name: 'C-3PO', territory: 'Brazil', products: ['Windows'] },
|
29
|
+
{ name: 'R2-D2', territory: 'Philippines', products: ['Doors', 'Gutters'] },
|
30
|
+
]
|
31
|
+
|
32
|
+
const FilterSidebar = (props) => {
|
33
|
+
const [name, setName] = useState('')
|
34
|
+
const [ territory, setTerritory ] = useState('')
|
35
|
+
const [ products, setProducts ] = useState({})
|
36
|
+
const handleUpdateName = ({ target }) => {
|
37
|
+
setName(target.value)
|
38
|
+
}
|
39
|
+
const handleUpdateTerritory = ({ target }) => {
|
40
|
+
setTerritory(target.value)
|
41
|
+
}
|
42
|
+
const handleCheckboxChange = ({ target }) => {
|
43
|
+
setProducts(prev => ({
|
44
|
+
...prev,
|
45
|
+
[target.name]: !prev[target.name],
|
46
|
+
}))
|
47
|
+
}
|
48
|
+
const [isCollapsed, setIsCollapsed] = useCollapsible(true)
|
49
|
+
const [isProductsCollapsed, setIsProductsCollapsed] = useCollapsible(true)
|
50
|
+
const options = [
|
51
|
+
{ value: 'USA' },
|
52
|
+
{ value: 'Canada' },
|
53
|
+
{ value: 'Brazil' },
|
54
|
+
{ value: 'Philippines' },
|
55
|
+
{ value: 'A galaxy far far away, like really far away...' },
|
56
|
+
]
|
57
|
+
|
58
|
+
const filteredPeople = people.filter((person) => {
|
59
|
+
const matchesName = person.name.toLowerCase().includes(name.toLowerCase())
|
60
|
+
|
61
|
+
const matchesTerritory = territory === '' ? true : person.territory === territory
|
62
|
+
|
63
|
+
const matchesProducts = Object.values(products).every((product) => !product) ? true : person.products.some(product => products[product])
|
64
|
+
|
65
|
+
return matchesName && matchesTerritory && matchesProducts
|
66
|
+
})
|
67
|
+
|
68
|
+
return (
|
69
|
+
<>
|
70
|
+
<Flex>
|
71
|
+
<Filter
|
72
|
+
isCollapsed={isCollapsed}
|
73
|
+
marginRight="xs"
|
74
|
+
onCollapse={() => setIsCollapsed(!isCollapsed)}
|
75
|
+
results={filteredPeople.length}
|
76
|
+
sortOptions={{
|
77
|
+
popularity: 'Popularity',
|
78
|
+
// eslint-disable-next-line
|
79
|
+
manager_title: 'Manager\'s Title',
|
80
|
+
// eslint-disable-next-line
|
81
|
+
manager_name: 'Manager\'s Name',
|
82
|
+
}}
|
83
|
+
sortValue={[{ name: 'popularity', dir: 'desc' }]}
|
84
|
+
variant="sidebar"
|
85
|
+
width="xs"
|
86
|
+
{...props}
|
87
|
+
>
|
88
|
+
<Filter.Section
|
89
|
+
collapsed={isCollapsed}
|
90
|
+
headerText="Full Name"
|
91
|
+
>
|
92
|
+
<TextInput
|
93
|
+
onChange={handleUpdateName}
|
94
|
+
placeholder="Enter name"
|
95
|
+
value={name}
|
96
|
+
{...props}
|
97
|
+
/>
|
98
|
+
</Filter.Section>
|
99
|
+
<SectionSeparator />
|
100
|
+
<Filter.Section
|
101
|
+
collapsed={isCollapsed}
|
102
|
+
collapsible
|
103
|
+
headerText="Territory"
|
104
|
+
>
|
105
|
+
<Select
|
106
|
+
blankSelection="Select One..."
|
107
|
+
name="location"
|
108
|
+
onChange={handleUpdateTerritory}
|
109
|
+
options={options}
|
110
|
+
{...props}
|
111
|
+
/>
|
112
|
+
</Filter.Section>
|
113
|
+
<SectionSeparator />
|
114
|
+
<Filter.Section
|
115
|
+
collapsed={isCollapsed}
|
116
|
+
collapsible
|
117
|
+
headerText="Products"
|
118
|
+
>
|
119
|
+
<div>
|
120
|
+
<Checkbox
|
121
|
+
marginBottom="sm"
|
122
|
+
name="Doors"
|
123
|
+
onChange={handleCheckboxChange}
|
124
|
+
text="Doors"
|
125
|
+
/>
|
126
|
+
</div>
|
127
|
+
<div>
|
128
|
+
<Checkbox
|
129
|
+
marginBottom="sm"
|
130
|
+
name="Windows"
|
131
|
+
onChange={handleCheckboxChange}
|
132
|
+
text="Windows"
|
133
|
+
/>
|
134
|
+
</div>
|
135
|
+
<div>
|
136
|
+
<Checkbox
|
137
|
+
marginBottom="sm"
|
138
|
+
name="Siding"
|
139
|
+
onChange={handleCheckboxChange}
|
140
|
+
text="Siding"
|
141
|
+
/>
|
142
|
+
</div>
|
143
|
+
{!isProductsCollapsed &&
|
144
|
+
<>
|
145
|
+
<div>
|
146
|
+
<Checkbox
|
147
|
+
checked={products["Roofing"]}
|
148
|
+
marginBottom="sm"
|
149
|
+
name="Roofing"
|
150
|
+
onChange={handleCheckboxChange}
|
151
|
+
text="Roofing"
|
152
|
+
/>
|
153
|
+
</div>
|
154
|
+
<div>
|
155
|
+
<Checkbox
|
156
|
+
checked={products["Gutters"]}
|
157
|
+
marginBottom="sm"
|
158
|
+
name="Gutters"
|
159
|
+
onChange={handleCheckboxChange}
|
160
|
+
text="Gutters"
|
161
|
+
/>
|
162
|
+
</div>
|
163
|
+
<div>
|
164
|
+
<Checkbox
|
165
|
+
checked={products["Solar"]}
|
166
|
+
marginBottom="sm"
|
167
|
+
name="Solar"
|
168
|
+
onChange={handleCheckboxChange}
|
169
|
+
text="Solar"
|
170
|
+
/>
|
171
|
+
</div>
|
172
|
+
<div>
|
173
|
+
<Checkbox
|
174
|
+
checked={products["Insulation"]}
|
175
|
+
marginBottom="sm"
|
176
|
+
name="Insulation"
|
177
|
+
onChange={handleCheckboxChange}
|
178
|
+
text="Insulation"
|
179
|
+
/>
|
180
|
+
</div>
|
181
|
+
</>
|
182
|
+
}
|
183
|
+
<div onClick={() => setIsProductsCollapsed(!isProductsCollapsed)}>
|
184
|
+
<Flex
|
185
|
+
cursor="pointer"
|
186
|
+
marginBottom="sm"
|
187
|
+
>
|
188
|
+
<Caption
|
189
|
+
color="link"
|
190
|
+
marginRight="xxs"
|
191
|
+
size="xs"
|
192
|
+
text={isProductsCollapsed ? "Show More" : "Show Less"}
|
193
|
+
/>
|
194
|
+
<Icon
|
195
|
+
icon={isProductsCollapsed ? "chevron-down" : "chevron-up"}
|
196
|
+
/>
|
197
|
+
</Flex>
|
198
|
+
</div>
|
199
|
+
</Filter.Section>
|
200
|
+
</Filter>
|
201
|
+
<Table
|
202
|
+
size="sm"
|
203
|
+
>
|
204
|
+
<thead>
|
205
|
+
<tr>
|
206
|
+
<th>{'Name'}</th>
|
207
|
+
<th>{'Territory'}</th>
|
208
|
+
<th>{'Products'}</th>
|
209
|
+
</tr>
|
210
|
+
</thead>
|
211
|
+
<tbody>
|
212
|
+
{filteredPeople.map((person) => (<tr key={person.name}>
|
213
|
+
<td>{ person.name }</td>
|
214
|
+
<td>{ person.territory }</td>
|
215
|
+
<td>{ person.products.join(", ") }</td>
|
216
|
+
</tr>))}
|
217
|
+
</tbody>
|
218
|
+
</Table>
|
219
|
+
</Flex>
|
220
|
+
</>
|
221
|
+
)
|
222
|
+
}
|
223
|
+
|
224
|
+
export default FilterSidebar
|
@@ -8,3 +8,4 @@ export { default as FilterMaxWidth } from './_filter_max_width.jsx'
|
|
8
8
|
export { default as FilterMaxHeight } from './_filter_max_height.jsx'
|
9
9
|
export { default as FilterPlacement } from './_filter_placement.jsx'
|
10
10
|
export { default as FilterPopoverProps } from './_filter_popover_props.jsx'
|
11
|
+
export { default as FilterSidebar } from './_filter_sidebar.jsx'
|
@@ -1,7 +1,7 @@
|
|
1
1
|
<%= pb_rails("table", props: { size: "md", responsive: "scroll", sticky_left_column: ["a"], sticky_right_column: ["b"] }) do %>
|
2
2
|
<thead>
|
3
3
|
<tr>
|
4
|
-
<th id="a">Column 1</th>
|
4
|
+
<th data-sticky-id="a">Column 1</th>
|
5
5
|
<th>Column 2</th>
|
6
6
|
<th>Column 3</th>
|
7
7
|
<th>Column 4</th>
|
@@ -15,12 +15,12 @@
|
|
15
15
|
<th>Column 12</th>
|
16
16
|
<th>Column 13</th>
|
17
17
|
<th>Column 14</th>
|
18
|
-
<th id="b">Column 15</th>
|
18
|
+
<th data-sticky-id="b">Column 15</th>
|
19
19
|
</tr>
|
20
20
|
</thead>
|
21
21
|
<tbody>
|
22
22
|
<tr>
|
23
|
-
<td id="a">Value 1</td>
|
23
|
+
<td data-sticky-id="a">Value 1</td>
|
24
24
|
<td>Value 2</td>
|
25
25
|
<td>Value 3</td>
|
26
26
|
<td>Value 4</td>
|
@@ -34,10 +34,10 @@
|
|
34
34
|
<td>Value 12</td>
|
35
35
|
<td>Value 13</td>
|
36
36
|
<td>Value 14</td>
|
37
|
-
<td id="b">Value 15</td>
|
37
|
+
<td data-sticky-id="b">Value 15</td>
|
38
38
|
</tr>
|
39
39
|
<tr>
|
40
|
-
<td id="a">Value 1</td>
|
40
|
+
<td data-sticky-id="a">Value 1</td>
|
41
41
|
<td>Value 2</td>
|
42
42
|
<td>Value 3</td>
|
43
43
|
<td>Value 4</td>
|
@@ -51,10 +51,10 @@
|
|
51
51
|
<td>Value 12</td>
|
52
52
|
<td>Value 13</td>
|
53
53
|
<td>Value 14</td>
|
54
|
-
<td id="b">Value 15</td>
|
54
|
+
<td data-sticky-id="b">Value 15</td>
|
55
55
|
</tr>
|
56
56
|
<tr>
|
57
|
-
<td id="a">Value 1</td>
|
57
|
+
<td data-sticky-id="a">Value 1</td>
|
58
58
|
<td>Value 2</td>
|
59
59
|
<td>Value 3</td>
|
60
60
|
<td>Value 4</td>
|
@@ -68,7 +68,7 @@
|
|
68
68
|
<td>Value 12</td>
|
69
69
|
<td>Value 13</td>
|
70
70
|
<td>Value 14</td>
|
71
|
-
<td id="b">Value 15</td>
|
71
|
+
<td data-sticky-id="b">Value 15</td>
|
72
72
|
</tr>
|
73
73
|
</tbody>
|
74
74
|
<% end %>
|