module IsoDoc::Function module Blocks @annotation = false def note_label(node) n = get_anchors[node["id"]] return @note_lbl if n.nil? || n[:label].nil? || n[:label].empty? l10n("#{@note_lbl} #{n[:label]}") end def note_p_parse(node, div) div.p do |p| p.span **{ class: "note_label" } do |s| s << note_label(node) end insert_tab(p, 1) node.first_element_child.children.each { |n| parse(n, p) } end node.element_children[1..-1].each { |n| parse(n, div) } end def note_parse1(node, div) div.p do |p| p.span **{ class: "note_label" } do |s| s << note_label(node) end insert_tab(p, 1) end node.children.each { |n| parse(n, div) } end def note_parse(node, out) @note = true out.div **{ id: node["id"], class: "Note" } do |div| if node.first_element_child.name == "p" note_p_parse(node, div) else note_parse1(node, div) end end @note = false end def figure_name_parse(node, div, name) return if name.nil? && node.at(ns("./figure")) div.p **{ class: "FigureTitle", style: "text-align:center;" } do |p| lbl = anchor(node['id'], :label, false) lbl.nil? or p << l10n("#{@figure_lbl} #{lbl}") name and !lbl.nil? and p << " — " name and name.children.each { |n| parse(n, div) } end end def figure_key(out) out.p do |p| p.b { |b| b << @key_lbl } end end def figure_parse(node, out) return pseudocode_parse(node, out) if node["class"] == "pseudocode" || node["type"] == "pseudocode" @in_figure = true out.div **attr_code(id: node["id"], class: "figure") do |div| node.children.each do |n| figure_key(out) if n.name == "dl" parse(n, div) unless n.name == "name" end figure_name_parse(node, div, node.at(ns("./name"))) end @in_figure = false end def pseudocode_parse(node, out) @in_figure = true name = node.at(ns("./name")) out.div **attr_code(id: node["id"], class: "pseudocode") do |div| node.children.each do |n| parse(n, div) unless n.name == "name" end sourcecode_name_parse(node, div, name) if name end @in_figure = false end def example_label(node, div, name) n = get_anchors[node["id"]] div.p **{ class: "example-title" } do |p| lbl = (n.nil? || n[:label].nil? || n[:label].empty?) ? @example_lbl : l10n("#{@example_lbl} #{n[:label]}") p << lbl name and !lbl.nil? and p << " — " name and name.children.each { |n| parse(n, div) } end end EXAMPLE_TBL_ATTR = { class: "example_label", style: "width:82.8pt;padding:0 0 0 0;\ margin-left:0pt;vertical-align:top;" }.freeze # used if we are boxing examples def example_div_parse(node, out) out.div **attr_code(id: node["id"], class: "example") do |div| example_label(node, div, node.at(ns("./name"))) node.children.each do |n| parse(n, div) unless n.name == "name" end end end def example_table_attr(node) attr_code(id: node["id"], class: "example", style: "border-collapse:collapse;border-spacing:0;" ) end EXAMPLE_TD_ATTR = { style: "vertical-align:top;padding:0;", class: "example" }.freeze def example_table_parse(node, out) out.table **example_table_attr(node) do |t| t.tr do |tr| tr.td **EXAMPLE_TBL_ATTR do |td| example_label(node, td, node.at(ns("./name"))) end tr.td **EXAMPLE_TD_ATTR do |td| node.children.each { |n| parse(n, td) unless n.name == "name" } end end end end def example_parse(node, out) example_div_parse(node, out) end def sourcecode_name_parse(_node, div, name) div.p **{ class: "SourceTitle", style: "text-align:center;" } do |p| name.children.each { |n| parse(n, p) } end end def admonition_name_parse(_node, div, name) div.p **{ class: "AdmonitionTitle", style: "text-align:center;" } do |p| name.children.each { |n| parse(n, p) } end end def sourcecode_parse(node, out) name = node.at(ns("./name")) out.p **attr_code(id: node["id"], class: "Sourcecode") do |div| @sourcecode = true node.children.each do |n| parse(n, div) unless n.name == "name" end @sourcecode = false end sourcecode_name_parse(node, out, name) if name end def pre_parse(node, out) out.pre node.text, **attr_code(id: node["id"]) end def annotation_parse(node, out) @sourcecode = false @annotation = true node.at("./preceding-sibling::*[local-name() = 'annotation']") or out << "
" out << "
" #out.span **{ class: "zzMoveToFollowing" } do |s| out << "<#{node.at(ns("//callout[@target='#{node['id']}']")).text}> " #end #node.children.each { |n| parse(n, out) } out << node&.children&.text&.strip @annotation = false end def admonition_class(node) "Admonition" end def admonition_name(node, type) name = node&.at(ns("./name")) and return name name = Nokogiri::XML::Node.new('name', node.document) return unless type && @admonition[type] name << @admonition[type]&.upcase name end def admonition_parse(node, out) type = node["type"] name = admonition_name(node, type) out.div **{ class: admonition_class(node) } do |t| admonition_name_parse(node, t, name) if name node.children.each do |n| parse(n, t) unless n.name == "name" end end end def formula_where(dl, out) return unless dl out.p { |p| p << @where_lbl } parse(dl, out) end def formula_parse1(node, out) out.div **attr_code(id: node["id"], class: "formula") do |div| div.p do |p| parse(node.at(ns("./stem")), div) lbl = anchor(node['id'], :label, false) unless lbl.nil? insert_tab(div, 1) div << "(#{lbl})" end end end end def formula_parse(node, out) formula_parse1(node, out) formula_where(node.at(ns("./dl")), out) node.children.each do |n| next if %w(stem dl).include? n.name parse(n, out) end end def para_class(_node) classtype = nil classtype = "MsoCommentText" if in_comment classtype = "Sourcecode" if @annotation classtype end def para_attrs(node) attrs = { class: para_class(node), id: node["id"] } unless node["align"].nil? #attrs[:align] = node["align"] unless node["align"] == "justify" attrs[:style] = "text-align:#{node['align']};" end attrs end def para_parse(node, out) out.p **attr_code(para_attrs(node)) do |p| unless @termdomain.empty? p << "<#{@termdomain}> " @termdomain = "" end node.children.each { |n| parse(n, p) } end end def quote_attribution(node, out) author = node.at(ns("./author")) source = node.at(ns("./source")) out.p **{ class: "QuoteAttribution" } do |p| p << "— #{author.text}" if author p << ", " if author && source eref_parse(source, p) if source end end def quote_parse(node, out) attrs = para_attrs(node) attrs[:class] = "Quote" out.div **attr_code(attrs) do |p| node.children.each do |n| parse(n, p) unless ["author", "source"].include? n.name end quote_attribution(node, out) end end def image_title_parse(out, caption) unless caption.nil? out.p **{ class: "FigureTitle", style: "text-align:center;" } do |p| p.b { |b| b << caption.to_s } end end end def image_parse(node, out, caption) attrs = { src: node["src"], height: node["height"] || "auto", width: node["width"] || "auto", title: node["title"], alt: node["alt"] } out.img **attr_code(attrs) image_title_parse(out, caption) end end end