metanorma/metanorma-iec

View on GitHub
lib/isodoc/iec/xref.rb

Summary

Maintainability
A
0 mins
Test Coverage
module IsoDoc
  module Iec
    class Xref < IsoDoc::Iso::Xref
      def parse(docxml)
        id = docxml&.at(ns("//bibdata/docnumber"))&.text
        @is_iev = id == "60050"
        id = docxml&.at(ns("//bibdata/docidentifier[@type = 'ISO']"))&.text
        m = /60050-(\d+)/.match(id) and @iev_part = m[1]
        super
      end

      def introduction_names(clause)
        return super unless @is_iev
      end

      def initial_anchor_names(docxml)
        super
        return unless @is_iev

        if @parse_settings.empty? || @parse_settings[:clauses]
          terms_iev_names(docxml)
        end
      end

      def terms_iev_names(docxml)
        docxml.xpath(ns("//sections/clause/terms")).each_with_index do |t, i|
          num = "#{@iev_part}-%02d" % [i + 1]
          @anchors[t["id"]] =
            { label: num, xref: l10n("#{@labels['section_iev']} #{num}"),
              level: 2, type: "clause", elem: @labels["section_iev"] }
          t.xpath(ns("./term")).each_with_index do |c, j|
            num2 = "%02d" % [j + 1]
            section_names1(c, "#{num}-#{num2}", 3)
          end
        end
      end

      def annex_name_lbl(clause, num)
        obl = l10n("(#{@labels['inform_annex']})")
        clause["obligation"] == "normative" and
          obl = l10n("(#{@labels['norm_annex']})")
        l10n("<strong>#{@labels['annex']} #{num}</strong><br/>#{obl}")
      end
    end
  end
end