Class: IsoDoc::Iec::WordConvert

Inherits:
IsoDoc::Iso::WordConvert
  • Object
show all
Includes:
BaseConvert, Init
Defined in:
lib/isodoc/iec/word_convert.rb

Constant Summary collapse

BOILERPLATE_PARAS =

Incredibly, the numbered boilerplate list in IEC is NOT A LIST, and it violates numbering conventions for ordered lists (arabic not alpha)

"//div[@class = 'boilerplate_legal']//li/p".freeze

Instance Method Summary collapse

Methods included from Init

#convert1, #i18n_init, #metadata_init, #std_docid_semantic, #xref_init

Methods included from BaseConvert

#biblio_list, #bibliography, #boilerplate, #foreword, #foreword1, #iec_orgname, #middle_title, #middle_title_parts, #set_termdomain, #terms_parse

Constructor Details

#initialize(options) ⇒ WordConvert

Returns a new instance of WordConvert.



9
10
11
12
# File 'lib/isodoc/iec/word_convert.rb', line 9

def initialize(options)
  super
  @libdir = File.dirname(__FILE__)
end

Instance Method Details

#annex_name(_annex, name, div) ⇒ Object



199
200
201
202
203
204
205
206
207
# File 'lib/isodoc/iec/word_convert.rb', line 199

def annex_name(_annex, name, div)
  preceding_floating_titles(name, div)
  return if name.nil?

  div.h1 **{ class: "Annex" } do |t|
    name.children.each { |c2| parse(c2, t) }
    clause_parse_subtitle(name, t)
  end
end

#authority_cleanup(docxml) ⇒ Object



163
164
165
166
167
168
# File 'lib/isodoc/iec/word_convert.rb', line 163

def authority_cleanup(docxml)
  auth = docxml.at("//div[@id = 'boilerplate-feedback' or " \
                   "@class = 'boilerplate-feedback']")
  auth&.remove
  super
end

#bibliography_attrsObject



176
177
178
# File 'lib/isodoc/iec/word_convert.rb', line 176

def bibliography_attrs
  { class: "Section3" }
end

#default_file_locations(_options) ⇒ Object



32
33
34
35
36
37
38
39
40
41
42
43
# File 'lib/isodoc/iec/word_convert.rb', line 32

def default_file_locations(_options)
  @libdir = File.dirname(__FILE__)
  {
    wordstylesheet: html_doc_path("wordstyle.scss"),
    standardstylesheet: html_doc_path("isodoc.scss"),
    header: html_doc_path("header.html"),
    wordcoverpage: html_doc_path("word_iec_titlepage.html"),
    wordintropage: html_doc_path("word_iec_intro.html"),
    ulstyle: "l22",
    olstyle: "l2",
  }
end

#default_fonts(options) ⇒ Object



20
21
22
23
24
25
26
27
28
29
30
# File 'lib/isodoc/iec/word_convert.rb', line 20

def default_fonts(options)
  {
    bodyfont: font_choice(options),
    headerfont: font_choice(options),
    monospacefont: '"Courier New",monospace',
    normalfontsize: "10.0pt",
    footnotefontsize: "8.0pt",
    smallerfontsize: "8.0pt",
    monospacefontsize: "9.0pt",
  }
end

#figure_name_attrs(_node) ⇒ Object



184
185
186
# File 'lib/isodoc/iec/word_convert.rb', line 184

def figure_name_attrs(_node)
  { class: "FigureTitle", style: "text-align:center;" }
end

#font_choice(options) ⇒ Object



14
15
16
17
18
# File 'lib/isodoc/iec/word_convert.rb', line 14

def font_choice(options)
  if options[:script] == "Hans" then '"Source Han Sans",serif'
  else '"Arial",sans-serif'
  end
end

#formula_parse1(node, out) ⇒ Object



209
210
211
212
213
214
215
216
217
218
219
220
# File 'lib/isodoc/iec/word_convert.rb', line 209

def formula_parse1(node, out)
  out.div **attr_code(class: "formula") do |div|
    div.p **attr_code(class: "formula") do |_p|
      insert_tab(div, 1)
      parse(node.at(ns("./stem")), div)
      if lbl = node&.at(ns("./name"))&.text
        insert_tab(div, 1)
        div << "(#{lbl})"
      end
    end
  end
end

#header_strip(hdr) ⇒ Object



75
76
77
78
# File 'lib/isodoc/iec/word_convert.rb', line 75

def header_strip(hdr)
  hdr = hdr.to_s.gsub(/<\/?p[^>]*>/, "")
  super
end

#make_body1(body, _docxml) ⇒ Object



170
# File 'lib/isodoc/iec/word_convert.rb', line 170

def make_body1(body, _docxml); end

#make_figure_word_toc(docxml) ⇒ Object



55
56
57
58
59
60
61
62
63
# File 'lib/isodoc/iec/word_convert.rb', line 55

