playbook_ui 7.13.0.pre.alpha1 → 7.16.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (262) hide show
  1. checksums.yaml +4 -4
  2. data/app/helpers/playbook/pb_sample_helper.rb +1 -1
  3. data/app/pb_kits/playbook/_playbook.scss +8 -8
  4. data/app/pb_kits/playbook/data/menu.yml +0 -1
  5. data/app/pb_kits/playbook/index.js +2 -2
  6. data/app/pb_kits/playbook/pb_avatar/_avatar.html.erb +4 -6
  7. data/app/pb_kits/playbook/pb_avatar/_avatar.jsx +6 -2
  8. data/app/pb_kits/playbook/pb_avatar/avatar.rb +4 -0
  9. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_no_image.html.erb +5 -0
  10. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_no_image.jsx +41 -0
  11. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_no_image.md +2 -0
  12. data/app/pb_kits/playbook/pb_avatar/docs/example.yml +2 -0
  13. data/app/pb_kits/playbook/pb_avatar/docs/index.js +1 -0
  14. data/app/pb_kits/playbook/pb_background/docs/example.yml +0 -2
  15. data/app/pb_kits/playbook/pb_background/docs/index.js +0 -1
  16. data/app/pb_kits/playbook/pb_card/_card.jsx +3 -1
  17. data/app/pb_kits/playbook/pb_card/_card.scss +2 -2
  18. data/app/pb_kits/playbook/pb_card/_card_mixin.scss +6 -0
  19. data/app/pb_kits/playbook/pb_card/card.rb +9 -1
  20. data/app/pb_kits/playbook/pb_card/docs/_card_border_radius.html.erb +53 -0
  21. data/app/pb_kits/playbook/pb_card/docs/_card_border_radius.jsx +71 -0
  22. data/app/pb_kits/playbook/pb_card/docs/_card_border_radius.md +1 -0
  23. data/app/pb_kits/playbook/pb_card/docs/_card_light.md +1 -0
  24. data/app/pb_kits/playbook/pb_card/docs/example.yml +2 -0
  25. data/app/pb_kits/playbook/pb_card/docs/index.js +1 -0
  26. data/app/pb_kits/playbook/pb_date_range_inline/_date_range_inline.jsx +1 -0
  27. data/app/pb_kits/playbook/pb_date_range_stacked/docs/example.yml +0 -4
  28. data/app/pb_kits/playbook/pb_date_range_stacked/docs/index.js +0 -1
  29. data/app/pb_kits/playbook/pb_date_stacked/docs/example.yml +0 -7
  30. data/app/pb_kits/playbook/pb_date_stacked/docs/index.js +0 -2
  31. data/app/pb_kits/playbook/pb_date_time/_date_time.jsx +2 -2
  32. data/app/pb_kits/playbook/pb_date_time/docs/_date_time_default.jsx +2 -2
  33. data/app/pb_kits/playbook/pb_date_time_stacked/docs/example.yml +0 -4
  34. data/app/pb_kits/playbook/pb_date_time_stacked/docs/index.js +0 -1
  35. data/app/pb_kits/playbook/pb_date_year_stacked/docs/example.yml +0 -2
  36. data/app/pb_kits/playbook/pb_date_year_stacked/docs/index.js +0 -1
  37. data/app/pb_kits/playbook/pb_distribution_bar/_distribution_bar.jsx +9 -4
  38. data/app/pb_kits/playbook/pb_distribution_bar/_distribution_bar.scss +12 -7
  39. data/app/pb_kits/playbook/pb_distribution_bar/distribution_bar.rb +4 -1
  40. data/app/pb_kits/playbook/pb_distribution_bar/docs/_distribution_bar_custom_colors.html.erb +4 -0
  41. data/app/pb_kits/playbook/pb_distribution_bar/docs/_distribution_bar_custom_colors.jsx +18 -0
  42. data/app/pb_kits/playbook/pb_distribution_bar/docs/_distribution_bar_custom_colors.md +1 -0
  43. data/app/pb_kits/playbook/pb_distribution_bar/docs/example.yml +2 -0
  44. data/app/pb_kits/playbook/pb_distribution_bar/docs/index.js +1 -0
  45. data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.jsx +12 -1
  46. data/app/pb_kits/playbook/pb_filter/Filter/FiltersPopover.jsx +5 -1
  47. data/app/pb_kits/playbook/pb_filter/docs/_filter_close_popover.jsx +61 -0
  48. data/app/pb_kits/playbook/pb_filter/docs/_filter_default.html.erb +41 -0
  49. data/app/pb_kits/playbook/pb_filter/docs/_filter_default.jsx +84 -37
  50. data/app/pb_kits/playbook/pb_filter/docs/_filter_default.md +1 -0
  51. data/app/pb_kits/playbook/pb_filter/docs/example.yml +1 -0
  52. data/app/pb_kits/playbook/pb_filter/docs/index.js +1 -0
  53. data/app/pb_kits/playbook/pb_filter/templates/_core.html.erb +18 -7
  54. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.jsx +5 -1
  55. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/example.yml +0 -5
  56. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/index.js +0 -2
  57. data/app/pb_kits/playbook/pb_flex/_flex.jsx +25 -9
  58. data/app/pb_kits/playbook/pb_flex/_flex.scss +40 -7
  59. data/app/pb_kits/playbook/pb_flex/_flex_item.jsx +8 -2
  60. data/app/pb_kits/playbook/pb_flex/_flex_item.scss +19 -0
  61. data/app/pb_kits/playbook/pb_flex/docs/_description.md +6 -0
  62. data/app/pb_kits/playbook/pb_flex/docs/_flex_align.html.erb +101 -0
  63. data/app/pb_kits/playbook/pb_flex/docs/{_flex_horizontal.jsx → _flex_align.jsx} +71 -77
  64. data/app/pb_kits/playbook/pb_flex/docs/_flex_align.md +7 -0
  65. data/app/pb_kits/playbook/pb_flex/docs/_flex_default.html.erb +15 -15
  66. data/app/pb_kits/playbook/pb_flex/docs/_flex_default.jsx +17 -15
  67. data/app/pb_kits/playbook/pb_flex/docs/_flex_default.md +3 -1
  68. data/app/pb_kits/playbook/pb_flex/docs/_flex_gap.html.erb +33 -0
  69. data/app/pb_kits/playbook/pb_flex/docs/_flex_gap.jsx +75 -0
  70. data/app/pb_kits/playbook/pb_flex/docs/_flex_gap.md +9 -0
  71. data/app/pb_kits/playbook/pb_flex/docs/_flex_inline.html.erb +8 -8
  72. data/app/pb_kits/playbook/pb_flex/docs/_flex_inline.md +5 -1
  73. data/app/pb_kits/playbook/pb_flex/docs/_flex_item.html.erb +49 -0
  74. data/app/pb_kits/playbook/pb_flex/docs/_flex_item.md +11 -0
  75. data/app/pb_kits/playbook/pb_flex/docs/_flex_item_example.jsx +113 -0
  76. data/app/pb_kits/playbook/pb_flex/docs/{_flex_horizontal.html.erb → _flex_justify.html.erb} +19 -21
  77. data/app/pb_kits/playbook/pb_flex/docs/{_flex_vertical.jsx → _flex_justify.jsx} +41 -99
  78. data/app/pb_kits/playbook/pb_flex/docs/_flex_justify.md +7 -0
  79. data/app/pb_kits/playbook/pb_flex/docs/_flex_reverse.html.erb +9 -9
  80. data/app/pb_kits/playbook/pb_flex/docs/_flex_reverse.jsx +2 -2
  81. data/app/pb_kits/playbook/pb_flex/docs/_flex_reverse.md +5 -0
  82. data/app/pb_kits/playbook/pb_flex/docs/_flex_spacing.html.erb +23 -8
  83. data/app/pb_kits/playbook/pb_flex/docs/_flex_spacing.jsx +4 -4
  84. data/app/pb_kits/playbook/pb_flex/docs/_flex_spacing.md +7 -0
  85. data/app/pb_kits/playbook/pb_flex/docs/_flex_wrap.jsx +1 -1
  86. data/app/pb_kits/playbook/pb_flex/docs/_flex_wrap.md +5 -0
  87. data/app/pb_kits/playbook/pb_flex/docs/example.yml +9 -4
  88. data/app/pb_kits/playbook/pb_flex/docs/index.js +4 -2
  89. data/app/pb_kits/playbook/pb_flex/flex.rb +79 -12
  90. data/app/pb_kits/playbook/pb_flex/flex_item.rb +25 -1
  91. data/app/pb_kits/playbook/pb_form_pill/_form_pill.jsx +7 -1
  92. data/app/pb_kits/playbook/pb_form_pill/_form_pill.scss +2 -0
  93. data/app/pb_kits/playbook/pb_gauge/docs/_gauge_sizing.html.erb +4 -4
  94. data/app/pb_kits/playbook/pb_gauge/docs/_gauge_sizing.jsx +12 -1
  95. data/app/pb_kits/playbook/pb_gauge/docs/_gauge_sizing.md +2 -1
  96. data/app/pb_kits/playbook/pb_gauge/docs/example.yml +4 -5
  97. data/app/pb_kits/playbook/pb_icon/docs/example.yml +1 -2
  98. data/app/pb_kits/playbook/pb_icon/docs/index.js +0 -1
  99. data/app/pb_kits/playbook/pb_icon_circle/docs/example.yml +0 -7
  100. data/app/pb_kits/playbook/pb_icon_circle/docs/index.js +0 -3
  101. data/app/pb_kits/playbook/pb_icon_value/docs/example.yml +0 -5
  102. data/app/pb_kits/playbook/pb_icon_value/docs/index.js +0 -2
  103. data/app/pb_kits/playbook/pb_image/_image.html.erb +3 -1
  104. data/app/pb_kits/playbook/pb_image/_image.jsx +4 -1
  105. data/app/pb_kits/playbook/pb_image/_image.scss +1 -0
  106. data/app/pb_kits/playbook/pb_image/docs/_custom_error_image.html.erb +75 -0
  107. data/app/pb_kits/playbook/pb_image/docs/_custom_error_image.jsx +55 -0
  108. data/app/pb_kits/playbook/pb_image/docs/example.yml +2 -0
  109. data/app/pb_kits/playbook/pb_image/docs/index.js +1 -0
  110. data/app/pb_kits/playbook/pb_image/image.rb +2 -0
  111. data/app/pb_kits/playbook/{pb_collapsible/child_kits/_collapsible_content.html.erb → pb_layout/_item.html.erb} +1 -2
  112. data/app/pb_kits/playbook/pb_layout/_layout.jsx +19 -1
  113. data/app/pb_kits/playbook/pb_layout/_layout.scss +42 -10
  114. data/app/pb_kits/playbook/pb_layout/docs/_layout_collection.html.erb +4 -4
  115. data/app/pb_kits/playbook/pb_layout/docs/_layout_collection.md +1 -0
  116. data/app/pb_kits/playbook/pb_layout/docs/_layout_collection_detail.jsx +1 -1
  117. data/app/pb_kits/playbook/pb_layout/docs/_layout_masonry.html.erb +48 -0
  118. data/app/pb_kits/playbook/pb_layout/docs/_layout_masonry.jsx +61 -0
  119. data/app/pb_kits/playbook/pb_layout/docs/example.yml +2 -3
  120. data/app/pb_kits/playbook/pb_layout/docs/index.js +1 -1
  121. data/app/pb_kits/playbook/pb_layout/item.rb +25 -0
  122. data/app/pb_kits/playbook/pb_layout/layout.rb +15 -15
  123. data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_legend.jsx +1 -1
  124. data/app/pb_kits/playbook/pb_popover/docs/example.yml +0 -13
  125. data/app/pb_kits/playbook/pb_popover/docs/index.js +0 -5
  126. data/app/pb_kits/playbook/pb_radio/_radio.scss +1 -0
  127. data/app/pb_kits/playbook/pb_select/_select.scss +6 -4
  128. data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.html.erb +54 -11
  129. data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.jsx +62 -8
  130. data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.scss +67 -9
  131. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_block.jsx +41 -44
  132. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_default.html.erb +2 -2
  133. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_default.jsx +53 -62
  134. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_error.html.erb +36 -0
  135. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_error.jsx +58 -0
  136. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_image.jsx +43 -53
  137. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_input.html.erb +105 -0
  138. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_input.jsx +158 -0
  139. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_input.md +1 -0
  140. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_single_select.html.erb +2 -2
  141. data/app/pb_kits/playbook/pb_selectable_card/docs/_selectable_card_single_select.jsx +46 -53
  142. data/app/pb_kits/playbook/pb_selectable_card/docs/example.yml +4 -0
  143. data/app/pb_kits/playbook/pb_selectable_card/docs/index.js +2 -0
  144. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.rb +38 -2
  145. data/app/pb_kits/playbook/pb_selectable_card_icon/_selectable_card_icon.scss +8 -8
  146. data/app/pb_kits/playbook/pb_table/_table.jsx +8 -0
  147. data/app/pb_kits/playbook/pb_table/docs/_table_alignment_shift_data.jsx +0 -1
  148. data/app/pb_kits/playbook/pb_table/docs/_table_responsive_table.html.erb +56 -4
  149. data/app/pb_kits/playbook/pb_table/docs/_table_responsive_table.jsx +64 -3
  150. data/app/pb_kits/playbook/pb_table/docs/_table_sm.md +2 -0
  151. data/app/pb_kits/playbook/pb_table/styles/_all.scss +3 -0
  152. data/app/pb_kits/playbook/pb_table/styles/_desktop_collapse.scss +135 -0
  153. data/app/pb_kits/playbook/pb_table/styles/_mobile_collapse.scss +135 -0
  154. data/app/pb_kits/playbook/pb_table/styles/_tablet_collapse.scss +135 -0
  155. data/app/pb_kits/playbook/pb_table/table.rb +8 -1
  156. data/app/pb_kits/playbook/pb_textarea/_textarea.jsx +10 -2
  157. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_resize.html.erb +2 -2
  158. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_resize.jsx +9 -1
  159. data/app/pb_kits/playbook/pb_textarea/index.js +17 -0
  160. data/app/pb_kits/playbook/pb_textarea/textarea.rb +3 -4
  161. data/app/pb_kits/playbook/pb_timestamp/_timestamp.html.erb +6 -4
  162. data/app/pb_kits/playbook/pb_timestamp/_timestamp.jsx +92 -16
  163. data/app/pb_kits/playbook/pb_timestamp/_timestamp.scss +12 -1
  164. data/app/pb_kits/playbook/pb_timestamp/docs/_description.md +1 -1
  165. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_align.jsx +26 -18
  166. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_default.html.erb +21 -1
  167. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_default.jsx +40 -8
  168. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_elapsed.jsx +12 -4
  169. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_timezones.jsx +26 -18
  170. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_updated.html.erb +0 -21
  171. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_updated.jsx +6 -28
  172. data/app/pb_kits/playbook/pb_timestamp/docs/example.yml +8 -0
  173. data/app/pb_kits/playbook/pb_timestamp/docs/index.js +4 -0
  174. data/app/pb_kits/playbook/pb_timestamp/timestamp.rb +83 -1
  175. data/app/pb_kits/playbook/pb_typeahead/_typeahead.html.erb +1 -1
  176. data/app/pb_kits/playbook/pb_typeahead/_typeahead.jsx +6 -1
  177. data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +38 -2
  178. data/app/pb_kits/playbook/pb_typeahead/components/Control.jsx +1 -0
  179. data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.jsx +2 -4
  180. data/app/pb_kits/playbook/pb_typeahead/components/Option.jsx +8 -3
  181. data/app/pb_kits/playbook/pb_typeahead/docs/{_typeahead_with_context_dark.html.erb → _typeahead_with_context.html.erb} +10 -2
  182. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills.html.erb +1 -1
  183. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async.jsx +13 -1
  184. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async_custom_options.jsx +111 -0
  185. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async_custom_options.md +1 -0
  186. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async_users.html.erb +1 -1
  187. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async_users.jsx +1 -0
  188. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +3 -2
  189. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -0
  190. data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +2 -1
  191. data/app/pb_kits/playbook/pb_user_badge/docs/index.js +0 -1
  192. data/app/pb_kits/playbook/tokens/_border_radius.scss +21 -7
  193. data/app/pb_kits/playbook/utilities/_max_width.scss +15 -0
  194. data/app/pb_kits/playbook/utilities/_spacing.scss +20 -20
  195. data/app/pb_kits/playbook/utilities/globalProps.js +7 -1
  196. data/app/pb_kits/playbook/vendor.js +3 -3
  197. data/lib/playbook.rb +1 -0
  198. data/lib/playbook/markdown/template_handler.rb +45 -0
  199. data/lib/playbook/props.rb +23 -1
  200. data/lib/playbook/version.rb +1 -1
  201. metadata +54 -72
  202. data/app/pb_kits/playbook/pb_background/docs/_background_dark.html.erb +0 -3
  203. data/app/pb_kits/playbook/pb_background/docs/_background_dark.jsx +0 -12
  204. data/app/pb_kits/playbook/pb_collapsible/_collapsible.html.erb +0 -9
  205. data/app/pb_kits/playbook/pb_collapsible/_collapsible.jsx +0 -77
  206. data/app/pb_kits/playbook/pb_collapsible/_collapsible.scss +0 -15
  207. data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleContent.jsx +0 -40
  208. data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleMain.jsx +0 -59
  209. data/app/pb_kits/playbook/pb_collapsible/child_kits/_collapsible_main.html.erb +0 -16
  210. data/app/pb_kits/playbook/pb_collapsible/collapsible.rb +0 -15
  211. data/app/pb_kits/playbook/pb_collapsible/collapsible_content.rb +0 -21
  212. data/app/pb_kits/playbook/pb_collapsible/collapsible_main.rb +0 -21
  213. data/app/pb_kits/playbook/pb_collapsible/docs/_collapsible_default.html.erb +0 -10
  214. data/app/pb_kits/playbook/pb_collapsible/docs/_collapsible_default.jsx +0 -19
  215. data/app/pb_kits/playbook/pb_collapsible/docs/example.yml +0 -8
  216. data/app/pb_kits/playbook/pb_collapsible/docs/index.js +0 -1
  217. data/app/pb_kits/playbook/pb_collapsible/index.js +0 -79
  218. data/app/pb_kits/playbook/pb_date_range_stacked/docs/_date_range_stacked_dark.html.erb +0 -1
  219. data/app/pb_kits/playbook/pb_date_range_stacked/docs/_date_range_stacked_dark.jsx +0 -15
  220. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_dark.html.erb +0 -5
  221. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_dark.jsx +0 -26
  222. data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_dark.html.erb +0 -1
  223. data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_dark.jsx +0 -14
  224. data/app/pb_kits/playbook/pb_date_year_stacked/docs/_date_year_stacked_dark.html.erb +0 -5
  225. data/app/pb_kits/playbook/pb_date_year_stacked/docs/_date_year_stacked_dark.jsx +0 -28
  226. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_dark.html.erb +0 -21
  227. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_dark.jsx +0 -43
  228. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line_dark.html.erb +0 -5
  229. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line_dark.jsx +0 -17
  230. data/app/pb_kits/playbook/pb_flex/docs/_flex_vertical.html.erb +0 -68
  231. data/app/pb_kits/playbook/pb_icon/docs/_icon_default_dark.html.erb +0 -3
  232. data/app/pb_kits/playbook/pb_icon/docs/_icon_default_dark.jsx +0 -18
  233. data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_color_dark.html.erb +0 -42
  234. data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_color_dark.jsx +0 -66
  235. data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_dark.html.erb +0 -4
  236. data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_dark.jsx +0 -17
  237. data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_sizes_dark.html.erb +0 -29
  238. data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_sizes_dark.jsx +0 -38
  239. data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_align_dark.html.erb +0 -23
  240. data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_align_dark.jsx +0 -37
  241. data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_dark.html.erb +0 -21
  242. data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_dark.jsx +0 -35
  243. data/app/pb_kits/playbook/pb_layout/docs/_layout_sizes_dark.html.erb +0 -32
  244. data/app/pb_kits/playbook/pb_layout/docs/_layout_sizes_dark.jsx +0 -97
  245. data/app/pb_kits/playbook/pb_popover/docs/_popover_close_dark.html.erb +0 -43
  246. data/app/pb_kits/playbook/pb_popover/docs/_popover_close_dark.jsx +0 -105
  247. data/app/pb_kits/playbook/pb_popover/docs/_popover_dark.html.erb +0 -25
  248. data/app/pb_kits/playbook/pb_popover/docs/_popover_dark.jsx +0 -51
  249. data/app/pb_kits/playbook/pb_popover/docs/_popover_list_dark.html.erb +0 -13
  250. data/app/pb_kits/playbook/pb_popover/docs/_popover_list_dark.jsx +0 -54
  251. data/app/pb_kits/playbook/pb_popover/docs/_popover_scroll_height_dark.html.erb +0 -25
  252. data/app/pb_kits/playbook/pb_popover/docs/_popover_scroll_height_dark.jsx +0 -57
  253. data/app/pb_kits/playbook/pb_popover/docs/_popover_z_index_dark.html.erb +0 -14
  254. data/app/pb_kits/playbook/pb_popover/docs/_popover_z_index_dark.jsx +0 -54
  255. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_elapsed_align.html.erb +0 -54
  256. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_elapsed_align.jsx +0 -73
  257. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_timezones_align.html.erb +0 -177
  258. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_timezones_align.jsx +0 -209
  259. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_updated_align.html.erb +0 -123
  260. data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_updated_align.jsx +0 -146
  261. data/app/pb_kits/playbook/pb_user_badge/docs/_user_badge_size_dark.html.erb +0 -21
  262. data/app/pb_kits/playbook/pb_user_badge/docs/_user_badge_size_dark.jsx +0 -36
