playbook_ui 13.26.0 → 13.27.0.pre.alpha.PBNTR294paginationstylingfix2899

Sign up to get free protection for your applications and to get access to all the features.
Files changed (195) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +14 -0
  3. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +14 -10
  4. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta.html.erb +33 -0
  5. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta.md +24 -0
  6. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_default.md +5 -0
  7. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +2 -2
  8. data/app/pb_kits/playbook/pb_advanced_table/index.js +78 -0
  9. data/app/pb_kits/playbook/pb_advanced_table/table_body.html.erb +9 -5
  10. data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +4 -2
  11. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +6 -2
  12. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +9 -4
  13. data/app/pb_kits/playbook/pb_avatar/Utilities/GetPlacementPropsHelper.tsx +60 -0
  14. data/app/pb_kits/playbook/pb_avatar/_avatar.scss +16 -0
  15. data/app/pb_kits/playbook/pb_avatar/_avatar.tsx +86 -21
  16. data/app/pb_kits/playbook/pb_avatar/avatar.html.erb +26 -3
  17. data/app/pb_kits/playbook/pb_avatar/avatar.rb +45 -0
  18. data/app/pb_kits/playbook/pb_avatar/avatar.test.js +47 -0
  19. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_badge_component_overlay.html.erb +51 -0
  20. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_badge_component_overlay.jsx +56 -0
  21. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_badge_component_overlay.md +3 -0
  22. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_circle_icon_component_overlay.html.erb +51 -0
  23. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_circle_icon_component_overlay.jsx +58 -0
  24. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_circle_icon_component_overlay.md +3 -0
  25. data/app/pb_kits/playbook/pb_avatar/docs/example.yml +4 -0
  26. data/app/pb_kits/playbook/pb_avatar/docs/index.js +2 -0
  27. data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.html.erb +6 -1
  28. data/app/pb_kits/playbook/pb_background/background.html.erb +11 -2
  29. data/app/pb_kits/playbook/pb_badge/badge.html.erb +6 -1
  30. data/app/pb_kits/playbook/pb_body/_body.scss +3 -0
  31. data/app/pb_kits/playbook/pb_body/_body_mixins.scss +1 -1
  32. data/app/pb_kits/playbook/pb_body/body.html.erb +6 -1
  33. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +6 -1
  34. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +7 -2
  35. data/app/pb_kits/playbook/pb_button/_button_mixins.scss +3 -3
  36. data/app/pb_kits/playbook/pb_button/button.html.erb +3 -2
  37. data/app/pb_kits/playbook/pb_button_toolbar/button_toolbar.html.erb +7 -2
  38. data/app/pb_kits/playbook/pb_caption/_caption_mixin.scss +1 -1
  39. data/app/pb_kits/playbook/pb_caption/caption.html.erb +6 -1
  40. data/app/pb_kits/playbook/pb_card/_card_mixin.scss +5 -0
  41. data/app/pb_kits/playbook/pb_card/card.html.erb +7 -1
  42. data/app/pb_kits/playbook/pb_card/card.rb +1 -1
  43. data/app/pb_kits/playbook/pb_card/card_body.html.erb +6 -1
  44. data/app/pb_kits/playbook/pb_card/card_header.html.erb +6 -1
  45. data/app/pb_kits/playbook/pb_card/docs/_card_background.html.erb +20 -0
  46. data/app/pb_kits/playbook/pb_card/docs/_card_background.jsx +41 -1
  47. data/app/pb_kits/playbook/pb_card/docs/_card_background.md +1 -1
  48. data/app/pb_kits/playbook/pb_card/docs/_card_header.html.erb +1 -1
  49. data/app/pb_kits/playbook/pb_card/docs/_card_header.md +1 -1
  50. data/app/pb_kits/playbook/pb_card/docs/_card_highlight.md +1 -1
  51. data/app/pb_kits/playbook/pb_checkbox/checkbox.html.erb +6 -1
  52. data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.html.erb +6 -1
  53. data/app/pb_kits/playbook/pb_collapsible/collapsible.html.erb +6 -1
  54. data/app/pb_kits/playbook/pb_collapsible/collapsible_content.html.erb +6 -1
  55. data/app/pb_kits/playbook/pb_collapsible/collapsible_main.html.erb +7 -1
  56. data/app/pb_kits/playbook/pb_contact/contact.html.erb +6 -1
  57. data/app/pb_kits/playbook/pb_currency/currency.html.erb +6 -1
  58. data/app/pb_kits/playbook/pb_dashboard_value/dashboard_value.html.erb +6 -1
  59. data/app/pb_kits/playbook/pb_date/date.html.erb +6 -1
  60. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +6 -2
  61. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.html.erb +5 -1
  62. data/app/pb_kits/playbook/pb_date_range_stacked/date_range_stacked.html.erb +5 -1
  63. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.html.erb +5 -1
  64. data/app/pb_kits/playbook/pb_date_time/date_time.html.erb +6 -1
  65. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.html.erb +7 -1
  66. data/app/pb_kits/playbook/pb_date_year_stacked/date_year_stacked.html.erb +5 -1
  67. data/app/pb_kits/playbook/pb_detail/_detail_mixins.scss +1 -1
  68. data/app/pb_kits/playbook/pb_detail/detail.html.erb +6 -1
  69. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +6 -1
  70. data/app/pb_kits/playbook/pb_dialog/dialog_body.html.erb +7 -2
  71. data/app/pb_kits/playbook/pb_dialog/dialog_footer.html.erb +5 -1
  72. data/app/pb_kits/playbook/pb_dialog/dialog_header.html.erb +6 -2
  73. data/app/pb_kits/playbook/pb_docs/kit_example.html.erb +3 -3
  74. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +3 -2
  75. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +4 -2
  76. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.html.erb +10 -0
  77. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure.html.erb +17 -0
  78. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure.md +3 -3
  79. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +1 -1
  80. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx +1 -1
  81. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.html.erb +60 -0
  82. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +1 -1
  83. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.html.erb +45 -0
  84. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.html.erb +17 -0
  85. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.html.erb +47 -0
  86. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.html.erb +10 -0
  87. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +9 -2
  88. data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +26 -0
  89. data/app/pb_kits/playbook/pb_dropdown/dropdown.rb +20 -0
  90. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.html.erb +21 -0
  91. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.rb +19 -0
  92. data/app/pb_kits/playbook/pb_dropdown/dropdown_option.html.erb +27 -0
  93. data/app/pb_kits/playbook/pb_dropdown/dropdown_option.rb +22 -0
  94. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.html.erb +43 -0
  95. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.rb +30 -0
  96. data/app/pb_kits/playbook/pb_dropdown/index.js +153 -0
  97. data/app/pb_kits/playbook/pb_dropdown/keyboard_accessibility.js +77 -0
  98. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +4 -2
  99. data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +6 -1
  100. data/app/pb_kits/playbook/pb_filter/filter.html.erb +5 -1
  101. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.html.erb +6 -1
  102. data/app/pb_kits/playbook/pb_flex/flex.html.erb +5 -1
  103. data/app/pb_kits/playbook/pb_flex/flex_item.html.erb +6 -2
  104. data/app/pb_kits/playbook/pb_form_group/_form_group.scss +15 -0
  105. data/app/pb_kits/playbook/pb_form_group/form_group.html.erb +6 -1
  106. data/app/pb_kits/playbook/pb_form_pill/form_pill.html.erb +1 -1
  107. data/app/pb_kits/playbook/pb_hashtag/hashtag.html.erb +6 -1
  108. data/app/pb_kits/playbook/pb_highlight/highlight.html.erb +5 -1
  109. data/app/pb_kits/playbook/pb_home_address_street/home_address_street.html.erb +5 -1
  110. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.html.erb +7 -2
  111. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.html.erb +6 -1
  112. data/app/pb_kits/playbook/pb_icon_value/icon_value.html.erb +6 -1
  113. data/app/pb_kits/playbook/pb_label_pill/label_pill.html.erb +6 -1
  114. data/app/pb_kits/playbook/pb_label_value/label_value.html.erb +6 -1
  115. data/app/pb_kits/playbook/pb_layout/body.html.erb +5 -1
  116. data/app/pb_kits/playbook/pb_layout/footer.html.erb +5 -1
  117. data/app/pb_kits/playbook/pb_layout/header.html.erb +5 -1
  118. data/app/pb_kits/playbook/pb_layout/item.html.erb +5 -1
  119. data/app/pb_kits/playbook/pb_layout/layout.html.erb +5 -1
  120. data/app/pb_kits/playbook/pb_layout/sidebar.html.erb +5 -1
  121. data/app/pb_kits/playbook/pb_list/item.html.erb +8 -2
  122. data/app/pb_kits/playbook/pb_list/list.html.erb +8 -2
  123. data/app/pb_kits/playbook/pb_loading_inline/_loading_inline.tsx +3 -1
  124. data/app/pb_kits/playbook/pb_loading_inline/docs/_loading_inline_custom.html.erb +13 -0
  125. data/app/pb_kits/playbook/pb_loading_inline/docs/_loading_inline_custom.jsx +26 -0
  126. data/app/pb_kits/playbook/pb_loading_inline/docs/{_loading_inline_light.html.erb → _loading_inline_default.html.erb} +2 -2
  127. data/app/pb_kits/playbook/pb_loading_inline/docs/{_loading_inline_light.jsx → _loading_inline_default.jsx} +2 -2
  128. data/app/pb_kits/playbook/pb_loading_inline/docs/example.yml +4 -2
  129. data/app/pb_kits/playbook/pb_loading_inline/docs/index.js +2 -1
  130. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.html.erb +7 -2
  131. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.rb +1 -0
  132. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.test.js +14 -0
  133. data/app/pb_kits/playbook/pb_message/message.html.erb +6 -1
  134. data/app/pb_kits/playbook/pb_message/message_mention.html.erb +6 -1
  135. data/app/pb_kits/playbook/pb_multi_level_select/multi_level_select.html.erb +6 -1
  136. data/app/pb_kits/playbook/pb_multiple_users/_multiple_users.scss +8 -0
  137. data/app/pb_kits/playbook/pb_multiple_users/multiple_users.html.erb +6 -1
  138. data/app/pb_kits/playbook/pb_multiple_users_stacked/multiple_users_stacked.html.erb +6 -1
  139. data/app/pb_kits/playbook/pb_nav/item.html.erb +14 -3
  140. data/app/pb_kits/playbook/pb_nav/nav.html.erb +6 -1
  141. data/app/pb_kits/playbook/pb_online_status/online_status.html.erb +6 -2
  142. data/app/pb_kits/playbook/pb_pagination/_pagination.scss +1 -1
  143. data/app/pb_kits/playbook/pb_pagination/pagination.html.erb +6 -1
  144. data/app/pb_kits/playbook/pb_passphrase/passphrase.html.erb +1 -1
  145. data/app/pb_kits/playbook/pb_person/person.html.erb +12 -7
  146. data/app/pb_kits/playbook/pb_person_contact/person_contact.html.erb +6 -1
  147. data/app/pb_kits/playbook/pb_pill/pill.html.erb +6 -1
  148. data/app/pb_kits/playbook/pb_popover/popover.html.erb +6 -1
  149. data/app/pb_kits/playbook/pb_progress_pills/progress_pills.html.erb +6 -2
  150. data/app/pb_kits/playbook/pb_progress_simple/progress_simple.html.erb +6 -3
  151. data/app/pb_kits/playbook/pb_progress_step/progress_step.html.erb +5 -1
  152. data/app/pb_kits/playbook/pb_progress_step/progress_step_item.html.erb +5 -1
  153. data/app/pb_kits/playbook/pb_radio/radio.html.erb +8 -2
  154. data/app/pb_kits/playbook/pb_section_separator/section_separator.html.erb +6 -1
  155. data/app/pb_kits/playbook/pb_select/select.html.erb +5 -1
  156. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +5 -1
  157. data/app/pb_kits/playbook/pb_selectable_card_icon/selectable_card_icon.html.erb +4 -1
  158. data/app/pb_kits/playbook/pb_selectable_icon/selectable_icon.html.erb +5 -1
  159. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +6 -1
  160. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +6 -1
  161. data/app/pb_kits/playbook/pb_source/source.html.erb +5 -1
  162. data/app/pb_kits/playbook/pb_star_rating/star_rating.html.erb +5 -1
  163. data/app/pb_kits/playbook/pb_stat_change/stat_change.html.erb +5 -1
  164. data/app/pb_kits/playbook/pb_stat_value/stat_value.html.erb +5 -1
  165. data/app/pb_kits/playbook/pb_table/table.html.erb +12 -2
  166. data/app/pb_kits/playbook/pb_table/table_body.html.erb +16 -6
  167. data/app/pb_kits/playbook/pb_table/table_cell.html.erb +16 -6
  168. data/app/pb_kits/playbook/pb_table/table_head.html.erb +16 -6
  169. data/app/pb_kits/playbook/pb_table/table_header.html.erb +13 -4
  170. data/app/pb_kits/playbook/pb_table/table_row.html.erb +16 -6
  171. data/app/pb_kits/playbook/pb_textarea/textarea.html.erb +5 -1
  172. data/app/pb_kits/playbook/pb_time/time.html.erb +5 -1
  173. data/app/pb_kits/playbook/pb_time_range_inline/time_range_inline.html.erb +5 -1
  174. data/app/pb_kits/playbook/pb_time_stacked/time_stacked.html.erb +5 -1
  175. data/app/pb_kits/playbook/pb_timeline/item.html.erb +7 -3
  176. data/app/pb_kits/playbook/pb_timeline/timeline.html.erb +5 -1
  177. data/app/pb_kits/playbook/pb_timestamp/timestamp.html.erb +6 -1
  178. data/app/pb_kits/playbook/pb_title/_title.scss +5 -1
  179. data/app/pb_kits/playbook/pb_title/title.html.erb +6 -1
  180. data/app/pb_kits/playbook/pb_title_count/title_count.html.erb +6 -1
  181. data/app/pb_kits/playbook/pb_title_detail/title_detail.html.erb +5 -1
  182. data/app/pb_kits/playbook/pb_toggle/toggle.html.erb +6 -1
  183. data/app/pb_kits/playbook/pb_tooltip/_tooltip.tsx +1 -1
  184. data/app/pb_kits/playbook/pb_tooltip/tooltip.html.erb +5 -1
  185. data/app/pb_kits/playbook/pb_user/user.html.erb +6 -1
  186. data/app/pb_kits/playbook/pb_user_badge/user_badge.html.erb +6 -1
  187. data/app/pb_kits/playbook/pb_weekday_stacked/weekday_stacked.html.erb +6 -1
  188. data/app/pb_kits/playbook/playbook-rails.js +6 -0
  189. data/app/pb_kits/playbook/tokens/_titles.scss +5 -1
  190. data/dist/menu.yml +1 -1
  191. data/dist/playbook-rails.js +6 -6
  192. data/lib/playbook/kit_base.rb +1 -1
  193. data/lib/playbook/version.rb +2 -2
  194. metadata +36 -8
  195. data/app/pb_kits/playbook/pb_advanced_table/docs/_description.md +0 -1
