playbook_ui 13.24.0.pre.alpha.play1305drycontenttag2689 → 13.25.0.pre.alpha.PBNTR272Dropdownkitv42769

Sign up to get free protection for your applications and to get access to all the features.
Files changed (173) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/_playbook.scss +2 -0
  3. data/app/pb_kits/playbook/index.js +2 -0
  4. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +1 -1
  5. data/app/pb_kits/playbook/pb_advanced_table/table_body.html.erb +1 -1
  6. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +1 -1
  7. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +1 -1
  8. data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.html.erb +1 -1
  9. data/app/pb_kits/playbook/pb_background/_background.tsx +7 -5
  10. data/app/pb_kits/playbook/pb_background/background.html.erb +0 -1
  11. data/app/pb_kits/playbook/pb_badge/badge.html.erb +1 -1
  12. data/app/pb_kits/playbook/pb_body/_body.tsx +1 -1
  13. data/app/pb_kits/playbook/pb_body/body.html.erb +1 -1
  14. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +1 -1
  15. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +1 -1
  16. data/app/pb_kits/playbook/pb_button/_button.scss +1 -1
  17. data/app/pb_kits/playbook/pb_button/button.html.erb +1 -2
  18. data/app/pb_kits/playbook/pb_button_toolbar/button_toolbar.html.erb +1 -1
  19. data/app/pb_kits/playbook/pb_caption/caption.html.erb +1 -1
  20. data/app/pb_kits/playbook/pb_card/card.html.erb +1 -1
  21. data/app/pb_kits/playbook/pb_card/card_body.html.erb +1 -1
  22. data/app/pb_kits/playbook/pb_card/card_header.html.erb +1 -1
  23. data/app/pb_kits/playbook/pb_checkbox/checkbox.html.erb +1 -1
  24. data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.html.erb +1 -1
  25. data/app/pb_kits/playbook/pb_collapsible/collapsible.html.erb +1 -1
  26. data/app/pb_kits/playbook/pb_collapsible/collapsible_content.html.erb +1 -1
  27. data/app/pb_kits/playbook/pb_collapsible/collapsible_main.html.erb +1 -2
  28. data/app/pb_kits/playbook/pb_contact/contact.html.erb +1 -1
  29. data/app/pb_kits/playbook/pb_currency/currency.html.erb +1 -1
  30. data/app/pb_kits/playbook/pb_currency/docs/_currency_alignment_swift.md +43 -0
  31. data/app/pb_kits/playbook/pb_currency/docs/_currency_props_swift.md +12 -0
  32. data/app/pb_kits/playbook/pb_currency/docs/_currency_size_swift.md +31 -0
  33. data/app/pb_kits/playbook/pb_currency/docs/example.yml +5 -0
  34. data/app/pb_kits/playbook/pb_dashboard_value/dashboard_value.html.erb +1 -1
  35. data/app/pb_kits/playbook/pb_date/date.html.erb +1 -1
  36. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +1 -2
  37. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.html.erb +1 -1
  38. data/app/pb_kits/playbook/pb_date_range_stacked/date_range_stacked.html.erb +1 -1
  39. data/app/pb_kits/playbook/pb_date_range_stacked/docs/_date_range_stacked_default_swift.md +14 -0
  40. data/app/pb_kits/playbook/pb_date_range_stacked/docs/_date_range_stacked_props_swift.md +9 -0
  41. data/app/pb_kits/playbook/pb_date_range_stacked/docs/example.yml +4 -0
  42. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.html.erb +1 -1
  43. data/app/pb_kits/playbook/pb_date_time/date_time.html.erb +1 -1
  44. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.html.erb +1 -1
  45. data/app/pb_kits/playbook/pb_date_year_stacked/date_year_stacked.html.erb +1 -1
  46. data/app/pb_kits/playbook/pb_detail/detail.html.erb +1 -1
  47. data/app/pb_kits/playbook/pb_dialog/_dialog.scss +4 -2
  48. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +1 -1
  49. data/app/pb_kits/playbook/pb_dialog/dialog_body.html.erb +1 -1
  50. data/app/pb_kits/playbook/pb_dialog/dialog_footer.html.erb +1 -1
  51. data/app/pb_kits/playbook/pb_dialog/dialog_header.html.erb +1 -2
  52. data/app/pb_kits/playbook/pb_dialog/docs/example.yml +1 -1
  53. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +181 -0
  54. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +266 -0
  55. data/app/pb_kits/playbook/pb_dropdown/context/index.tsx +5 -0
  56. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.jsx +38 -0
  57. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.md +1 -0
  58. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +87 -0
  59. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.md +1 -0
  60. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx +102 -0
  61. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.md +1 -0
  62. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +104 -0
  63. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.md +5 -0
  64. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.jsx +63 -0
  65. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.md +1 -0
  66. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.jsx +48 -0
  67. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.md +1 -0
  68. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.jsx +77 -0
  69. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.md +1 -0
  70. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_external_control.jsx +62 -0
  71. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_hook.jsx +75 -0
  72. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.jsx +39 -0
  73. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.md +1 -0
  74. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +15 -0
  75. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +10 -0
  76. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +207 -0
  77. data/app/pb_kits/playbook/pb_dropdown/hooks/useDropdown.tsx +17 -0
  78. data/app/pb_kits/playbook/pb_dropdown/hooks/useHandleOnKeydown.tsx +61 -0
  79. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownContainer.tsx +109 -0
  80. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +116 -0
  81. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownTrigger.tsx +190 -0
  82. data/app/pb_kits/playbook/pb_dropdown/utilities/subComponentHelper.tsx +61 -0
  83. data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +1 -1
  84. data/app/pb_kits/playbook/pb_filter/filter.html.erb +1 -1
  85. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.html.erb +1 -1
  86. data/app/pb_kits/playbook/pb_flex/flex.html.erb +1 -1
  87. data/app/pb_kits/playbook/pb_flex/flex_item.html.erb +1 -2
  88. data/app/pb_kits/playbook/pb_form_group/form_group.html.erb +1 -1
  89. data/app/pb_kits/playbook/pb_form_pill/form_pill.html.erb +1 -1
  90. data/app/pb_kits/playbook/pb_hashtag/hashtag.html.erb +1 -1
  91. data/app/pb_kits/playbook/pb_highlight/highlight.html.erb +1 -1
  92. data/app/pb_kits/playbook/pb_home_address_street/home_address_street.html.erb +1 -1
  93. data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.scss +1 -1
  94. data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.tsx +1 -1
  95. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.html.erb +1 -1
  96. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.rb +1 -1
  97. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.test.js +3 -3
  98. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.html.erb +1 -1
  99. data/app/pb_kits/playbook/pb_icon_value/icon_value.html.erb +1 -1
  100. data/app/pb_kits/playbook/pb_label_pill/label_pill.html.erb +1 -1
  101. data/app/pb_kits/playbook/pb_label_value/label_value.html.erb +1 -1
  102. data/app/pb_kits/playbook/pb_layout/body.html.erb +1 -1
  103. data/app/pb_kits/playbook/pb_layout/footer.html.erb +1 -1
  104. data/app/pb_kits/playbook/pb_layout/header.html.erb +1 -1
  105. data/app/pb_kits/playbook/pb_layout/item.html.erb +1 -1
  106. data/app/pb_kits/playbook/pb_layout/layout.html.erb +1 -1
  107. data/app/pb_kits/playbook/pb_layout/sidebar.html.erb +1 -1
  108. data/app/pb_kits/playbook/pb_list/_list_item.tsx +2 -2
  109. data/app/pb_kits/playbook/pb_list/item.html.erb +1 -2
  110. data/app/pb_kits/playbook/pb_list/list.html.erb +1 -3
  111. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.html.erb +1 -1
  112. data/app/pb_kits/playbook/pb_message/message.html.erb +1 -1
  113. data/app/pb_kits/playbook/pb_message/message_mention.html.erb +1 -1
  114. data/app/pb_kits/playbook/pb_multi_level_select/multi_level_select.html.erb +1 -1
  115. data/app/pb_kits/playbook/pb_multiple_users/multiple_users.html.erb +1 -1
  116. data/app/pb_kits/playbook/pb_multiple_users_stacked/multiple_users_stacked.html.erb +1 -1
  117. data/app/pb_kits/playbook/pb_nav/item.html.erb +1 -4
  118. data/app/pb_kits/playbook/pb_nav/nav.html.erb +1 -1
  119. data/app/pb_kits/playbook/pb_online_status/online_status.html.erb +1 -2
  120. data/app/pb_kits/playbook/pb_pagination/pagination.html.erb +1 -1
  121. data/app/pb_kits/playbook/pb_passphrase/passphrase.html.erb +1 -1
  122. data/app/pb_kits/playbook/pb_person/person.html.erb +1 -1
  123. data/app/pb_kits/playbook/pb_person_contact/person_contact.html.erb +1 -1
  124. data/app/pb_kits/playbook/pb_pill/pill.html.erb +1 -1
  125. data/app/pb_kits/playbook/pb_popover/popover.html.erb +1 -1
  126. data/app/pb_kits/playbook/pb_progress_pills/progress_pills.html.erb +1 -2
  127. data/app/pb_kits/playbook/pb_progress_simple/progress_simple.html.erb +1 -2
  128. data/app/pb_kits/playbook/pb_progress_step/progress_step.html.erb +1 -1
  129. data/app/pb_kits/playbook/pb_progress_step/progress_step_item.html.erb +1 -1
  130. data/app/pb_kits/playbook/pb_radio/radio.html.erb +1 -2
  131. data/app/pb_kits/playbook/pb_section_separator/_section_separator.scss +6 -2
  132. data/app/pb_kits/playbook/pb_section_separator/_section_separator_mixin.scss +11 -1
  133. data/app/pb_kits/playbook/pb_section_separator/section_separator.html.erb +1 -1
  134. data/app/pb_kits/playbook/pb_select/select.html.erb +1 -1
  135. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +1 -1
  136. data/app/pb_kits/playbook/pb_selectable_card_icon/selectable_card_icon.html.erb +1 -1
  137. data/app/pb_kits/playbook/pb_selectable_icon/selectable_icon.html.erb +1 -1
  138. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +1 -1
  139. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +1 -1
  140. data/app/pb_kits/playbook/pb_source/source.html.erb +1 -1
  141. data/app/pb_kits/playbook/pb_source/source.test.js +2 -2
  142. data/app/pb_kits/playbook/pb_star_rating/star_rating.html.erb +1 -1
  143. data/app/pb_kits/playbook/pb_stat_change/stat_change.html.erb +1 -1
  144. data/app/pb_kits/playbook/pb_stat_value/stat_value.html.erb +1 -1
  145. data/app/pb_kits/playbook/pb_table/table.html.erb +2 -8
  146. data/app/pb_kits/playbook/pb_table/table_body.html.erb +2 -2
  147. data/app/pb_kits/playbook/pb_table/table_cell.html.erb +2 -2
  148. data/app/pb_kits/playbook/pb_table/table_head.html.erb +2 -2
  149. data/app/pb_kits/playbook/pb_table/table_header.html.erb +2 -3
  150. data/app/pb_kits/playbook/pb_table/table_row.html.erb +2 -2
  151. data/app/pb_kits/playbook/pb_text_input/text_input.html.erb +5 -1
  152. data/app/pb_kits/playbook/pb_textarea/textarea.html.erb +1 -1
  153. data/app/pb_kits/playbook/pb_time/time.html.erb +1 -1
  154. data/app/pb_kits/playbook/pb_time_range_inline/time_range_inline.html.erb +1 -1
  155. data/app/pb_kits/playbook/pb_time_stacked/time_stacked.html.erb +1 -1
  156. data/app/pb_kits/playbook/pb_timeline/item.html.erb +1 -1
  157. data/app/pb_kits/playbook/pb_timeline/timeline.html.erb +1 -1
  158. data/app/pb_kits/playbook/pb_timestamp/timestamp.html.erb +1 -1
  159. data/app/pb_kits/playbook/pb_title/title.html.erb +1 -3
  160. data/app/pb_kits/playbook/pb_title_count/title_count.html.erb +1 -1
  161. data/app/pb_kits/playbook/pb_title_detail/title_detail.html.erb +1 -1
  162. data/app/pb_kits/playbook/pb_toggle/toggle.html.erb +1 -1
  163. data/app/pb_kits/playbook/pb_tooltip/tooltip.html.erb +1 -1
  164. data/app/pb_kits/playbook/pb_user/user.html.erb +1 -1
  165. data/app/pb_kits/playbook/pb_user_badge/user_badge.html.erb +1 -1
  166. data/app/pb_kits/playbook/pb_weekday_stacked/weekday_stacked.html.erb +1 -1
  167. data/app/pb_kits/playbook/playbook-doc.js +2 -0
  168. data/dist/menu.yml +5 -1
  169. data/dist/playbook-rails.js +5 -5
  170. data/lib/playbook/kit_base.rb +1 -1
  171. data/lib/playbook/version.rb +2 -2
  172. metadata +38 -3
  173. /data/app/pb_kits/playbook/pb_dialog/docs/{_dialog_props_table.md → _dialog_props_swift.md} +0 -0