@@ -10,9 +10,17 @@ module Playbook
10
10
  prop :fixed_size, default: nil
11
11
  prop :grow, type: Playbook::Props::Boolean,
12
12
  default: false
13
+ prop :shrink, type: Playbook::Props::Boolean,
14
+ default: false
15
+ prop :flex, type: Playbook::Props::Enum,
16
+ values: %w[0 1 2 3 4 5 6 7 8 9 10 11 12 none],
17
+ default: "none"
18
+ prop :overflow, type: Playbook::Props::Enum,
19
+ values: %w[auto hidden inherit initial scroll visible] + [nil],
20
+ default: nil
13
21
 
14
22
  def classname
15
- generate_classname("pb_flex_item_kit", fixed_size_class, grow_class)
23
+ generate_classname("pb_flex_item_kit", fixed_size_class, grow_class, shrink_class, flex_class) + overflow_class
16
24
  end
17
25
 
18
26
  def style_value
@@ -28,6 +36,22 @@ module Playbook
28
36
  def grow_class
29
37
  grow ? "grow" : nil
30
38
  end
39
+
40
+ def overflow_class
41
+ overflow ? " overflow_#{overflow}" : ""
42
+ end
43
+
44
+ def shrink_class
45
+ shrink ? "shrink" : nil
46
+ end
47
+
48
+ def flex_class
49
+ if flex == "none"
50
+ nil
51
+ else
52
+ "flex_#{flex}"
53
+ end
54
+ end
31
55
  end
