playbook_ui 13.24.0 → 13.25.0.pre.alpha.PBNTR272Dropdownkitv42769

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (194) 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 +10 -14
  5. data/app/pb_kits/playbook/pb_advanced_table/table_body.html.erb +5 -9
  6. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +2 -6
  7. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +2 -6
  8. data/app/pb_kits/playbook/pb_avatar/avatar.html.erb +1 -6
  9. data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.html.erb +1 -6
  10. data/app/pb_kits/playbook/pb_background/_background.tsx +7 -5
  11. data/app/pb_kits/playbook/pb_background/background.html.erb +2 -11
  12. data/app/pb_kits/playbook/pb_badge/badge.html.erb +1 -6
  13. data/app/pb_kits/playbook/pb_bar_graph/_bar_graph.tsx +41 -6
  14. data/app/pb_kits/playbook/pb_bar_graph/bar_graph.rb +4 -0
  15. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_negative_numbers.html.erb +23 -0
  16. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_negative_numbers.jsx +35 -0
  17. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_secondary_y_axis.html.erb +26 -0
  18. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_secondary_y_axis.jsx +36 -0
  19. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_secondary_y_axis.md +3 -0
  20. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_stacked.html.erb +22 -0
  21. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_stacked.jsx +34 -0
  22. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_stacked.md +1 -0
  23. data/app/pb_kits/playbook/pb_bar_graph/docs/example.yml +6 -0
  24. data/app/pb_kits/playbook/pb_bar_graph/docs/index.js +3 -0
  25. data/app/pb_kits/playbook/pb_body/_body.scss +3 -3
  26. data/app/pb_kits/playbook/pb_body/_body.tsx +1 -1
  27. data/app/pb_kits/playbook/pb_body/body.html.erb +1 -6
  28. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +1 -6
  29. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +2 -7
  30. data/app/pb_kits/playbook/pb_button/_button.scss +1 -1
  31. data/app/pb_kits/playbook/pb_button/button.html.erb +2 -3
  32. data/app/pb_kits/playbook/pb_button_toolbar/button_toolbar.html.erb +2 -7
  33. data/app/pb_kits/playbook/pb_caption/caption.html.erb +1 -6
  34. data/app/pb_kits/playbook/pb_card/card.html.erb +1 -7
  35. data/app/pb_kits/playbook/pb_card/card_body.html.erb +1 -6
  36. data/app/pb_kits/playbook/pb_card/card_header.html.erb +1 -6
  37. data/app/pb_kits/playbook/pb_checkbox/checkbox.html.erb +1 -6
  38. data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.html.erb +1 -6
  39. data/app/pb_kits/playbook/pb_collapsible/collapsible.html.erb +1 -6
  40. data/app/pb_kits/playbook/pb_collapsible/collapsible_content.html.erb +1 -6
  41. data/app/pb_kits/playbook/pb_collapsible/collapsible_main.html.erb +1 -7
  42. data/app/pb_kits/playbook/pb_contact/contact.html.erb +1 -6
  43. data/app/pb_kits/playbook/pb_currency/currency.html.erb +1 -6
  44. data/app/pb_kits/playbook/pb_currency/docs/_currency_alignment_swift.md +43 -0
  45. data/app/pb_kits/playbook/pb_currency/docs/_currency_props_swift.md +12 -0
  46. data/app/pb_kits/playbook/pb_currency/docs/_currency_size_swift.md +31 -0
  47. data/app/pb_kits/playbook/pb_currency/docs/example.yml +5 -0
  48. data/app/pb_kits/playbook/pb_dashboard_value/dashboard_value.html.erb +1 -6
  49. data/app/pb_kits/playbook/pb_date/date.html.erb +1 -6
  50. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +2 -6
  51. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.html.erb +1 -5
  52. data/app/pb_kits/playbook/pb_date_range_stacked/date_range_stacked.html.erb +1 -5
  53. data/app/pb_kits/playbook/pb_date_range_stacked/docs/_date_range_stacked_default_swift.md +14 -0
  54. data/app/pb_kits/playbook/pb_date_range_stacked/docs/_date_range_stacked_props_swift.md +9 -0
  55. data/app/pb_kits/playbook/pb_date_range_stacked/docs/example.yml +4 -0
  56. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.html.erb +1 -5
  57. data/app/pb_kits/playbook/pb_date_time/date_time.html.erb +1 -6
  58. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.html.erb +1 -7
  59. data/app/pb_kits/playbook/pb_date_year_stacked/date_year_stacked.html.erb +1 -5
  60. data/app/pb_kits/playbook/pb_detail/detail.html.erb +1 -6
  61. data/app/pb_kits/playbook/pb_dialog/_dialog.scss +4 -2
  62. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +1 -6
  63. data/app/pb_kits/playbook/pb_dialog/dialog_body.html.erb +2 -7
  64. data/app/pb_kits/playbook/pb_dialog/dialog_footer.html.erb +1 -5
  65. data/app/pb_kits/playbook/pb_dialog/dialog_header.html.erb +2 -6
  66. data/app/pb_kits/playbook/pb_dialog/docs/example.yml +1 -1
  67. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +181 -0
  68. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +266 -0
  69. data/app/pb_kits/playbook/pb_dropdown/context/index.tsx +5 -0
  70. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.jsx +38 -0
  71. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.md +1 -0
  72. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +87 -0
  73. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.md +1 -0
  74. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx +102 -0
  75. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.md +1 -0
  76. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +104 -0
  77. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.md +5 -0
  78. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.jsx +63 -0
  79. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.md +1 -0
  80. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.jsx +48 -0
  81. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.md +1 -0
  82. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.jsx +77 -0
  83. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.md +1 -0
  84. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_external_control.jsx +62 -0
  85. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_hook.jsx +75 -0
  86. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.jsx +39 -0
  87. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.md +1 -0
  88. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +15 -0
  89. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +10 -0
  90. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +207 -0
  91. data/app/pb_kits/playbook/pb_dropdown/hooks/useDropdown.tsx +17 -0
  92. data/app/pb_kits/playbook/pb_dropdown/hooks/useHandleOnKeydown.tsx +61 -0
  93. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownContainer.tsx +109 -0
  94. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +116 -0
  95. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownTrigger.tsx +190 -0
  96. data/app/pb_kits/playbook/pb_dropdown/utilities/subComponentHelper.tsx +61 -0
  97. data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +1 -6
  98. data/app/pb_kits/playbook/pb_filter/filter.html.erb +1 -5
  99. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.html.erb +1 -6
  100. data/app/pb_kits/playbook/pb_flex/flex.html.erb +1 -5
  101. data/app/pb_kits/playbook/pb_flex/flex_item.html.erb +2 -6
  102. data/app/pb_kits/playbook/pb_form_group/form_group.html.erb +1 -6
  103. data/app/pb_kits/playbook/pb_form_pill/form_pill.html.erb +1 -1
  104. data/app/pb_kits/playbook/pb_hashtag/hashtag.html.erb +1 -6
  105. data/app/pb_kits/playbook/pb_highlight/highlight.html.erb +1 -5
  106. data/app/pb_kits/playbook/pb_home_address_street/home_address_street.html.erb +1 -5
  107. data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.scss +1 -1
  108. data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.tsx +1 -1
  109. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.html.erb +2 -7
  110. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.rb +1 -1
  111. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.test.js +3 -3
  112. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.html.erb +1 -6
  113. data/app/pb_kits/playbook/pb_icon_value/icon_value.html.erb +1 -6
  114. data/app/pb_kits/playbook/pb_label_pill/label_pill.html.erb +1 -6
  115. data/app/pb_kits/playbook/pb_label_value/label_value.html.erb +1 -6
  116. data/app/pb_kits/playbook/pb_layout/body.html.erb +1 -5
  117. data/app/pb_kits/playbook/pb_layout/footer.html.erb +1 -5
  118. data/app/pb_kits/playbook/pb_layout/header.html.erb +1 -5
  119. data/app/pb_kits/playbook/pb_layout/item.html.erb +1 -5
  120. data/app/pb_kits/playbook/pb_layout/layout.html.erb +1 -5
  121. data/app/pb_kits/playbook/pb_layout/sidebar.html.erb +1 -5
  122. data/app/pb_kits/playbook/pb_list/_list_item.tsx +2 -2
  123. data/app/pb_kits/playbook/pb_list/item.html.erb +2 -8
  124. data/app/pb_kits/playbook/pb_list/list.html.erb +2 -8
  125. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.html.erb +1 -6
  126. data/app/pb_kits/playbook/pb_message/message.html.erb +1 -6
  127. data/app/pb_kits/playbook/pb_message/message_mention.html.erb +1 -6
  128. data/app/pb_kits/playbook/pb_multi_level_select/multi_level_select.html.erb +1 -6
  129. data/app/pb_kits/playbook/pb_multiple_users/multiple_users.html.erb +1 -6
  130. data/app/pb_kits/playbook/pb_multiple_users_stacked/multiple_users_stacked.html.erb +1 -6
  131. data/app/pb_kits/playbook/pb_nav/item.html.erb +3 -14
  132. data/app/pb_kits/playbook/pb_nav/nav.html.erb +1 -6
  133. data/app/pb_kits/playbook/pb_online_status/online_status.html.erb +2 -6
  134. data/app/pb_kits/playbook/pb_pagination/pagination.html.erb +1 -6
  135. data/app/pb_kits/playbook/pb_passphrase/passphrase.html.erb +1 -1
  136. data/app/pb_kits/playbook/pb_person/person.html.erb +7 -12
  137. data/app/pb_kits/playbook/pb_person_contact/person_contact.html.erb +1 -6
  138. data/app/pb_kits/playbook/pb_pill/pill.html.erb +1 -6
  139. data/app/pb_kits/playbook/pb_popover/popover.html.erb +1 -6
  140. data/app/pb_kits/playbook/pb_progress_pills/progress_pills.html.erb +2 -6
  141. data/app/pb_kits/playbook/pb_progress_simple/progress_simple.html.erb +3 -6
  142. data/app/pb_kits/playbook/pb_progress_step/progress_step.html.erb +1 -5
  143. data/app/pb_kits/playbook/pb_progress_step/progress_step_item.html.erb +1 -5
  144. data/app/pb_kits/playbook/pb_radio/radio.html.erb +2 -8
  145. data/app/pb_kits/playbook/pb_section_separator/_section_separator.scss +6 -2
  146. data/app/pb_kits/playbook/pb_section_separator/_section_separator_mixin.scss +11 -1
  147. data/app/pb_kits/playbook/pb_section_separator/section_separator.html.erb +1 -6
  148. data/app/pb_kits/playbook/pb_select/select.html.erb +1 -5
  149. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +1 -5
  150. data/app/pb_kits/playbook/pb_selectable_card_icon/selectable_card_icon.html.erb +1 -4
  151. data/app/pb_kits/playbook/pb_selectable_icon/selectable_icon.html.erb +1 -5
  152. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +1 -6
  153. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +1 -6
  154. data/app/pb_kits/playbook/pb_source/source.html.erb +1 -5
  155. data/app/pb_kits/playbook/pb_source/source.test.js +2 -2
  156. data/app/pb_kits/playbook/pb_star_rating/star_rating.html.erb +1 -5
  157. data/app/pb_kits/playbook/pb_stat_change/stat_change.html.erb +1 -5
  158. data/app/pb_kits/playbook/pb_stat_value/stat_value.html.erb +1 -5
  159. data/app/pb_kits/playbook/pb_table/table.html.erb +2 -12
  160. data/app/pb_kits/playbook/pb_table/table_body.html.erb +6 -16
  161. data/app/pb_kits/playbook/pb_table/table_cell.html.erb +6 -16
  162. data/app/pb_kits/playbook/pb_table/table_head.html.erb +6 -16
  163. data/app/pb_kits/playbook/pb_table/table_header.html.erb +4 -13
  164. data/app/pb_kits/playbook/pb_table/table_row.html.erb +6 -16
  165. data/app/pb_kits/playbook/pb_textarea/textarea.html.erb +1 -5
  166. data/app/pb_kits/playbook/pb_time/time.html.erb +1 -5
  167. data/app/pb_kits/playbook/pb_time_range_inline/time_range_inline.html.erb +1 -5
  168. data/app/pb_kits/playbook/pb_time_stacked/time_stacked.html.erb +1 -5
  169. data/app/pb_kits/playbook/pb_timeline/item.html.erb +3 -7
  170. data/app/pb_kits/playbook/pb_timeline/timeline.html.erb +1 -5
  171. data/app/pb_kits/playbook/pb_timestamp/timestamp.html.erb +1 -6
  172. data/app/pb_kits/playbook/pb_title/title.html.erb +1 -6
  173. data/app/pb_kits/playbook/pb_title_count/title_count.html.erb +1 -6
  174. data/app/pb_kits/playbook/pb_title_detail/title_detail.html.erb +1 -5
  175. data/app/pb_kits/playbook/pb_toggle/toggle.html.erb +1 -6
  176. data/app/pb_kits/playbook/pb_tooltip/tooltip.html.erb +1 -5
  177. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +27 -19
  178. data/app/pb_kits/playbook/pb_typeahead/components/MenuList.tsx +4 -2
  179. data/app/pb_kits/playbook/pb_typeahead/components/index.tsx +19 -0
  180. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_menu_list.jsx +51 -0
  181. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_highlight.jsx +1 -1
  182. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +1 -0
  183. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -0
  184. data/app/pb_kits/playbook/pb_user/user.html.erb +1 -6
  185. data/app/pb_kits/playbook/pb_user_badge/user_badge.html.erb +1 -6
  186. data/app/pb_kits/playbook/pb_weekday_stacked/weekday_stacked.html.erb +1 -6
  187. data/app/pb_kits/playbook/playbook-doc.js +2 -0
  188. data/app/pb_kits/playbook/tokens/_colors.scss +1 -1
  189. data/dist/menu.yml +5 -1
  190. data/dist/playbook-rails.js +6 -6
  191. data/lib/playbook/kit_base.rb +21 -1
  192. data/lib/playbook/version.rb +2 -2
  193. metadata +51 -6
  194. /data/app/pb_kits/playbook/pb_dialog/docs/{_dialog_props_table.md → _dialog_props_swift.md} +0 -0