@@ -1,4 +1,9 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ id: object.id,
4
+ data: object.data,
5
+ class: object.classname,
6
+ **combined_html_options) do %>
2
7
  <%= pb_rails("caption", props: object.caption_props) %>
3
8
 
4
9
  <div class=<%= "pb_currency_wrapper#{object.variant_class || object.emphasized_class}" %>>
@@ -1,4 +1,9 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.id,
6
+ **combined_html_options) do %>
2
7
  <% if object.stat_label.present? %>
3
8
  <%= pb_rails("body", props: { color: "light", text: object.stat_label } ) %>
4
9
  <% end %>
@@ -1,4 +1,9 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ aria: object.aria,
6
+ **combined_html_options) do %>
2
7
 
3
8
  <% if object.unstyled %>
4
9
  <!-- icon -->
@@ -1,5 +1,9 @@
1
- <%= pb_content_tag(:div,
2
- class: object.classname + object.error_class) do %>
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ class: object.classname + object.error_class,
4
+ data: object.data,
5
+ id: object.id,
6
+ **combined_html_options) do %>
3
7
  <div class="input_wrapper">
4
8
  <% if content.present? %>
5
9
  <%= content %>
@@ -1,4 +1,8 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
  <div class="pb_date_range_inline_wrapper">
3
7
  <% if object.icon == true %>
