Module: IsoDoc::Function::Lists

Included in:
Common
Defined in:
lib/isodoc/function/lists.rb

Constant Summary collapse

OL_STYLE =
{
  arabic: "1",
  roman: "i",
  alphabet: "a",
  roman_upper: "I",
  alphabet_upper: "A",
}.freeze

Instance Method Summary collapse

Instance Method Details

#dl_attrs(node) ⇒ Object



92
93
94
# File 'lib/isodoc/function/lists.rb', line 92

def dl_attrs(node)
  attr_code(id: node["id"], style: keep_style(node), class: node["class"])
end

#dl_parse(node, out) ⇒ Object



96
97
98
99
100
101
102
103
104
105
106
# File 'lib/isodoc/function/lists.rb', line 96

def dl_parse(node, out)
  out.div **attr_code(class: "figdl") do |div|
    list_title_parse(node, div)
    div.dl **dl_attrs(node) do |v|
      node.elements.select { |n| dt_dd? n }.each_slice(2) do |dt, dd|
        dl_parse1(v, dt, dd)
      end
    end
    dl_parse_notes(node, div)
  end
end

#dl_parse1(dlist, dterm, ddef) ⇒ Object



113
114
115
116
117
118
119
120
# File 'lib/isodoc/function/lists.rb', line 113

def dl_parse1(dlist, dterm, ddef)
  dlist.dt **attr_code(id: dterm["id"]) do |term|
    dt_parse(dterm, term)
  end
  dlist.dd **attr_code(id: ddef["id"]) do |listitem|
    ddef.children.each { |n| parse(n, listitem) }
  end
end

#dl_parse_notes(node, out) ⇒ Object



108
109
110
111
# File 'lib/isodoc/function/lists.rb', line 108

def dl_parse_notes(node, out)
  node.elements.reject { |n| dt_dd?(n) || n.name == "fmt-name" }
    .each { |n| parse(n, out) }
end

#dt_dd?(node) ⇒ Boolean

Returns:

  • (Boolean)


88
89
90
# File 'lib/isodoc/function/lists.rb', line 88

def dt_dd?(node)
  %w{dt dd}.include? node.name
end

#dt_parse(dterm, term) ⇒ Object



78
79
80
81
82
83
84
85
86
# File 'lib/isodoc/function/lists.rb', line 78

def dt_parse(dterm, term)
  if dterm.elements.empty?
    term.p do |p|
      dterm.children.each { |n| parse(n, p) }
    end
  else
    dterm.children.each { |n| parse(n, term) }
  end
end

#li_parse(node, out) ⇒ Object



65
66
67
68
69
70
71
72
73
74
75
76
# File 'lib/isodoc/function/lists.rb', line 65

def li_parse(node, out)
  out.li **attr_code(id: node["id"]) do |li|
    if node["uncheckedcheckbox"] == "true"
      li << '<span class="zzMoveToFollowing">' \
            '<input type="checkbox" checked="checked"/></span>'
    elsif node["checkedcheckbox"] == "true"
      li << '<span class="zzMoveToFollowing">' \
            '<input type="checkbox"/></span>'
    end
    node.children.each { |n| parse(n, li) }
  end
end

#list_title_parse(node, out) ⇒ Object



4
5
6
7
8
9
# File 'lib/isodoc/function/lists.rb', line 4

def list_title_parse(node, out)
  name = node.at(ns("./fmt-name")) or return
  out.p class: "ListTitle" do |p|
    name.children&.each { |n| parse(n, p) }
  end
end

#ol_attrs(node) ⇒ Object



51
52
53
54
# File 'lib/isodoc/function/lists.rb', line 51

def ol_attrs(node)
  { type: node["type"] ? ol_style(node["type"].to_sym) : ol_depth(node),
    id: node["id"], style: keep_style(node) }
end

#ol_depth(node) ⇒ Object

We don’t really want users to specify type of ordered list; we will use a fixed hierarchy as practiced by ISO (though not fully spelled out): a) 1) i) A) I)



41
42
43
44
45
46
47
48
49
# File 'lib/isodoc/function/lists.rb', line 41

def ol_depth(node)
  depth = node.ancestors("ul, ol").size + 1
  type = :alphabet
  type = :arabic if [2, 7].include? depth
  type = :roman if [3, 8].include? depth
  type = :alphabet_upper if [4, 9].include? depth
  type = :roman_upper if [5, 10].include? depth
  ol_style(type)
end

#ol_parse(node, out) ⇒ Object



56
57
58
59
60
61
62
63
# File 'lib/isodoc/function/lists.rb', line 56

def ol_parse(node, out)
  out.div **attr_code(class: "ol_wrap") do |div|
    list_title_parse(node, div)
    div.ol **attr_code(ol_attrs(node)) do |ol|
      node.children.each { |n| n.name == "fmt-name" or parse(n, ol) }
    end
  end
end

#ol_style(type) ⇒ Object



32
33
34
35
# File 'lib/isodoc/function/lists.rb', line 32

def ol_style(type)
  type ||= :alphabet
  OL_STYLE[type.to_sym]
end

#ul_attrs(node) ⇒ Object



11
12
13
# File 'lib/isodoc/function/lists.rb', line 11

def ul_attrs(node)
  { id: node["id"], style: keep_style(node) }
end

#ul_parse(node, out) ⇒ Object



15
16
17
18
19
20
21
22
# File 'lib/isodoc/function/lists.rb', line 15

def ul_parse(node, out)
  out.div **attr_code(class: "ul_wrap") do |div|
    list_title_parse(node, div)
    div.ul **attr_code(ul_attrs(node)) do |ul|
      node.children.each { |n| n.name == "fmt-name" or parse(n, ul) }
    end
  end
end