@@ -1,19 +1,9 @@
1
1
  <% if object.tag == "table" %>
2
- <%= content_tag(:td,
3
- aria: object.aria,
4
- class: object.classname,
5
- data: object.data,
6
- id: object.id,
7
- **combined_html_options) do %>
8
- <%= content.presence || object.text %>
9
- <% end %>
2
+ <%= pb_content_tag(:td) do %>
3
+ <%= content.presence || object.text %>
4
+ <% end %>
10
5
  <% else %>
11
- <%= content_tag(:div,
12
- aria: object.aria,
13
- class: object.classname,
14
- data: object.data,
15
- id: object.id,
16
- **combined_html_options) do %>
17
- <%= content.presence || object.text %>
18
- <% end %>
6
+ <%= pb_content_tag do %>
7
+ <%= content.presence || object.text %>
8
+ <% end %>
19
9
  <% end %>
@@ -1,19 +1,9 @@
1
1
  <% if object.tag == "table" %>
2
- <%= content_tag(:thead,
3
- aria: object.aria,
4
- class: object.classname,
5
- data: object.data,
6
- id: object.id,
7
- **combined_html_options) do %>
8
- <%= content.presence %>
9
- <% end %>
2
+ <%= pb_content_tag(:thead) do %>
3
+ <%= content.presence %>
4
+ <% end %>
10
5
  <% else %>