4
8
  <%= pb_rails(object.text_kit, props: { tag: "span", dark: object.dark, color: object.icon_color, text: pb_rails("icon", props: { icon: "calendar-alt", fixed_width: true, size: object.size, classname: "pb_date_range_inline_icon" }) }) %>
@@ -1,4 +1,8 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
 
3
7
  <%= pb_rails("flex", props: {vertical: "center"}) do %>
4
8
  <%= pb_rails("flex/flex_item") do %>
@@ -1,4 +1,8 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
 
3
7
  <% if object.bold == false %>
4
8
 
@@ -1,4 +1,9 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ id: object.id,
4
+ data: object.data,
5
+ class: object.classname,
6
+ **combined_html_options) do %>
2
7
 
3
8
  <%= pb_rails("flex", props: {
4
9
  orientation: "row",
@@ -1,4 +1,10 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ aria: object.aria,
6
+ **combined_html_options) do %>
7
+
2
8
  <%= pb_rails("flex", props: {classname: "flex-container", vertical: "stretch"}) do %>
3
9
  <%= pb_rails("body", props: {classname: "flex-item"}) do %>
4
10
  <%= pb_rails("date_stacked", props: { date: object.date_time_value, size: "sm", align: "right", bold: true, dark: object.dark }) %>
@@ -1,4 +1,8 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
  <%= pb_rails("title", props: { text: object.day_month, size: 4, dark: object.dark }) %>
3
7
  <%= pb_rails("body", props: { text: object.year, size: 4, color: "light", dark: object.dark }) %>
4
8
  <% end %>
@@ -15,7 +15,7 @@ $pb_dark_detail_colors: (
15
15
  light: $text_dk_light,
16
16
  default: $text_dk_default,
17
17
  lighter: $text_dk_lighter,
18
- link: $primary,
18
+ link: $active_dark,
19
19
  error: $error_dark,
20
20
  success: $text_dk_success_sm,
21
21
  );
@@ -1,3 +1,8 @@
1
- <%= pb_content_tag(object.tag) do %>
1
+ <%= content_tag(object.tag,
2
+ aria: object.aria,
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.id,
6
+ **combined_html_options) do %>
2
7
  <%= object.content %>
3
8
  <% end %>
@@ -1,5 +1,10 @@
1
1
  <div class="pb_dialog_wrapper_rails <%= object.full_height_style %>" data-overlay-click= <%= object.overlay_close %> >
2
- <%= pb_content_tag(:dialog) do %>
2
+ <%= content_tag(:dialog,
3
+ aria: object.aria,
4
+ data: object.data,
5
+ id: object.id,
6
+ class: object.classname,
7
+ **combined_html_options) do %>
3
8
  <% if object.status === "" && object.title %>
4
9
  <%= pb_rails("dialog/dialog_header", props: { title: object.title, id: object.id }) %>
5
10
  <% end %>
@@ -1,3 +1,8 @@
1
- <%= pb_content_tag do %>
2
- <%= content.presence || object.text %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ aria: object.aria,
6
+ **combined_html_options) do %>
7
+ <%= content.presence || object.text %>
3
8
  <% end %>
