Class: IsoDoc::Unece::HtmlConvert
- Inherits:
-
HtmlConvert
- Object
- HtmlConvert
- IsoDoc::Unece::HtmlConvert
show all
- Includes:
- BaseConvert
- Defined in:
- lib/isodoc/unece/html_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
Instance Method Summary
collapse
#admonition_name_parse, #admonition_parse, #annex_leaf_section, #annex_levelnumber, #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, #leaf_section, #levelnumber, #metadata_init, #section_names, #section_names1, #sequential_admonition_names, #sequential_asset_names
Constructor Details
#initialize(options) ⇒ HtmlConvert
Returns a new instance of HtmlConvert.
11
12
13
14
|
# File 'lib/isodoc/unece/html_convert.rb', line 11
def initialize(options)
@libdir = File.dirname(__FILE__)
super
end
|
Instance Method Details
#clause_parse_title(node, div, c1, out) ⇒ Object
107
108
109
110
111
112
113
114
115
116
117
118
|
# File 'lib/isodoc/unece/html_convert.rb', line 107
def clause_parse_title(node, div, c1, out)
if node["inline-header"] == "true"
(out, node, c1)
else
div.send "h#{anchor(node['id'], :level) || '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/html_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.html"),
}
end
|
#default_fonts(options) ⇒ Object
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
# File 'lib/isodoc/unece/html_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
133
134
135
136
137
138
139
140
141
142
|
# File 'lib/isodoc/unece/html_convert.rb', line 133
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
|
#googlefonts ⇒ Object
48
49
50
51
52
53
|
# File 'lib/isodoc/unece/html_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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
# File 'lib/isodoc/unece/html_convert.rb', line 80
def html_preface(docxml)
super
=begin
preface_container = docxml.at("//div[@id = 'preface_container']") # recommendation
abstractbox = docxml.at("//div[@id = 'abstractbox']") # plenary
foreword = docxml.at("//p[@class = 'ForewordTitle']/..")
intro = docxml.at("//p[@class = 'IntroTitle']/..")
abstract = docxml.at("//h1[@class = 'AbstractTitle']/..")
abstract.parent = (abstractbox || preface_container) if abstract
docxml.at("//h1[@class = 'AbstractTitle']").remove if abstractbox
foreword.parent = preface_container if foreword && preface_container
intro.parent = preface_container if intro && preface_container
if abstractbox && !intro && !foreword
sect2 = docxml.at("//div[@class='WordSection2']")
sect2.next_element.remove # pagebreak
sect2.remove # pagebreak
end
=end
docxml
end
|
#introduction(isoxml, out) ⇒ Object
120
121
122
123
124
125
126
127
128
129
130
131
|
# File 'lib/isodoc/unece/html_convert.rb', line 120
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/html_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
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
|
# File 'lib/isodoc/unece/html_convert.rb', line 69
def make_body3(body, docxml)
body.div **{ class: "main-section" } do |div3|
abstract docxml, div3
foreword docxml, div3
introduction docxml, div3
middle docxml, div3
div3
div3
end
end
|
#middle(isoxml, out) ⇒ Object
101
102
103
104
105
|
# File 'lib/isodoc/unece/html_convert.rb', line 101
def middle(isoxml, out)
clause isoxml, out
annex isoxml, out
bibliography isoxml, out
end
|