11
- <%= content_tag(:div,
12
- aria: object.aria,
13
- class: object.classname,
14
- data: object.data,
15
- id: object.id,
16
- **combined_html_options) do %>
17
- <%= content.presence %>
18
- <% end %>
6
+ <%= pb_content_tag do %>
7
+ <%= content.presence %>
8
+ <% end %>
19
9
  <% end %>
@@ -1,11 +1,7 @@
1
1
  <% if object.tag == "table" %>
2
- <%= content_tag(:th,
2
+ <%= pb_content_tag(:th,
3
3
  colspan: object.colspan,
4
- aria: object.aria,
5
- class: object.classname,
6
- data: object.data,
7
- id: "pb-th#{object.id}",
8
- **combined_html_options) do %>
4
+ id: "pb-th#{object.id}") do %>
9
5
  <% unless sorting_style? %>
10
6
  <%= pb_rails("flex", props:{ align: object.align_content, justify: object.justify_sort_icon, classname: "pb_th_nolink" }) do %>
11
7
  <%= content.presence || object.text %>
@@ -48,12 +44,7 @@
48
44
  <% end %>
49
45
  <% end %>
50
46
  <% else %>
51
- <%= content_tag(:div,
52
- aria: object.aria,
53
- class: object.classname,
54
- data: object.data,
55
- id: object.id,
56
- **combined_html_options) do %>
57
- <%= content.presence || object.text %>
47
+ <%= pb_content_tag do %>
48
+ <%= content.presence || object.text %>
58
49
  <% end %>
