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