Module: IsoDoc::WordFunction::Footnotes

Included in:
IsoDoc::WordConvert
Defined in:
lib/isodoc/word_function/footnotes.rb

Instance Method Summary collapse

Instance Method Details

#bookmarkidObject



3
4
5
6
7
8
9
10
# File 'lib/isodoc/word_function/footnotes.rb', line 3

def bookmarkid
  ret = "X"
  until !@bookmarks_allocated[ret] do
    ret = Random.rand(1000000000)
  end
  @bookmarks_allocated[ret] = true
  sprintf "%09d", ret
end

#footnote_parse(node, out) ⇒ Object



80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# File 'lib/isodoc/word_function/footnotes.rb', line 80

def footnote_parse(node, out)
  return table_footnote_parse(node, out) if (@in_table || @in_figure) &&
    !node.ancestors.map {|m| m.name }.include?("name")
  fn = node["reference"] || UUIDTools::UUID.random_create.to_s
  return seen_footnote_parse(node, out, fn) if @seen_footnote.include?(fn)
  @fn_bookmarks[fn] = bookmarkid
  out.span **{style: "mso-bookmark:_Ref#{@fn_bookmarks[fn]}"} do |s|
    s.a **{ "class": "FootnoteRef", "epub:type": "footnote", href: "#ftn#{fn}" } do |a|
      a.sup { |sup| sup << fn }
    end
  end
  @in_footnote = true
  @footnotes << make_generic_footnote_text(node, fn)
  @in_footnote = false
  @seen_footnote << fn
end

#footnotes(div) ⇒ Object



12
13
14
15
# File 'lib/isodoc/word_function/footnotes.rb', line 12

def footnotes(div)
  return if @footnotes.empty?
  @footnotes.each { |fn| div.parent << fn }
end

#get_table_ancestor_id(node) ⇒ Object



52
53
54
55
56
# File 'lib/isodoc/word_function/footnotes.rb', line 52

def get_table_ancestor_id(node)
  table = node.ancestors("table") || node.ancestors("figure")
  return UUIDTools::UUID.random_create.to_s if table.empty?
  table.last["id"]
end

#make_footnote(node, fn) ⇒ Object



97
98
99
100
101
102
103
# File 'lib/isodoc/word_function/footnotes.rb', line 97

def make_footnote(node, fn)
  return if @seen_footnote.include?(fn)
  @in_footnote = true
  @footnotes << make_generic_footnote_text(node, fn)
  @in_footnote = false
  @seen_footnote << fn
end

#make_generic_footnote_text(node, fnid) ⇒ Object



44
45
46
47
48
49
50
# File 'lib/isodoc/word_function/footnotes.rb', line 44

def make_generic_footnote_text(node, fnid)
  noko do |xml|
    xml.aside **{ id: "ftn#{fnid}" } do |div|
      node.children.each { |n| parse(n, div) }
    end
  end.join("\n")
end


17
18
19
20
21
22
# File 'lib/isodoc/word_function/footnotes.rb', line 17

def make_table_footnote_link(out, fnid, fnref)
  attrs = { href: "##{fnid}", class: "TableFootnoteRef" }
  out.a **attrs do |a|
    a << fnref
  end
end

#make_table_footnote_target(out, fnid, fnref) ⇒ Object



24
25
26
27
28
29
30
31
32
# File 'lib/isodoc/word_function/footnotes.rb', line 24

def make_table_footnote_target(out, fnid, fnref)
  attrs = { id: fnid, class: "TableFootnoteRef" }
  out.span do |s|
    out.span **attrs do |a|
      a << fnref
    end
    insert_tab(s, 1)
  end
end

#make_table_footnote_text(node, fnid, fnref) ⇒ Object



34
35
36
37
38
39
40
41
42
# File 'lib/isodoc/word_function/footnotes.rb', line 34

def make_table_footnote_text(node, fnid, fnref)
  attrs = { id: "ftn#{fnid}" }
  noko do |xml|
    xml.div **attr_code(attrs) do |div|
      make_table_footnote_target(div, fnid, fnref)
      node.children.each { |n| parse(n, div) }
    end
  end.join("\n")
end

#seen_footnote_parse(node, out, fn) ⇒ Object



70
71
72
73
74
75
76
77
78
# File 'lib/isodoc/word_function/footnotes.rb', line 70

def seen_footnote_parse(node, out, fn)
  out.span **{style: "mso-element:field-begin"}
  out << " NOTEREF _Ref#{@fn_bookmarks[fn]} \\f \\h"
  out.span **{style: "mso-element:field-separator"}
  out.span **{class: "MsoFootnoteReference"} do |s|
    s << fn
  end
  out.span **{style: "mso-element:field-end"}
end

#table_footnote_parse(node, out) ⇒ Object



58
59
60
61
62
63
64
65
66
67
68
# File 'lib/isodoc/word_function/footnotes.rb', line 58

def table_footnote_parse(node, out)
  fn = node["reference"] || UUIDTools::UUID.random_create.to_s
  tid = get_table_ancestor_id(node)
  make_table_footnote_link(out, tid + fn, fn)
  # do not output footnote text if we have already seen it for this table
  return if @seen_footnote.include?(tid + fn)
  @in_footnote = true
  out.aside { |a| a << make_table_footnote_text(node, tid + fn, fn) }
  @in_footnote = false
  @seen_footnote << (tid + fn)
end