59
50
  <% end %>
@@ -1,19 +1,9 @@
1
1
  <% if object.tag == "table" %>
2
- <%= content_tag(:tr,
3
- aria: object.aria,
4
- class: object.classname,
5
- data: object.data,
6
- id: object.id,
7
- **combined_html_options) do %>
8
- <%= content.presence %>
9
- <% end %>
2
+ <%= pb_content_tag(:tr) do %>
3
+ <%= content.presence %>
4
+ <% end %>
10
5
  <% else %>
11
- <%= content_tag(:div,
12
- aria: object.aria,
13
- class: object.classname,
14
- data: object.data,
15
- id: object.id,
16
- **combined_html_options) do %>
17
- <%= content.presence %>
18
- <% end %>
6
+ <%= pb_content_tag do %>
7
+ <%= content.presence %>
8
+ <% end %>
19
9
  <% end %>
@@ -1,8 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
  <% if object.label.present? %>
7
3
  <%= pb_rails("caption", props: {text: object.label, dark: object.dark}) %>
8
4
  <% end %>
@@ -1,8 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
  <%
7
3
  # convert deprecated prop values
8
4
  size = object.size
@@ -1,8 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
  <div class="pb_time_range_inline_wrapper">
7
3
  <% if object.icon == true %>
8
4
  <%= pb_rails(object.text_kit, props: { tag: "span", dark: object.dark, color: object.icon_color, text: pb_rails("icon", props: { icon: "clock", dark: object.dark, classname:"pb_time_range_inline_icon", fixed_width: true, size: object.size }) }) %>