@@ -0,0 +1,61 @@
1
+ import React, { ReactElement } from "react";
2
+ import DropdownTrigger from "../subcomponents/DropdownTrigger";
3
+ import DropdownContainer from "../subcomponents/DropdownContainer";
4
+
5
+ type PrepareComponentsProps = {
6
+ children: React.ReactChild[] | React.ReactChild;
7
+ container: React.ReactChild;
8
+ dark?: boolean;
9
+ hasContainerSubcomponent: boolean;
10
+ hasTriggerSubcomponent: boolean;
11
+ otherChildren: React.ReactChild[];
12
+ trigger: React.ReactChild;
13
+ };
14
+
15
+ export const separateChildComponents = (children: React.ReactChild[] | React.ReactChild | ReactElement[]) => {
16
+ let trigger: React.ReactChild = null;
17
+ let container: React.ReactChild = null;
18
+ const otherChildren: React.ReactChild[] = [];
19
+
20
+ React.Children.forEach(children, (child) => {
21
+ if (child && (child as ReactElement).type === DropdownTrigger) {
22
+ trigger = child;
23
+ } else if (child && (child as ReactElement).type === DropdownContainer) {
24
+ container = child;
25
+ } else {
26
+ otherChildren.push(child);
27
+ }
28
+ });
29
+
30
+ return { trigger, container, otherChildren };
31
+ };
32
+
33
+ export const prepareSubcomponents = ({
34
+ children,
35
+ hasTriggerSubcomponent,
36
+ hasContainerSubcomponent,
37
+ trigger,
38
+ container,
39
+ otherChildren,
40
+ dark
41
+ }: PrepareComponentsProps) => {
42
+ const componentsToRender = [];
43
+
44
+ if (!hasTriggerSubcomponent && !hasContainerSubcomponent) {
45
+ componentsToRender.push(<DropdownTrigger dark={dark}/>);
46
+ componentsToRender.push(<DropdownContainer dark={dark}>{children}</DropdownContainer>);
47
+ } else if (!hasTriggerSubcomponent && hasContainerSubcomponent) {
48
+ componentsToRender.push(<DropdownTrigger dark={dark}/>);
49
+ componentsToRender.push(children);
50
+ } else if (hasTriggerSubcomponent && !hasContainerSubcomponent) {
51
+ componentsToRender.push(trigger);
52
+ componentsToRender.push(
53
+ <DropdownContainer dark={dark}>{otherChildren}</DropdownContainer>
54
+ );
55
+ } else {
56
+ componentsToRender.push(trigger);
57
+ componentsToRender.push(container);
58
+ }
59
+
60
+ return componentsToRender;
61
+ };
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("form_group", props: {cursor: "pointer", full_width: object.full_width}) do %>
3
3
  <label for="upload-<%= object.id %>" class="pb_button_kit_secondary_inline_enabled"><%= "#{object.label}" %></label>
