primer_view_components 0.0.97 → 0.0.98

Sign up to get free protection for your applications and to get access to all the features.
Files changed (99) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +10 -0
  3. data/app/components/primer/beta/avatar.rb +10 -10
  4. data/app/components/primer/beta/avatar_stack.rb +9 -9
  5. data/app/components/primer/beta/blankslate.rb +2 -2
  6. data/app/components/primer/button_component.rb +1 -1
  7. data/app/components/primer/image.rb +4 -4
  8. data/app/components/primer/image_crop.rb +3 -3
  9. data/app/components/primer/timeline_item_component.rb +1 -1
  10. data/lib/primer/deprecations.rb +0 -1
  11. data/lib/primer/example_image.rb +7 -0
  12. data/lib/primer/view_components/version.rb +1 -1
  13. data/lib/tasks/docs.rake +4 -4
  14. data/lib/tasks/test.rake +1 -1
  15. data/previews/primer/alpha/action_list_preview/heading.html.erb +4 -0
  16. data/previews/primer/alpha/action_list_preview.rb +308 -0
  17. data/previews/primer/alpha/auto_complete_preview.rb +42 -0
  18. data/previews/primer/alpha/button_marketing_preview.rb +17 -0
  19. data/previews/primer/alpha/dialog_preview/custom_header.html.erb +7 -0
  20. data/previews/primer/alpha/dialog_preview/test.html.erb +7 -0
  21. data/previews/primer/alpha/dialog_preview/with_footer.html.erb +8 -0
  22. data/previews/primer/alpha/dialog_preview/with_form.html.erb +12 -0
  23. data/previews/primer/alpha/dialog_preview.rb +85 -0
  24. data/previews/primer/alpha/hidden_text_expander_preview.rb +15 -0
  25. data/previews/primer/alpha/layout_preview.rb +23 -0
  26. data/previews/primer/alpha/nav_list_preview.rb +64 -0
  27. data/previews/primer/alpha/tab_panels_preview.rb +23 -0
  28. data/previews/primer/alpha/text_field_preview.rb +66 -0
  29. data/previews/primer/alpha/toggle_switch_preview.rb +50 -0
  30. data/previews/primer/alpha/tooltip_preview/with_multiple_on_a_page.html.erb +14 -0
  31. data/previews/primer/alpha/tooltip_preview/with_right_most_position.html.erb +7 -0
  32. data/previews/primer/alpha/tooltip_preview.rb +83 -0
  33. data/previews/primer/alpha/underline_nav_preview/default.html.erb +8 -0
  34. data/previews/primer/alpha/underline_nav_preview.rb +41 -0
  35. data/previews/primer/alpha/underline_panels_preview.rb +23 -0
  36. data/previews/primer/beta/auto_complete_item_preview/default.html.erb +9 -0
  37. data/previews/primer/beta/auto_complete_item_preview/with_description.html.erb +11 -0
  38. data/previews/primer/beta/auto_complete_item_preview.rb +40 -0
  39. data/previews/primer/beta/auto_complete_preview/with_submit_button.html.erb +20 -0
  40. data/previews/primer/beta/auto_complete_preview.rb +245 -0
  41. data/previews/primer/beta/avatar_preview.rb +17 -0
  42. data/previews/primer/beta/avatar_stack_preview.rb +44 -0
  43. data/previews/primer/beta/base_button_preview.rb +17 -0
  44. data/previews/primer/beta/blankslate_preview.rb +94 -0
  45. data/previews/primer/beta/border_box_preview.rb +32 -0
  46. data/previews/primer/beta/breadcrumbs_preview.rb +19 -0
  47. data/previews/primer/beta/button_group_preview.rb +20 -0
  48. data/previews/primer/beta/button_preview/all_schemes.html.erb +26 -0
  49. data/previews/primer/beta/button_preview/leading_visual.html.erb +10 -0
  50. data/previews/primer/beta/button_preview/trailing_action.html.erb +10 -0
  51. data/previews/primer/beta/button_preview/trailing_visual.html.erb +11 -0
  52. data/previews/primer/beta/button_preview/with_tooltip.html.erb +10 -0
  53. data/previews/primer/beta/button_preview.rb +256 -0
  54. data/previews/primer/beta/close_button_preview.rb +15 -0
  55. data/previews/primer/beta/counter_preview.rb +24 -0
  56. data/previews/primer/beta/details_preview.rb +45 -0
  57. data/previews/primer/beta/flash_preview.rb +20 -0
  58. data/previews/primer/beta/heading_preview.rb +16 -0
  59. data/previews/primer/beta/icon_button_preview.rb +107 -0
  60. data/previews/primer/beta/text_preview.rb +16 -0
  61. data/previews/primer/beta/truncate_preview.rb +47 -0
  62. data/previews/primer/clipboard_copy_preview/element.html.erb +2 -0
  63. data/previews/primer/clipboard_copy_preview.rb +29 -0
  64. data/previews/primer/dropdown_preview.rb +39 -0
  65. data/previews/primer/forms/forms_preview/after_content_form.html.erb +3 -0
  66. data/previews/primer/forms/forms_preview/array_check_box_group_form.html.erb +3 -0
  67. data/previews/primer/forms/forms_preview/caption_template_form.html.erb +3 -0
  68. data/previews/primer/forms/forms_preview/check_box_group_form.html.erb +3 -0
  69. data/previews/primer/forms/forms_preview/composed_form.html.erb +4 -0
  70. data/previews/primer/forms/forms_preview/horizontal_form.html.erb +3 -0
  71. data/previews/primer/forms/forms_preview/invalid_form.html.erb +3 -0
  72. data/previews/primer/forms/forms_preview/multi_input_form.html.erb +3 -0
  73. data/previews/primer/forms/forms_preview/multi_text_field_form.html.erb +3 -0
  74. data/previews/primer/forms/forms_preview/radio_button_group_form.html.erb +3 -0
  75. data/previews/primer/forms/forms_preview/radio_button_with_nested_form.html.erb +3 -0
  76. data/previews/primer/forms/forms_preview/select_list_form.html.erb +3 -0
  77. data/previews/primer/forms/forms_preview/single_text_field_form.html.erb +3 -0
  78. data/previews/primer/forms/forms_preview/submit_button_form.html.erb +3 -0
  79. data/previews/primer/forms/forms_preview/text_field_and_checkbox_form.html.erb +3 -0
  80. data/previews/primer/forms/forms_preview.rb +37 -0
  81. data/previews/primer/hellip_button_preview.rb +14 -0
  82. data/previews/primer/image_crop_preview.rb +22 -0
  83. data/previews/primer/label_component_preview.rb +15 -0
  84. data/previews/primer/layout_component_preview.rb +18 -0
  85. data/previews/primer/link_component_preview.rb +29 -0
  86. data/previews/primer/local_time_component_preview.rb +41 -0
  87. data/previews/primer/markdown_preview.rb +280 -0
  88. data/previews/primer/menu_component_preview/default.html.erb +17 -0
  89. data/previews/primer/menu_component_preview.rb +9 -0
  90. data/previews/primer/octicon_component_preview.rb +14 -0
  91. data/previews/primer/popover_component_preview.rb +20 -0
  92. data/previews/primer/progress_bar_component_preview.rb +17 -0
  93. data/previews/primer/spinner_component_preview.rb +13 -0
  94. data/previews/primer/state_component_preview.rb +16 -0
  95. data/previews/primer/subhead_component_preview.rb +23 -0
  96. data/previews/primer/time_ago_component_preview.rb +16 -0
  97. data/previews/primer/timeline_item_component_preview.rb +17 -0
  98. data/static/statuses.json +1 -1
  99. metadata +87 -3
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: e350542f645d77a1d752b926ee53d2e197a5f97d89e39a89cbc09e3431e93d5c
4
- data.tar.gz: 252230dd0d07e03433a13f03bd49fc65b8cc2035a0c133029f7a2c134ded8ea5
3
+ metadata.gz: 47893a22bb4a08e254dae2744724c97bcc998116747da9c6596ae156b71ba5e9
4
+ data.tar.gz: f54f340e71d3dc92edcffd5b5e1aaa507dc0dab4d268d855e6d3f0fc06895c3c
5
5
  SHA512:
