playbook_ui 13.28.0.pre.alpha.PLAY1349checkboxzindexsticky2947 → 13.28.0.pre.alpha.dialogturbostreameventlistener3017
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/_playbook.scss +2 -3
- data/app/pb_kits/playbook/index.js +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_subrow_headers.html.erb +40 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_subrow_headers.md +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_subrow_headers.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_body.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +14 -4
- data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +10 -2
- data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_subrow_header.html.erb +34 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_subrow_header.rb +31 -0
- data/app/pb_kits/playbook/pb_bar_graph/_bar_graph.tsx +4 -1
- data/app/pb_kits/playbook/pb_bar_graph/barGraph.test.js +31 -0
- data/app/pb_kits/playbook/pb_bar_graph/bar_graph.rb +16 -0
- data/app/pb_kits/playbook/pb_circle_chart/_circle_chart.tsx +5 -2
- data/app/pb_kits/playbook/pb_circle_chart/circleChart.test.js +45 -0
- data/app/pb_kits/playbook/pb_circle_chart/circle_chart.rb +16 -0
- data/app/pb_kits/playbook/pb_collapsible/__snapshots__/collapsible.test.js.snap +53 -0
- data/app/pb_kits/playbook/pb_collapsible/_collapsible.tsx +14 -8
- data/app/pb_kits/playbook/pb_collapsible/collapsible.test.js +24 -0
- data/app/pb_kits/playbook/pb_dashboard/pbChartsDarkTheme.ts +7 -1
- data/app/pb_kits/playbook/pb_dashboard/pbChartsLightTheme.ts +9 -1
- data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +2 -3
- data/app/pb_kits/playbook/pb_draggable/_draggable.scss +10 -0
- data/app/pb_kits/playbook/pb_draggable/_draggable.tsx +53 -0
- data/app/pb_kits/playbook/pb_draggable/context/index.tsx +92 -0
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_default.jsx +53 -0
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_multiple_containers.jsx +159 -0
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_cards.jsx +121 -0
- data/app/pb_kits/playbook/pb_draggable/docs/example.yml +9 -0
- data/app/pb_kits/playbook/pb_draggable/docs/index.js +3 -0
- data/app/pb_kits/playbook/pb_draggable/draggable.test.jsx +65 -0
- data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableContainer.tsx +54 -0
- data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableItem.tsx +57 -0
- data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +10 -0
- data/app/pb_kits/playbook/pb_form_group/_form_group.scss +2 -2
- data/app/pb_kits/playbook/pb_gauge/gauge.test.js +35 -0
- data/app/pb_kits/playbook/pb_line_graph/_line_graph.tsx +4 -1
- data/app/pb_kits/playbook/pb_line_graph/lineGraph.test.js +52 -0
- data/app/pb_kits/playbook/pb_line_graph/line_graph.rb +16 -0
- data/app/pb_kits/playbook/pb_pill/docs/_description.md +1 -1
- data/app/pb_kits/playbook/pb_table/_table.tsx +5 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_column.jsx +33 -32
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_column.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_column_rails.md +2 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_row.jsx +33 -33
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_row.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_row_rails.html.erb +34 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_row_rails.md +2 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_data.jsx +51 -50
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_data.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_data_rails.html.erb +54 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_data_rails.md +2 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_row.jsx +37 -38
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_row.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_row_rails.html.erb +53 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_row_rails.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/{_table_alignment_row.html.erb → _table_outer_padding.html.erb} +7 -7
- data/app/pb_kits/playbook/pb_table/docs/_table_outer_padding.jsx +76 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_outer_padding.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/example.yml +9 -9
- data/app/pb_kits/playbook/pb_table/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_table/styles/_all.scss +1 -0
- data/app/pb_kits/playbook/pb_table/styles/_outer_padding.scss +21 -0
- data/app/pb_kits/playbook/pb_table/table.rb +14 -1
- data/app/pb_kits/playbook/pb_table/table.test.js +5 -1
- data/app/pb_kits/playbook/pb_tooltip/index.js +1 -0
- data/app/pb_kits/playbook/pb_treemap_chart/treemapChart.test.js +61 -0
- data/app/pb_kits/playbook/playbook-doc.js +2 -0
- data/app/pb_kits/playbook/tokens/_vertical_align.scss +18 -0
- data/app/pb_kits/playbook/utilities/_vertical_align.scss +16 -0
- data/app/pb_kits/playbook/utilities/globalProps.ts +12 -1
- data/dist/menu.yml +5 -2
- data/dist/playbook-rails.js +6 -6
- data/lib/playbook/classnames.rb +1 -0
- data/lib/playbook/forms/builder/dropdown_field.rb +14 -0
- data/lib/playbook/forms/builder.rb +1 -0
- data/lib/playbook/kit_base.rb +2 -0
- data/lib/playbook/version.rb +1 -1
- data/lib/playbook/vertical_align.rb +37 -0
- metadata +40 -6
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_data.html.erb +0 -63
- data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_row.html.erb +0 -52
- /data/app/pb_kits/playbook/pb_table/docs/{_table_alignment_column.html.erb → _table_alignment_column_rails.html.erb} +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 1bd7bd6815e9740c4e1e7febfe25ed403ca7770a4fb38d4d69996c86477e0f70
|
4
|
+
data.tar.gz: 9b519498a395899248ba40190f22bd31238dbaa16f53481d679651376bec465f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 819b8020171a9fae3359cb072ea067e837eecd8a2caccbe5db6c869692cd976dbca0145314c76d1ebdbab6f14c4a7b7548367254241fa862d42567e098da7a90
|
7
|
+
data.tar.gz: bbccaaacd3bffe3e5962063fafa80a631ef6f63bf1ac73777f15eb71221c9e97630cc4778eea6951aa258775526daa65c0e5e0f7d7a4baaea1749b86187142c9
|
@@ -1,6 +1,3 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
1
|
@import 'pb_advanced_table/advanced_table';
|
5
2
|
@import 'pb_avatar/avatar';
|
6
3
|
@import 'pb_avatar_action_button/avatar_action_button';
|
@@ -31,6 +28,7 @@
|
|
31
28
|
@import 'pb_detail/detail';
|
32
29
|
@import 'pb_dialog/dialog';
|
33
30
|
@import 'pb_distribution_bar/distribution_bar';
|
31
|
+
@import 'pb_draggable/draggable';
|
34
32
|
@import 'pb_dropdown/dropdown';
|
35
33
|
@import 'pb_file_upload/file_upload';
|
36
34
|
@import 'pb_filter/filter';
|
@@ -121,3 +119,4 @@
|
|
121
119
|
@import './utilities/text_align';
|
122
120
|
@import './utilities/overflow';
|
123
121
|
@import './utilities/truncate';
|
122
|
+
@import './utilities/vertical_align';
|
@@ -35,6 +35,8 @@ export { default as DateYearStacked } from './pb_date_year_stacked/_date_year_st
|
|
35
35
|
export { default as Detail} from './pb_detail/_detail'
|
36
36
|
export { default as Dialog } from './pb_dialog/_dialog'
|
37
37
|
export { default as DistributionBar } from './pb_distribution_bar/_distribution_bar'
|
38
|
+
export { default as Draggable} from './pb_draggable/_draggable'
|
39
|
+
export { DraggableProvider} from './pb_draggable/context'
|
38
40
|
export { default as Dropdown} from './pb_dropdown/_dropdown'
|
39
41
|
export { default as FileUpload } from './pb_file_upload/_file_upload'
|
40
42
|
export { default as Filter } from './pb_filter/_filter'
|
@@ -3,8 +3,8 @@
|
|
3
3
|
<% if content.present? %>
|
4
4
|
<% content.presence %>
|
5
5
|
<% else %>
|
6
|
-
<%= pb_rails("advanced_table/table_header", props: {column_definitions: object.column_definitions, enable_toggle_expansion: object.enable_toggle_expansion }) %>
|
7
|
-
<%= pb_rails("advanced_table/table_body", props: {table_data: object.table_data, column_definitions: object.column_definitions}) %>
|
6
|
+
<%= pb_rails("advanced_table/table_header", props: { column_definitions: object.column_definitions, enable_toggle_expansion: object.enable_toggle_expansion }) %>
|
7
|
+
<%= pb_rails("advanced_table/table_body", props: { id: object.id, table_data: object.table_data, column_definitions: object.column_definitions }) %>
|
8
8
|
<% end %>
|
9
9
|
<% end %>
|
10
10
|
<% end %>
|
@@ -0,0 +1,40 @@
|
|
1
|
+
<%
|
2
|
+
column_definitions = [
|
3
|
+
{
|
4
|
+
accessor: "year",
|
5
|
+
label: "Year",
|
6
|
+
cellAccessors: ["quarter", "month", "day"],
|
7
|
+
},
|
8
|
+
{
|
9
|
+
accessor: "newEnrollments",
|
10
|
+
label: "New Enrollments",
|
11
|
+
},
|
12
|
+
{
|
13
|
+
accessor: "scheduledMeetings",
|
14
|
+
label: "Scheduled Meetings",
|
15
|
+
},
|
16
|
+
{
|
17
|
+
accessor: "attendanceRate",
|
18
|
+
label: "Attendance Rate",
|
19
|
+
},
|
20
|
+
{
|
21
|
+
accessor: "completedClasses",
|
22
|
+
label: "Completed Classes",
|
23
|
+
},
|
24
|
+
{
|
25
|
+
accessor: "classCompletionRate",
|
26
|
+
label: "Class Completion Rate",
|
27
|
+
},
|
28
|
+
{
|
29
|
+
accessor: "graduatedStudents",
|
30
|
+
label: "Graduated Students",
|
31
|
+
}
|
32
|
+
]
|
33
|
+
|
34
|
+
subrow_headers = ["Quarter", "Month", "Day"]
|
35
|
+
%>
|
36
|
+
|
37
|
+
<%= pb_rails("advanced_table", props: { table_data: @table_data, column_definitions: column_definitions }) do %>
|
38
|
+
<%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
|
39
|
+
<%= pb_rails("advanced_table/table_body", props: { id: "subrow_headers", table_data: @table_data, column_definitions: column_definitions, subrow_headers: subrow_headers, enable_toggle_expansion: "all" }) %>
|
40
|
+
<% end %>
|
@@ -0,0 +1,3 @@
|
|
1
|
+
`subrow_headers` is an optional prop that if present will add header rows at each level of the nested data. The prop takes an array of strings, each string being the text for each header row. The array of strings must be in the order in which they need to be rendered in the UI according to depth.
|
2
|
+
|
3
|
+
`enable_toggle_expansion` is an additional optional prop that can be used in conjunction with the subRowHeaders prop. `enable_toggle_expansion` is a string that can be "all", "header" or "none". If set to "all", the toggle exapansion button will appear in the table header as well as in the subRow headers. If set to "header" button will only appear in header and NOT in subRow headers. This is set to "header" by default.
|
@@ -1,3 +1,3 @@
|
|
1
1
|
`subRowHeaders` is an optional prop that if present will add header rows at each level of the nested data. The prop takes an array of strings, each string being the text for each header row. The array of strings must be in the order in which they need to be rendered in the UI according to depth.
|
2
2
|
|
3
|
-
`enableToggleExpansion` is an additional optional prop that can be used in conjunction with the subRowHeaders prop. `enableToggleExpansion` is a string that can be
|
3
|
+
`enableToggleExpansion` is an additional optional prop that can be used in conjunction with the subRowHeaders prop. `enableToggleExpansion` is a string that can be "all", "header" or "none". If set to "all", the toggle exapansion button will appear in the table header as well as in the subRow headers. If set to "header" button will only appear in header and NOT in subRow headers. This is set to "header" by default.
|
@@ -1,6 +1,7 @@
|
|
1
1
|
examples:
|
2
2
|
rails:
|
3
3
|
- advanced_table_beta: Default (Required Props)
|
4
|
+
- advanced_table_beta_subrow_headers: SubRow Headers
|
4
5
|
react:
|
5
6
|
- advanced_table_default: Default (Required Props)
|
6
7
|
- advanced_table_loading: Loading State
|
@@ -12,4 +13,3 @@ examples:
|
|
12
13
|
- advanced_table_table_options: Table Options
|
13
14
|
- advanced_table_table_props: Table Props
|
14
15
|
- advanced_table_inline_row_loading: inline Row Loading
|
15
|
-
|
@@ -3,20 +3,30 @@
|
|
3
3
|
module Playbook
|
4
4
|
module PbAdvancedTable
|
5
5
|
class TableBody < Playbook::KitBase
|
6
|
+
prop :id, type: Playbook::Props::String,
|
7
|
+
default: ""
|
6
8
|
prop :table_data, type: Playbook::Props::Array,
|
7
9
|
default: []
|
8
10
|
prop :column_definitions, type: Playbook::Props::Array,
|
9
11
|
default: []
|
12
|
+
prop :enable_toggle_expansion, type: Playbook::Props::Enum,
|
13
|
+
values: %w[all header none],
|
14
|
+
default: "header"
|
15
|
+
prop :subrow_headers, type: Playbook::Props::Array,
|
16
|
+
default: []
|
10
17
|
|
11
|
-
def render_row_and_children(row, column_definitions, current_depth
|
18
|
+
def render_row_and_children(row, column_definitions, current_depth, first_parent_child)
|
12
19
|
output = ActiveSupport::SafeBuffer.new
|
20
|
+
is_first_child_of_subrow = current_depth.positive? && first_parent_child && subrow_headers[current_depth - 1].present?
|
13
21
|
|
14
|
-
output << pb_rails("advanced_table/
|
22
|
+
output << pb_rails("advanced_table/table_subrow_header", props: { row: row, column_definitions: column_definitions, depth: current_depth, subrow_header: subrow_headers[current_depth - 1] }) if is_first_child_of_subrow && enable_toggle_expansion == "all"
|
23
|
+
|
24
|
+
output << pb_rails("advanced_table/table_row", props: { id: id, row: row, column_definitions: column_definitions, depth: current_depth })
|
15
25
|
|
16
26
|
if row[:children].present?
|
17
|
-
output << content_tag(:div, class: "toggle-content", data: { advanced_table_content: row.object_id }) do
|
27
|
+
output << content_tag(:div, class: "toggle-content", data: { advanced_table_content: row.object_id.to_s + id }) do
|
18
28
|
row[:children].map do |child_row|
|
19
|
-
render_row_and_children(child_row, column_definitions, current_depth + 1)
|
29
|
+
render_row_and_children(child_row, column_definitions, current_depth + 1, row.children.first == child_row)
|
20
30
|
end.join.html_safe
|
21
31
|
end
|
22
32
|
end
|
@@ -4,7 +4,7 @@
|
|
4
4
|
<%= pb_rails("table/table_header", props: { tag:"div", id:item[:accessor], classname:object.th_classname}) do %>
|
5
5
|
<%= pb_rails("flex", props:{ align: "center", justify: index.zero? ? "start" : "end", text_align:"end" }) do %>
|
6
6
|
<% if index.zero? && (object.enable_toggle_expansion == "header" || object.enable_toggle_expansion == "all") %>
|
7
|
-
<button class="gray-icon toggle-all-icon">
|
7
|
+
<button class="gray-icon toggle-all-icon" onclick="expandAllRows(this)">
|
8
8
|
<%= pb_rails("icon", props: { icon: "arrows-from-line", cursor: "pointer", fixed_width: true, padding_right:"xs" }) %>
|
9
9
|
</button>
|
10
10
|
<% end %>
|
@@ -13,4 +13,12 @@
|
|
13
13
|
<% end %>
|
14
14
|
<% end %>
|
15
15
|
<% end %>
|
16
|
-
<% end %>
|
16
|
+
<% end %>
|
17
|
+
|
18
|
+
<script type="text/javascript">
|
19
|
+
var expandAllRows = (element) => {
|
20
|
+
element.closest('.pb_table').querySelectorAll('.pb_advanced_table_body > .pb_table_tr [data-advanced-table]').forEach((button) => {
|
21
|
+
button.dispatchEvent(new Event('click'));
|
22
|
+
});
|
23
|
+
};
|
24
|
+
</script>
|
@@ -5,7 +5,7 @@
|
|
5
5
|
<div style="padding-left: <%= depth * 1.25 %>em">
|
6
6
|
<%= pb_rails("flex", props:{align: "center", column_gap: "xs"}) do %>
|
7
7
|
<% if index.zero? && object.row[:children].present? %>
|
8
|
-
<button id="<%= object.row.object_id %>" class="gray-icon expand-toggle-icon" data-advanced-table="true" >
|
8
|
+
<button id="<%= object.row.object_id.to_s + object.id %>" class="gray-icon expand-toggle-icon" data-advanced-table="true" >
|
9
9
|
<%= pb_rails("icon", props: { id: "advanced-table_open_icon", icon: "circle-play", cursor: "pointer" }) %>
|
10
10
|
<%= pb_rails("icon", props: { id: "advanced-table_close_icon", display: "none", icon: "circle-play", cursor: "pointer", rotation: 90 }) %>
|
11
11
|
</button>
|
@@ -0,0 +1,34 @@
|
|
1
|
+
<%= content_tag(:div,
|
2
|
+
aria: object.aria,
|
3
|
+
class: object.classname,
|
4
|
+
data: object.data,
|
5
|
+
id: object.id) do %>
|
6
|
+
<% object.column_definitions.each_with_index do |column, index| %>
|
7
|
+
<%= pb_rails("table/table_cell", props: { tag: "div", classname: object.td_classname}) do %>
|
8
|
+
<%= pb_rails("flex", props:{ align: "center", justify: "start" }) do %>
|
9
|
+
<div style="padding-left: <%= depth * 1.25 %>em">
|
10
|
+
<%= pb_rails("flex", props:{align: "center", column_gap: "xs"}) do %>
|
11
|
+
<% if index.zero? && object.row[:children].present? %>
|
12
|
+
<button class="gray-icon toggle-all-icon" onclick="expandAllSubRows(this, <%= depth %>)">
|
13
|
+
<%= pb_rails("icon", props: { icon: "arrows-from-line", cursor: "pointer", fixed_width: true, padding_right:"xs" }) %>
|
14
|
+
</button>
|
15
|
+
<% end %>
|
16
|
+
<%= pb_rails("flex/flex_item") do %>
|
17
|
+
<% if index.zero? %>
|
18
|
+
<%= pb_rails("caption", props: { margin_left: object.row[:children].present? ? "none" : "xs", text: object.subrow_header }) %>
|
19
|
+
<% end %>
|
20
|
+
<% end %>
|
21
|
+
<% end %>
|
22
|
+
</div>
|
23
|
+
<% end %>
|
24
|
+
<% end %>
|
25
|
+
<% end %>
|
26
|
+
<% end %>
|
27
|
+
|
28
|
+
<script type="text/javascript">
|
29
|
+
var expandAllSubRows = (element, rowDepth) => {
|
30
|
+
element.closest(".toggle-content").querySelectorAll('.depth-sub-row-' + rowDepth + ' [data-advanced-table]').forEach((button) => {
|
31
|
+
button.dispatchEvent(new Event('click'));
|
32
|
+
});
|
33
|
+
};
|
34
|
+
</script>
|
@@ -0,0 +1,31 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Playbook
|
4
|
+
module PbAdvancedTable
|
5
|
+
class TableSubrowHeader < Playbook::KitBase
|
6
|
+
prop :column_definitions, type: Playbook::Props::Array,
|
7
|
+
default: []
|
8
|
+
prop :depth
|
9
|
+
prop :row
|
10
|
+
prop :enable_toggle_expansion, type: Playbook::Props::Enum,
|
11
|
+
values: %w[all header none],
|
12
|
+
default: "header"
|
13
|
+
prop :subrow_header, type: Playbook::Props::String,
|
14
|
+
default: ""
|
15
|
+
|
16
|
+
def classname
|
17
|
+
generate_classname("pb_table_tr", "bg-white", subrow_depth_classname, separator: " ")
|
18
|
+
end
|
19
|
+
|
20
|
+
def td_classname
|
21
|
+
generate_classname("id-cell", "chrome-styles", separator: " ")
|
22
|
+
end
|
23
|
+
|
24
|
+
private
|
25
|
+
|
26
|
+
def subrow_depth_classname
|
27
|
+
depth.positive? ? "depth-sub-row-#{depth}" : ""
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -163,6 +163,9 @@ if (Array.isArray(axisTitle) && axisTitle.length > 1 && axisTitle[1].name) {
|
|
163
163
|
staticOptions.plotOptions.series.events = { legendItemClick: () => false };
|
164
164
|
}
|
165
165
|
|
166
|
+
const filteredProps: any = {...props};
|
167
|
+
delete filteredProps.verticalAlign;
|
168
|
+
|
166
169
|
const [options, setOptions] = useState({});
|
167
170
|
|
168
171
|
useEffect(() => {
|
@@ -172,7 +175,7 @@ if (Array.isArray(axisTitle) && axisTitle.length > 1 && axisTitle[1].name) {
|
|
172
175
|
return (
|
173
176
|
<HighchartsReact
|
174
177
|
containerProps={{
|
175
|
-
className: classnames(globalProps(
|
178
|
+
className: classnames(globalProps(filteredProps), className),
|
176
179
|
id: id,
|
177
180
|
...ariaProps,
|
178
181
|
...dataProps,
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { render, screen } from '../utilities/test-utils';
|
3
|
+
import BarGraph from './_bar_graph';
|
4
|
+
|
5
|
+
beforeEach(() => {
|
6
|
+
// Silences error logs within the test suite.
|
7
|
+
jest.spyOn(console, 'error');
|
8
|
+
jest.spyOn(console, 'warn');
|
9
|
+
console.error.mockImplementation(() => {});
|
10
|
+
console.warn.mockImplementation(() => {});
|
11
|
+
});
|
12
|
+
|
13
|
+
afterEach(() => {
|
14
|
+
console.error.mockRestore();
|
15
|
+
console.warn.mockRestore();
|
16
|
+
});
|
17
|
+
|
18
|
+
const testId = 'bargraph1';
|
19
|
+
|
20
|
+
test('bargraph uses exact classname', () => {
|
21
|
+
render(
|
22
|
+
<BarGraph
|
23
|
+
className='super_important_class'
|
24
|
+
data={{ testid: testId }}
|
25
|
+
id='bar-default'
|
26
|
+
/>
|
27
|
+
);
|
28
|
+
|
29
|
+
const kit = screen.getByTestId(testId);
|
30
|
+
expect(kit).toHaveClass('super_important_class');
|
31
|
+
});
|
@@ -74,6 +74,22 @@ module Playbook
|
|
74
74
|
standard_options.deep_merge(custom_options)
|
75
75
|
end
|
76
76
|
|
77
|
+
def vertical_align_props
|
78
|
+
if vertical_align
|
79
|
+
if object.vertical_align
|
80
|
+
original_result = super
|
81
|
+
class_to_remove = "vertical_align_#{object.vertical_align}"
|
82
|
+
|
83
|
+
modified_result = original_result.gsub(class_to_remove, "").strip
|
84
|
+
modified_result.empty? ? nil : modified_result
|
85
|
+
else
|
86
|
+
super
|
87
|
+
end
|
88
|
+
else
|
89
|
+
super
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
77
93
|
def classname
|
78
94
|
generate_classname("pb_bar_graph")
|
79
95
|
end
|
@@ -115,6 +115,9 @@ const CircleChart = ({
|
|
115
115
|
innerSizes[size];
|
116
116
|
|
117
117
|
|
118
|
+
const filteredProps: any = {...props};
|
119
|
+
delete filteredProps.verticalAlign;
|
120
|
+
|
118
121
|
const [options, setOptions] = useState({});
|
119
122
|
|
120
123
|
useEffect(() => {
|
@@ -181,7 +184,7 @@ const CircleChart = ({
|
|
181
184
|
<div id={`wrapper-circle-chart-${id}`}>
|
182
185
|
<HighchartsReact
|
183
186
|
containerProps={{
|
184
|
-
className: classnames("pb_circle_chart", globalProps(
|
187
|
+
className: classnames("pb_circle_chart", globalProps(filteredProps)),
|
185
188
|
id: id,
|
186
189
|
...ariaProps,
|
187
190
|
...dataProps,
|
@@ -195,7 +198,7 @@ const CircleChart = ({
|
|
195
198
|
) : (
|
196
199
|
<HighchartsReact
|
197
200
|
containerProps={{
|
198
|
-
className: classnames("pb_circle_chart", globalProps(
|
201
|
+
className: classnames("pb_circle_chart", globalProps(filteredProps)),
|
199
202
|
id: id,
|
200
203
|
...ariaProps,
|
201
204
|
...dataProps,
|
@@ -0,0 +1,45 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { render, screen } from '../utilities/test-utils';
|
3
|
+
import CircleChart from './_circle_chart';
|
4
|
+
|
5
|
+
beforeEach(() => {
|
6
|
+
// Silences error logs within the test suite.
|
7
|
+
jest.spyOn(console, 'error');
|
8
|
+
jest.spyOn(console, 'warn');
|
9
|
+
console.error.mockImplementation(() => {});
|
10
|
+
console.warn.mockImplementation(() => {});
|
11
|
+
});
|
12
|
+
|
13
|
+
afterEach(() => {
|
14
|
+
console.error.mockRestore();
|
15
|
+
console.warn.mockRestore();
|
16
|
+
});
|
17
|
+
|
18
|
+
const testId = 'circlechart1';
|
19
|
+
|
20
|
+
test('uses exact classname', () => {
|
21
|
+
const data = [
|
22
|
+
{
|
23
|
+
name: 'Waiting for Calls',
|
24
|
+
value: 41,
|
25
|
+
},
|
26
|
+
{
|
27
|
+
name: 'On Call',
|
28
|
+
value: 49,
|
29
|
+
},
|
30
|
+
{
|
31
|
+
name: 'After call',
|
32
|
+
value: 10,
|
33
|
+
},
|
34
|
+
]
|
35
|
+
render(
|
36
|
+
<CircleChart
|
37
|
+
chartData={data}
|
38
|
+
data={{ testid: testId }}
|
39
|
+
id='circlechartid'
|
40
|
+
/>
|
41
|
+
);
|
42
|
+
|
43
|
+
const kit = screen.getByTestId(testId);
|
44
|
+
expect(kit).toHaveClass('pb_circle_chart');
|
45
|
+
});
|
@@ -68,6 +68,22 @@ module Playbook
|
|
68
68
|
}
|
69
69
|
end
|
70
70
|
|
71
|
+
def vertical_align_props
|
72
|
+
if vertical_align
|
73
|
+
if object.vertical_align
|
74
|
+
original_result = super
|
75
|
+
class_to_remove = "vertical_align_#{object.vertical_align}"
|
76
|
+
|
77
|
+
modified_result = original_result.gsub(class_to_remove, "").strip
|
78
|
+
modified_result.empty? ? nil : modified_result
|
79
|
+
else
|
80
|
+
super
|
81
|
+
end
|
82
|
+
else
|
83
|
+
super
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
71
87
|
def classname
|
72
88
|
generate_classname("pb_circle_chart")
|
73
89
|
end
|
@@ -0,0 +1,53 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`html structure is correct 1`] = `
|
4
|
+
<div>
|
5
|
+
<div
|
6
|
+
class="pb_collapsible_kit additional_class"
|
7
|
+
data-testid="collapsible1"
|
8
|
+
>
|
9
|
+
<div
|
10
|
+
class="pb_collapsible_main_kit cursor_pointer"
|
11
|
+
>
|
12
|
+
<div>
|
13
|
+
<div
|
14
|
+
class="pb_flex_kit_orientation_row_justify_content_left_align_items_center_spacing_between"
|
15
|
+
>
|
16
|
+
<div
|
17
|
+
class="pb_flex_item_kit"
|
18
|
+
>
|
19
|
+
<div>
|
20
|
+
Main Section
|
21
|
+
</div>
|
22
|
+
</div>
|
23
|
+
<div
|
24
|
+
class="pb_flex_item_kit"
|
25
|
+
>
|
26
|
+
<div
|
27
|
+
class="icon_wrapper"
|
28
|
+
style="vertical-align: middle; color: rgb(193, 205, 214);"
|
29
|
+
>
|
30
|
+
<i
|
31
|
+
class="pb_icon_kit far fa-fw fa-lg fa-chevron-down"
|
32
|
+
/>
|
33
|
+
<span
|
34
|
+
aria-label="chevron-down icon"
|
35
|
+
hidden=""
|
36
|
+
/>
|
37
|
+
</div>
|
38
|
+
</div>
|
39
|
+
</div>
|
40
|
+
</div>
|
41
|
+
</div>
|
42
|
+
<div
|
43
|
+
class="pb_collapsible_content_kit toggle-content"
|
44
|
+
data-collapsible-content="true"
|
45
|
+
style="height: 0px;"
|
46
|
+
>
|
47
|
+
<div>
|
48
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. In vel erat sed purus hendrerit viverra. Duis et vestibulum metus. Sed consequat ut ante non vehicula. Etiam nunc massa, pharetra vel quam id, posuere rhoncus quam. Quisque imperdiet arcu enim, nec aliquet justo auctor eget. Curabitur in metus nec nunc rhoncus faucibus vitae ac elit. Nulla facilisi. Vestibulum quis pretium nulla. Nulla ut accumsan velit. Duis varius urna sed sem tempor, sit amet fermentum nibh auctor. Praesent lorem arcu, egestas non ante quis, placerat pellentesque lectus.Vestibulum lacinia ipsum quis venenatis tristique. Vivamus suscipit, libero eu fringilla egestas, orci urna commodo arcu, vel gravida turpis ipsum molestie nibh. Donec cursus eu ante sagittis ultrices. Phasellus id sagittis risus. Mauris dapibus neque faucibus, tempor ligula vel, cursus ante. Donec faucibus gravida porta. Nullam egestas est quis aliquam feugiat. Sed eget metus diam. Cras eget placerat libero.
|
49
|
+
</div>
|
50
|
+
</div>
|
51
|
+
</div>
|
52
|
+
</div>
|
53
|
+
`;
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import React, { useEffect } from 'react'
|
1
|
+
import React, { useEffect, ReactElement } from 'react'
|
2
2
|
import classnames from 'classnames'
|
3
3
|
import useCollapsible from './useCollapsible'
|
4
4
|
|
@@ -11,9 +11,16 @@ import CollapsibleContext from './context'
|
|
11
11
|
import { IconSizes } from "../pb_icon/_icon"
|
12
12
|
import CollapsibleIcon from './child_kits/CollapsibleIcon'
|
13
13
|
|
14
|
+
type CollapsibleMainProps = {
|
15
|
+
children: React.ReactNode
|
16
|
+
}
|
17
|
+
|
18
|
+
type CollapsibleContentProps = {
|
19
|
+
children: React.ReactNode
|
20
|
+
}
|
14
21
|
|
15
22
|
type CollapsibleProps = {
|
16
|
-
children?:
|
23
|
+
children?: [ReactElement<CollapsibleMainProps>, ReactElement<CollapsibleContentProps>],
|
17
24
|
aria?: {[key: string]: string},
|
18
25
|
className?: string,
|
19
26
|
collapsed?: boolean,
|
@@ -30,7 +37,7 @@ type CollapsibleProps = {
|
|
30
37
|
const Collapsible = ({
|
31
38
|
aria = {},
|
32
39
|
className,
|
33
|
-
children
|
40
|
+
children,
|
34
41
|
collapsed = true,
|
35
42
|
data = {},
|
36
43
|
htmlOptions = {},
|
@@ -48,13 +55,12 @@ const Collapsible = ({
|
|
48
55
|
setIsCollapsed(collapsed)
|
49
56
|
},[collapsed])
|
50
57
|
|
51
|
-
|
52
|
-
|
53
|
-
if (CollapsibleParent.length !== 2) {
|
58
|
+
if (children.length !== 2) {
|
54
59
|
throw new Error('Collapsible requires <CollapsibleMain> and <CollapsibleContent> to function properly.')
|
55
60
|
}
|
56
|
-
|
57
|
-
const
|
61
|
+
|
62
|
+
const FirstChild = children[0]
|
63
|
+
const SecondChild = children[1]
|
58
64
|
|
59
65
|
const Main = FirstChild.type === CollapsibleMain ? FirstChild : null
|
60
66
|
const Content = SecondChild.type === CollapsibleContent ? SecondChild : null
|
@@ -48,3 +48,27 @@ test('returns namespaced additional_class class name', () => {
|
|
48
48
|
const kit = screen.getByTestId(testId)
|
49
49
|
expect(kit).toHaveClass(`${kitClass} additional_class`)
|
50
50
|
})
|
51
|
+
|
52
|
+
test('html structure is correct', () => {
|
53
|
+
const { container } = render(
|
54
|
+
<Collapsible
|
55
|
+
className="additional_class"
|
56
|
+
data={{ testid: testId }}
|
57
|
+
iconColor='lighter'
|
58
|
+
iconSize="lg"
|
59
|
+
>
|
60
|
+
<Collapsible.Main>
|
61
|
+
<div>{'Main Section'}</div>
|
62
|
+
</Collapsible.Main>
|
63
|
+
<Collapsible.Content>
|
64
|
+
<div>
|
65
|
+
{
|
66
|
+
'Lorem ipsum dolor sit amet, consectetur adipiscing elit. In vel erat sed purus hendrerit viverra. Duis et vestibulum metus. Sed consequat ut ante non vehicula. Etiam nunc massa, pharetra vel quam id, posuere rhoncus quam. Quisque imperdiet arcu enim, nec aliquet justo auctor eget. Curabitur in metus nec nunc rhoncus faucibus vitae ac elit. Nulla facilisi. Vestibulum quis pretium nulla. Nulla ut accumsan velit. Duis varius urna sed sem tempor, sit amet fermentum nibh auctor. Praesent lorem arcu, egestas non ante quis, placerat pellentesque lectus.Vestibulum lacinia ipsum quis venenatis tristique. Vivamus suscipit, libero eu fringilla egestas, orci urna commodo arcu, vel gravida turpis ipsum molestie nibh. Donec cursus eu ante sagittis ultrices. Phasellus id sagittis risus. Mauris dapibus neque faucibus, tempor ligula vel, cursus ante. Donec faucibus gravida porta. Nullam egestas est quis aliquam feugiat. Sed eget metus diam. Cras eget placerat libero.'
|
67
|
+
}
|
68
|
+
</div>
|
69
|
+
</Collapsible.Content>
|
70
|
+
</Collapsible>
|
71
|
+
)
|
72
|
+
|
73
|
+
expect(container).toMatchSnapshot()
|
74
|
+
})
|
@@ -3,6 +3,12 @@ import typography from '../tokens/exports/_typography.scss'
|
|
3
3
|
|
4
4
|
import { ThemeProps } from './themeTypes'
|
5
5
|
|
6
|
+
interface CustomTreemapOptions extends Highcharts.SeriesTreemapOptions {
|
7
|
+
traverseUpButton?: {
|
8
|
+
position: { y: number };
|
9
|
+
};
|
10
|
+
}
|
11
|
+
|
6
12
|
const highchartsDarkTheme: ThemeProps = {
|
7
13
|
lang: {
|
8
14
|
thousandsSep: ',',
|
@@ -200,7 +206,7 @@ const highchartsDarkTheme: ThemeProps = {
|
|
200
206
|
traverseUpButton: {
|
201
207
|
position: { y: -50 },
|
202
208
|
},
|
203
|
-
},
|
209
|
+
} as CustomTreemapOptions,
|
204
210
|
},
|
205
211
|
credits: {
|
206
212
|
enabled: false
|
@@ -3,6 +3,13 @@ import typography from '../tokens/exports/_typography.scss'
|
|
3
3
|
|
4
4
|
import { ThemeProps } from './themeTypes'
|
5
5
|
|
6
|
+
interface CustomTreemapOptions extends Highcharts.SeriesTreemapOptions {
|
7
|
+
traverseUpButton?: {
|
8
|
+
position: { y: number };
|
9
|
+
};
|
10
|
+
}
|
11
|
+
|
12
|
+
|
6
13
|
const highchartsTheme: ThemeProps = {
|
7
14
|
lang: {
|
8
15
|
thousandsSep: ',',
|
@@ -150,6 +157,7 @@ const highchartsTheme: ThemeProps = {
|
|
150
157
|
fontSize: typography.text_smaller,
|
151
158
|
color: colors.text_lt_light,
|
152
159
|
fontWeight: typography.regular,
|
160
|
+
textOutline: '2px $white',
|
153
161
|
},
|
154
162
|
},
|
155
163
|
},
|
@@ -198,7 +206,7 @@ const highchartsTheme: ThemeProps = {
|
|
198
206
|
traverseUpButton: {
|
199
207
|
position: { y: -50 },
|
200
208
|
},
|
201
|
-
},
|
209
|
+
} as CustomTreemapOptions,
|
202
210
|
},
|
203
211
|
credits: {
|
204
212
|
enabled: false
|
@@ -37,7 +37,6 @@
|
|
37
37
|
</div>
|
38
38
|
|
39
39
|
<%= javascript_tag do %>
|
40
|
-
window.addEventListener("DOMContentLoaded", () =>
|
41
|
-
|
42
|
-
})
|
40
|
+
window.addEventListener("DOMContentLoaded", () => dialogHelper())
|
41
|
+
window.addEventListener("turbo:frame-load", () => dialogHelper())
|
43
42
|
<% end %>
|