@@ -1,8 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
 
7
3
  <%= pb_rails("body", props: { color: "light", dark: object.dark, classname: "pb_time_stacked time-spacing" }) do %>
8
4
  <time>
@@ -1,8 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
 
7
3
  <div class="pb_timeline_item_left_block">
8
4
  <% if object.date.present? %>
@@ -11,7 +7,7 @@
11
7
  size: "sm",
12
8
  align: "center"
13
9
  }) %>
14
- <% end %>
10
+ <% end %>
15
11
  </div>
16
12
 
17
13
  <div class="pb_timeline_item_step">
@@ -20,7 +16,7 @@
20
16
  variant: object.icon_color,
21
17
  size: "xs"
22
18
  }) %>
23
- <div class="pb_timeline_item_connector"></div>
19
+ <div class="pb_timeline_item_connector"></div>
24
20
  </div>
25
21
 
26
22
  <div class="pb_timeline_item_right_block">
@@ -1,7 +1,3 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
  <%= content.presence %>
7
3
  <% end %>
@@ -1,9 +1,4 @@
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 %>
1
+ <%= pb_content_tag do %>
7
2
 
8
3
  <% if object.unstyled %>
9
4
  <div><%= object.timestamp_text %></div>
@@ -1,7 +1,2 @@
1
- <%= content_tag(object.tag,
2
- aria: object.aria,
3
- id: object.id,
4
- data: object.data,
5
- class: object.classname,
6
- **combined_html_options) do %><%= content.presence || object.text %><% end %>
1
+ <%= pb_content_tag(object.tag) do %><%= content.presence || object.text %><% end %>
7
2
 