4
4
  <%= pb_rails("text_input", props: {
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= object.wrapper do %>
3
3
  <%= pb_rails("flex", props: { orientation: "row", padding_right: "lg", vertical: "center" }) do %>
4
4
  <% if (object.template != "sort_only") %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("icon", props: { icon: object.icon_value, classname: "pb_icon", fixed_width: true }) %>
3
3
 
4
4
  <% if content %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,5 +1,4 @@
1
1
  <%= pb_content_tag(:div,
2
- style: object.style_value,
3
- **combined_html_options) do %>
2
+ style: object.style_value) do %>
4
3
  <%= content.presence %>
5
4
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, class: object.classname + object.size_class, **combined_html_options) do %>
1
+ <%= pb_content_tag(:div, class: object.classname + object.size_class) do %>
2
2
  <% if object.name.present? %>
3
3
  <%= pb_rails("avatar", props: { name: object.name, image_url: object.avatar_url, size: "xs" }) %>
4
4
  <%= pb_rails("title", props: { text: object.name, size: 4, classname: "pb_form_pill_text" }) %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:span, **combined_html_options) do %>
1
+ <%= pb_content_tag(:span) do %>
2
2
  <%= link_to object.url, target: object.link_option do %>
3
3
  <%= pb_rails("badge", props: { dark: object.dark, variant: "primary", text: object.hashtag_text }) %>