6
- metadata.gz: 77068320cb0755cb82c7403df704c4c3d112f64a9784570f551a9dd518525e688c49b64940cf4b59c1758147373b4034b6ca59530bb816a7ef7a151f718e6cb1
7
- data.tar.gz: 04d8bcefddc160b67c0e30c778c12f9a0ff8b3632ca524a796f5b0af6d17c40142aca0094ec4087038b341f5d435e7014963f673383da915712fda9ce615df65
6
+ metadata.gz: c5e6d60d6de17b2c74f05c2e988dbe4b90a4581c16dda91c0a181013c2e2c1147cac6ec350f059a8363dd81e24517b4d40ad90ace61d1bf899478c06bcc22f4e
7
+ data.tar.gz: 9c3fd3c0cec9c5077f885293703076ff183ebb865ed962930e1440a92504abebc16c22d5dcba3bda7b6463a2ae0daa763e7f3a028481231d5f92017e1c00165e
data/CHANGELOG.md CHANGED
@@ -1,5 +1,15 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## 0.0.98
4
+
5
+ ### Patch Changes
6
+
7
+ - [#1420](https://github.com/primer/view_components/pull/1420) [`d6623553`](https://github.com/primer/view_components/commit/d662355359b1b5d8801cc6a86a1376cb1d2da63b) Thanks [@mxriverlynn](https://github.com/mxriverlynn)! - un-deprecate Primer::ButtonComponent for now, due to inconsistencies and issues in migrating to Primer::Beta::Button
8
+
9
+ * [`1d4b6851`](https://github.com/primer/view_components/commit/1d4b685174ca82cb0f67e65cc095810841b0b390) Thanks [@jonrohan](https://github.com/jonrohan)! - Move previews into root and include in gemspec. Thanks [@steves](https://github.com/steves)! [#1404](https://github.com/primer/view_components/pull/1404)
10
+
11
+ - [#1416](https://github.com/primer/view_components/pull/1416) [`f99156fd`](https://github.com/primer/view_components/commit/f99156fddcab45467a4da773387efa4ea13401c3) Thanks [@jonrohan](https://github.com/jonrohan)! - Don't use outside images in docs examples
12
+
3
13
  ## 0.0.97
4
14
 
5
15
  ### Patch Changes
@@ -28,22 +28,22 @@ module Primer
28
28
  SIZE_OPTIONS = [16, DEFAULT_SIZE, SMALL_THRESHOLD, 32, 40, 48, 80].freeze
29
29
 
30
30
  # @example Default
31
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser")) %>
31
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser")) %>
32
32
  #
33
33
  # @example Square
34
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", shape: :square)) %>
34
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", shape: :square)) %>
35
35
  #
36
36
  # @example Link
37
- # <%= render(Primer::Beta::Avatar.new(href: "#", src: "http://placekitten.com/200/200", alt: "@kittenuser profile")) %>
37
+ # <%= render(Primer::Beta::Avatar.new(href: "#", src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser profile")) %>
38
38
  #
39
39
  # @example With size
40
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", size: 16)) %>
41
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", size: 20)) %>
42
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", size: 24)) %>
43
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", size: 32)) %>
44
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", size: 40)) %>
45
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", size: 48)) %>
46
- # <%= render(Primer::Beta::Avatar.new(src: "http://placekitten.com/200/200", alt: "@kittenuser", size: 80)) %>
40
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", size: 16)) %>
41
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", size: 20)) %>
42
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", size: 24)) %>
43
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", size: 32)) %>
44
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", size: 40)) %>
45
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", size: 48)) %>
46
+ # <%= render(Primer::Beta::Avatar.new(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser", size: 80)) %>
47
47
  #
48
48
  # @param src [String] The source url of the avatar image.
49
49
  # @param alt [String] Passed through to alt on img tag.
@@ -21,23 +21,23 @@ module Primer
21
21
 
22
22
  # @example Default
23
23
  # <%= render(Primer::Beta::AvatarStack.new) do |c| %>
24
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
25
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
26
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
24
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
25
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
26
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
27
27
  # <% end %>
28
28
  #
29
29
  # @example Align right
30
30
  # <%= render(Primer::Beta::AvatarStack.new(align: :right)) do |c| %>
31
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
32
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
33
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
31
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
32
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
33
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
34
34
  # <% end %>
35
35
  #
36
36
  # @example With tooltip
37
37
  # <%= render(Primer::Beta::AvatarStack.new(tooltipped: true, body_arguments: { label: 'This is a tooltip!' })) do |c| %>
38
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
39
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
40
- # <% c.with_avatar(src: "http://placekitten.com/200/200", alt: "@kittenuser") %>
38
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
39
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
40
+ # <% c.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "@kittenuser") %>
41
41
  # <% end %>
42
42
  #
43
43
  # @param tag [Symbol] <%= one_of(Primer::Beta::AvatarStack::TAG_OPTIONS) %>
@@ -83,7 +83,7 @@ module Primer
83
83
  system_arguments[:size] = :medium
84
84
  system_arguments[:scheme] ||= :primary
85
85
 
86
- Primer::ButtonComponent.new(**system_arguments)
86
+ Primer::ButtonComponent.new(**system_arguments) # rubocop:disable Primer/ComponentNameMigration
87
87
  }
88
88
 
89
89
  # Optional secondary action
@@ -130,7 +130,7 @@ module Primer
130
130
  # Add an `image` to give context that an Octicon couldn't.
131
131
  # @code
132
132
  # <%= render Primer::Beta::Blankslate.new do |c| %>
133
- # <% c.visual_image(src: "https://github.githubassets.com/images/modules/site/features/security-icon.svg", alt: "Security - secure vault") %>
133
+ # <% c.visual_image(src: Primer::ExampleImage::BASE64_SRC, alt: "Security - secure vault") %>
134
134
  # <% c.heading(tag: :h2).with_content("Title") %>
135
135
  # <% c.description { "Description"} %>
136
136
  # <% end %>
@@ -3,7 +3,7 @@
3
3
  module Primer
4
4
  # Use `Button` for actions (e.g. in forms). Use links for destinations, or moving from one page to another.
5
5
  class ButtonComponent < Primer::Component
6
- status :deprecated
6
+ status :beta
7
7
 
8
8
  DEFAULT_SCHEME = :default
9
9
  LINK_SCHEME = :link
@@ -8,19 +8,19 @@ module Primer
8
8
  class Image < Primer::Component
9
9
  # @example Default
10
10
  #
11
- # <%= render(Primer::Image.new(src: "https://github.com/github.png", alt: "GitHub")) %>
11
+ # <%= render(Primer::Image.new(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub")) %>
12
12
  #
13
13
  # @example Helper
14
14
  #
15
- # <%= primer_image(src: "https://github.com/github.png", alt: "GitHub") %>
15
+ # <%= primer_image(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub") %>
16
16
  #
17
17
  # @example Lazy loading
18
18
  #
19
- # <%= render(Primer::Image.new(src: "https://github.com/github.png", alt: "GitHub", lazy: true)) %>
19
+ # <%= render(Primer::Image.new(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub", lazy: true)) %>
20
20
  #
21
21
  # @example Custom size
22
22
  #
23
- # <%= render(Primer::Image.new(src: "https://github.com/github.png", alt: "GitHub", height: 100, width: 100)) %>
23
+ # <%= render(Primer::Image.new(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub", height: 100, width: 100)) %>
24
24
  #
25
25
  # @param src [String] The source url of the image.
26
26
  # @param alt [String] Specifies an alternate text for the image.
@@ -14,13 +14,13 @@ module Primer
14
14
  }
15
15
 
16
16
  # @example Simple cropper
17
- # <%= render(Primer::ImageCrop.new(src: "https://github.com/koddsson.png")) %>
17
+ # <%= render(Primer::ImageCrop.new(src: Primer::ExampleImage::BASE64_SRC)) %>
18
18
  #
19
19
  # @example Square cropper
20
- # <%= render(Primer::ImageCrop.new(src: "https://github.com/koddsson.png", rounded: false)) %>
20
+ # <%= render(Primer::ImageCrop.new(src: Primer::ExampleImage::BASE64_SRC, rounded: false)) %>
21
21
  #
22
22
  # @example Cropper with a custom loader
23
- # <%= render(Primer::ImageCrop.new(src: "https://github.com/koddsson.png", rounded: false)) do |cropper| %>
23
+ # <%= render(Primer::ImageCrop.new(src: Primer::ExampleImage::BASE64_SRC, rounded: false)) do |cropper| %>
24
24
  # <% cropper.with_loading(style: "width: 120px").with_content("Loading...") %>
25
25
  # <% end %>
26
26
  #
@@ -40,7 +40,7 @@ module Primer
40
40
  # @example Default
41
41
  # <div style="padding-left: 60px">
42
42
  # <%= render(Primer::TimelineItemComponent.new) do |component| %>
43
- # <% component.with_avatar(src: "https://github.com/github.png", alt: "github") %>
43
+ # <% component.with_avatar(src: Primer::ExampleImage::BASE64_SRC, alt: "github") %>
44
44
  # <% component.with_badge(bg: :success_emphasis, color: :on_emphasis, icon: :check) %>
45
45
  # <% component.with_body { "Success!" } %>
46
46
  # <% end %>
@@ -9,7 +9,6 @@ module Primer
9
9
  "Primer::Alpha::AutoComplete::Item" => "Primer::Beta::AutoComplete::Item",
10
10
  "Primer::BlankslateComponent" => "Primer::Beta::Blankslate",
11
11
  "Primer::BoxComponent" => "Primer::Box",
12
- "Primer::ButtonComponent" => "Primer::Beta::Button",
13
12
  "Primer::CloseButton" => "Primer::Beta::CloseButton",
14
13
  "Primer::CounterComponent" => "Primer::Beta::Counter",
15
14
  "Primer::DetailsComponent" => "Primer::Beta::Details",
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Primer
4
+ class ExampleImage
5
+ BASE64_SRC = ""
6
+ end
7
+ end
@@ -5,7 +5,7 @@ module Primer
5
5
  module VERSION
6
6
  MAJOR = 0
7
7
  MINOR = 0
8
- PATCH = 97
8
+ PATCH = 98
9
9
 
10
10
  STRING = [MAJOR, MINOR, PATCH].join(".")
11
11
  end
data/lib/tasks/docs.rake CHANGED
@@ -386,7 +386,7 @@ namespace :docs do
386
386
  task :preview do
387
387
  registry = generate_yard_registry
388
388
 
389
- FileUtils.rm_rf("test/previews/primer/docs/")
389
+ FileUtils.rm_rf("previews/primer/docs/")
390
390
 
391
391
  components = Primer::Component.descendants
392
392
 
@@ -400,7 +400,7 @@ namespace :docs do
400
400
 
401
401
  yard_example_tags = initialize_method.tags(:example)
402
402
 
403
- path = Pathname.new("test/previews/docs/#{short_name.underscore}_preview.rb")
403
+ path = Pathname.new("previews/docs/#{short_name.underscore}_preview.rb")
404
404
  path.dirname.mkdir unless path.dirname.exist?
405
405
 
406
406
  File.open(path, "w") do |f|
@@ -412,7 +412,7 @@ namespace :docs do
412
412
  method_name = name.split("|").first.downcase.parameterize.underscore
413
413
  f.puts(" def #{method_name}; end")
414
414
  f.puts unless index == yard_example_tags.size - 1
415
- path = Pathname.new("test/previews/docs/#{short_name.underscore}_preview/#{method_name}.html.erb")
415
+ path = Pathname.new("previews/docs/#{short_name.underscore}_preview/#{method_name}.html.erb")
416
416
  path.dirname.mkdir unless path.dirname.exist?
417
417
  File.open(path, "w") do |view_file|
418
418
  view_file.puts(code.to_s)
@@ -514,7 +514,7 @@ namespace :docs do
514
514
  def preview_exists?(component)
515
515
  path = component.name.underscore
516
516
 
517
- File.exist?("test/previews/#{path}_preview.rb")
517
+ File.exist?("previews/#{path}_preview.rb")
518
518
  end
519
519
 
520
520
  def example_path(component)
data/lib/tasks/test.rake CHANGED
@@ -33,7 +33,7 @@ namespace :test do
33
33
 
34
34
  t.libs << "test"
35
35
  t.libs << "lib"
36
- t.test_files = FileList["test/system/**/*_test.rb", "test/previews/**/*_test.rb"]
36
+ t.test_files = FileList["test/system/**/*_test.rb"]
37
37
  end
38
38
 
39
39
  Rake::TestTask.new(:bench) do |t|
@@ -0,0 +1,4 @@
1
+ <%# this <ul> is necessary here to make axe happy %>
2
+ <ul>
3
+ <%= render(Primer::Alpha::ActionList::Heading.new(scheme: scheme, list_id: list_id, title: title, subtitle: subtitle)) %>
4
+ </ul>
@@ -0,0 +1,308 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Primer
4
+ module Alpha
5
+ # @label ActionList
6
+ class ActionListPreview < ViewComponent::Preview
7
+ # @label Default
8
+ #
9
+ # @param role text
10
+ # @param scheme [Symbol] select [full, inset]
11
+ # @param show_dividers toggle
12
+ def default(
13
+ role: Primer::Alpha::ActionList::DEFAULT_ROLE,
14
+ scheme: Primer::Alpha::ActionList::DEFAULT_SCHEME,
15
+ show_dividers: false
16
+ )
17
+ render(Primer::Alpha::ActionList.new(
18
+ role: role,
19
+ scheme: scheme,
20
+ show_dividers: show_dividers,
21
+ aria: { label: "Action List" }
22
+ )) do |c|
23
+ c.with_heading(title: "Action List")
24
+ c.with_item(label: "Item one", href: "/") do |item|
25
+ item.with_leading_visual_icon(icon: :gear)
26
+ end
27
+ c.with_item(label: "Item two", href: "/") do |item|
28
+ item.with_leading_visual_icon(icon: :star)
29
+ end
30
+ c.with_item(label: "Item three", href: "/") do |item|
31
+ item.with_leading_visual_icon(icon: :heart)
32
+ end
33
+ end
34
+ end
35
+
36
+ # @label Divider
37
+ #
38
+ # @param scheme [Symbol] select [subtle, filled]
39
+ def divider(
40
+ scheme: Primer::Alpha::ActionList::Divider::DEFAULT_SCHEME
41
+ )
42
+ render(Primer::Alpha::ActionList::Divider.new(scheme: scheme))
43
+ end
44
+
45
+ # @label Heading
46
+ #
47
+ # @param scheme [Symbol] select [subtle, filled]
48
+ # @param title text
49
+ # @param subtitle text
50
+ # @param list_id text
51
+ def heading(
52
+ scheme: Primer::Alpha::ActionList::Heading::DEFAULT_SCHEME,
53
+ title: "This is a title",
54
+ list_id: "unique-id",
55
+ subtitle: "This is a subtitle"
56
+ )
57
+ render_with_template(
58
+ locals: {
59
+ scheme: scheme,
60
+ title: title,
61
+ list_id: list_id,
62
+ subtitle: subtitle
63
+ }
64
+ )
65
+ end
66
+
67
+ # @label Item [playground]
68
+ #
69
+ # @param label text
70
+ # @param truncate_label toggle
71
+ # @param href text
72
+ # @param size [Symbol] select [medium, large, xlarge]
73
+ # @param scheme [Symbol] select [default, danger]
74
+ # @param disabled toggle
75
+ # @param description text
76
+ # @param description_scheme [Symbol] select [inline, block]
77
+ # @param active toggle
78
+ # @param leading_visual_icon [Symbol] octicon
79
+ # @param leading_visual_avatar_src text
80
+ # @param trailing_visual_icon [Symbol] octicon
81
+ # @param trailing_visual_label text
82
+ # @param trailing_visual_counter number
83
+ # @param trailing_visual_text text
84
+ # @param private_leading_action_icon [Symbol] octicon
85
+ # @param private_trailing_action_icon [Symbol] octicon
86
+ # @param trailing_action toggle
87
+ # @param trailing_action_on_hover toggle
88
+ # @param tooltip toggle
89
+ def item(
90
+ label: "Label",
91
+ truncate_label: false,
92
+ href: nil,
93
+ size: Primer::Alpha::ActionList::Item::DEFAULT_SIZE,
94
+ scheme: Primer::Alpha::ActionList::Item::DEFAULT_SCHEME,
95
+ disabled: false,
96
+ description: nil,
97
+ description_scheme: Primer::Alpha::ActionList::Item::DEFAULT_DESCRIPTION_SCHEME,
98
+ active: false,
99
+ expanded: false,
100
+ leading_visual_icon: nil,
101
+ leading_visual_avatar_src: nil,
102
+ trailing_visual_icon: nil,
103
+ trailing_visual_label: nil,
104
+ trailing_visual_counter: nil,
105
+ trailing_visual_text: nil,
106
+ private_leading_action_icon: nil,
107
+ private_trailing_action_icon: nil,
108
+ trailing_action_on_hover: false,
109
+ trailing_action: false,
110
+ tooltip: false
111
+ )
112
+ list = Primer::Alpha::ActionList.new(aria: { label: "Action List" })
113
+ list.item(
114
+ label: label,
115
+ truncate_label: truncate_label,
116
+ href: href,
117
+ size: size,
118
+ scheme: scheme,
119
+ disabled: disabled,
120
+ description_scheme: description_scheme,
121
+ active: active,
122
+ expanded: expanded,
123
+ id: "tooltip-test"
124
+ ) do |item|
125
+ if leading_visual_icon && leading_visual_icon != :none
126
+ item.with_leading_visual_icon(icon: leading_visual_icon)
127
+ elsif leading_visual_avatar_src
128
+ item.with_leading_visual_avatar(src: leading_visual_avatar_src, alt: "An avatar")
129
+ end
130
+
131
+ if trailing_visual_icon && trailing_visual_icon != :none
132
+ item.with_trailing_visual_icon(icon: trailing_visual_icon)
133
+ elsif trailing_visual_label
134
+ item.with_trailing_visual_label { trailing_visual_label }
135
+ elsif trailing_visual_counter
136
+ item.with_trailing_visual_counter(count: trailing_visual_counter)
137
+ elsif trailing_visual_text
138
+ item.with_trailing_visual_text(trailing_visual_text)
139
+ end
140
+
141
+ if private_leading_action_icon && private_leading_action_icon != :none
142
+ item.with_private_leading_action_icon(icon: private_leading_action_icon)
143
+ elsif private_trailing_action_icon
144
+ item.with_private_trailing_action_icon(icon: private_trailing_action_icon)
145
+ end
146
+
147
+ item.with_trailing_action(show_on_hover: trailing_action_on_hover, icon: "plus", "aria-label": "Button tooltip", size: :medium) if trailing_action && trailing_action != :none
148
+
149
+ item.description { description } if description
150
+
151
+ item.with_tooltip(text: "Tooltip text", for_id: "tooltip-test", type: :description) if tooltip
152
+ end
153
+
154
+ render(list)
155
+ end
156
+
157
+ # @label Item [default]
158
+ def item_default
159
+ render(Primer::Alpha::ActionList.new(
160
+ aria: { label: "List heading" }
161
+ )) do |c|
162
+ c.with_item(label: "Default item", href: "/")
163
+ end
164
+ end
165
+
166
+ # @label Item [size large]
167
+ def item_size_large
168
+ render(Primer::Alpha::ActionList.new(
169
+ aria: { label: "List heading" }
170
+ )) do |c|
171
+ c.with_item(label: "Default item", href: "/", size: :large)
172
+ end
173
+ end
174
+
175
+ # @label Item [size xlarge]
176
+ def item_size_xlarge
177
+ render(Primer::Alpha::ActionList.new(
178
+ aria: { label: "List heading" }
179
+ )) do |c|
180
+ c.with_item(label: "Default item", href: "/", size: :xlarge)
181
+ end
182
+ end
183
+
184
+ # @label Item [leading visual]
185
+ def item_leading_visual
186
+ render(Primer::Alpha::ActionList.new(
187
+ aria: { label: "List heading" }
188
+ )) do |c|
189
+ c.with_item(label: "Item with leading visual", href: "/") do |item|
190
+ item.with_leading_visual_icon(icon: :star)
191
+ end
192
+ end
193
+ end
194
+
195
+ # @label Item [trailing visual]
196
+ def item_trailing_visual
197
+ render(Primer::Alpha::ActionList.new(
198
+ aria: { label: "List heading" }
199
+ )) do |c|
200
+ c.with_item(label: "Item with trailing visual", href: "/") do |item|
201
+ item.with_trailing_visual_icon(icon: :star)
202
+ end
203
+ end
204
+ end
205
+
206
+ # @label Item [leading and trailing visual]
207
+ def item_leading_trailing_visual
208
+ render(Primer::Alpha::ActionList.new(
209
+ aria: { label: "List heading" }
210
+ )) do |c|
211
+ c.with_item(label: "Item with trailing visual", href: "/") do |item|
212
+ item.with_leading_visual_icon(icon: :heart)
213
+ item.with_trailing_visual_icon(icon: :star)
214
+ end
215
+ end
216
+ end
217
+
218
+ # @label Item [description]
219
+ def item_with_description
220
+ render(Primer::Alpha::ActionList.new(
221
+ aria: { label: "List heading" }
222
+ )) do |c|
223
+ c.with_item(label: "Default item", href: "/") do |item|
224
+ item.with_description.with_content("This is a description")
225
+ end
226
+ end
227
+ end
228
+
229
+ # @label Item [inline description]
230
+ def item_with_description_inline
231
+ render(Primer::Alpha::ActionList.new(
232
+ aria: { label: "List heading" }
233
+ )) do |c|
234
+ c.with_item(label: "Default item", href: "/", description_scheme: :inline) do |item|
235
+ item.with_description.with_content("This is a description")
236
+ end
237
+ end
238
+ end
239
+
240
+ # @label Item [trailing action]
241
+ def item_trailing_action
242
+ render(Primer::Alpha::ActionList.new(
243
+ aria: { label: "List heading" }
244
+ )) do |c|
245
+ c.with_item(label: "Default item", href: "/") do |item|
246
+ item.with_trailing_action(show_on_hover: false, icon: "plus", "aria-label": "Button tooltip", size: :medium)
247
+ end
248
+ end
249
+ end
250
+
251
+ # @label Item [trailing action on hover]
252
+ def item_trailing_action_hover
253
+ render(Primer::Alpha::ActionList.new(
254
+ aria: { label: "List heading" }
255
+ )) do |c|
256
+ c.with_item(label: "Default item", href: "/") do |item|
257
+ item.with_trailing_action(show_on_hover: true, icon: "plus", "aria-label": "Button tooltip", size: :medium)
258
+ end
259
+ end
260
+ end
261
+
262
+ # @label Item [danger]
263
+ def item_danger
264
+ render(Primer::Alpha::ActionList.new(
265
+ aria: { label: "List heading" }
266
+ )) do |c|
267
+ c.with_item(label: "Danger item", href: "/", scheme: :danger)
268
+ end
269
+ end
270
+
271
+ # @label Item [disabled]
272
+ def item_disabled
273
+ render(Primer::Alpha::ActionList.new(
274
+ aria: { label: "List heading" }
275
+ )) do |c|
276
+ c.with_item(label: "Disabled item", href: "/", disabled: true)
277
+ end
278
+ end
279
+
280
+ # @label Item [wrap label]
281
+ def item_wrap_label
282
+ render(Primer::Alpha::ActionList.new(
283
+ aria: { label: "List heading" }
284
+ )) do |c|
285
+ c.with_item(label: "This is a very long string of text that will wrap if it runs out of horizontal space", href: "/")
286
+ end
287
+ end
288
+
289
+ # @label Item [truncate label]
290
+ def item_truncate_label
291
+ render(Primer::Alpha::ActionList.new(
292
+ aria: { label: "List heading" }
293
+ )) do |c|
294
+ c.with_item(label: "This is a very long string of text that will truncate if it runs out of horizontal space", href: "/", truncate_label: true)
295
+ end
296
+ end
297
+
298
+ # @label Item [active]
299
+ def item_active
300
+ render(Primer::Alpha::ActionList.new(
301
+ aria: { label: "List heading" }
302
+ )) do |c|
303
+ c.with_item(label: "Active item", href: "/", active: true)
304
+ end
305
+ end
306
+ end
307
+ end
308
+ end