playbook_ui 13.25.0.pre.alpha.barchartfix2766 → 13.26.0.pre.alpha.PBNTR291Dropdownrailsv22840

Sign up to get free protection for your applications and to get access to all the features.
Files changed (223) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/index.js +1 -0
  3. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +14 -0
  4. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +14 -10
  5. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta.html.erb +33 -0
  6. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta.md +24 -0
  7. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_default.md +5 -0
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +2 -2
  9. data/app/pb_kits/playbook/pb_advanced_table/index.js +78 -0
  10. data/app/pb_kits/playbook/pb_advanced_table/table_body.html.erb +9 -5
  11. data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +4 -2
  12. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +6 -2
  13. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +9 -4
  14. data/app/pb_kits/playbook/pb_avatar/Utilities/GetPlacementPropsHelper.tsx +44 -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 +41 -0
  18. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_badge_component_overlay.html.erb +71 -0
  19. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_badge_component_overlay.jsx +77 -0
  20. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_circle_icon_component_overlay.html.erb +71 -0
  21. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_circle_icon_component_overlay.jsx +77 -0
  22. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_default.jsx +20 -0
  23. data/app/pb_kits/playbook/pb_avatar/docs/example.yml +4 -0
  24. data/app/pb_kits/playbook/pb_avatar/docs/index.js +2 -0
  25. data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.html.erb +6 -1
  26. data/app/pb_kits/playbook/pb_background/background.html.erb +11 -2
  27. data/app/pb_kits/playbook/pb_badge/badge.html.erb +6 -1
  28. data/app/pb_kits/playbook/pb_body/body.html.erb +6 -1
  29. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +6 -1
  30. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +7 -2
  31. data/app/pb_kits/playbook/pb_button/button.html.erb +3 -2
  32. data/app/pb_kits/playbook/pb_button_toolbar/button_toolbar.html.erb +7 -2
  33. data/app/pb_kits/playbook/pb_caption/caption.html.erb +6 -1
  34. data/app/pb_kits/playbook/pb_card/card.html.erb +7 -1
  35. data/app/pb_kits/playbook/pb_card/card_body.html.erb +6 -1
  36. data/app/pb_kits/playbook/pb_card/card_header.html.erb +6 -1
  37. data/app/pb_kits/playbook/pb_checkbox/_checkbox.scss +49 -0
  38. data/app/pb_kits/playbook/pb_checkbox/_checkbox.tsx +3 -0
  39. data/app/pb_kits/playbook/pb_checkbox/checkbox.html.erb +6 -1
  40. data/app/pb_kits/playbook/pb_checkbox/checkbox.rb +2 -1
  41. data/app/pb_kits/playbook/pb_checkbox/checkbox.test.js +14 -0
  42. data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_disabled.html.erb +23 -0
  43. data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_disabled.jsx +29 -0
  44. data/app/pb_kits/playbook/pb_checkbox/docs/example.yml +2 -0
  45. data/app/pb_kits/playbook/pb_checkbox/docs/index.js +1 -0
  46. data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.html.erb +6 -1
  47. data/app/pb_kits/playbook/pb_collapsible/collapsible.html.erb +6 -1
  48. data/app/pb_kits/playbook/pb_collapsible/collapsible_content.html.erb +6 -1
  49. data/app/pb_kits/playbook/pb_collapsible/collapsible_main.html.erb +7 -1
  50. data/app/pb_kits/playbook/pb_contact/contact.html.erb +6 -1
  51. data/app/pb_kits/playbook/pb_currency/currency.html.erb +6 -1
  52. data/app/pb_kits/playbook/pb_dashboard_value/dashboard_value.html.erb +6 -1
  53. data/app/pb_kits/playbook/pb_date/date.html.erb +6 -1
  54. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +6 -2
  55. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_on_change.md +3 -1
  56. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_on_close.md +3 -1
  57. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_quick_pick_range_limit.md +1 -1
  58. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.html.erb +5 -1
  59. data/app/pb_kits/playbook/pb_date_range_stacked/date_range_stacked.html.erb +5 -1
  60. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.html.erb +5 -1
  61. data/app/pb_kits/playbook/pb_date_time/date_time.html.erb +6 -1
  62. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.html.erb +7 -1
  63. data/app/pb_kits/playbook/pb_date_year_stacked/date_year_stacked.html.erb +5 -1
  64. data/app/pb_kits/playbook/pb_detail/detail.html.erb +6 -1
  65. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +6 -1
  66. data/app/pb_kits/playbook/pb_dialog/dialog_body.html.erb +7 -2
  67. data/app/pb_kits/playbook/pb_dialog/dialog_footer.html.erb +5 -1
  68. data/app/pb_kits/playbook/pb_dialog/dialog_header.html.erb +6 -2
  69. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +94 -32
  70. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +64 -23
  71. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.html.erb +10 -0
  72. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.jsx +2 -20
  73. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.md +1 -0
  74. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure.html.erb +17 -0
  75. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure.jsx +42 -0
  76. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure.md +7 -0
  77. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +2 -5
  78. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx +1 -2
  79. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.html.erb +60 -0
  80. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +2 -2
  81. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.md +3 -1
  82. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.html.erb +45 -0
  83. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.jsx +1 -4
  84. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.md +1 -1
  85. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.html.erb +17 -0
  86. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.jsx +1 -4
  87. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.html.erb +47 -0
  88. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_external_control.jsx +59 -0
  89. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_hook.jsx +72 -0
  90. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.html.erb +10 -0
  91. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.jsx +39 -0
  92. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.md +1 -0
  93. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +15 -4
  94. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +5 -1
  95. data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +26 -0
  96. data/app/pb_kits/playbook/pb_dropdown/dropdown.rb +20 -0
  97. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +200 -10
  98. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.html.erb +21 -0
  99. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.rb +19 -0
  100. data/app/pb_kits/playbook/pb_dropdown/dropdown_option.html.erb +27 -0
  101. data/app/pb_kits/playbook/pb_dropdown/dropdown_option.rb +22 -0
  102. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.html.erb +43 -0
  103. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.rb +30 -0
  104. data/app/pb_kits/playbook/pb_dropdown/hooks/useDropdown.tsx +2 -2
  105. data/app/pb_kits/playbook/pb_dropdown/hooks/useHandleOnKeydown.tsx +4 -4
  106. data/app/pb_kits/playbook/pb_dropdown/index.js +153 -0
  107. data/app/pb_kits/playbook/pb_dropdown/keyboard_accessibility.js +77 -0
  108. data/app/pb_kits/playbook/pb_dropdown/scss_partials/_dropdown_animation.scss +18 -0
  109. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownContainer.tsx +17 -8
  110. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +29 -17
  111. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownTrigger.tsx +96 -78
  112. data/app/pb_kits/playbook/pb_dropdown/utilities/clickOutsideHelper.tsx +41 -0
  113. data/app/pb_kits/playbook/pb_dropdown/utilities/index.ts +2 -0
  114. data/app/pb_kits/playbook/pb_dropdown/utilities/subComponentHelper.tsx +9 -7
  115. data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +6 -1
  116. data/app/pb_kits/playbook/pb_filter/filter.html.erb +5 -1
  117. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.html.erb +6 -1
  118. data/app/pb_kits/playbook/pb_flex/flex.html.erb +5 -1
  119. data/app/pb_kits/playbook/pb_flex/flex_item.html.erb +6 -2
  120. data/app/pb_kits/playbook/pb_form_group/form_group.html.erb +6 -1
  121. data/app/pb_kits/playbook/pb_form_pill/form_pill.html.erb +1 -1
  122. data/app/pb_kits/playbook/pb_hashtag/hashtag.html.erb +6 -1
  123. data/app/pb_kits/playbook/pb_highlight/highlight.html.erb +5 -1
  124. data/app/pb_kits/playbook/pb_home_address_street/home_address_street.html.erb +5 -1
  125. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.html.erb +7 -2
  126. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.html.erb +6 -1
  127. data/app/pb_kits/playbook/pb_icon_value/icon_value.html.erb +6 -1
  128. data/app/pb_kits/playbook/pb_label_pill/label_pill.html.erb +6 -1
  129. data/app/pb_kits/playbook/pb_label_value/label_value.html.erb +6 -1
  130. data/app/pb_kits/playbook/pb_layout/body.html.erb +5 -1
  131. data/app/pb_kits/playbook/pb_layout/footer.html.erb +5 -1
  132. data/app/pb_kits/playbook/pb_layout/header.html.erb +5 -1
  133. data/app/pb_kits/playbook/pb_layout/item.html.erb +5 -1
  134. data/app/pb_kits/playbook/pb_layout/layout.html.erb +5 -1
  135. data/app/pb_kits/playbook/pb_layout/sidebar.html.erb +5 -1
  136. data/app/pb_kits/playbook/pb_list/item.html.erb +8 -2
  137. data/app/pb_kits/playbook/pb_list/list.html.erb +8 -2
  138. data/app/pb_kits/playbook/pb_loading_inline/_loading_inline.tsx +3 -1
  139. data/app/pb_kits/playbook/pb_loading_inline/docs/_loading_inline_custom.html.erb +13 -0
  140. data/app/pb_kits/playbook/pb_loading_inline/docs/_loading_inline_custom.jsx +26 -0
  141. data/app/pb_kits/playbook/pb_loading_inline/docs/{_loading_inline_light.html.erb → _loading_inline_default.html.erb} +2 -2
  142. data/app/pb_kits/playbook/pb_loading_inline/docs/{_loading_inline_light.jsx → _loading_inline_default.jsx} +2 -2
  143. data/app/pb_kits/playbook/pb_loading_inline/docs/example.yml +4 -2
  144. data/app/pb_kits/playbook/pb_loading_inline/docs/index.js +2 -1
  145. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.html.erb +7 -2
  146. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.rb +1 -0
  147. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.test.js +14 -0
  148. data/app/pb_kits/playbook/pb_message/message.html.erb +6 -1
  149. data/app/pb_kits/playbook/pb_message/message_mention.html.erb +6 -1
  150. data/app/pb_kits/playbook/pb_multi_level_select/multi_level_select.html.erb +6 -1
  151. data/app/pb_kits/playbook/pb_multiple_users/multiple_users.html.erb +6 -1
  152. data/app/pb_kits/playbook/pb_multiple_users_stacked/multiple_users_stacked.html.erb +6 -1
  153. data/app/pb_kits/playbook/pb_nav/item.html.erb +14 -3
  154. data/app/pb_kits/playbook/pb_nav/nav.html.erb +6 -1
  155. data/app/pb_kits/playbook/pb_online_status/online_status.html.erb +6 -2
  156. data/app/pb_kits/playbook/pb_pagination/pagination.html.erb +6 -1
  157. data/app/pb_kits/playbook/pb_passphrase/passphrase.html.erb +1 -1
  158. data/app/pb_kits/playbook/pb_person/person.html.erb +12 -7
  159. data/app/pb_kits/playbook/pb_person_contact/person_contact.html.erb +6 -1
  160. data/app/pb_kits/playbook/pb_pill/pill.html.erb +6 -1
  161. data/app/pb_kits/playbook/pb_popover/popover.html.erb +6 -1
  162. data/app/pb_kits/playbook/pb_progress_pills/progress_pills.html.erb +6 -2
  163. data/app/pb_kits/playbook/pb_progress_simple/docs/_progress_simple_flex.html.erb +3 -0
  164. data/app/pb_kits/playbook/pb_progress_simple/docs/_progress_simple_flex.jsx +16 -0
  165. data/app/pb_kits/playbook/pb_progress_simple/docs/_progress_simple_flex.md +1 -0
  166. data/app/pb_kits/playbook/pb_progress_simple/docs/example.yml +2 -0
  167. data/app/pb_kits/playbook/pb_progress_simple/docs/index.js +1 -0
  168. data/app/pb_kits/playbook/pb_progress_simple/progress_simple.html.erb +6 -3
  169. data/app/pb_kits/playbook/pb_progress_simple/progress_simple.rb +1 -1
  170. data/app/pb_kits/playbook/pb_progress_step/progress_step.html.erb +5 -1
  171. data/app/pb_kits/playbook/pb_progress_step/progress_step_item.html.erb +5 -1
  172. data/app/pb_kits/playbook/pb_radio/_radio.scss +35 -0
  173. data/app/pb_kits/playbook/pb_radio/_radio.tsx +3 -0
  174. data/app/pb_kits/playbook/pb_radio/docs/_radio_alignment.jsx +4 -1
  175. data/app/pb_kits/playbook/pb_radio/docs/_radio_default.jsx +4 -1
  176. data/app/pb_kits/playbook/pb_radio/docs/_radio_disabled.html.erb +26 -0
  177. data/app/pb_kits/playbook/pb_radio/docs/_radio_disabled.jsx +31 -0
  178. data/app/pb_kits/playbook/pb_radio/docs/_radio_error.jsx +2 -1
  179. data/app/pb_kits/playbook/pb_radio/docs/example.yml +2 -0
  180. data/app/pb_kits/playbook/pb_radio/docs/index.js +1 -0
  181. data/app/pb_kits/playbook/pb_radio/radio.html.erb +8 -2
  182. data/app/pb_kits/playbook/pb_radio/radio.rb +5 -0
  183. data/app/pb_kits/playbook/pb_radio/radio.test.js +17 -0
  184. data/app/pb_kits/playbook/pb_section_separator/section_separator.html.erb +6 -1
  185. data/app/pb_kits/playbook/pb_select/select.html.erb +5 -1
  186. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +5 -1
  187. data/app/pb_kits/playbook/pb_selectable_card_icon/selectable_card_icon.html.erb +4 -1
  188. data/app/pb_kits/playbook/pb_selectable_icon/selectable_icon.html.erb +5 -1
  189. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +6 -1
  190. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +6 -1
  191. data/app/pb_kits/playbook/pb_source/source.html.erb +5 -1
  192. data/app/pb_kits/playbook/pb_star_rating/star_rating.html.erb +5 -1
  193. data/app/pb_kits/playbook/pb_stat_change/stat_change.html.erb +5 -1
  194. data/app/pb_kits/playbook/pb_stat_value/stat_value.html.erb +5 -1
  195. data/app/pb_kits/playbook/pb_table/table.html.erb +12 -2
  196. data/app/pb_kits/playbook/pb_table/table_body.html.erb +16 -6
  197. data/app/pb_kits/playbook/pb_table/table_cell.html.erb +16 -6
  198. data/app/pb_kits/playbook/pb_table/table_head.html.erb +16 -6
  199. data/app/pb_kits/playbook/pb_table/table_header.html.erb +13 -4
  200. data/app/pb_kits/playbook/pb_table/table_row.html.erb +16 -6
  201. data/app/pb_kits/playbook/pb_textarea/textarea.html.erb +5 -1
  202. data/app/pb_kits/playbook/pb_time/time.html.erb +5 -1
  203. data/app/pb_kits/playbook/pb_time_range_inline/time_range_inline.html.erb +5 -1
  204. data/app/pb_kits/playbook/pb_time_stacked/time_stacked.html.erb +5 -1
  205. data/app/pb_kits/playbook/pb_timeline/item.html.erb +7 -3
  206. data/app/pb_kits/playbook/pb_timeline/timeline.html.erb +5 -1
  207. data/app/pb_kits/playbook/pb_timestamp/timestamp.html.erb +6 -1
  208. data/app/pb_kits/playbook/pb_title/title.html.erb +6 -1
  209. data/app/pb_kits/playbook/pb_title_count/title_count.html.erb +6 -1
  210. data/app/pb_kits/playbook/pb_title_detail/title_detail.html.erb +5 -1
  211. data/app/pb_kits/playbook/pb_toggle/toggle.html.erb +6 -1
  212. data/app/pb_kits/playbook/pb_tooltip/_tooltip.tsx +1 -1
  213. data/app/pb_kits/playbook/pb_tooltip/tooltip.html.erb +5 -1
  214. data/app/pb_kits/playbook/pb_user/user.html.erb +6 -1
  215. data/app/pb_kits/playbook/pb_user_badge/user_badge.html.erb +6 -1
  216. data/app/pb_kits/playbook/pb_weekday_stacked/weekday_stacked.html.erb +6 -1
  217. data/app/pb_kits/playbook/playbook-rails.js +6 -0
  218. data/dist/menu.yml +1 -1
  219. data/dist/playbook-rails.js +6 -6
  220. data/lib/playbook/kit_base.rb +1 -1
  221. data/lib/playbook/version.rb +2 -2
  222. metadata +47 -5
  223. data/app/pb_kits/playbook/pb_advanced_table/docs/_description.md +0 -1