4
4
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:span, **combined_html_options) do %>
1
+ <%= pb_content_tag(:span) do %>
2
2
  <mark>
3
3
  <%= content.presence || object.text %>
4
4
  </mark>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("home_address_street/#{emphasis}_emphasis", props: object.send("#{emphasis}_emphasis_props")) %>
3
3
  <% end %>
4
4
 
@@ -51,7 +51,7 @@ $pb_icon_circle_sizes: (
51
51
  }
52
52
 
53
53
  @each $name, $size in $pb_icon_circle_sizes {
54
- &[class*=_#{$name}] {
54
+ &[class*=_size_#{$name}] {
55
55
  width: $size;
56
56
  height: $size;
57
57
  border-radius: $size/2;
@@ -43,7 +43,7 @@ const IconCircle = (props: IconCircleProps) => {
43
43
  const ariaProps = buildAriaProps(aria)
44
44
  const dataProps = buildDataProps(data)
45
45
  const htmlProps = buildHtmlProps(htmlOptions)
46
- const classes = classnames(buildCss('pb_icon_circle_kit', size, variant), globalProps(props), className)
46
+ const classes = classnames(buildCss('pb_icon_circle_kit', `size_${size}`, variant), globalProps(props), className)
47
47
 
48
48
 
49
49
  return (
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("icon", props: { dark: object.dark, icon: object.icon, fixed_width: true }) %>
3
3
  <% end %>
@@ -14,7 +14,7 @@ module Playbook
14
14
  default: "default"
15
15
 
16
16
  def classname
17
- generate_classname("pb_icon_circle_kit", size, variant)
17
+ generate_classname("pb_icon_circle_kit", "size_#{size}", variant)
18
18
  end
19
19
  end
20
20
  end
@@ -16,7 +16,7 @@ describe("IconCircle Kit", () => {
16
16
  )
17
17
 
18
18
  const kit = screen.getByTestId(testId)
19
- expect(kit).toHaveClass("pb_icon_circle_kit_md_default")
19
+ expect(kit).toHaveClass("pb_icon_circle_kit_size_md_default")
20
20
  })
21
21
 
22
22
  test("renders icon", () => {
@@ -66,7 +66,7 @@ describe("IconCircle Kit", () => {
66
66
  />
67
67
  )
68
68
  const kit = screen.getByTestId(testId)
69
- expect(kit).toHaveClass(`pb_icon_circle_kit_sm_${colorVariant}`)
69
+ expect(kit).toHaveClass(`pb_icon_circle_kit_size_sm_${colorVariant}`)
70
70
 
71
71
  cleanup()
72
72
  })
@@ -89,7 +89,7 @@ describe("IconCircle Kit", () => {
89
89
  />
90
90
  )
91
91
  const kit = screen.getByTestId(testId)
92
- expect(kit).toHaveClass(`pb_icon_circle_kit_${sizeVariant}_default`)
92
+ expect(kit).toHaveClass(`pb_icon_circle_kit_size_${sizeVariant}_default`)
93
93
 
94
94
  cleanup()
95
95
  })
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
 
3
3
  <%= pb_rails("icon_circle", props: {
4
4
  dark: object.dark,
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("body", props: { color: "light", dark: object.dark }) do %>
3
3
  <%= pb_rails("icon", props: { icon: object.icon, fixed_width: true }) %>
4
4
  <%= object.text %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("caption", props: { text: object.label, classname: "pb_label_pill_label"}) %>
3
3
  <%= pb_rails("pill", props: { text: object.pill_value, variant: object.variant, classname: "pb_label_pill_pill" }) %>
4
4
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("caption", props: { text: object.label, dark: object.dark }) %>
3
3
  <% if object.variant == "details" %>
4
4
  <%= pb_rails("flex", props: {inline: true, vertical: "center"}) do %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(object.tag, **combined_html_options) do %>
1
+ <%= pb_content_tag(object.tag) do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(object.tag, **combined_html_options) do %>
1
+ <%= pb_content_tag(object.tag) do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(object.tag, **combined_html_options) do %>
1
+ <%= pb_content_tag(object.tag) do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= content %>
3
3
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,7 +1,7 @@
1
1
  import React from 'react'
2
2
  import classnames from 'classnames'
3
3
  import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props'
4
- import { globalProps } from '../utilities/globalProps'
4
+ import { globalProps, GlobalProps } from '../utilities/globalProps'
5
5
 
6
6
  type ListItemProps = {
7
7
  aria?: { [key: string]: string },
@@ -11,7 +11,7 @@ type ListItemProps = {
11
11
  htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
12
12
  id?: string,
13
13
  tabIndex?: number,
14
- }
14
+ } & GlobalProps
15
15
 
16
16
  const ListItem = (props: ListItemProps) => {
17
17
  const {
@@ -1,5 +1,4 @@
1
1
  <%= pb_content_tag(:li,
2
- tabindex: object.tabindex,
3
- **combined_html_options) do %>
2
+ tabindex: object.tabindex) do %>
4
3
  <%= content.presence %>
5
4
  <% end %>
@@ -1,9 +1,7 @@
1
1
  <%= content_tag(:div, class: object.list_classname) do %>
2
2
  <%= pb_content_tag(:"#{object.ordered_class}",
3
3
  role: object.role,
4
- tabindex: object.tabindex,
5
- **combined_html_options
6
- ) do %>
4
+ tabindex: object.tabindex) do %>
7
5
  <%= content.presence %>
8
6
  <% end %>
9
7
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("body", props: { color: "light", dark: object.dark }) do %>
3
3
  <%= pb_rails("icon", props: { aria: { label: "loading icon" }, fixed_width: true, icon: "spinner", pulse: true }) %> Loading
4
4
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <% if object.valid? %>
3
3
  <%= pb_rails("avatar", props: {
4
4
  name: object.avatar_name,
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= content %>
3
3
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= react_component("MultiLevelSelect", object.multi_level_select_options) %>
3
3
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <% object.users.take(object.display_count).each do |user| %>
3
3
  <%= pb_rails("avatar", props: user.merge({size: object.size, classname: "pb_multiple_users_item", dark: object.dark}) ) %>
4
4
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("avatar", props: object.users[0].merge({size: "xs", classname: "pb_multiple_users_stacked_item", dark: object.dark}) ) %>
3
3
 
4
4
  <% unless object.only_one %>
@@ -5,8 +5,7 @@
5
5
  dark: object.dark,
6
6
  href: object.link && object.link,
7
7
  target: object.link && object.target,
8
- **combined_html_options
9
- ) do %>
8
+ ) do %>
10
9
  <% if object.image_url %>
11
10
  <%= pb_rails("image", props: { url: object.image_url, classname: "pb_nav_img_wrapper_collapsible" }) %>
12
11
  <% end %>
@@ -24,8 +23,6 @@
24
23
  <% end %>
25
24
  <% else %>
26
25
  <%= pb_content_tag(object.tag,
27
- **combined_html_options,
28
- dark: object.dark,
29
26
  href: object.link && object.link,
30
27
  target: object.link && object.target
31
28
  ) do %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:nav, **combined_html_options) do %>
1
+ <%= pb_content_tag(:nav) do %>
2
2
  <% if object.title %>
3
3
  <%= content_tag(:div, class: "pb_nav_list_title") do %>
4
4
  <%= content_tag(:a, class: "pb_nav_list_item_link_text", href: object.link) do %>
@@ -1,4 +1,3 @@
1
1
  <%= pb_content_tag(:div,
2
- aria: object.aria.merge!(label: object.status),
3
- **combined_html_options) do %>
2
+ aria: object.aria.merge!(label: object.status)) do %>
4
3
  <% end %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= will_paginate object.model, renderer: Playbook::Pagination::Rails %>
3
3
  <% end %>
@@ -1 +1 @@
1
- <%= react_component('Passphrase', object.passphrase_options, class: object.classname, **combined_html_options) %>
1
+ <%= react_component('Passphrase', object.passphrase_options, class: object.classname) %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("body", props: {
3
3
  tag: "span",
4
4
  classname: "pb_person_first" }) { object.first_name } %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("person", props: {
3
3
  first_name: object.first_name,
4
4
  last_name: object.last_name,
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("title", props: { text: object.display_text, tag: "div", size: 4, classname: "pb_pill_text" }) %>
3
3
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <div class="pb_popover_tooltip hide" id="<%= object.tooltip_id %>" role="tooltip" style="<%= object.z_index_helper %>">
3
3
  <div class="pb_popover_body <%= object.width_height_class_helper %> <%= object.popover_spacing_helper %>" style="<%= object.width_height_helper %>">
4
4
  <%= content.presence %>
@@ -1,6 +1,5 @@
1
1
  <%= pb_content_tag(:div,
2
- aria: object.aria_attributes,
3
- **combined_html_options) do %>
2
+ aria: object.aria_attributes) do %>
4
3
 
5
4
  <div class="progress_pills_status">
6
5
  <% object.with_status do |status| %>
@@ -1,8 +1,7 @@
1
1
  <%= content_tag(:div, class: object.wrapper_classname) do %>
2
2
  <%= pb_content_tag(:div,
3
3
  data: object.data_values,
4
- style: object.style,
5
- **combined_html_options) do %>
4
+ style: object.style) do %>
6
5
  <%= content_tag(:div, "",
7
6
  class: "progress_simple_value",
8
7
  style: object.value_style) %>
@@ -1,3 +1,3 @@
1
- <%= pb_content_tag(:ul, **combined_html_options) do %>
1
+ <%= pb_content_tag(:ul) do %>
2
2
  <%= content.presence %>
3
3
  <% end %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:li, **combined_html_options) do %>
1
+ <%= pb_content_tag(:li) do %>
2
2
  <div class="box" style="max-width: min-content;" id="<%= object.tooltip_trigger_class %>">
3
3
  <div class="circle">
4
4
  <%= pb_rails("icon", props: { icon: object.icon, size: "xs" }) if object.icon.present? %>
@@ -1,6 +1,5 @@
1
1
  <%= pb_content_tag(:label,
2
- checked: object.checked,
3
- **combined_html_options) do %>
2
+ checked: object.checked) do %>
4
3
 
5
4
  <% if content.present? %>
6
5
  <%= content %>
@@ -47,8 +47,7 @@ $section_colors_dark: (
47
47
 
48
48
  &[class*=_dashed] {
49
49
  &::before, &::after {
50
- border: 1px dashed $border_light;
51
- background: none;
50
+ @include section_separator_dashed(false);
52
51
  }
53
52
  }
54
53
 
@@ -66,5 +65,10 @@ $section_colors_dark: (
66
65
  @include section_separator_vertical(true);
67
66
  }
68
67
  }
68
+ &[class*=_dashed] {
69
+ &::before, &::after {
70
+ @include section_separator_dashed(true);
71
+ }
72
+ }
69
73
  }
70
74
  }
