# frozen_string_literal: true module Decidim module ContentRenderers # A renderer that searches Global IDs representing proposals in content # and replaces it with a link to their show page. # # e.g. gid:///Decidim::Proposals::Proposal/1 # # @see BaseRenderer Examples of how to use a content renderer class ProposalRenderer < BaseRenderer # Matches a global id representing a Decidim::User GLOBAL_ID_REGEX = %r{gid:\/\/([\w-]*\/Decidim::Proposals::Proposal\/(\d+))}i.freeze # Replaces found Global IDs matching an existing proposal with # a link to its show page. The Global IDs representing an # invalid Decidim::Proposals::Proposal are replaced with '???' string. # # @return [String] the content ready to display (contains HTML) def render content.gsub(GLOBAL_ID_REGEX) do |proposal_gid| proposal = GlobalID::Locator.locate(proposal_gid) Decidim::Proposals::ProposalPresenter.new(proposal).display_mention rescue ActiveRecord::RecordNotFound proposal_id = proposal_gid.split("/").last "~#{proposal_id}" end end end end end