Module: IsoDoc::Function::Blocks
- Included in:
- Common
- Defined in:
- lib/isodoc/function/reqt.rb,
lib/isodoc/function/blocks.rb,
lib/isodoc/function/blocks_example_note.rb
Constant Summary collapse
- EXAMPLE_TBL_ATTR =
{ class: "example_label", style: "width:82.8pt;padding:0 0 0 0;\ margin-left:0pt;vertical-align:top;" }.freeze
- EXAMPLE_TD_ATTR =
{ style: "vertical-align:top;padding:0;", class: "example" }.freeze
Instance Method Summary collapse
- #admonition_attrs(node) ⇒ Object
- #admonition_class(_node) ⇒ Object
- #admonition_name(node, _type) ⇒ Object
- #admonition_name_parse(_node, div, name) ⇒ Object
- #admonition_parse(node, out) ⇒ Object
- #annotation_parse(node, out) ⇒ Object
- #columnbreak_parse(node, out) ⇒ Object
- #cross_align_parse(node, out) ⇒ Object
- #div_parse(node, out) ⇒ Object
- #example_div_attr(node) ⇒ Object
-
#example_div_parse(node, out) ⇒ Object
used if we are boxing examples.
- #example_label(_node, div, name) ⇒ Object
- #example_parse(node, out) ⇒ Object
- #example_table_attr(node) ⇒ Object
- #example_table_parse(node, out) ⇒ Object
- #figure_attrs(node) ⇒ Object
- #figure_key(out) ⇒ Object
- #figure_name_parse(_node, div, name) ⇒ Object
- #figure_parse(node, out) ⇒ Object
- #figure_parse1(node, out) ⇒ Object
- #formula_attrs(node) ⇒ Object
- #formula_parse(node, out) ⇒ Object
- #formula_parse1(node, out) ⇒ Object
- #keep_style(node) ⇒ Object
- #note_attrs(node) ⇒ Object
- #note_delim ⇒ Object
- #note_p_parse(node, div) ⇒ Object
- #note_parse(node, out) ⇒ Object
- #note_parse1(node, div) ⇒ Object
- #para_attrs(node) ⇒ Object
- #para_class(node) ⇒ Object
- #para_parse(node, out) ⇒ Object
- #passthrough_parse(node, out) ⇒ Object
- #permission_parse(node, out) ⇒ Object
- #pre_parse(node, out) ⇒ Object
- #pseudocode_attrs(node) ⇒ Object
- #pseudocode_parse(node, out) ⇒ Object
- #quote_attribution(node, out) ⇒ Object
- #quote_parse(node, out) ⇒ Object
- #recommendation_name(name, out) ⇒ Object
- #recommendation_parse(node, out) ⇒ Object
- #recommendation_parse1(node, out) ⇒ Object
- #reqt_attrs(node, klass) ⇒ Object
- #requirement_parse(node, out) ⇒ Object
- #source_parse(node, out) ⇒ Object
- #sourcecode_attrs(node) ⇒ Object
- #sourcecode_name_parse(_node, div, name) ⇒ Object
- #sourcecode_parse(node, out) ⇒ Object
- #sourcecode_parse1(node, div) ⇒ Object
- #svg_parse(node, out) ⇒ Object
- #toc_parse(node, out) ⇒ Object
Instance Method Details
#admonition_attrs(node) ⇒ Object
127 128 129 130 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 127 def admonition_attrs(node) attr_code(id: node["id"], class: admonition_class(node), style: keep_style(node), coverpage: node["coverpage"]) end |
#admonition_class(_node) ⇒ Object
119 120 121 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 119 def admonition_class(_node) "Admonition" end |
#admonition_name(node, _type) ⇒ Object
123 124 125 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 123 def admonition_name(node, _type) node&.at(ns("./name")) end |
#admonition_name_parse(_node, div, name) ⇒ Object
113 114 115 116 117 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 113 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 |
#admonition_parse(node, out) ⇒ Object
132 133 134 135 136 137 138 139 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 132 def admonition_parse(node, out) type = node["type"] name = admonition_name(node, type) out.div **admonition_attrs(node) do |t| admonition_name_parse(node, t, name) if name node.children.each { |n| parse(n, t) unless n.name == "name" } end end |
#annotation_parse(node, out) ⇒ Object
95 96 97 98 99 100 101 102 103 |
# File 'lib/isodoc/function/blocks.rb', line 95 def annotation_parse(node, out) dl = node.at(ns("./dl")) or return @sourcecode = false # @annotation = true out.div class: "annotation" do |div| parse(dl, div) # @annotation = false end end |
#columnbreak_parse(node, out) ⇒ Object
220 |
# File 'lib/isodoc/function/blocks.rb', line 220 def columnbreak_parse(node, out); end |
#cross_align_parse(node, out) ⇒ Object
208 209 210 211 212 213 214 215 216 217 218 |
# File 'lib/isodoc/function/blocks.rb', line 208 def cross_align_parse(node, out) out.table do |t| t.tbody do |b| node.xpath(ns("./align-cell")).each do |c| b.td do |td| c.children.each { |n| parse(n, td) } end end end end end |
#div_parse(node, out) ⇒ Object
41 42 43 44 45 46 47 |
# File 'lib/isodoc/function/reqt.rb', line 41 def div_parse(node, out) out.div **reqt_attrs(node, node["type"]) do |t| node.children.each do |n| parse(n, t) end end end |
#example_div_attr(node) ⇒ Object
16 17 18 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 16 def example_div_attr(node) attr_code(id: node["id"], class: "example", style: keep_style(node)) end |
#example_div_parse(node, out) ⇒ Object
used if we are boxing examples
21 22 23 24 25 26 27 28 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 21 def example_div_parse(node, out) out.div **example_div_attr(node) 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 |
#example_label(_node, div, name) ⇒ Object
4 5 6 7 8 9 10 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 4 def example_label(_node, div, name) return if name.nil? div.p class: "example-title" do |_p| name.children.each { |n| parse(n, div) } end end |
#example_parse(node, out) ⇒ Object
52 53 54 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 52 def example_parse(node, out) example_div_parse(node, out) end |
#example_table_attr(node) ⇒ Object
30 31 32 33 34 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 30 def example_table_attr(node) attr_code(id: node["id"], class: "example", style: "border-collapse:collapse;border-spacing:0;" \ "#{keep_style(node)}") end |
#example_table_parse(node, out) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 39 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 |
#figure_attrs(node) ⇒ Object
21 22 23 |
# File 'lib/isodoc/function/blocks.rb', line 21 def figure_attrs(node) attr_code(id: node["id"], class: "figure", style: keep_style(node)) end |
#figure_key(out) ⇒ Object
15 16 17 18 19 |
# File 'lib/isodoc/function/blocks.rb', line 15 def figure_key(out) out.p style: "page-break-after:avoid;" do |p| p.b { |b| b << @i18n.key } end end |
#figure_name_parse(_node, div, name) ⇒ Object
8 9 10 11 12 13 |
# File 'lib/isodoc/function/blocks.rb', line 8 def figure_name_parse(_node, div, name) name.nil? and return div.p class: "FigureTitle", style: "text-align:center;" do |p| name.children.each { |n| parse(n, p) } end end |
#figure_parse(node, out) ⇒ Object
25 26 27 28 29 30 31 32 |
# File 'lib/isodoc/function/blocks.rb', line 25 def figure_parse(node, out) return pseudocode_parse(node, out) if node["class"] == "pseudocode" || node["type"] == "pseudocode" @in_figure = true figure_parse1(node, out) @in_figure = false end |
#figure_parse1(node, out) ⇒ Object
34 35 36 37 38 39 40 41 42 |
# File 'lib/isodoc/function/blocks.rb', line 34 def figure_parse1(node, out) out.div **figure_attrs(node) 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 end |
#formula_attrs(node) ⇒ Object
117 118 119 |
# File 'lib/isodoc/function/blocks.rb', line 117 def formula_attrs(node) attr_code(id: node["id"], style: keep_style(node)) end |
#formula_parse(node, out) ⇒ Object
121 122 123 124 125 126 127 128 129 130 |
# File 'lib/isodoc/function/blocks.rb', line 121 def formula_parse(node, out) out.div **formula_attrs(node) do |div| formula_parse1(node, div) node.children.each do |n| next if %w(stem name).include? n.name parse(n, div) end end end |
#formula_parse1(node, out) ⇒ Object
105 106 107 108 109 110 111 112 113 114 115 |
# File 'lib/isodoc/function/blocks.rb', line 105 def formula_parse1(node, out) out.div **attr_code(class: "formula") do |div| div.p do |_p| parse(node.at(ns("./stem")), div) if lbl = node&.at(ns("./name"))&.text insert_tab(div, 1) div << "(#{lbl})" end end end end |
#keep_style(node) ⇒ Object
84 85 86 87 88 89 90 91 92 93 94 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 84 def keep_style(node) ret = "" node["style"] and ret += "#{node['style']};" node["keep-with-next"] == "true" and ret += "page-break-after: avoid;" node["keep-lines-together"] == "true" and ret += "page-break-inside: avoid;" return nil if ret.empty? ret end |
#note_attrs(node) ⇒ Object
96 97 98 99 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 96 def note_attrs(node) attr_code(id: node["id"], class: "Note", style: keep_style(node), coverpage: node["coverpage"]) end |
#note_delim ⇒ Object
56 57 58 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 56 def note_delim "" end |
#note_p_parse(node, div) ⇒ Object
60 61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 60 def note_p_parse(node, div) name = node.at(ns("./name"))&.remove div.p do |p| name and p.span class: "note_label" do |s| name.children.each { |n| parse(n, s) } s << note_delim 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 |
#note_parse(node, out) ⇒ Object
101 102 103 104 105 106 107 108 109 110 111 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 101 def note_parse(node, out) @note = true out.div **note_attrs(node) do |div| if node&.at(ns("./*[local-name() != 'name'][1]"))&.name == "p" note_p_parse(node, div) else note_parse1(node, div) end end @note = false end |
#note_parse1(node, div) ⇒ Object
73 74 75 76 77 78 79 80 81 82 |
# File 'lib/isodoc/function/blocks_example_note.rb', line 73 def note_parse1(node, div) name = node.at(ns("./name")) and div.p do |p| p.span class: "note_label" do |s| name.remove.children.each { |n| parse(n, s) } s << note_delim end insert_tab(p, 1) end node.children.each { |n| parse(n, div) } end |
#para_attrs(node) ⇒ Object
143 144 145 146 147 148 149 |
# File 'lib/isodoc/function/blocks.rb', line 143 def para_attrs(node) attrs = { class: para_class(node), id: node["id"] } s = node["align"].nil? ? "" : "text-align:#{node['align']};" s = "#{s}#{keep_style(node)}" attrs[:style] = s unless s.empty? attrs end |
#para_class(node) ⇒ Object
132 133 134 135 136 137 138 139 140 141 |
# File 'lib/isodoc/function/blocks.rb', line 132 def para_class(node) classtype = nil classtype = "MsoCommentText" if in_comment classtype = "Sourcecode" if @annotation if node["type"] == "floating-title" classtype = "h#{node['depth']}" end classtype ||= node["class"] classtype end |
#para_parse(node, out) ⇒ Object
151 152 153 154 155 156 157 158 159 |
# File 'lib/isodoc/function/blocks.rb', line 151 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 |
#passthrough_parse(node, out) ⇒ Object
183 184 185 186 187 188 |
# File 'lib/isodoc/function/blocks.rb', line 183 def passthrough_parse(node, out) return if node["format"] && !(node["format"].split(",").include? @format.to_s) out.passthrough node.text end |
#permission_parse(node, out) ⇒ Object
35 36 37 38 39 |
# File 'lib/isodoc/function/reqt.rb', line 35 def (node, out) out.div **reqt_attrs(node, "permission") do |t| recommendation_parse1(node, t) end end |
#pre_parse(node, out) ⇒ Object
91 92 93 |
# File 'lib/isodoc/function/blocks.rb', line 91 def pre_parse(node, out) out.pre node.text, **attr_code(id: node["id"]) end |
#pseudocode_attrs(node) ⇒ Object
44 45 46 |
# File 'lib/isodoc/function/blocks.rb', line 44 def pseudocode_attrs(node) attr_code(id: node["id"], class: "pseudocode", style: keep_style(node)) end |
#pseudocode_parse(node, out) ⇒ Object
48 49 50 51 52 53 54 55 56 |
# File 'lib/isodoc/function/blocks.rb', line 48 def pseudocode_parse(node, out) @in_figure = true name = node.at(ns("./name")) out.div **pseudocode_attrs(node) do |div| node.children.each { |n| parse(n, div) unless n.name == "name" } sourcecode_name_parse(node, div, name) end @in_figure = false end |
#quote_attribution(node, out) ⇒ Object
161 162 163 164 165 166 167 168 169 170 |
# File 'lib/isodoc/function/blocks.rb', line 161 def quote_attribution(node, out) = node.at(ns("./author")) source = node.at(ns("./source")) .nil? && source.nil? and return out.p class: "QuoteAttribution" do |p| p << "— #{.text}" if p << ", " if && source eref_parse(source, p) if source end end |
#quote_parse(node, out) ⇒ Object
172 173 174 175 176 177 178 179 180 181 |
# File 'lib/isodoc/function/blocks.rb', line 172 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 %w(author source).include? n.name end quote_attribution(node, out) end end |
#recommendation_name(name, out) ⇒ Object
4 5 6 7 8 9 10 |
# File 'lib/isodoc/function/reqt.rb', line 4 def recommendation_name(name, out) return if name.nil? out.p class: "RecommendationTitle" do |p| name.children.each { |n| parse(n, p) } end end |
#recommendation_parse(node, out) ⇒ Object
16 17 18 19 20 |
# File 'lib/isodoc/function/reqt.rb', line 16 def recommendation_parse(node, out) out.div **reqt_attrs(node, "recommend") do |t| recommendation_parse1(node, t) end end |
#recommendation_parse1(node, out) ⇒ Object
22 23 24 25 26 27 |
# File 'lib/isodoc/function/reqt.rb', line 22 def recommendation_parse1(node, out) recommendation_name(node.at(ns("./name")), out) node.children.each do |n| parse(n, out) unless n.name == "name" end end |
#reqt_attrs(node, klass) ⇒ Object
12 13 14 |
# File 'lib/isodoc/function/reqt.rb', line 12 def reqt_attrs(node, klass) attr_code(class: klass, id: node["id"], style: keep_style(node)) end |
#requirement_parse(node, out) ⇒ Object
29 30 31 32 33 |
# File 'lib/isodoc/function/reqt.rb', line 29 def requirement_parse(node, out) out.div **reqt_attrs(node, "require") do |t| recommendation_parse1(node, t) end end |
#source_parse(node, out) ⇒ Object
200 201 202 203 204 205 206 |
# File 'lib/isodoc/function/blocks.rb', line 200 def source_parse(node, out) out.div class: "BlockSource" do |d| d.p do |p| node.children.each { |n| parse(n, p) } end end end |
#sourcecode_attrs(node) ⇒ Object
66 67 68 |
# File 'lib/isodoc/function/blocks.rb', line 66 def sourcecode_attrs(node) attr_code(id: node["id"], class: "Sourcecode", style: keep_style(node)) end |
#sourcecode_name_parse(_node, div, name) ⇒ Object
58 59 60 61 62 63 64 |
# File 'lib/isodoc/function/blocks.rb', line 58 def sourcecode_name_parse(_node, div, name) return if name.nil? div.p class: "SourceTitle", style: "text-align:center;" do |p| name.children.each { |n| parse(n, p) } end end |
#sourcecode_parse(node, out) ⇒ Object
70 71 72 73 74 75 76 77 |
# File 'lib/isodoc/function/blocks.rb', line 70 def sourcecode_parse(node, out) name = node.at(ns("./name")) out.p **sourcecode_attrs(node) do |div| sourcecode_parse1(node, div) end annotation_parse(node, out) sourcecode_name_parse(node, out, name) end |
#sourcecode_parse1(node, div) ⇒ Object
79 80 81 82 83 84 85 86 87 88 89 |
# File 'lib/isodoc/function/blocks.rb', line 79 def sourcecode_parse1(node, div) @sourcecode = "pre" node.at(ns(".//table[@class = 'rouge-line-table']")) || node.at("./ancestor::xmlns:table[@class = 'rouge-line-table']") and @sourcecode = "table" node.children.each do |n| %w(name dl).include?(n.name) and next parse(n, div) end @sourcecode = false end |
#svg_parse(node, out) ⇒ Object
190 191 192 |
# File 'lib/isodoc/function/blocks.rb', line 190 def svg_parse(node, out) out.parent.add_child(node) end |
#toc_parse(node, out) ⇒ Object
194 195 196 197 198 |
# File 'lib/isodoc/function/blocks.rb', line 194 def toc_parse(node, out) out.div class: "toc" do |div| node.children.each { |n| parse(n, div) } end end |