@@ -9,7 +9,7 @@
9
9
  }
10
10
  content: "";
11
11
  height: 100%;
12
- width: 1px;
12
+ width: 1.9px;
13
13
  position: initial;
14
14
  z-index: 0;
15
15
  }
@@ -21,3 +21,13 @@
21
21
  background: $border_dark;
22
22
  }
23
23
  }
24
+
25
+ @mixin section_separator_dashed($dark: false) {
26
+ @if $dark == false {
27
+ border: 1px dashed $border_light;
28
+ background: none;
29
+ } @else {
30
+ border: 1px dashed $border_dark;
31
+ background: none;
32
+ }
33
+ }
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <% if object.orientation === 'horizontal' %>
3
3
  <% if content %>
4
4
  <%= content %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <% if object.label %>
3
3
  <label class="pb_select_kit_label" for="<%= object.name %>">
4
4
  <%= pb_rails("caption", props: { text: object.label }) %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
 
3
3
  <% if object.multi %>
4
4
  <%= check_box_tag(object.name, object.value, object.checked, object.additional_input_options) %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
 
3
3
  <%= pb_rails("selectable_card", props: {
4
4
  input_id: object.input_id,
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
 
3
3
  <% if object.inputs == "disabled" %>
4
4
 
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("list") do %>
3
3
  <% object.items.each do |item| %>
4
4
  <%= pb_rails("selectable_list/selectable_list_item", props: item.merge(variant: object.variant, id: object.get_id(item)) )%>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:li, **combined_html_options) do %>
1
+ <%= pb_content_tag(:li) do %>
2
2
  <% if object.variant == "radio"%>
3
3
  <%= pb_rails("radio", props: { text: object.text, checked: object.checked, input_options: object.input_options } ) %>
4
4
  <% if content.present? %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <div class="pb__source_layout">
3
3
  <% if !object.hide_icon %>
4
4
  <% if object.show_icon? %>
@@ -52,13 +52,13 @@ test('should pass source prop', () => {
52
52
  test('should not hide icon by default', () => {
53
53
  render(<SourceDefault />)
54
54
  const kit = screen.getByTestId(testId)
55
- expect(kit.querySelector('.pb_icon_circle_kit_sm_default')).toBeTruthy()
55
+ expect(kit.querySelector('.pb_icon_circle_kit_size_sm_default')).toBeTruthy()
56
56
  })
57
57
 
58
58
  test('should hide icon', () => {
59
59
  render(<SourceDefault hideIcon />)
60
60
  const kit = screen.getByTestId(testId)
61
- expect(kit.querySelector('.pb_icon_circle_kit_sm_default')).toBeFalsy()
61
+ expect(kit.querySelector('.pb_icon_circle_kit_size_sm_default')).toBeFalsy()
62
62
  })
63
63
 
64
64
  test('should pass user prop', () => {
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <% if layout_option == "number" %>
3
3
  <% case object.size %>
4
4
  <% when "xs", "sm" %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <%= pb_rails("body", props: { status: object.status }) do %>
3
3
  <%= pb_rails("icon", props: { fixed_width: true, icon: object.returned_icon }) if object.returned_icon %>
4
4
  <%= "#{object.value}%" if object.value %>
@@ -1,4 +1,4 @@
1
- <%= pb_content_tag(:div, **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
2
2
  <div class="pb_stat_value_wrapper">
3
3
  <%= pb_rails "title", props: {
4
4
  classname: "pb_stat_value_kit",
@@ -1,16 +1,10 @@
1
1
  <%= content_tag(:div) do %>
2
2
  <% if object.tag == "table" %>
3
- <%= pb_content_tag(:table,
4
- **combined_html_options) do %>
3
+ <%= pb_content_tag(:table) do %>
5
4
  <%= content.presence %>
6
5
  <% end %>
7
6
  <% else %>
8
- <%= content_tag(:div,
9
- aria: object.aria,
10
- class: object.classname,
11
- data: object.data,
12
- id: object.id,
13
- **combined_html_options) do %>
7
+ <%= pb_content_tag do %>
14
8
  <%= content.presence %>
15
9
  <% end %>
16
10
  <% end %>