# frozen_string_literal: true module Primer module Beta # @label NavList class NavListPreview < ViewComponent::Preview # @label Playground def playground render(Primer::Beta::NavList.new(selected_item_id: :collaborators)) do |list| list.with_heading(title: "Repository settings") list.with_item(label: "General", href: "/general") do |item| item.with_leading_visual_icon(icon: :gear) end list.with_group do |group| group.with_heading(title: "Access") group.with_item(label: "Collaborators and teams", href: "/collaborators", selected_by_ids: :collaborators) do |item| item.with_leading_visual_icon(icon: :people) end group.with_item(label: "Moderation options") do |item| item.with_leading_visual_icon(icon: :"comment-discussion") item.with_item(label: "Interaction limits", href: "/interaction-limits", selected_by_ids: :interaction_limits) item.with_item(label: "Code review limits", href: "/review-limits", selected_by_ids: :code_review_limits) item.with_item(label: "Reported content", href: "/reported-content", selected_by_ids: :reported_content) end end end end # @label Default # @snapshot def default render(Primer::Beta::NavList.new(selected_item_id: :code_review_limits)) do |list| list.with_heading(title: "Repository settings") list.with_item(label: "General", href: "/general") do |item| item.with_leading_visual_icon(icon: :gear) end list.with_divider list.with_item(label: "Settings", href: "/settings") do |item| item.with_leading_visual_icon(icon: :beaker) end list.with_group do |group| group.with_heading(title: "Access") group.with_avatar_item( src: "https://avatars.githubusercontent.com/u/103004183?v=4", username: "hulk_smash", full_name: "Bruce Banner", full_name_scheme: :inline, href: "/profile", avatar_arguments: { shape: :square } ) group.with_item(label: "Collaborators and teams", href: "/collaborators", selected_by_ids: :collaborators) do |item| item.with_leading_visual_icon(icon: :people) end group.with_item(label: "Moderation options") do |item| item.with_leading_visual_icon(icon: :"comment-discussion") item.with_item(label: "Interaction limits", href: "/interaction-limits", selected_by_ids: :interaction_limits) item.with_item(label: "Code review limits", href: "/review-limits", selected_by_ids: :code_review_limits) item.with_item(label: "Reported content", href: "/reported-content", selected_by_ids: :reported_content) end end end end # @label Top-level items # def top_level_items render(Primer::Beta::NavList.new) do |list| list.with_heading(title: "Account settings") list.with_item(label: "General", href: "/general") do |item| item.with_leading_visual_icon(icon: :gear) end list.with_item(label: "Billing", href: "/billing") do |item| item.with_leading_visual_icon(icon: :"credit-card") end list.with_item(label: "Change password", href: "/change_password") do |item| item.with_leading_visual_icon(icon: :key) end list.with_avatar_item( src: "https://avatars.githubusercontent.com/u/103004183?v=4", username: "hulk_smash", full_name: "Bruce Banner", full_name_scheme: :inline, href: "/profile" ) end end # @label Show more item # @snapshot def show_more_item render(Primer::Beta::NavList.new(aria: { label: "My favorite foods" })) do |list| list.with_group(id: "foods") do |group| group.with_heading(title: "My favorite foods") group.with_item(label: "Popplers", href: "/foods/popplers") group.with_item(label: "Slurm", href: "/foods/slurm") group.with_show_more_item(label: "Show more foods", src: UrlHelpers.nav_list_items_path, pages: 2) do |item| item.with_trailing_visual_icon(icon: :plus) end end list.with_group(id: "snacks") do |group| group.with_heading(title: "My favorite snacks") group.with_item(label: "Popplers", href: "/foods/popplers") group.with_item(label: "Slurm", href: "/foods/slurm") group.with_show_more_item(label: "Show more snacks", src: UrlHelpers.nav_list_items_path, pages: 4) do |item| item.with_trailing_visual_icon(icon: :plus) end end end end # @label Trailing action # @snapshot def trailing_action; end # @label Long label truncate overflow # # @param truncate_label [Symbol] select [none, truncate, show_tooltip] # @snapshot def long_label_with_tooltip(truncate_label: :show_tooltip) render(Primer::Beta::NavList.new(aria: { label: "List heading" })) do |component| component.with_item( label: "Really really long label that may wrap, truncate, or appear as a tooltip", truncate_label: truncate_label ) do |item| item.with_trailing_visual_icon(icon: :plus) end end end def long_label_wrap(truncate_label: :none) render(Primer::Beta::NavList.new(aria: { label: "List heading" })) do |component| component.with_item( label: "Really really long label that may wrap, truncate, or appear as a tooltip", truncate_label: truncate_label ) end end def long_label_truncate_no_tooltip(truncate_label: :truncate) render(Primer::Beta::NavList.new(aria: { label: "List heading" })) do |component| component.with_item( label: "Really really long label that may wrap, truncate, or appear as a tooltip", truncate_label: truncate_label ) end end def long_label_show_tooltip_no_truncate_label render(Primer::Beta::NavList.new(aria: { label: "List heading" })) do |component| component.with_item( label: "Really really long label that may wrap, truncate, or appear as a tooltip", ) do |item| item.with_tooltip(text: "this is a tooltip") end end end end end end