require_relative "base_convert"
require "isodoc"
module IsoDoc
module Unece
# A {Converter} implementation that generates HTML output, and a document
# schema encapsulation of the document for validation
#
class PdfConvert < IsoDoc::PdfConvert
def initialize(options)
@libdir = File.dirname(__FILE__)
super
end
#def convert1(docxml, filename, dir)
#FileUtils.cp html_doc_path('logo.jpg'), File.join(@localdir, "logo.jpg")
#@files_to_delete << File.join(@localdir, "logo.jpg")
#super
#end
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
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
def googlefonts
<<~HEAD.freeze
HEAD
end
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
def make_body3(body, docxml)
body.div **{ class: "main-section" } do |div3|
abstract docxml, div3
foreword docxml, div3
introduction docxml, div3
middle docxml, div3
footnotes div3
comments div3
end
end
def html_preface(docxml)
super
docxml
end
def middle(isoxml, out)
clause isoxml, out
annex isoxml, out
bibliography isoxml, out
end
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) || '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
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
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
include BaseConvert
end
end
end