@@ -1,9 +1,4 @@
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 %>
1
+ <%= pb_content_tag do %>
7
2
  <%= pb_rails("title", props: {
8
3
  dark: object.dark,
9
4
  size: object.title_size,
@@ -1,8 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
  <%= pb_rails("title", props: { text: object.title, size: 4 }) %>
7
3
  <%= pb_rails("body", props: { text: object.detail, color: "light" }) %>
8
4
  <% end %>
@@ -1,9 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- aria: object.aria,
5
- class: object.classname,
6
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
7
2
  <label class="pb_toggle_wrapper">
8
3
  <%= content.presence || object.input %>
9
4
  <div class="pb_toggle_control"></div>
@@ -1,8 +1,4 @@
1
- <%= content_tag(:div,
2
- id: object.id,
3
- data: object.data,
4
- class: object.classname,
5
- **combined_html_options) do %>
1
+ <%= pb_content_tag do %>
6
2
  <div class="tooltip_tooltip" id="<%= object.tooltip_id %>" role="tooltip">
7
3
  <%= content.presence %>
8
4
  <div class="arrow" id="<%= object.tooltip_id %>-arrow"></div>
@@ -7,17 +7,21 @@ import { get, isString, uniqueId } from 'lodash'
7
7
  import { globalProps } from '../utilities/globalProps'
8
8
  import classnames from 'classnames'
9
9
 
10
- import Control from './components/Control'
11
- import ClearIndicator from './components/ClearIndicator'
12
- import IndicatorsContainer from './components/IndicatorsContainer'
13
- import MenuList from './components/MenuList'
14
- import MultiValue from './components/MultiValue'
15
- import Option from './components/Option'
16
- import Placeholder from './components/Placeholder'
17
- import ValueContainer from './components/ValueContainer'
10
+ import {
11
+ Control,
12
+ ClearIndicator,
13
+ IndicatorsContainer,
14
+ MenuList,
15
+ MultiValue,
16
+ Option,
17
+ Placeholder,
18
+ ValueContainer,
19
+ } from "./components"
20
+
21
+ import * as kitComponents from "./components"
18
22
 
19
23
  import { noop, buildDataProps, buildHtmlProps } from '../utilities/props'
20
- import { Noop } from '../types'
24
+ import { GenericObject, Noop } from '../types'
21
25
 
22
26
  /**
23
27
  * @typedef {object} Props
@@ -29,7 +33,7 @@ import { Noop } from '../types'
29
33
  type TypeaheadProps = {
30
34
  async?: boolean,
31
35
  className?: string,
32
- components?: object,
36
+ components?: GenericObject,
33
37
  createable?: boolean,
34
38
  dark?: boolean,
35
39
  data?: { [key: string]: string },
@@ -100,7 +104,7 @@ const Typeahead = ({
100
104
  multiKit: '',
101
105
  onCreateOption: null as null,
102
106
  plusIcon: false,
103
- onMultiValueClick: (_option: SelectValueType) => { },
107
+ onMultiValueClick: (_option: SelectValueType): any => undefined,
104
108
  ...props,
105
109
  }
106
110
 
@@ -137,19 +141,23 @@ const Typeahead = ({
137
141
  const inlineClass = selectProps.inline ? 'inline' : null
138
142
 
139
143
  return (
140
- <div
141
- {...dataProps}
142
- {...htmlProps}
143
- className={classnames(classes, inlineClass)}
144
+ <div
145
+ {...dataProps}
146
+ {...htmlProps}
147
+ className={classnames(classes, inlineClass)}
144
148
  >
145
149
  <Tag
146
- classNamePrefix="typeahead-kit-select"
147
- error={error}
148
- onChange={handleOnChange}
149
- {...selectProps}
150
+ classNamePrefix="typeahead-kit-select"
151
+ error={error}
152
+ onChange={handleOnChange}
153
+ {...selectProps}
150
154
  />
151
155
  </div>
152
156
  )
153
157
  }
154
158
 
159
+ Object.keys(kitComponents).forEach((k) => {
160
+ (Typeahead as GenericObject)[k] = (kitComponents as {[key: string]: unknown})[k]
161
+ })
162
+
155
163
  export default Typeahead
@@ -1,10 +1,12 @@
1
1
  import React from 'react'
2
2
  import { components } from 'react-select'
3
3
 
4
- const MenuList = (props: any) => (
4
+ const MenuList = (props: any) => {
5
+ return (
5
6
  <components.MenuList {...props}>
6
7
  {props.children}
8
+ {props.footer}
7
9
  </components.MenuList>
8
- )
10
+ )}
9
11
 
10
12
  export default MenuList
@@ -0,0 +1,19 @@
1
+ import Control from './Control'
2
+ import ClearIndicator from './ClearIndicator'
3
+ import IndicatorsContainer from './IndicatorsContainer'
4
+ import MenuList from './MenuList'
5
+ import MultiValue from './MultiValue'
6
+ import Option from './Option'
7
+ import Placeholder from './Placeholder'
8
+ import ValueContainer from './ValueContainer'
9
+
10
+ export {
11
+ Control,
12
+ ClearIndicator,
13
+ IndicatorsContainer,
14
+ MenuList,
15
+ MultiValue,
16
+ Option,
17
+ Placeholder,
18
+ ValueContainer,
19
+ }
@@ -0,0 +1,51 @@
1
+ import React, { useState } from 'react'
2
+
3
+ import {
4
+ Button,
5
+ } from '../..'
6
+
7
+ import Typeahead from '../_typeahead'
8
+
9
+ const options = [
10
+ { label: 'Orange', value: '#FFA500' },
11
+ { label: 'Red', value: '#FF0000' },
12
+ { label: 'Green', value: '#00FF00' },
13
+ { label: 'Blue', value: '#0000FF' },
14
+ { label: 'Amaranth', value: '#9F2B68' },
15
+ { label: 'Key Lime', value: '#DAF7A6' },
16
+ { label: 'Turquois', value: '#00FFD0' },
17
+ ]
18
+
19
+ const TypeaheadCustomMenuList = (props) => {
20
+ const defaultColorOptions = options.slice(0, 3)
21
+ const [colorOptions, setColorOptions] = useState(defaultColorOptions)
22
+
23
+ const moreToLoad = colorOptions.length == defaultColorOptions.length
24
+ const loadColors = moreToLoad ? () => setColorOptions(options) : () => setColorOptions(defaultColorOptions)
25
+
26
+ const menuListProps = {
27
+ footer: (<Button
28
+ margin="sm"
29
+ onClick={loadColors}
30
+ text={`Load ${moreToLoad ? "More" : "Less"}`}
31
+ />)
32
+ }
33
+
34
+ const MenuList = (props) => (
35
+ <Typeahead.MenuList
36
+ {...menuListProps}
37
+ {...props}
38
+ />
39
+ )
40
+
41
+ return (
42
+ <Typeahead
43
+ components={{ MenuList }}
44
+ label="Colors"
45
+ options={colorOptions}
46
+ {...props}
47
+ />
48
+ )
49
+ }
50
+
51
+ export default TypeaheadCustomMenuList
@@ -46,7 +46,7 @@ const TypeaheadWithHighlight = (props) => {
46
46
  if (!inputValue.length) return text
47
47
  return text.replace(
48
48
  new RegExp(inputValue, 'gi'),
49
- highlighted => `<mark>${highlighted}</mark>`
49
+ (highlighted) => `<mark>${highlighted}</mark>`
50
50
  )
51
51
  }
52
52
  return (
@@ -22,3 +22,4 @@ examples:
22
22
  - typeahead_createable: Createable
23
23
  - typeahead_async_createable: Createable (+ Async Data)
24
24
  - typeahead_error_state: Error State
25
+ - typeahead_custom_menu_list: Custom MenuList
@@ -9,3 +9,4 @@ export { default as TypeaheadMultiKit } from './_typeahead_multi_kit.jsx'
9
9
  export { default as TypeaheadCreateable } from './_typeahead_createable.jsx'
10
10
  export { default as TypeaheadAsyncCreateable } from './_typeahead_async_createable.jsx'
11
11
  export { default as TypeaheadErrorState } from './_typeahead_error_state.jsx'
12
+ export { default as TypeaheadCustomMenuList } from './_typeahead_custom_menu_list.jsx'
@@ -1,9 +1,4 @@
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 %>
1
+ <%= pb_content_tag do %>
7
2
  <% if object.avatar_url.present? || object.avatar %>
8
3
  <%= pb_rails("avatar", props: {
9
4
  name: object.name,
@@ -1,8 +1,3 @@
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 %>
1
+ <%= pb_content_tag do %>
7
2
  <%= content_tag(:div, object.display_badge, class: "pb_user_badge_wrapper") %>
8
3
  <% end %>
@@ -1,9 +1,4 @@
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 %>
1
+ <%= pb_content_tag do %>
7
2
  <%= pb_rails("caption", props: {dark: object.dark, text: object.day_of_week}) %>
8
3
  <%= pb_rails("title", props: {dark: object.dark, size: 4, tag: "span", text: object.formatted_month_and_day}) %>
9
4
  <% end %>
@@ -34,6 +34,7 @@ import * as DateYearStacked from 'pb_date_year_stacked/docs'
34
34
  import * as Detail from 'pb_detail/docs'
35
35
  import * as Dialog from 'pb_dialog/docs'
36
36
  import * as DistributionBarDocs from 'pb_distribution_bar/docs'
37
+ import * as Dropdown from 'pb_dropdown/docs'
37
38
  import * as FileUpload from 'pb_file_upload/docs'
38
39
  import * as Filter from 'pb_filter/docs'
39
40
  import * as FixedConfirmationToast from 'pb_fixed_confirmation_toast/docs'
@@ -136,6 +137,7 @@ WebpackerReact.registerComponents({
136
137
  ...Detail,
137
138
  ...Dialog,
138
139
  ...DistributionBarDocs,
140
+ ...Dropdown,
139
141
  ...FileUpload,
140
142
  ...Filter,
141
143
  ...FixedConfirmationToast,
@@ -213,7 +213,7 @@ $status_color_text: (
213
213
  warning: darken($warning, 10%),
214
214
  error: $error,
215
215
  info: $info,
216
- neutral: darken($neutral, 15%),
216
+ neutral: $text_lt_light,
217
217
  primary: $primary
218
218
  );
219
219
 
data/dist/menu.yml CHANGED
@@ -254,6 +254,10 @@ kits:
254
254
  platforms: *web
255
255
  description: Playbook's date picker is built using flatpickr, a vanilla js library. Common date picker use cases and features have been adapted into simple prop based configuration detailed in the docs below.
256
256
  status: "stable"
257
+ - name: dropdown
258
+ platforms: *react_only
259
+ description: ""
260
+ status: "beta"
257
261
  - name: "multi_level_select"
258
262
  platforms: *web
259
263
  description: The MultiLevelSelect kit renders a multi leveled select dropdown based on data from the user.
@@ -460,4 +464,4 @@ kits:
460
464
  - name: "user"
461
465
  platforms: *web
462
466
  description: This kit was created for having a systematic way of displaying users with avatar, titles, name and territory. This is a versatile kit with features than can be added to display more info.
463
- status: "stable"
467
+ status: "stable"