Sha256: bf846782fe911eb21f03b9f78ea589f4e7da65ec0d7e7d55c0f2ff308de92f4d

Contents?: true

Size: 1.66 KB

Versions: 91

Compression:

Stored size: 1.66 KB

Contents

# frozen_string_literal: true

module Ariadne
  # Use `Image` to render images.
  #
  # @accessibility
  #   Always provide a meaningful `alt`.
  class ImageComponent < Ariadne::Component
    DEFAULT_TAG = :img

    # @example Default
    #
    #   <%= render(Ariadne::ImageComponent.new(src: "https://github.com/github.png", alt: "GitHub")) %>
    #
    # @example Helper
    #
    #   <%= ariadne_image(src: "https://github.com/github.png", alt: "GitHub") %>
    #
    # @example Lazy loading
    #
    #   <%= render(Ariadne::ImageComponent.new(src: "https://github.com/github.png", alt: "GitHub", lazy: true)) %>
    #
    # @example Custom size
    #
    #   <%= render(Ariadne::ImageComponent.new(src: "https://github.com/github.png", alt: "GitHub", attributes: { height: 100, width: 100 })) %>
    #
    # @param tag [Symbol, String] The rendered tag name
    # @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 classes [String] <%= link_to_classes_docs %>
    # @param attributes [Hash] <%= link_to_attributes_docs %>
    def initialize(tag: DEFAULT_TAG, src:, alt:, lazy: false, classes: "", attributes: {})
      @attributes = attributes

      @src = src
      @tag = check_incoming_tag(DEFAULT_TAG, tag)
      @classes = classes

      @attributes[:alt] = alt
      @attributes[:src] = image_path(@src)

      return unless lazy

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

    def call
      render(Ariadne::BaseComponent.new(tag: @tag, classes: @classes, attributes: @attributes))
    end
  end
end

Version data entries

91 entries across 91 versions & 1 rubygems

Version Path
ariadne_view_components-0.0.22 app/components/ariadne/image_component.rb
ariadne_view_components-0.0.22-x86_64-linux app/components/ariadne/image_component.rb
ariadne_view_components-0.0.22-x86_64-darwin app/components/ariadne/image_component.rb
ariadne_view_components-0.0.22-x64-mingw32 app/components/ariadne/image_component.rb
ariadne_view_components-0.0.22-x64-mingw-ucrt app/components/ariadne/image_component.rb
ariadne_view_components-0.0.22-arm64-darwin app/components/ariadne/image_component.rb
ariadne_view_components-0.0.22-aarch64-linux app/components/ariadne/image_component.rb
ariadne_view_components-0.0.21 app/components/ariadne/image_component.rb
ariadne_view_components-0.0.21-x86_64-linux app/components/ariadne/image_component.rb
ariadne_view_components-0.0.21-x86_64-darwin app/components/ariadne/image_component.rb
ariadne_view_components-0.0.21-x64-mingw32 app/components/ariadne/image_component.rb
ariadne_view_components-0.0.21-x64-mingw-ucrt app/components/ariadne/image_component.rb
ariadne_view_components-0.0.21-arm64-darwin app/components/ariadne/image_component.rb
ariadne_view_components-0.0.21-aarch64-linux app/components/ariadne/image_component.rb
ariadne_view_components-0.0.20 app/components/ariadne/image_component.rb
ariadne_view_components-0.0.20-x86_64-linux app/components/ariadne/image_component.rb
ariadne_view_components-0.0.20-x86_64-darwin app/components/ariadne/image_component.rb
ariadne_view_components-0.0.20-x64-mingw32 app/components/ariadne/image_component.rb
ariadne_view_components-0.0.20-x64-mingw-ucrt app/components/ariadne/image_component.rb
ariadne_view_components-0.0.20-arm64-darwin app/components/ariadne/image_component.rb