Class: IsoDoc::Acme::WordConvert

Inherits:
WordConvert
  • Object
show all
Defined in:
lib/isodoc/acme/word_convert.rb

Overview

A Converter implementation that generates Word output, and a document schema encapsulation of the document for validation

Instance Method Summary collapse

Constructor Details

#initialize(options) ⇒ WordConvert

Returns a new instance of WordConvert.



11
12
13
14
15
# File 'lib/isodoc/acme/word_convert.rb', line 11

def initialize(options)
  @libdir = File.dirname(__FILE__)
  super
  FileUtils.cp html_doc_path('logo.jpg'), "logo.jpg"
end

Instance Method Details

#annex_name(annex, name, div) ⇒ Object



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

def annex_name(annex, name, div)
  div.h1 **{ class: "Annex" } do |t|
    t << "#{get_anchors[annex['id']][:label]} "
    t.br
    t.b do |b|
    name&.children&.each { |c2| parse(c2, b) }
  end
  end
end

#cleanup(docxml) ⇒ Object



93
94
95
96
# File 'lib/isodoc/acme/word_convert.rb', line 93

def cleanup(docxml)
  super
  term_cleanup(docxml)
end

#default_file_locations(options) ⇒ Object



25
26
27
28
29
30
31
32
33
34
35
# File 'lib/isodoc/acme/word_convert.rb', line 25

def default_file_locations(options)
  {
    wordstylesheet: html_doc_path("wordstyle.scss"),
    standardstylesheet: html_doc_path("acme.scss"),
    header: html_doc_path("header.html"),
    wordcoverpage: html_doc_path("word_acme_titlepage.html"),
    wordintropage: html_doc_path("word_acme_intro.html"),
    ulstyle: "l3",
    olstyle: "l2",
  }
end

#default_fonts(options) ⇒ Object



17
18
19
20
21
22
23
# File 'lib/isodoc/acme/word_convert.rb', line 17

def default_fonts(options)
  {
    bodyfont: (options[:script] == "Hans" ? '"SimSun",serif' : '"Arial",sans-serif'),
    headerfont: (options[:script] == "Hans" ? '"SimHei",sans-serif' : '"Arial",sans-serif'),
    monospacefont: '"Courier New",monospace'
  }
end

#fileloc(loc) ⇒ Object



89
90
91
# File 'lib/isodoc/acme/word_convert.rb', line 89

def fileloc(loc)
  File.join(File.dirname(__FILE__), loc)
end

#i18n_init(lang, script) ⇒ Object



84
85
86
87
# File 'lib/isodoc/acme/word_convert.rb', line 84

def i18n_init(lang, script)
  super
  @annex_lbl = "Appendix"
end

#info(isoxml, out) ⇒ Object

def make_body2(body, docxml)

  body.div **{ class: "WordSection2" } do |div2|
    info docxml, div2
    div2.p { |p| p << "&nbsp;" } # placeholder
  end
  section_break(body)
end


61
62
63
64
# File 'lib/isodoc/acme/word_convert.rb', line 61

def info(isoxml, out)
  @meta.security isoxml, out
  super
end

#make_body(xml, docxml) ⇒ Object



42
43
44
45
46
47
48
49
# File 'lib/isodoc/acme/word_convert.rb', line 42

def make_body(xml, docxml)
  body_attr = { lang: "EN-US", link: "blue", vlink: "#954F72" }
  xml.body **body_attr do |body|
    make_body1(body, docxml)
    make_body2(body, docxml)
    make_body3(body, docxml)
  end
end

#metadata_init(lang, script, labels) ⇒ Object



38
39
40
# File 'lib/isodoc/acme/word_convert.rb', line 38

def (lang, script, labels)
  @meta = Metadata.new(lang, script, labels)
end

#term_cleanup(docxml) ⇒ Object



98
99
100
101
102
103
104
105
# File 'lib/isodoc/acme/word_convert.rb', line 98

def term_cleanup(docxml)
  docxml.xpath("//p[@class = 'Terms']").each do |d|
    h2 = d.at("./preceding-sibling::*[@class = 'TermNum'][1]")
    h2.add_child("&nbsp;")
    h2.add_child(d.remove)
  end
  docxml
end

#term_defs_boilerplate(div, source, term, preface) ⇒ Object



76
77
78
79
80
81
82
# File 'lib/isodoc/acme/word_convert.rb', line 76

def term_defs_boilerplate(div, source, term, preface)
  if source.empty? && term.nil?
    div << @no_terms_boilerplate
  else
    div << term_defs_boilerplate_cont(source, term)
  end
end