@@ -1,4 +1,8 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ aria: object.aria,
5
+ **combined_html_options) do %>
2
6
  <% if object.confirm_button && object.cancel_button %>
3
7
  <div class="dialog-pseudo-footer"></div>
4
8
  <%= pb_rails("flex", props: { classname:object.classname, spacing:"between", padding_x:"sm", padding:"sm", padding_bottom:"sm" }) do %>
@@ -1,5 +1,9 @@
1
- <%= pb_content_tag(:div,
2
- class: object.sticky_header) do %>
1
+ <%= content_tag(:div,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.sticky_header,
5
+ aria: object.aria,
6
+ **combined_html_options) do %>
3
7
  <%= pb_rails("flex", props: {classname:object.classname, spacing:"between", padding:"sm", align:"center"}) do %>
4
8
  <%= content.presence || object.title %>
5
9
 
@@ -23,11 +23,11 @@
23
23
  <ul>
24
24
  <% hide_button = type == "rails" ? 'flex' : 'none' %>
25
25
  <li>
26
- <%= pb_rails("button", props: { id:"copy-html-#{example_key}", icon: "copy", text: "Copy HTML", variant: "link", size: "sm", display: hide_button }) %>
26
+ <%= pb_rails("button", props: { id:"copy-html-#{example_key}", icon: "copy", text: "Copy HTML", classname: dark ? "dark" : "", variant: "link", size: "sm", display: hide_button }) %>
27
27
  </li>
