Sha256: 24454da5de8854b66920eae0bb59da9d14eb209e7862a9c59149150d33ecdc34

Contents?: true

Size: 1.59 KB

Versions: 1

Compression:

Stored size: 1.59 KB

Contents

# frozen_string_literal: true

module Primer
  module Alpha
    # Use `Image` to render images.
    #
    # @accessibility
    #   Always provide a meaningful `alt`.
    class Image < Primer::Component
      warn_on_deprecated_slot_setter
      status :alpha

      # @example Default
      #
      #   <%= render(Primer::Alpha::Image.new(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub")) %>
      #
      # @example Helper
      #
      #   <%= primer_image(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub") %>
      #
      # @example Lazy loading
      #
      #   <%= render(Primer::Alpha::Image.new(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub", lazy: true)) %>
      #
      # @example Custom size
      #
      #   <%= render(Primer::Alpha::Image.new(src: Primer::ExampleImage::BASE64_SRC, alt: "GitHub", height: 100, width: 100)) %>
      #
      # @param src [String] The source url of the image.
      # @param alt [String] Specifies an alternate text for the image.
      # @param lazy [Boolean] Whether or not to lazily load the image.
      # @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
      def initialize(src:, alt:, lazy: false, **system_arguments)
        @system_arguments = deny_tag_argument(**system_arguments)

        @src = src
        @system_arguments[:tag] = :img
        @system_arguments[:alt] = alt

        return unless lazy

        @system_arguments[:loading] = :lazy
        @system_arguments[:decoding] = :async
      end

      def call
        render(Primer::BaseComponent.new(src: image_path(@src), **@system_arguments))
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
primer_view_components-0.0.115 app/components/primer/alpha/image.rb