Sha256: 344049294f0505e6108de73bb9b4337dbd954d8894173f73667c3c21788d726d

Contents?: true

Size: 1.02 KB

Versions: 5

Compression:

Stored size: 1.02 KB

Contents

# frozen_string_literal: true

module Decidim
  module ContentRenderers
    # A renderer that searches Global IDs representing users in content
    # and replaces it with a link to their profile with the nickname.
    #
    # e.g. gid://<APP_NAME>/Decidim::User/1
    #
    # @see BaseRenderer Examples of how to use a content renderer
    class UserRenderer < BaseRenderer
      # Matches a global id representing a Decidim::User
      GLOBAL_ID_REGEX = %r{gid://\S+/Decidim::User/\d+}

      # Replaces found Global IDs matching an existing user with
      # a link to their profile. The Global IDs representing an
      # invalid Decidim::User are replaced with an empty string.
      #
      # @return [String] the content ready to display (contains HTML)
      def render
        content.gsub(GLOBAL_ID_REGEX) do |user_gid|
          user = GlobalID::Locator.locate(user_gid)
          Decidim::UserPresenter.new(user).display_mention
        rescue ActiveRecord::RecordNotFound => _ex
          ""
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
decidim-core-0.18.1 lib/decidim/content_renderers/user_renderer.rb
decidim-core-0.17.2 lib/decidim/content_renderers/user_renderer.rb
decidim-core-0.18.0 lib/decidim/content_renderers/user_renderer.rb
decidim-core-0.17.1 lib/decidim/content_renderers/user_renderer.rb
decidim-core-0.17.0 lib/decidim/content_renderers/user_renderer.rb