def make_figure_word_toc(docxml)
  docxml.at(figure_toc_xpath) or return ""
  toc = ""
  docxml.xpath(figure_toc_xpath).each do |h|
    toc += word_toc_entry(1, header_strip(h))
  end
  toc.sub(/(<p class="MsoToc1">)/,
          %{\\1#{word_toc_figure_preface1}}) + WORD_TOC_SUFFIX1
end

#make_table_word_toc(docxml) ⇒ Object



45
46
47
48
49
50
51
52
53
# File 'lib/isodoc/iec/word_convert.rb', line 45

def make_table_word_toc(docxml)
  docxml.at(table_toc_xpath) or return ""
  toc = ""
  docxml.xpath(table_toc_xpath).each do |h|
    toc += word_toc_entry(1, header_strip(h))
  end
  toc.sub(/(<p class="MsoToc1">)/,
          %{\\1#{word_toc_table_preface1}}) + WORD_TOC_SUFFIX1
end

#make_tr_attr(cell, row, totalrows, header, bordered) ⇒ Object



86
87
88
89
90
91
# File 'lib/isodoc/iec/word_convert.rb', line 86

def make_tr_attr(cell, row, totalrows, header, bordered)
  ret = super
  css_class =
    cell.name == "th" || header ? "TABLE-col-heading" : "TABLE-cell"
  ret.merge(class: css_class)
end

#non_annex_h1(docxml) ⇒ Object



135
136
137
138
139
140
141
142
# File 'lib/isodoc/iec/word_convert.rb', line 135

def non_annex_h1(docxml)
  docxml.xpath("//h1[not(@class)]").each do |h1|
    h1["class"] = "main"
  end
  docxml.xpath("//h1[@class = 'Section3']").each do |h1|
    h1["class"] = "main"
  end
end

#para_class(_node) ⇒ Object



192
193
194
195
196
197
# File 'lib/isodoc/iec/word_convert.rb', line 192

def para_class(_node)
  classtype = nil
  classtype = "MsoCommentText" if @in_comment
  classtype = "Sourcecode" if @annotation
  classtype
end

#style_cleanup(docxml) ⇒ Object



174
# File 'lib/isodoc/iec/word_convert.rb', line 174

def style_cleanup(docxml); end

#table_title_attrs(_node) ⇒ Object



188
189
190
# File 'lib/isodoc/iec/word_convert.rb', line 188

def table_title_attrs(_node)
  { class: "TableTitle", style: "text-align:center;" }
end

#termref_attrsObject



180
181
182
# File 'lib/isodoc/iec/word_convert.rb', line 180

def termref_attrs
  {}
end

#tr_parse(node, out, ord, totalrows, header) ⇒ Object



93
94
95
96
97
98
99
100
101
102
103
104
105
# File 'lib/isodoc/iec/word_convert.rb', line 93

def tr_parse(node, out, ord, totalrows, header)
  c = node.parent.parent["class"]
  bordered = %w(modspec).include?(c) || !c
  out.tr do |r|
    node.elements.each do |td|
      attrs = make_tr_attr(td, ord, totalrows - 1, header, bordered)
      attrs[:class] = "TABLE-col-heading" if header
      r.send td.name, **attr_code(attrs) do |entry|
        td.children.each { |n| parse(n, entry) }
      end
    end
  end
end

#word_annex_cleanup(docxml) ⇒ Object



130
131
132
133
# File 'lib/isodoc/iec/word_convert.rb', line 130

def word_annex_cleanup(docxml)
  super
  non_annex_h1(docxml)
end

#word_cleanup(docxml) ⇒ Object



80
81
82
83
84
# File 'lib/isodoc/iec/word_convert.rb', line 80

def word_cleanup(docxml)
  word_foreword_cleanup(docxml)
  word_table_cleanup(docxml)
  super
end

#word_cover(docxml) ⇒ Object



172
# File 'lib/isodoc/iec/word_convert.rb', line 172

def word_cover(docxml); end

#word_foreword_cleanup(docxml) ⇒ Object



149
150
151
152
153
154
155
156
157
158
159
160
161
# File 'lib/isodoc/iec/word_convert.rb', line 149

def word_foreword_cleanup(docxml)
  docxml.xpath(BOILERPLATE_PARAS).each_with_index do |l, i|
    l["class"] = "FOREWORD"
    l.children.first.add_previous_sibling(
      %{#{i + 1})<span style="mso-tab-count:1">&#xA0; </span>},
    )
  end
  docxml.xpath("//div[@class = 'boilerplate_legal']//li").each do |l|
    l.replace(l.children)
  end
  b = docxml.at("div[@class = 'boilerplate_legal']")
  b.replace(b.children)
end

#word_table_cleanup(docxml) ⇒ Object



107
108
109
110
111
112
113
114
# File 'lib/isodoc/iec/word_convert.rb', line 107

def word_table_cleanup(docxml)
  docxml.xpath("//table//*[@class = 'Sourcecode']").each do |p|
    p["class"] = "CODE-TableCell"
  end
  %w(TABLE-col-heading TABLE-cell).each do |style|
    word_table_cleanup1(docxml, style)
  end
end

#word_table_cleanup1(docxml, style) ⇒ Object



116
117
118
119
120
121
122
123
124
125
126
127
128
# File 'lib/isodoc/iec/word_convert.rb', line 116

def word_table_cleanup1(docxml, style)
  %w(td th).each do |tdh|
    docxml.xpath("//#{tdh}[@class = '#{style}'][not(descendant::p)]")
      .each do |td|
      p = Nokogiri::XML::Element.new("p", docxml)
      td.children.each { |c| c.parent = p }
      p.parent = td
    end
    docxml.xpath("//#{tdh}[@class = '#{style}']//p").each do |p|
      p["class"] ||= style
    end
  end
end

#word_toc_preface(level) ⇒ Object



65
66
67
68
69
70
71
72
73
# File 'lib/isodoc/iec/word_convert.rb', line 65

def word_toc_preface(level)
  <<~TOC.freeze
    <span lang="EN-GB"><span
      style='mso-element:field-begin'></span><span
      style='mso-spacerun:yes'>&#xA0;</span>TOC
      \\o "1-#{level}" \\h \\z \\u <span
      style='mso-element:field-separator'></span></span>
  TOC
end