Class: IsoDoc::MPFA::Xref
- Inherits:
-
Xref
- Object
- Xref
- IsoDoc::MPFA::Xref
- Defined in:
- lib/isodoc/mpfa/xref.rb
Constant Summary collapse
- FRONT_CLAUSE =
"//*[parent::preface]".freeze
Instance Method Summary collapse
- #annex_name_anchors(clause, num) ⇒ Object
- #annex_name_lbl(_clause, num) ⇒ Object
- #annex_names(clause, num) ⇒ Object
- #annex_names1(clause, num, level) ⇒ Object
- #annex_naming(clause, num, lvl, idx) ⇒ Object
- #clause_names(docxml, sect_num) ⇒ Object
- #container_names(clause, lvl) ⇒ Object
- #initial_anchor_names(doc) ⇒ Object
- #sect_names(clause, num, i, lvl, _prev_lvl) ⇒ Object
Instance Method Details
#annex_name_anchors(clause, num) ⇒ Object
83 84 85 86 87 88 |
# File 'lib/isodoc/mpfa/xref.rb', line 83 def annex_name_anchors(clause, num) { label: annex_name_lbl(clause, num), elem: @labels["annex"], type: "clause", value: num.to_s, level: 1, xref: l10n("#{@labels['annex']} #{num}") } end |
#annex_name_lbl(_clause, num) ⇒ Object
23 24 25 |
# File 'lib/isodoc/mpfa/xref.rb', line 23 def annex_name_lbl(_clause, num) l10n("<strong>#{@labels['annex']} #{num}</strong>") end |
#annex_names(clause, num) ⇒ Object
90 91 92 93 94 95 96 97 98 99 100 101 102 103 |
# File 'lib/isodoc/mpfa/xref.rb', line 90 def annex_names(clause, num) @anchors[clause["id"]] = annex_name_anchors(clause, num) if @klass.single_term_clause?(clause) annex_names1(clause.at(ns("./references | ./terms | ./definitions")), num.to_s, 1) else i = 0 clause.xpath(ns("./clause | ./references | ./terms | ./definitions")).each do |c| container_names(c, 0) i = annex_naming(c, num, 1, i) end end hierarchical_asset_names(clause, num) end |
#annex_names1(clause, num, level) ⇒ Object
105 106 107 108 109 110 111 112 113 114 115 |
# File 'lib/isodoc/mpfa/xref.rb', line 105 def annex_names1(clause, num, level) unless clause["container"] @anchors[clause["id"]] = { label: num, elem: @labels["annex"], xref: l10n("#{@labels['annex']} #{num}"), level: level } end i = 0 clause.xpath(ns("./clause | ./references")).each do |c| i = annex_naming(c, num, level, i) end end |
#annex_naming(clause, num, lvl, idx) ⇒ Object
74 75 76 77 78 79 80 81 |
# File 'lib/isodoc/mpfa/xref.rb', line 74 def annex_naming(clause, num, lvl, idx) if clause["guidance"] then annex_names1(clause, "#{num}E", lvl + 1) else idx += 1 unless clause["container"] annex_names1(clause, "#{num}.#{idx}", lvl + 1) end idx end |
#clause_names(docxml, sect_num) ⇒ Object
27 28 29 30 31 32 33 34 35 |
# File 'lib/isodoc/mpfa/xref.rb', line 27 def clause_names(docxml, sect_num) q = "//clause[parent::sections]" @topnum = nil lvl = 0 docxml.xpath(ns(q)).each do |c| container_names(c, 0) sect_num, lvl = sect_names(c, nil, sect_num, 0, lvl) end end |
#container_names(clause, lvl) ⇒ Object
37 38 39 40 41 42 43 44 45 46 |
# File 'lib/isodoc/mpfa/xref.rb', line 37 def container_names(clause, lvl) if clause["container"] @anchors[clause["id"]] = { label: nil, xref: clause.at(ns("./title"))&.text, level: lvl + 1 } end clause.xpath(ns("./clause | ./term | ./terms | "\ "./definitions")).each do |c| container_names(c, clause["container"] ? lvl + 1 : lvl) end end |
#initial_anchor_names(doc) ⇒ Object
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
# File 'lib/isodoc/mpfa/xref.rb', line 6 def initial_anchor_names(doc) if @parse_settings.empty? || @parse_settings[:clauses] doc.xpath(ns(self.class::FRONT_CLAUSE)).each do |c| preface_names(c) end clause_names(doc, 0) end if @parse_settings.empty? doc.xpath(ns(self.class::FRONT_CLAUSE)).each do |c| sequential_asset_names(c) end middle_section_asset_names(doc) termnote_anchor_names(doc) termexample_anchor_names(doc) end end |
#sect_names(clause, num, i, lvl, _prev_lvl) ⇒ Object
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
# File 'lib/isodoc/mpfa/xref.rb', line 48 def sect_names(clause, num, i, lvl, _prev_lvl) return i if clause.nil? curr = i if !clause["container"] i += 1 curr = i name = num.nil? ? i.to_s : "#{num}.#{i}" @anchors[clause["id"]] = { label: name, level: lvl + 1, elem: @labels["clause"], xref: l10n("#{@labels['clause']} #{name}") } end prev = lvl j = 0 clause.xpath(ns("./clause | ./term | ./terms | "\ "./definitions")).each do |c| if clause["container"] i, lvl = sect_names(c, num, i, lvl, lvl) else j, prev = sect_names(c, name, j, lvl + 1, prev) end end i = j if j.positive? i = curr if lvl < prev [i, prev] end |