Class: IsoDoc::Unece::PdfConvert

Inherits:
PdfConvert
  • Object
show all
Includes:
BaseConvert
Defined in:
lib/isodoc/unece/pdf_convert.rb

Overview

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

Constant Summary

Constants included from BaseConvert

BaseConvert::MIDDLE_CLAUSE, BaseConvert::NONTERMINAL

Instance Method Summary collapse

Methods included from BaseConvert

#admonition_name_parse, #admonition_parse, #annex_levelnum, #annex_name, #annex_name_lbl, #annex_names, #annex_names1, #back_anchor_names, #clause_names, #fileloc, #hierarchical_admonition_names, #hierarchical_asset_names, #i18n_init, #initial_anchor_names, #inline_header_title, #label_annex_leaf_section, #label_leaf_section, #leaf_section?, #levelnumber, #metadata_init, #section_names, #section_names1, #sequential_admonition_names, #sequential_asset_names

Constructor Details

#initialize(options) ⇒ PdfConvert

Returns a new instance of PdfConvert.



11
12
13
14
# File 'lib/isodoc/unece/pdf_convert.rb', line 11

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

Instance Method Details

#clause_parse_title(node, div, c1, out) ⇒ Object



92
93
94
95
96
97
98
99
100
101
102
103
# File 'lib/isodoc/unece/pdf_convert.rb', line 92

def clause_parse_title(node, div, c1, out)
  if node["inline-header"] == "true"
    inline_header_title(out, node, c1)
  else
    div.send "h#{anchor(node['id'], :level, false) || '1'}" do |h|
      lbl = anchor(node['id'], :label, false)
      h << "#{lbl}. " if lbl && !@suppressheadingnumbers
      insert_tab(h, 1) if lbl && !@suppressheadingnumbers
      c1&.children&.each { |c2| parse(c2, h) }
    end
  end
end

#default_file_locations(_options) ⇒ Object



38
39
40
41
42
43
44
45
# File 'lib/isodoc/unece/pdf_convert.rb', line 38

def default_file_locations(_options)
  {
    htmlstylesheet: html_doc_path("htmlstyle.scss"),
    htmlcoverpage: html_doc_path("html_unece_titlepage.html"),
    htmlintropage: html_doc_path("html_unece_intro.html"),
    scripts: html_doc_path("scripts.pdf.html"),
  }
end

#default_fonts(options) ⇒ Object

end



22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# File 'lib/isodoc/unece/pdf_convert.rb', line 22

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

#foreword(isoxml, out) ⇒ Object



118
119
120
121
122
123
124
125
126
127
# File 'lib/isodoc/unece/pdf_convert.rb', line 118

def foreword(isoxml, out)
  f = isoxml.at(ns("//foreword")) || return
  page_break(out)
  out.div **attr_code(id: f["id"]) do |s|
    s.h1(**{ class: "ForewordTitle" }) do |h1|
      h1 << @foreword_lbl
    end
    f.elements.each { |e| parse(e, s) unless e.name == "title" }
  end
end

#googlefontsObject



48
49
50
51
52
53
# File 'lib/isodoc/unece/pdf_convert.rb', line 48

def googlefonts
  <<~HEAD.freeze
    <link href="https://fonts.googleapis.com/css?family=Open+Sans:300,300i,400,400i,600,600i|Space+Mono:400,700" rel="stylesheet">
    <link href="https://fonts.googleapis.com/css?family=Roboto:300,400,400i,500,700,900" rel="stylesheet">
  HEAD
end

#html_preface(docxml) ⇒ Object



81
82
83
84
# File 'lib/isodoc/unece/pdf_convert.rb', line 81

def html_preface(docxml)
  super
  docxml
end

#introduction(isoxml, out) ⇒ Object



105
106
107
108
109
110
111
112
113
114
115
116
# File 'lib/isodoc/unece/pdf_convert.rb', line 105

def introduction(isoxml, out)
  f = isoxml.at(ns("//introduction")) || return
  page_break(out)
  out.div **{ class: "Section3", id: f["id"] } do |div|
    div.h1(**{ class: "IntroTitle" }) do |h1|
      h1 << @introduction_lbl
    end
    f.elements.each do |e|
      parse(e, div) unless e.name == "title"
    end
  end
end

#make_body(xml, docxml) ⇒ Object



55
56
57
58
59
60
61
62
63
64
65
66
67
# File 'lib/isodoc/unece/pdf_convert.rb', line 55

def make_body(xml, docxml)
  plenary = docxml.at(ns("//bibdata/ext[doctype = 'plenary']"))
  body_attr = { lang: "EN-US", link: "blue", vlink: "#954F72", "xml:lang": "EN-US", class: "container" }
  if plenary && @htmlcoverpage == html_doc_path("html_unece_titlepage.html")
    @htmlcoverpage = html_doc_path("html_unece_plenary_titlepage.html")
  end
  #@htmlintropage = nil if plenary
  xml.body **body_attr do |body|
    make_body1(body, docxml)
    make_body2(body, docxml)
    make_body3(body, docxml)
  end
end

#make_body3(body, docxml) ⇒ Object



69
70
71
72
73
74
75
76
77
78
79
# File 'lib/isodoc/unece/pdf_convert.rb', line 69

def make_body3(body, docxml)
  body.div **{ class: "main-section" } do |div3|
    boilerplate docxml, div3
    abstract docxml, div3
    foreword docxml, div3
    introduction docxml, div3
    middle docxml, div3
    footnotes div3
    comments div3
  end
end

#middle(isoxml, out) ⇒ Object



86
87
88
89
90
# File 'lib/isodoc/unece/pdf_convert.rb', line 86

def middle(isoxml, out)
  clause isoxml, out
  annex isoxml, out
  bibliography isoxml, out
end