@@ -1,3 +1,7 @@
1
- <%= pb_content_tag(object.tag) do %>
1
+ <%= content_tag(object.tag,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
  <%= content.presence %>
3
7
  <% end %>
@@ -1,3 +1,7 @@
1
- <%= pb_content_tag(object.tag) do %>
1
+ <%= content_tag(object.tag,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
  <%= content.presence %>
3
7
  <% end %>
@@ -1,3 +1,7 @@
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
  <%= content %>
3
7
  <% end %>
@@ -1,3 +1,7 @@
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
  <%= content.presence %>
3
7
  <% end %>
@@ -1,3 +1,7 @@
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
  <%= content.presence %>
3
7
  <% end %>
@@ -1,4 +1,10 @@
1
- <%= pb_content_tag(:li,
2
- tabindex: object.tabindex) do %>
1
+ <%= content_tag(:li,
2
+ aria: object.aria,
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.id,
6
+ tabindex: object.tabindex,
7
+ **combined_html_options
8
+ ) do %>
3
9
  <%= content.presence %>
4
10
  <% end %>
@@ -1,7 +1,13 @@
1
1
  <%= content_tag(:div, class: object.list_classname) do %>
2
- <%= pb_content_tag(:"#{object.ordered_class}",
2
+ <%= content_tag(:"#{object.ordered_class}",
3
+ aria: object.aria,
4
+ class: object.classname,
5
+ data: object.data,
6
+ id: object.id,
3
7
  role: object.role,
4
- tabindex: object.tabindex) do %>
8
+ tabindex: object.tabindex,
9
+ **combined_html_options
10
+ ) do %>
5
11
  <%= content.presence %>
6
12
  <% end %>
7
13
  <% end %>
@@ -14,6 +14,7 @@ type LoadingInlineProps = {
14
14
  data?: { [key: string]: string },
15
15
  htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
16
16
  id?: string,
17
+ text?: string,
17
18
  }
18
19
 
19
20
  const LoadingInline = (props: LoadingInlineProps) => {
@@ -24,6 +25,7 @@ const LoadingInline = (props: LoadingInlineProps) => {
24
25
  data = {},
25
26
  htmlOptions = {},
26
27
  id,
28
+ text = ' Loading',
27
29
  } = props
28
30
 
29
31
  const ariaProps = buildAriaProps(aria)
@@ -50,7 +52,7 @@ const LoadingInline = (props: LoadingInlineProps) => {
50
52
  icon="spinner"
51
53
  pulse
52
54
  />
53
- {' Loading'}
55
+ {text}
54
56
  </Body>
55
57
  </div>
56
58
  )
@@ -0,0 +1,13 @@
1
+ <%= pb_rails("loading_inline", props: {
2
+ text: "Saving"
3
+ }) %>
4
+
5
+ <%= pb_rails("loading_inline", props: {
6
+ align: "center",
7
+ text: "Saving"
8
+ }) %>
9
+
10
+ <%= pb_rails("loading_inline", props: {
11
+ align: "right",
12
+ text: "Saving",
13
+ }) %>
@@ -0,0 +1,26 @@
1
+ import React from 'react'
2
+
3
+ import LoadingInline from '../_loading_inline'
4
+
5
+ const LoadingInlineCustom = (props) => {
6
+ return (
7
+ <div>
8
+ <LoadingInline
9
+ text=' Saving'
10
+ {...props}
11
+ />
12
+ <LoadingInline
13
+ align="center"
14
+ text=' Saving'
15
+ {...props}
16
+ />
17
+ <LoadingInline
18
+ align="right"
19
+ text=' Saving'
20
+ {...props}
21
+ />
22
+ </div>
23
+ )
24
+ }
25
+
26
+ export default LoadingInlineCustom
@@ -1,9 +1,9 @@
1
1
  <%= pb_rails("loading_inline") %>
2
2
 
3
3
  <%= pb_rails("loading_inline", props: {
4
- align: "center"
4
+ align: "center"
5
5
  }) %>
6
6
 
7
7
  <%= pb_rails("loading_inline", props: {
8
- align: "right"
8
+ align: "right"
9
9
  }) %>
@@ -2,7 +2,7 @@ import React from 'react'
2
2
 
3
3
  import LoadingInline from '../_loading_inline'
4
4
 
5
- const LoadingInlineLight = (props) => {
5
+ const LoadingInlineDefault = (props) => {
6
6
  return (
7
7
  <div>
8
8
  <LoadingInline
@@ -20,4 +20,4 @@ const LoadingInlineLight = (props) => {
20
20
  )
21
21
  }
22
22
 
23
- export default LoadingInlineLight
23
+ export default LoadingInlineDefault
@@ -1,9 +1,11 @@
1
1
  examples:
2
2
 
3
3
  rails:
4
- - loading_inline_light: Light
4
+ - loading_inline_default: Default
5
+ - loading_inline_custom: Custom Text
5
6
 
6
7
 
7
8
 
8
9
  react:
9
- - loading_inline_light: Default
10
+ - loading_inline_default: Default
11
+ - loading_inline_custom: Custom Text
@@ -1 +1,2 @@
1
- export { default as LoadingInlineLight } from './_loading_inline_light.jsx'
1
+ export { default as LoadingInlineDefault } from './_loading_inline_default.jsx'
2
+ export { default as LoadingInlineCustom } from './_loading_inline_custom.jsx'
@@ -1,5 +1,10 @@
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 %>
6
+
2
7
  <%= pb_rails("body", props: { color: "light", dark: object.dark }) do %>
3
- <%= pb_rails("icon", props: { aria: { label: "loading icon" }, fixed_width: true, icon: "spinner", pulse: true }) %> Loading
8
+ <%= pb_rails("icon", props: { aria: { label: "loading icon" }, fixed_width: true, icon: "spinner", pulse: true }) %> <%= object.text %>
4
9
  <% end %>
5
10
  <% end %>
@@ -7,6 +7,7 @@ module Playbook
7
7
  values: %w[left center right],
8
8
  default: "left"
9
9
  prop :dark, type: Playbook::Props::Boolean, default: false
10
+ prop :text, type: Playbook::Props::String, default: "Loading"
10
11
 
11
12
  def classname
12
13
  generate_classname("pb_loading_inline_kit", align)
@@ -39,3 +39,17 @@ test('should render aria-label', () => {
39
39
  const kit = screen.getByTestId(testId)
40
40
  expect(kit).toHaveAttribute('aria-label', testId)
41
41
  })
42
+
43
+
44
+ test('displays custom text content', () => {
45
+ render(
46
+ <LoadingInline
47
+ aria={{ label: testId }}
48
+ data={{ testid: testId }}
49
+ text=' Saving'
50
+ />
51
+ )
52
+
53
+ const kit = screen.getByTestId(testId)
54
+ expect(kit).toHaveTextContent('Saving')
55
+ })
@@ -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
  <% if object.valid? %>
3
8
  <%= pb_rails("avatar", props: {
4
9
  name: object.avatar_name,
@@ -1,3 +1,8 @@
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
  <%= content %>
3
8
  <% end %>
@@ -1,3 +1,8 @@
1
- <%= pb_content_tag do %>
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ data: object.data,
4
+ id: object.id,
5
+ class: object.classname,
6
+ **combined_html_options) do %>
2
7
  <%= react_component("MultiLevelSelect", object.multi_level_select_options) %>
3
8
  <% end %>
@@ -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
  <% object.users.take(object.display_count).each do |user| %>
3
8
  <%= pb_rails("avatar", props: user.merge({size: object.size, classname: "pb_multiple_users_item", dark: object.dark}) ) %>
4
9
  <% end %>
@@ -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
  <%= pb_rails("avatar", props: object.users[0].merge({size: "xs", classname: "pb_multiple_users_stacked_item", dark: object.dark}) ) %>
3
8
 
4
9
  <% unless object.only_one %>
@@ -1,11 +1,16 @@
1
1
  <% if object.collapsible %>
2
2
  <%= pb_rails("collapsible", props: { name: "collapsible-nav-example", classname: object.collapsible_nav_classname }) do %>
3
3
  <%= pb_rails("collapsible/collapsible_main", props: { name: "default-collapsible-nav", icon: object.collapsible_icons, size: "xs", dark: object.dark, classname:object.margin_classes }) do %>
4
- <%= pb_content_tag(object.tag,
4
+ <%= content_tag(object.tag,
5
+ aria: object.aria,
6
+ class: object.classname,
7
+ data: object.data,
5
8
  dark: object.dark,
9
+ id: object.id,
6
10
  href: object.link && object.link,
7
11
  target: object.link && object.target,
8
- ) do %>
12
+ **combined_html_options
13
+ ) do %>
9
14
  <% if object.image_url %>
10
15
  <%= pb_rails("image", props: { url: object.image_url, classname: "pb_nav_img_wrapper_collapsible" }) %>
11
16
  <% end %>
@@ -22,7 +27,13 @@
22
27
  <% end %>
23
28
  <% end %>
24
29
  <% else %>
25
- <%= pb_content_tag(object.tag,
30
+ <%= content_tag(object.tag,
31
+ aria: object.aria,
32
+ class: object.classname,
33
+ **combined_html_options,
34
+ data: object.data,
35
+ dark: object.dark,
36
+ id: object.id,
26
37
  href: object.link && object.link,
27
38
  target: object.link && object.target
28
39
  ) do %>
@@ -1,4 +1,9 @@
1
- <%= pb_content_tag(:nav) do %>
1
+ <%= content_tag(:nav,
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.title %>
3
8
  <%= content_tag(:div, class: "pb_nav_list_title") do %>
4
9
  <%= content_tag(:a, class: "pb_nav_list_item_link_text", href: object.link) do %>
@@ -1,3 +1,7 @@
1
- <%= pb_content_tag(:div,
2
- aria: object.aria.merge!(label: object.status)) do %>
1
+ <%= content_tag(:div,
2
+ aria: object.aria.merge!(label: object.status),
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.id,
6
+ **combined_html_options) do %>
3
7
  <% end %>
@@ -1,3 +1,8 @@
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
  <%= will_paginate object.model, renderer: Playbook::Pagination::Rails %>
3
8
  <% end %>
@@ -1 +1 @@
1
- <%= react_component('Passphrase', object.passphrase_options, class: object.classname) %>
1
+ <%= react_component('Passphrase', object.passphrase_options, class: object.classname, **combined_html_options) %>
@@ -1,8 +1,13 @@
1
- <%= pb_content_tag do %>
2
- <%= pb_rails("body", props: {
3
- tag: "span",
4
- classname: "pb_person_first" }) { object.first_name } %>
5
- <%= pb_rails("title", props: {
6
- text: object.last_name,
7
- size: 4 }) if object.last_name %>
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 %>
7
+ <%= pb_rails("body", props: {
8
+ tag: "span",
9
+ classname: "pb_person_first" }) { object.first_name } %>
10
+ <%= pb_rails("title", props: {
11
+ text: object.last_name,
12
+ size: 4 }) if object.last_name %>
8
13
  <% end %>
@@ -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("person", props: {
3
8
  first_name: object.first_name,
4
9
  last_name: object.last_name,
@@ -1,3 +1,8 @@
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
  <%= pb_rails("title", props: { text: object.display_text, tag: "div", size: 4, classname: "pb_pill_text" }) %>
3
8
  <% end %>
@@ -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
  <div class="pb_popover_tooltip hide" id="<%= object.tooltip_id %>" role="tooltip" style="<%= object.z_index_helper %>">
3
8
  <div class="pb_popover_body <%= object.width_height_class_helper %> <%= object.popover_spacing_helper %>" style="<%= object.width_height_helper %>">
4
9
  <%= content.presence %>
@@ -1,5 +1,9 @@
1
- <%= pb_content_tag(:div,
2
- aria: object.aria_attributes) do %>
1
+ <%= content_tag(:div,
2
+ aria: object.aria_attributes,
3
+ id: object.id,
4
+ data: object.data,
5
+ class: object.classname,
6
+ **combined_html_options) do %>
3
7
 
4
8
  <div class="progress_pills_status">
5
9
  <% object.with_status do |status| %>
@@ -0,0 +1,3 @@
1
+ <%= pb_rails("flex") do %>
2
+ <%= pb_rails("progress_simple", props: { flex: "1", percent: 50 }) %>
3
+ <% end %>
@@ -0,0 +1,16 @@
1
+ import React from 'react'
2
+ import { Flex, ProgressSimple } from '../..'
3
+
4
+ const ProgressSimpleFlex = () => {
5
+ return (
6
+ <Flex>
7
+ <ProgressSimple
8
+ align="left"
9
+ flex="1"
10
+ percent={68}
11
+ />
12
+ </Flex>
13
+ )
14
+ }
15
+
16
+ export default ProgressSimpleFlex
@@ -0,0 +1 @@
1
+ When rendering a Progress Simple through within a Flex container, you must pass `flex="1"` to the kit itself so that it fills the available space
@@ -3,6 +3,7 @@ examples:
3
3
  rails:
4
4
  - progress_simple_default: Default
5
5
  - progress_simple_value: Setting Values
6
+ - progress_simple_flex: Within a Flex
6
7
  - progress_simple_width: Progress Bar Width
7
8
  - progress_simple_variants: Variants
8
9
  - progress_simple_muted: Muted
@@ -12,6 +13,7 @@ examples:
12
13
  react:
13
14
  - progress_simple_default: Default
14
15
  - progress_simple_value: Setting Values
16
+ - progress_simple_flex: Within a Flex
15
17
  - progress_simple_width: Progress Bar Width
16
18
  - progress_simple_variants: Variants
17
19
  - progress_simple_muted: Muted
@@ -2,6 +2,7 @@ export { default as ProgressSimpleAlign } from './_progress_simple_align.jsx'
2
2
  export { default as ProgressSimpleDefault } from './_progress_simple_default.jsx'
3
3
  export { default as ProgressSimpleMuted } from './_progress_simple_muted.jsx'
4
4
  export { default as ProgressSimpleValue } from './_progress_simple_value.jsx'
5
+ export { default as ProgressSimpleFlex } from './_progress_simple_flex.jsx'
5
6
  export { default as ProgressSimpleWidth } from './_progress_simple_width.jsx'
6
7
  export { default as ProgressSimpleVariants } from './_progress_simple_variants.jsx'
7
8
 
@@ -1,7 +1,10 @@
1
1
  <%= content_tag(:div, class: object.wrapper_classname) do %>
2
- <%= pb_content_tag(:div,
3
- data: object.data_values,
4
- style: object.style) do %>
2
+ <%= content_tag(:div,
3
+ id: object.id,
4
+ data: object.data_values,
5
+ class: object.classname,
6
+ style: object.style,
7
+ **combined_html_options) do %>
5
8
  <%= content_tag(:div, "",
6
9
  class: "progress_simple_value",
7
10
  style: object.value_style) %>
@@ -48,7 +48,7 @@ module Playbook
48
48
  end
49
49
 
50
50
  def wrapper_classname
51
- "pb_progress_simple_wrapper_#{align}"
51
+ generate_classname("pb_progress_simple_wrapper_#{align}")
52
52
  end
53
53
 
54
54
  def classname
@@ -1,3 +1,7 @@
1
- <%= pb_content_tag(:ul) do %>
1
+ <%= content_tag(:ul,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
  <%= content.presence %>
3
7
  <% end %>
@@ -1,4 +1,8 @@
1
- <%= pb_content_tag(:li) do %>
1
+ <%= content_tag(:li,
2
+ id: object.id,
3
+ data: object.data,
4
+ class: object.classname,
5
+ **combined_html_options) do %>
2
6
  <div class="box" style="max-width: min-content;" id="<%= object.tooltip_trigger_class %>">
3
7
  <div class="circle">
4
8
  <%= pb_rails("icon", props: { icon: object.icon, size: "xs" }) if object.icon.present? %>
@@ -40,6 +40,23 @@
40
40
  border: 6px solid $primary;
41
41
  }
42
42
  }
43
+
44
+ &:disabled + .pb_radio_button {
45
+ cursor: not-allowed;
46
+ background-color: mix($charcoal, $white, 5%);
47
+ border-color: $border_light;
48
+
49
+ & ~ .pb_body_kit {
50
+ cursor: not-allowed;
51
+ color: $text_lt_light;
52
+ }
53
+ }
54
+
55
+ &:disabled:checked + .pb_radio_button{
56
+ cursor: not-allowed;
57
+ background-color: $white;
58
+ border: 6px solid $neutral;
59
+ }
43
60
  }
44
61
 
45
62
  &[class*=vertical] {
@@ -66,6 +83,24 @@
66
83
  border: 6px solid $primary;
67
84
  }
68
85
  }
86
+
87
+ &:disabled + .pb_radio_button {
88
+ cursor: not-allowed;
89
+ background-color: mix($charcoal, $white, 80%);
90
+ border: 2px solid $border_dark;
91
+
92
+ & ~ .pb_body_kit {
93
+ cursor: not-allowed;
94
+ color: $text_dk_light;
95
+ }
96
+ }
97
+
98
+ &:disabled:checked {
99
+ & ~ .pb_radio_button {
100
+ background-color: mix($charcoal, $white, 80%);
101
+ border: 6px solid $border_dark;
102
+ }
103
+ }
69
104
  }
70
105
 
71
106
  @media (hover:hover) {
@@ -14,6 +14,7 @@ type RadioProps = {
14
14
  className?: string,
15
15
  dark?: boolean,
16
16
  data?: {[key: string]: string},
17
+ disabled?: boolean,
17
18
  error?: boolean,
18
19
  htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
19
20
  id?: string,
@@ -31,6 +32,7 @@ const Radio = ({
31
32
  className,
32
33
  dark = false,
33
34
  data = {},
35
+ disabled = false,
34
36
  error = false,
35
37
  htmlOptions = {},
36
38
  id,
@@ -56,6 +58,7 @@ const Radio = ({
56
58
  else
57
59
  return (
58
60
  <input
61
+ disabled={disabled}
59
62
  id={id}
60
63
  name={name}
61
64
  onChange={onChange}
@@ -1,7 +1,7 @@
1
1
  import React from 'react'
2
2
  import { Flex, Radio } from '../../'
3
3
 
4
- const RadioAlignment = () => {
4
+ const RadioAlignment = (props) => {
5
5
  return (
6
6
  <Flex>
7
7
  <Radio
@@ -11,6 +11,7 @@ const RadioAlignment = () => {
11
11
  name="Group2"
12
12
  tabIndex={0}
13
13
  value="Power"
14
+ {...props}
14
15
  />
15
16
  <br />
16
17
  <Radio
@@ -20,6 +21,7 @@ const RadioAlignment = () => {
20
21
  marginRight="sm"
21
22
  name="Group2"
22
23
  value="Nitro"
24
+ {...props}
23
25
  />
24
26
  <br />
25
27
  <Radio
@@ -28,6 +30,7 @@ const RadioAlignment = () => {
28
30
  label="Google"
29
31
  name="Group2"
30
32
  value="Google"
33
+ {...props}
31
34
  />
32
35
  </Flex>
33
36
  )