playbook_ui 14.13.0.pre.alpha.play1852reacthookformsupportradio6153 → 14.13.0.pre.alpha.play1852reacthookformsupportradio6213
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/_playbook.scss +0 -1
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +6 -5
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +8 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_headers_custom_cell.jsx +75 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_rails.md +3 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_react.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header.html.erb +33 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_rails.md +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +2 -1
- data/app/pb_kits/playbook/pb_checkbox/_checkbox.tsx +17 -8
- data/app/pb_kits/playbook/pb_checkbox/checkbox.test.js +16 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_react_hook.jsx +69 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_react_hook.md +1 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/example.yml +2 -1
- data/app/pb_kits/playbook/pb_checkbox/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_overlay/_overlay.tsx +4 -0
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.jsx +37 -0
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional_react.md +1 -0
- data/app/pb_kits/playbook/pb_overlay/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_overlay/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_overlay/subcomponents/_overlay_token.tsx +48 -10
- data/app/pb_kits/playbook/pb_progress_pills/_progress_pills.scss +6 -1
- data/app/pb_kits/playbook/pb_progress_pills/_progress_pills.tsx +7 -5
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_default.html.erb +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_default.jsx +7 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_default.md +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_full_width.html.erb +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_full_width.jsx +18 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_full_width_rails.md +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_full_width_react.md +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/progress_pills.html.erb +2 -7
- data/app/pb_kits/playbook/pb_progress_pills/progress_pills.rb +6 -0
- data/app/pb_kits/playbook/pb_progress_pills/progress_pills.test.js +26 -1
- data/app/pb_kits/playbook/pb_progress_simple/progress_simple.html.erb +1 -5
- data/app/pb_kits/playbook/pb_progress_step/progress_step.html.erb +1 -5
- data/app/pb_kits/playbook/pb_progress_step/progress_step_item.html.erb +1 -5
- data/app/pb_kits/playbook/pb_radio/radio.html.erb +6 -11
- data/dist/chunks/{_typeahead-B7kfgseZ.js → _typeahead-BdE70xxu.js} +3 -3
- data/dist/chunks/_weekday_stacked-Dze0K01W.js +45 -0
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +0 -7
- data/dist/playbook-doc.js +1 -1
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/version.rb +1 -1
- metadata +16 -20
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.scss +0 -66
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.tsx +0 -98
- data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.html.erb +0 -28
- data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.rb +0 -42
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_actions.html.erb +0 -19
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_actions.jsx +0 -26
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_default.html.erb +0 -10
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_default.jsx +0 -17
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_on_click.jsx +0 -19
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_onclick.html.erb +0 -16
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_placement.html.erb +0 -35
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_placement.jsx +0 -42
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_tooltip.html.erb +0 -13
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/example.yml +0 -15
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/index.js +0 -4
- data/app/pb_kits/playbook/pb_avatar_action_button/pb_avatar_action_button.test.js +0 -31
- data/dist/chunks/_weekday_stacked-CQggx3_W.js +0 -45
@@ -13,6 +13,7 @@ type ProgressPillsProps = {
|
|
13
13
|
className?: string,
|
14
14
|
data?: { [key: string]: string },
|
15
15
|
dark?: boolean,
|
16
|
+
fullWidthPill?: boolean,
|
16
17
|
htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
|
17
18
|
id?: string,
|
18
19
|
steps?: number,
|
@@ -20,19 +21,19 @@ type ProgressPillsProps = {
|
|
20
21
|
value?: string,
|
21
22
|
}
|
22
23
|
|
23
|
-
const ProgressPill = ({ active, dark, steps: step }: ProgressPillsProps) => (
|
24
|
+
const ProgressPill = ({ active, dark, steps: step, fullWidthPill }: ProgressPillsProps) => (
|
24
25
|
<div
|
25
26
|
className={`pb_progress_pill${step <= active ? '_active' : '_inactive'}${dark ? ' dark' : ''
|
26
|
-
}`}
|
27
|
+
}${fullWidthPill ? ' full_width_pill' : ''}`}
|
27
28
|
key={step}
|
28
29
|
/>
|
29
30
|
)
|
30
31
|
|
31
|
-
const showSteps = (steps: number, active: number, dark: boolean) => {
|
32
|
+
const showSteps = (steps: number, active: number, dark: boolean, fullWidthPill: boolean) => {
|
32
33
|
const items = []
|
33
34
|
|
34
35
|
for (let step = 1; step <= steps; step++) {
|
35
|
-
items.push(ProgressPill({ steps: step, active, dark }))
|
36
|
+
items.push(ProgressPill({ steps: step, active, dark, fullWidthPill }))
|
36
37
|
}
|
37
38
|
|
38
39
|
return items
|
@@ -44,6 +45,7 @@ const ProgressPills = (props: ProgressPillsProps) => {
|
|
44
45
|
aria = { hidden: 'true' },
|
45
46
|
className,
|
46
47
|
data = {},
|
48
|
+
fullWidthPill = false,
|
47
49
|
htmlOptions = {},
|
48
50
|
id,
|
49
51
|
steps = 3,
|
@@ -79,7 +81,7 @@ const ProgressPills = (props: ProgressPillsProps) => {
|
|
79
81
|
text={value}
|
80
82
|
/>
|
81
83
|
</div>}
|
82
|
-
<div className="progress_pills">{showSteps(steps, active, dark)}</div>
|
84
|
+
<div className="progress_pills">{showSteps(steps, active, dark, fullWidthPill)}</div>
|
83
85
|
</div>
|
84
86
|
)
|
85
87
|
}
|
@@ -0,0 +1 @@
|
|
1
|
+
Progress pills start at `45px` wide if the container allows, but will shrink down to `1px` as the container gets smaller. Resize this window to see each pill shrink.
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= pb_rails("progress_pills", props: { aria: { label: "2 out of 5 steps complete" }, steps: 5, active: 2, full_width_pill: true }) %>
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import ProgressPills from '../_progress_pills'
|
3
|
+
|
4
|
+
const ProgressPillsFullWidth = (props) => {
|
5
|
+
return (
|
6
|
+
<>
|
7
|
+
<ProgressPills
|
8
|
+
active={2}
|
9
|
+
aria={{ label: '2 out of 5 steps complete' }}
|
10
|
+
fullWidthPill
|
11
|
+
steps={5}
|
12
|
+
{...props}
|
13
|
+
/>
|
14
|
+
</>
|
15
|
+
)
|
16
|
+
}
|
17
|
+
|
18
|
+
export default ProgressPillsFullWidth
|
@@ -0,0 +1 @@
|
|
1
|
+
Pass `full_width_pill: true` to the Progress Pill kit to get true 100% full width pills. The kit will take up the full width of the container that it is in.
|
@@ -0,0 +1 @@
|
|
1
|
+
Pass `fullWidthPill` to the Progress Pill kit to get true 100% full width pills. The kit will take up the full width of the container that it is in.
|
@@ -3,9 +3,11 @@ examples:
|
|
3
3
|
rails:
|
4
4
|
- progress_pills_default: Default
|
5
5
|
- progress_pills_status: Status
|
6
|
+
- progress_pills_full_width: Full Container Width
|
6
7
|
|
7
8
|
|
8
9
|
|
9
10
|
react:
|
10
11
|
- progress_pills_default: Default
|
11
12
|
- progress_pills_status: Status
|
13
|
+
- progress_pills_full_width: Full Container Width
|
@@ -1,9 +1,4 @@
|
|
1
|
-
<%=
|
2
|
-
aria: object.aria_attributes,
|
3
|
-
id: object.id,
|
4
|
-
data: object.data,
|
5
|
-
class: object.classname,
|
6
|
-
**combined_html_options) do %>
|
1
|
+
<%= pb_content_tag do %>
|
7
2
|
|
8
3
|
<div class="progress_pills_status">
|
9
4
|
<% object.with_status do |status| %>
|
@@ -14,7 +9,7 @@
|
|
14
9
|
|
15
10
|
<div class="progress_pills">
|
16
11
|
<% object.each_step do |step| %>
|
17
|
-
<span class="pb_progress_pill<%= object.active_step(step) %><%= object.dark_pill %>"></span>
|
12
|
+
<span class="pb_progress_pill<%= object.active_step(step) %><%= object.make_full_width %><%= object.dark_pill %>"></span>
|
18
13
|
<% end %>
|
19
14
|
</div>
|
20
15
|
|
@@ -9,6 +9,8 @@ module Playbook
|
|
9
9
|
prop :steps, type: Playbook::Props::Number,
|
10
10
|
default: 3
|
11
11
|
prop :title
|
12
|
+
prop :full_width_pill, type: Playbook::Props::Boolean,
|
13
|
+
default: false
|
12
14
|
|
13
15
|
def classname
|
14
16
|
generate_classname("pb_progress_pills_kit")
|
@@ -26,6 +28,10 @@ module Playbook
|
|
26
28
|
step <= active ? "_active" : "_inactive"
|
27
29
|
end
|
28
30
|
|
31
|
+
def make_full_width
|
32
|
+
full_width_pill ? " full_width_pill" : nil
|
33
|
+
end
|
34
|
+
|
29
35
|
def aria_attributes
|
30
36
|
return aria if aria.present?
|
31
37
|
|
@@ -23,6 +23,20 @@ const ProgressPillsDefault = () => {
|
|
23
23
|
)
|
24
24
|
}
|
25
25
|
|
26
|
+
const ProgressPillsFullWidth = () => {
|
27
|
+
return (
|
28
|
+
<ProgressPills
|
29
|
+
active={2}
|
30
|
+
aria={{ label: ariaLabel }}
|
31
|
+
data={{ testid: testId }}
|
32
|
+
fullWidthPill
|
33
|
+
steps={3}
|
34
|
+
title={title}
|
35
|
+
value={value}
|
36
|
+
/>
|
37
|
+
)
|
38
|
+
}
|
39
|
+
|
26
40
|
test('should pass data prop', () => {
|
27
41
|
render(<ProgressPillsDefault />)
|
28
42
|
const kit = screen.getByTestId(testId)
|
@@ -51,4 +65,15 @@ test('should render value', () => {
|
|
51
65
|
render(<ProgressPillsDefault />)
|
52
66
|
const kit = screen.getByText(value)
|
53
67
|
expect(kit).toBeInTheDocument()
|
54
|
-
})
|
68
|
+
})
|
69
|
+
|
70
|
+
test('should apply fullWidthPill styling when fullWidthPill prop is true', () => {
|
71
|
+
render(<ProgressPillsFullWidth />)
|
72
|
+
const container = screen.getByTestId(testId)
|
73
|
+
const pillElements = container.querySelectorAll('.full_width_pill')
|
74
|
+
|
75
|
+
expect(pillElements.length).toBeGreaterThan(0)
|
76
|
+
pillElements.forEach((pill) => {
|
77
|
+
expect(pill).toHaveClass('full_width_pill')
|
78
|
+
})
|
79
|
+
})
|
@@ -1,11 +1,7 @@
|
|
1
1
|
<%= content_tag(:div,
|
2
2
|
class: object.wrapper_classname,
|
3
3
|
style: object.style) do %>
|
4
|
-
<%=
|
5
|
-
id: object.id,
|
6
|
-
data: object.data_values,
|
7
|
-
class: object.classname,
|
8
|
-
**combined_html_options) do %>
|
4
|
+
<%= pb_content_tag do %>
|
9
5
|
<%= content_tag(:div, "",
|
10
6
|
class: "progress_simple_value",
|
11
7
|
style: object.value_style) %>
|
@@ -1,8 +1,4 @@
|
|
1
|
-
<%=
|
2
|
-
id: object.id,
|
3
|
-
data: object.data,
|
4
|
-
class: object.classname,
|
5
|
-
**combined_html_options) do %>
|
1
|
+
<%= pb_content_tag(:li) do %>
|
6
2
|
<div class="box" style="max-width: min-content;" id="<%= object.tooltip_trigger_class %>">
|
7
3
|
<div class="circle">
|
8
4
|
<%= pb_rails("icon", props: { icon: object.icon, size: "xs" }) if object.icon.present? %>
|
@@ -7,26 +7,21 @@
|
|
7
7
|
data: object.data,
|
8
8
|
**combined_html_options
|
9
9
|
}) do %>
|
10
|
-
<%=
|
10
|
+
<%= pb_content_tag(:label,
|
11
11
|
'data-pb-radio-children': 'true',
|
12
12
|
checked: object.checked,
|
13
|
-
|
14
|
-
|
15
|
-
value: object.value) do %>
|
13
|
+
value: object.value
|
14
|
+
) do %>
|
16
15
|
<%= input %>
|
17
16
|
<span class="pb_radio_button"></span>
|
18
17
|
<% end %>
|
19
18
|
<div data-pb-radio-children-wrapper="true"> <%= content %> </div>
|
20
19
|
<% end %>
|
21
20
|
<% else %>
|
22
|
-
<%=
|
23
|
-
aria: object.aria,
|
21
|
+
<%= pb_content_tag(:label,
|
24
22
|
checked: object.checked,
|
25
|
-
class: object.classname,
|
26
|
-
data: object.data,
|
27
|
-
id: object.id,
|
28
23
|
value: object.value,
|
29
|
-
|
24
|
+
) do %>
|
30
25
|
|
31
26
|
<% if content.present? %>
|
32
27
|
<%= content %>
|
@@ -37,4 +32,4 @@
|
|
37
32
|
<span class="pb_radio_button"></span>
|
38
33
|
<%= pb_rails("body", props: { status: object.body_status, text: object.text, dark: object.dark }) %>
|
39
34
|
<% end %>
|
40
|
-
<% end %>
|
35
|
+
<% end %>
|