32
56
  end
33
57
  end
@@ -14,9 +14,14 @@ type FormPillProps = {
14
14
  onClick?: EventHandler,
15
15
  avatar?: boolean,
16
16
  avatarUrl?: string,
17
+ closeProps?: {
18
+ onClick?: EventHandler,
19
+ onMouseDown?: EventHandler,
20
+ onTouchEnd?: EventHandler,
21
+ },
17
22
  }
18
23
  const FormPill = (props: FormPillProps) => {
19
- const { className, text, name, onClick = () => {}, avatarUrl } = props
24
+ const { className, text, name, onClick = () => {}, avatarUrl, closeProps = {} } = props
20
25
  const css = classnames(
21
26
  `pb_form_pill_kit_${'primary'}`,
22
27
  globalProps(props),
@@ -46,6 +51,7 @@ const FormPill = (props: FormPillProps) => {
46
51
  <div
47
52
  className="pb_form_pill_close"
48
53
  onClick={onClick}
54
+ {...closeProps}
49
55
  >
50
56
  <Icon
51
57
  fixedWidth
@@ -18,6 +18,8 @@ $form_pill_colors: (
18
18
  padding: 0 $space-sm/3;
19
19
  height: $pb_form_pill_height;
20
20
  border-radius: $pb_form_pill_height/2;
21
+ margin-bottom: 2px;
22
+ margin-top: 2px;
21
23
  cursor: pointer;
22
24
  @each $color_name, $color_value in $form_pill_colors {
23
25
  &[class*=_#{$color_name}] {
@@ -1,23 +1,23 @@
1
1
  <%= pb_rails("flex", props: {wrap: true}) do %>
2
- <%= pb_rails("flex/flex_item", props: {fixed_size: "400px"}) do %>
2
+ <%= pb_rails("flex/flex_item", props: {fixed_size: "400px", overflow: "hidden", shrink: true }) do %>
3
3
  <%= pb_rails("gauge", props: {
4
4
  id: "gauge-sizing4",
5
5
  chart_data: [{ name: "Point 1", value: 100 }],
6
6
  }) %>
7
7
  <% end %>
8
- <%= pb_rails("flex/flex_item", props: {fixed_size: "300px"}) do %>
8
+ <%= pb_rails("flex/flex_item", props: {fixed_size: "300px", overflow: "hidden", shrink: true }) do %>
9
9
  <%= pb_rails("gauge", props: {
10
10
  id: "gauge-sizing3",
11
11
  chart_data: [{ name: "Point 2", value: 75 }],
12
12
  }) %>
13
13
  <% end %>
14
- <%= pb_rails("flex/flex_item", props: {fixed_size: "200px"}) do %>
14
+ <%= pb_rails("flex/flex_item", props: {fixed_size: "200px", overflow: "hidden", shrink: true }) do %>
15
15
  <%= pb_rails("gauge", props: {
16
16
  id: "gauge-sizing2",
17
17
  chart_data: [{ name: "Point 3", value: 50 }],
18
18
  }) %>
19
19
  <% end %>
20
- <%= pb_rails("flex/flex_item", props: {fixed_size: "125px"}) do %>
20
+ <%= pb_rails("flex/flex_item", props: {fixed_size: "125px", overflow: "hidden", shrink: true }) do %>
21
21
  <%= pb_rails("gauge", props: {
22
22
  id: "gauge-sizing1",
23
23
  chart_data: [{ name: "Point 4", value: 25 }],
@@ -9,6 +9,8 @@ const GaugeSizing = (props) => (
9
9
  >
10
10
  <FlexItem
11
11
  fixedSize="400px"
12
+ overflow="hidden"
13
+ shrink
12
14
  {...props}
13
15
  >
14
16
  <Gauge
@@ -19,6 +21,8 @@ const GaugeSizing = (props) => (
19
21
  </FlexItem>
20
22
  <FlexItem
21
23
  fixedSize="300px"
24
+ overflow="hidden"
25
+ shrink
22
26
  {...props}
23
27
  >
24
28
  <Gauge
@@ -29,6 +33,8 @@ const GaugeSizing = (props) => (
29
33
  </FlexItem>
30
34
  <FlexItem
31
35
  fixedSize="200px"
36
+ overflow="hidden"
37
+ shrink
32
38
  {...props}
33
39
  >
34
40
  <Gauge
@@ -37,7 +43,12 @@ const GaugeSizing = (props) => (
37
43
  {...props}
38
44
  />
39
45
  </FlexItem>
40
- <FlexItem fixedSize="125px">
46
+ <FlexItem
47
+ fixedSize="125px"
48
+ overflow="hidden"
49
+ shrink
50
+ {...props}
51
+ >
41
52
  <Gauge
42
53
  chartData={[ { name: 'Point 4', value: 25 } ]}
43
54
  id="gauge-sizing1"
@@ -1 +1,2 @@
1
- ### Gauge resizes dynamically to fit whatever element it's placed within.
1
+ ### Gauge resizes dynamically to fit whatever element it's placed within.
2
+ #### Note: set `overflow` to hidden on the parent element when nesting gauges inside of a flex items to best respond to shrinking screens.
@@ -1,5 +1,5 @@
1
1
  examples:
2
-
2
+
3
3
  rails:
4
4
  - gauge_default: Default
5
5
  - gauge_disable_animation: Disable Animation
@@ -9,16 +9,15 @@ examples:
9
9
  - gauge_min_max: Min Max Labels
10
10
  - gauge_sizing: Sizing
11
11
  - gauge_height: Height
12
-
13
-
12
+
13
+
14
14
  react:
15
15
  - gauge_default: Default
16
16
  - gauge_disable_animation: Disable Animation
17
- - gauge_title: Title
17
+ - gauge_title: Title
18
18
  - gauge_units: Units
19
19
  - gauge_full_circle: Full Circle
20
20
  - gauge_min_max: Min Max Labels
21
21
  - gauge_sizing: Sizing
22
22
  - gauge_height: Height
23
23
  - gauge_live_data: Live Data
24
-
@@ -7,7 +7,7 @@ examples:
7
7
  - icon_pull: Icon Pull
8
8
  - icon_border: Icon Border
9
9
  - icon_sizes: Icon Sizes
10
- - icon_default_dark: Icon Default Dark
10
+
11
11
  react:
12
12
  - icon_default: Icon Default
13
13
  - icon_rotate: Icon Rotate
@@ -16,4 +16,3 @@ examples:
16
16
  - icon_pull: Icon Pull
17
17
  - icon_border: Icon Border
18
18
  - icon_sizes: Icon Sizes
19
- - icon_default_dark: Icon Default Dark
@@ -5,4 +5,3 @@ export { default as IconAnimate } from './_icon_animate.jsx'
5
5
  export { default as IconPull } from './_icon_pull.jsx'
6
6
  export { default as IconBorder } from './_icon_border.jsx'
7
7
  export { default as IconSizes } from './_icon_sizes.jsx'
8
- export { default as IconDefaultDark } from './_icon_default_dark.jsx'
@@ -4,15 +4,8 @@ examples:
4
4
  - icon_circle_default: Default
5
5
  - icon_circle_sizes: Size
6
6
  - icon_circle_color: Color
7
- - icon_circle_dark: Dark
8
- - icon_circle_sizes_dark: Dark Size
9
- - icon_circle_color_dark: Dark Color
10
-
11
7
 
12
8
  react:
13
9
  - icon_circle_default: Default
14
10
  - icon_circle_sizes: Size
15
11
  - icon_circle_color: Color
16
- - icon_circle_dark: Dark
17
- - icon_circle_sizes_dark: Dark Size
18
- - icon_circle_color_dark: Dark Color
@@ -1,6 +1,3 @@
1
1
  export { default as IconCircleColor } from './_icon_circle_color.jsx'
2
2
  export { default as IconCircleDefault } from './_icon_circle_default.jsx'
3
3
  export { default as IconCircleSizes } from './_icon_circle_sizes.jsx'
4
- export { default as IconCircleDark } from './_icon_circle_dark.jsx'
5
- export { default as IconCircleColorDark } from './_icon_circle_color_dark.jsx'
6
- export { default as IconCircleSizesDark } from './_icon_circle_sizes_dark.jsx'
@@ -3,12 +3,7 @@ examples:
3
3
  rails:
4
4
  - icon_value_default: Default
5
5
  - icon_value_align: Align
6
- - icon_value_dark: Dark
7
- - icon_value_align_dark: Align Dark
8
-
9
6
 
10
7
  react:
11
8
  - icon_value_default: Default
12
9
  - icon_value_align: Align
13
- - icon_value_dark: Dark
14
- - icon_value_align_dark: Align Dark
@@ -1,4 +1,2 @@
1
1
  export { default as IconValueDefault } from './_icon_value_default.jsx'
2
2
  export { default as IconValueAlign } from './_icon_value_align.jsx'
3
- export { default as IconValueDark } from './_icon_value_dark.jsx'
4
- export { default as IconValueAlignDark } from './_icon_value_align_dark.jsx'
@@ -4,5 +4,7 @@
4
4
  class: object.classname,
5
5
  aria: object.aria,
6
6
  src: object.url,
7
- alt: object.alt)
7
+ alt: object.alt,
8
+ onerror: object.on_error,
9
+ )
8
10
  %>
@@ -11,6 +11,7 @@ type ImageProps = {
11
11
  className?: string,
12
12
  data?: object,
13
13
  id?: string,
14
+ onError?: () => {},
14
15
  size: "xs" | "sm" | "md" | "lg" | "xl",
15
16
  rounded?: boolean,
16
17
  url: string,
@@ -23,6 +24,7 @@ const Image = (props: ImageProps) => {
23
24
  className,
24
25
  data = {},
25
26
  id,
27
+ onError = null,
26
28
  rounded = false,
27
29
  size = '',
28
30
  url = '',
@@ -46,7 +48,8 @@ const Image = (props: ImageProps) => {
46
48
  className={classes}
47
49
  data-src={url}
48
50
  id={id}
49
- rounded={rounded}
51
+ onError={onError}
52
+ rounded={+rounded}
50
53
  src={url}
51
54
  />
52
55
  </div>
@@ -11,6 +11,7 @@ $image-sizes: (
11
11
 
12
12
  [class^=pb_image_kit] {
13
13
  position: relative;
14
+ object-fit: cover;
14
15
 
15
16
  @each $name, $size in $image-sizes {
16
17
  &[class*=_#{$name}] {
@@ -0,0 +1,75 @@
1
+ <style>
2
+ .image-error:before {
3
+ content: "Sorry, the image below seems to be broken.";
4
+ display: block;
5
+ margin-bottom: 10px;
6
+ }
7
+ .image-error {
8
+ margin: 5px;
9
+ padding: 5px;
10
+ outline: 1px solid red;
11
+ }
12
+ </style>
13
+
14
+ <%= pb_rails("body",
15
+ props: {
16
+ text: "Handle when an image fails to load or a broken link is passed. This is not neccessary most of the time."
17
+ }
18
+ ) %>
19
+
20
+ <br>
21
+ <br>
22
+
23
+ <%= pb_rails("body",
24
+ props: {
25
+ text: "Alter the display when the image fails to load:"
26
+ }
27
+ ) %>
28
+
29
+ <%= pb_rails("image",
30
+ props: {
31
+ alt: "This is the alt text!",
32
+ on_error: "this.style.color = 'red'",
33
+ rounded: true,
34
+ size: "xs",
35
+ url: "not_a_picture"
36
+ }
37
+ ) %>
38
+
39
+ <br>
40
+ <br>
41
+
42
+ <%= pb_rails("body",
43
+ props: {
44
+ text: "Give it an error class:"
45
+ }
46
+ ) %>
47
+
48
+ <%= pb_rails("image",
49
+ props: {
50
+ alt: "This is the alt text!",
51
+ on_error: "this.classList.add('image-error')",
52
+ rounded: true,
53
+ size: "xs",
54
+ url: "not_a_picture"
55
+ }
56
+ ) %>
57
+
58
+ <br>
59
+ <br>
60
+
61
+ <%= pb_rails("body",
62
+ props: {
63
+ text: "Or hide it completely:"
64
+ }
65
+ ) %>
66
+
67
+ <%= pb_rails("image",
68
+ props: {
69
+ alt: "This is the alt text!",
70
+ on_error: "this.style.display = 'none'",
71
+ rounded: true,
72
+ size: "xs",
73
+ url: "not_a_picture",
74
+ }
75
+ ) %>
@@ -0,0 +1,55 @@
1
+ import React from 'react'
2
+ import { Body, Image } from '../../'
3
+
4
+ const CustomErrorImage = (props) => {
5
+ return (
6
+ <>
7
+ <Body text="Handle when an image fails to load or a broken link is passed. This is not neccessary most of the time." />
8
+ <br />
9
+ <Body text="Alter the display when the image fails to load:" />
10
+ <Image
11
+ alt="This is the alt text!"
12
+ onError={(e) => e.target.style.color = 'red'}
13
+ rounded
14
+ size="xs"
15
+ url="not_a_valid_url"
16
+ {...props}
17
+ />
18
+ <br />
19
+ <br />
20
+ <Body text="Give it an error class:" />
21
+ <Image
22
+ alt="This is the alt text!"
23
+ onError={(e) => e.target.classList.add('image-error')}
24
+ rounded
25
+ size="sm"
26
+ url="not_a_valid_url"
27
+ {...props}
28
+ />
29
+ <br />
30
+ <br />
31
+ <Body text="Set an inline style" />
32
+ <Image
33
+ alt="This is the alt text!"
34
+ onError={(e) => e.target.style.outline = '1px solid red'}
35
+ rounded
36
+ size="md"
37
+ url="not_a_valid_url"
38
+ {...props}
39
+ />
40
+ <br />
41
+ <br />
42
+ <Body text="Hide it completely!" />
43
+ <Image
44
+ alt="This is the alt text!"
45
+ onError={(e) => e.target.style.display = 'none'}
46
+ rounded
47
+ size="md"
48
+ url="not_a_valid_url"
49
+ {...props}
50
+ />
51
+ </>
52
+ )
53
+ }
54
+
55
+ export default CustomErrorImage
@@ -2,6 +2,8 @@ examples:
2
2
  rails:
3
3
  - default_image: Default
4
4
  - rounded_image: Rounded
5
+ - custom_error_image: Error Handling
5
6
  react:
6
7
  - default_image: Default
7
8
  - rounded_image: Rounded
9
+ - custom_error_image: Error Handling
@@ -1,2 +1,3 @@
1
1
  export { default as DefaultImage } from './_default_image.jsx'
2
2
  export { default as RoundedImage } from './_rounded_image.jsx'
3
+ export { default as CustomErrorImage } from './_custom_error_image.jsx'
@@ -8,6 +8,8 @@ module Playbook
8
8
  partial "pb_image/image"
9
9
 
10
10
  prop :alt
11
+ prop :on_error, type: Playbook::Props::String,
12
+ default: nil
11
13
  prop :rounded, type: Playbook::Props::Boolean,
12
14
  default: false
13
15
  prop :size, type: Playbook::Props::Enum,