28
28
  <li>
29
- <%= pb_rails("button", props: { icon: "code", id:"toggle-open-opened", text: "Close Code", variant: "link", size: "sm", display: "none" }) %>
30
- <%= pb_rails("button", props: { icon: "code", id:"toggle-open-closed", text: "Show Code", variant: "link", size: "sm" }) %>
29
+ <%= pb_rails("button", props: { icon: "code", classname: dark ? "dark" : "", id:"toggle-open-opened", text: "Close Code", variant: "link", size: "sm", display: "none" }) %>
30
+ <%= pb_rails("button", props: { icon: "code", classname: dark ? "dark" : "", id:"toggle-open-closed", text: "Show Code", variant: "link", size: "sm" }) %>
31
31
  </li>
32
32
  </ul>
33
33
  </div>
@@ -37,7 +37,7 @@
37
37
  }
38
38
  }
39
39
  &:focus {
40
- box-shadow: 0px 0px 0 1px $primary;
40
+ box-shadow: 0px 0px 0 1px $primary !important;
41
41
  outline: unset;
42
42
  transition: box-shadow 0.15s ease-in-out;
43
43
  }
@@ -77,8 +77,9 @@
77
77
  }
78
78
  &[class*="selected"] {
79
79
  background-color: $primary;
80
+ color: $white;
80
81
  [class^="pb_body"],
81
- [class^="pb_title_kit"] {
82
+ [class^="pb_title_kit"], a {
82
83
  color: $white !important;
83
84
  }
84
85
  &:hover {
@@ -114,8 +114,10 @@ const Dropdown = (props: DropdownProps) => {
114
114
  setIsDropDownClosed(isClosed)
115
115
  },[isClosed])
116
116
 
117
- const filteredOptions = options?.filter((option: GenericObject) =>
118
- option.label.toLowerCase().includes(filterItem.toLowerCase())
117
+ const filteredOptions = options?.filter((option: GenericObject) => {
118
+ const label = typeof option.label === 'string' ? option.label.toLowerCase() : option.label;
119
+ return String(label).toLowerCase().includes(filterItem.toLowerCase());
120
+ }
119
121
  );
120
122
 
121
123
  // For keyboard accessibility: Set focus within dropdown to selected item if it exists
@@ -0,0 +1,10 @@
1
+ <%
2
+ options = [
3
+ { label: 'United States', value: 'United States', id: 'us' },
4
+ { label: 'Canada', value: 'Canada', id: 'ca' },
5
+ { label: 'Pakistan', value: 'Pakistan', id: 'pk' },
6
+ ]
7
+
8
+ %>
9
+
10
+ <%= pb_rails("dropdown", props: {options: options}) %>
@@ -0,0 +1,17 @@
1
+ <%
2
+ options = [
3
+ { label: 'United States', value: 'United States', id: 'us' },
4
+ { label: 'Canada', value: 'Canada', id: 'ca' },
5
+ { label: 'Pakistan', value: 'Pakistan', id: 'pk' },
6
+ ]
7
+
8
+ %>
9
+
10
+ <%= pb_rails("dropdown", props: {options: options}) do %>
11
+ <%= pb_rails("dropdown/dropdown_trigger") %>
12
+ <%= pb_rails("dropdown/dropdown_container") do %>
13
+ <% options.each do |option| %>
14
+ <%= pb_rails("dropdown/dropdown_option", props: {option: option}) %>
15
+ <% end %>
16
+ <% end %>
17
+ <% end %>
@@ -1,7 +1,7 @@
1
1
  The dropdown comes with the following subcomponents that can be used to achieve various levels of customization:
2
2
 
3
- `Dropdown. Trigger`
4
- `Dropdown.Container`
5
- `Dropdown.Option`
3
+ `Dropdown. Trigger` / `dropdown/dropdown_trigger`
4
+ `Dropdown.Container`/ `dropdown/dropdown_container`
5
+ `Dropdown.Option` / `dropdown/dropdown_option`
6
6
 
7
7
  See the code snippet below for a visual on how to use the kit with subcomponents. Each subcomponent allows for GlobalProps in addition to any subcomponent specfic props.
@@ -16,7 +16,7 @@ const DropdownWithAutocomplete = (props) => {
16
16
  label: "Ramon Ruiz",
17
17
  value: "Ramon Ruiz",
18
18
  territory: "PHL",
19
- title: "Senior UX Desinger",
19
+ title: "Senior UX Designer",
20
20
  id: "ramon-ruiz",
21
21
  status: "Away"
22
22
  },
@@ -17,7 +17,7 @@ const DropdownWithAutocompleteAndCustomDisplay = (props) => {
17
17
  label: "Ramon Ruiz",
18
18
  value: "Ramon Ruiz",
19
19
  territory: "PHL",
20
- title: "Senior UX Desinger",
20
+ title: "Senior UX Designer",
21
21
  id: "ramon-ruiz",
22
22
  status: "Away"
23
23
  },
@@ -0,0 +1,60 @@
1
+ <%
2
+ options = [
3
+ {
4
+ label: "Jasper Furniss",
5
+ value: "Jasper Furniss",
6
+ territory: "PHL",
7
+ title: "Senior UX Engineer",
8
+ id: "jasper-furniss",
9
+ status: "Offline"
10
+ },
11
+ {
12
+ label: "Ramon Ruiz",
13
+ value: "Ramon Ruiz",
14
+ territory: "PHL",
15
+ title: "Senior UX Designer",
16
+ id: "ramon-ruiz",
17
+ status: "Away"
18
+ },
19
+ {
20
+ label: "Jason Cypret",
21
+ value: "Jason Cypret",
22
+ territory: "PHL",
23
+ title: "VP of User Experience",
24
+ id: "jason-cypret",
25
+ status: "Online"
26
+ },
27
+ {
28
+ label: "Courtney Long",
29
+ value: "Courtney Long",
30
+ territory: "PHL",
31
+ title: "UX Design Mentor",
32
+ id: "courtney-long",
33
+ status: "Online"
34
+ }
35
+ ]
36
+
37
+ %>
38
+
39
+ <%
40
+ custom_display = capture do
41
+ pb_rails("avatar", props: { name: "Courtney Long", size: "xs" })
42
+ end
43
+ %>
44
+
45
+
46
+ <%= pb_rails("dropdown", props: {options: options}) do %>
47
+ <%= pb_rails("dropdown/dropdown_trigger", props: {placeholder: "Select a User", custom_display: custom_display}) %>
48
+ <%= pb_rails("dropdown/dropdown_container") do %>
49
+ <% options.each do |option| %>
50
+ <%= pb_rails("dropdown/dropdown_option", props: {option: option}) do %>
51
+ <%= pb_rails("flex/flex_item") do %>
52
+ <%= pb_rails("user", props: {name: option[:label], align:"left", avatar: true, orientation:"horizontal", territory:option[:territory], title: option[:title]}) %>
53
+ <% end %>
54
+ <%= pb_rails("flex/flex_item") do %>
55
+ <%= pb_rails("badge", props: {rounded: true, dark: true, text: option[:status], variant: option[:status] == "Offline" ? "neutral" : option[:status] == "Online" ? "success" : "warning" }) %>
56
+ <% end %>
57
+ <% end %>
58
+ <% end %>
59
+ <% end %>
60
+ <% end %>
@@ -17,7 +17,7 @@ const DropdownWithCustomDisplay = (props) => {
17
17
  label: "Ramon Ruiz",
18
18
  value: "Ramon Ruiz",
19
19
  territory: "PHL",
20
- title: "Senior UX Desinger",
20
+ title: "Senior UX Designer",
21
21
  id: "ramon-ruiz",
22
22
  status: "Away"
23
23
  },
@@ -0,0 +1,45 @@
1
+ <%
2
+ options = [
3
+ {
4
+ label: "United States",
5
+ value: "United States",
6
+ areaCode: "+1",
7
+ icon: "🇺🇸",
8
+ id: "us"
9
+ },
10
+ {
11
+ label: "Canada",
12
+ value: "Canada",
13
+ areaCode: "+1",
14
+ icon: "🇨🇦",
15
+ id: "ca"
16
+ },
17
+ {
18
+ label: "Pakistan",
19
+ value: "Pakistan",
20
+ areaCode: "+92",
21
+ icon: "🇵🇰",
22
+ id: "pk"
23
+ }
24
+ ]
25
+
26
+ %>
27
+
28
+ <%= pb_rails("dropdown", props: {options: options}) do %>
29
+ <%= pb_rails("dropdown/dropdown_trigger") %>
30
+ <%= pb_rails("dropdown/dropdown_container") do %>
31
+ <% options.each do |option| %>
32
+ <%= pb_rails("dropdown/dropdown_option", props: {option: option}) do %>
33
+ <%= pb_rails("flex/flex_item") do %>
34
+ <%= pb_rails("flex") do %>
35
+ <%= pb_rails("icon", props: {icon: option[:icon]}) %>
36
+ <%= pb_rails("body", props: {text: option[:label], padding_left:"xs"}) %>
37
+ <% end %>
38
+ <% end %>
39
+ <%= pb_rails("flex/flex_item") do %>
40
+ <%= pb_rails("body", props: {color:"light", text: option[:areaCode]}) %>
41
+ <% end %>
42
+ <% end %>
43
+ <% end %>
44
+ <% end %>
45
+ <% end %>
@@ -0,0 +1,17 @@
1
+ <%
2
+ options = [
3
+ { label: 'United States', value: 'United States', id: 'us' },
4
+ { label: 'Canada', value: 'Canada', id: 'ca' },
5
+ { label: 'Pakistan', value: 'Pakistan', id: 'pk' },
6
+ ]
7
+
8
+ %>
9
+
10
+ <%= pb_rails("dropdown", props: {options: options}) do %>
11
+ <%= pb_rails("dropdown/dropdown_trigger") %>
12
+ <%= pb_rails("dropdown/dropdown_container") do %>
13
+ <% options.each do |option| %>
14
+ <%= pb_rails("dropdown/dropdown_option", props: {option: option, padding:"sm"}) %>
15
+ <% end %>
16
+ <% end %>
17
+ <% end %>
@@ -0,0 +1,47 @@
1
+ <%
2
+ options = [
3
+ {
4
+ label: "United States",
5
+ value: "United States",
6
+ areaCode: "+1",
7
+ icon: "🇺🇸",
8
+ id: "us"
9
+ },
10
+ {
11
+ label: "Canada",
12
+ value: "Canada",
13
+ areaCode: "+1",
14
+ icon: "🇨🇦",
15
+ id: "ca"
16
+ },
17
+ {
18
+ label: "Pakistan",
19
+ value: "Pakistan",
20
+ areaCode: "+92",
21
+ icon: "🇵🇰",
22
+ id: "pk"
23
+ }
24
+ ]
25
+
26
+ %>
27
+
28
+ <%= pb_rails("dropdown", props: {options: options}) do %>
29
+ <%= pb_rails("dropdown/dropdown_trigger") do %>
30
+ <%= pb_rails("icon_circle", props: {icon:"flag", cursor: "pointer", variant:"royal"}) %>
31
+ <% end %>
32
+ <%= pb_rails("dropdown/dropdown_container", props:{max_width:"xs"}) do %>
33
+ <% options.each do |option| %>
34
+ <%= pb_rails("dropdown/dropdown_option", props: {option: option}) do %>
35
+ <%= pb_rails("flex/flex_item") do %>
36
+ <%= pb_rails("flex") do %>
37
+ <%= pb_rails("icon", props: {icon: option[:icon]}) %>
38
+ <%= pb_rails("body", props: {text: option[:label], padding_left:"xs"}) %>
39
+ <% end %>
40
+ <% end %>
41
+ <%= pb_rails("flex/flex_item") do %>
42
+ <%= pb_rails("body", props: {color:"light", text: option[:areaCode]}) %>
43
+ <% end %>
44
+ <% end %>
45
+ <% end %>
46
+ <% end %>
47
+ <% end %>
@@ -0,0 +1,10 @@
1
+ <%
2
+ options = [
3
+ { label: 'United States', value: 'United States', id: 'us' },
4
+ { label: 'Canada', value: 'Canada', id: 'ca' },
5
+ { label: 'Pakistan', value: 'Pakistan', id: 'pk' },
6
+ ]
7
+
8
+ %>
9
+
10
+ <%= pb_rails("dropdown", props: {options: options, label: "Select a Country"}) %>
@@ -1,6 +1,13 @@
1
1
  examples:
2
-
3
-
2
+ rails:
3
+ - dropdown_default: Default
4
+ - dropdown_subcomponent_structure: Subcomponent Structure
5
+ - dropdown_with_label: With Label
6
+ - dropdown_with_custom_options: Custom Options
7
+ - dropdown_with_custom_display: Custom Display
8
+ - dropdown_with_custom_trigger: Custom Trigger
9
+ - dropdown_with_custom_padding: Custom Padding for Dropdown Options
10
+
4
11
  react:
5
12
  - dropdown_default: Default
6
13
  - dropdown_subcomponent_structure: Subcomponent Structure
@@ -0,0 +1,26 @@
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.id,
6
+ **combined_html_options) do %>
7
+ <% if object.label.present? %>
8
+ <%= pb_rails("caption", props: {text: object.label, margin_bottom:"xs"}) %>
9
+ <% end %>
10
+ <div class="dropdown_wrapper" style="position: relative">
11
+ <input type="hidden" name="<%= object.name %>" id="dropdown-selected-option" value=""/>
12
+ <% if content.present? %>
13
+ <%= content.presence %>
14
+ <% else %>
15
+ <%= pb_rails("dropdown/dropdown_trigger") %>
16
+ <%= pb_rails("dropdown/dropdown_container") do %>
17
+ <% if object.options.present? %>
18
+ <% object.options.each do |option| %>
19
+ <%= pb_rails("dropdown/dropdown_option", props: {option: option}) %>
20
+ <% end %>
21
+ <% end %>
22
+ <% end %>
23
+ <% end %>
24
+ </div>
25
+ <% end %>
26
+
@@ -0,0 +1,20 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Playbook
4
+ module PbDropdown
5
+ class Dropdown < Playbook::KitBase
6
+ prop :options, type: Playbook::Props::Array,
7
+ default: []
8
+ prop :label, type: Playbook::Props::String
9
+ prop :name, type: Playbook::Props::String
10
+
11
+ def data
12
+ Hash(prop(:data)).merge(pb_dropdown: true)
13
+ end
14
+
15
+ def classname
16
+ generate_classname("pb_dropdown")
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,21 @@
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.id,
6
+ style: object.container_style,
7
+ **combined_html_options) do %>
8
+ <%= pb_rails("list", props: {ordered: false, borderless: false}) do %>
9
+ <% if content.present? %>
10
+ <%= content.presence %>
11
+ <% else %>
12
+ <%= pb_rails("list/item", props: {
13
+ display: "flex",
14
+ justify_content: "center",
15
+ padding:"xs",
16
+ }) do %>
17
+ <%= pb_rails("body", props: {text: "No option"}) %>
18
+ <% end %>
19
+ <% end %>
20
+ <% end %>
21
+ <% end %>
@@ -0,0 +1,19 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Playbook
4
+ module PbDropdown
5
+ class DropdownContainer < Playbook::KitBase
6
+ def classname
7
+ generate_classname("pb_dropdown_container", "close", separator: " ")
8
+ end
9
+
10
+ def container_style
11
+ "position: absolute"
12
+ end
13
+
14
+ def data
15
+ Hash(prop(:data)).merge(dropdown_container: true)
16
+ end
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,27 @@
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.option[:id],
6
+ **combined_html_options) do %>
7
+ <%= pb_rails("list/item", props: {
8
+ display: "flex",
9
+ justify_content: "center",
10
+ padding:"none",
11
+ cursor: "pointer"
12
+ }) do %>
13
+ <%= pb_rails("flex", props: {
14
+ align: "center",
15
+ classname:"dropdown_option_wrapper",
16
+ justify: "between",
17
+ padding_x:"sm",
18
+ padding_y:"xxs",
19
+ }) do %>
20
+ <% if content.present? %>
21
+ <%= content.presence %>
22
+ <% else %>
23
+ <%= pb_rails("body", props: {text: object.option[:label]}) %>
24
+ <% end %>
25
+ <% end %>
26
+ <% end %>
27
+ <% end %>