Sha256: 14379d4cd11e99e6c0b7c5ae5856a2c2b1a7ae46c495aa0ba89804235ffba069

Contents?: true

Size: 1.8 KB

Versions: 4

Compression:

Stored size: 1.8 KB

Contents

module GovukTechDocs
  # Helper included
  module ContributionBanner
    def source_urls
      SourceUrls.new(current_page, config)
    end
  end

  class SourceUrls
    attr_reader :current_page, :config

    def initialize(current_page, config)
      @current_page = current_page
      @config = config
    end

    def view_source_url
      override_from_page || source_from_yaml_file || source_from_file
    end

    def report_issue_url
      url = config[:source_urls]&.[](:report_issue_url)
      params = {
        body: "Problem with '#{current_page.data.title}' (#{config[:tech_docs][:host]}#{current_page.url})",
      }

      if url.nil?
        url = "#{repo_url}/issues/new"
        params["labels"] = "bug"
        params["title"] = "Re: '#{current_page.data.title}'"
      else
        params["subject"] = "Re: '#{current_page.data.title}'"
      end
      "#{url}?#{URI.encode_www_form(params)}"
    end

    def repo_url
      "https://github.com/#{config[:tech_docs][:github_repo]}"
    end

    def repo_branch
      config[:tech_docs][:github_branch] || "master"
    end

  private

    # If a `page` local exists, see if it has a `source_url`. This is used by the
    # pages that are created by the proxy system because they can't use frontmatter
    def override_from_page
      locals.key?(:page) ? locals[:page].try(:source_url) : false
    end

    # In the frontmatter we can specify a `source_url`. Use this if the actual
    # source of the page is in another GitHub repo.
    def source_from_yaml_file
      current_page.data.source_url
    end

    # As the last fallback link to the source file in this repository.
    def source_from_file
      "#{repo_url}/blob/#{repo_branch}/source/#{current_page.file_descriptor[:relative_path]}"
    end

    def locals
      current_page.metadata[:locals]
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
govuk_tech_docs-3.2.1 lib/govuk_tech_docs/contribution_banner.rb
govuk_tech_docs-3.2.0 lib/govuk_tech_docs/contribution_banner.rb
govuk_tech_docs-3.1.0 lib/govuk_tech_docs/contribution_banner.rb
govuk_tech_docs-3.0.1 lib/govuk_tech_docs/contribution_banner.rb