isodoc 1.0.7 → 1.0.8

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 61c4078b846eee8f29ef7322bcb1ac497c0418c4d7eaaba8d79ff4549b4d5b47
4
- data.tar.gz: 311efba07534c2f7a6c35af286478a3beb31f082f50424ce4fdbfe0956eebb95
3
+ metadata.gz: ef21cf58dadc44402088da8688039f145c7c772d2241207790e22721d4509acf
4
+ data.tar.gz: 5ba2928a7dd29b05b5042bec243d40ef5bc0b57c4cbbf9062469bef4f89ec6e1
5
5
  SHA512:
6
- metadata.gz: f30695762aa1626b376317e3e928b4dab2d7dca5493f8d9990df4d8daf6b1d7f958e21f3217e227a974b9af1db1c46921a1c9250f25164f63cd3c4edd6ba73d8
7
- data.tar.gz: 20e1f4f1e19a51c828ad06d07814c5af1d37213b37615376e68bafddf0f9bcd5fba7cf991571de5f38bb8983b10f7be45eb8720b76f45bbc0899028e8267b6f7
6
+ metadata.gz: 4d20eccad075ca4cafff9e8b873514d7d955fe19c02f21b032a7c578b5441b414cb5d3e1f8abbe701b686b2e5ff56d1c8dc6b1fa86e6707727b2a76d05b9b513
7
+ data.tar.gz: f69deb2000b76e5e24902aad3d11179395f6930a446b5b10244510f7d1be26667164ef1acb16e1c44233d617a1368e53b2d4f15ba4640e83c82be13d66f5e4fa
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- isodoc (1.0.7)
4
+ isodoc (1.0.8)
5
5
  asciimath
6
6
  html2doc (~> 0.9.0)
7
7
  htmlentities (~> 4.3.4)
@@ -26,7 +26,7 @@ GEM
26
26
  docile (1.3.2)
27
27
  equivalent-xml (0.6.0)
28
28
  nokogiri (>= 1.4.3)
29
- ffi (1.11.1)
29
+ ffi (1.11.2)
30
30
  formatador (0.2.5)
31
31
  guard (2.16.1)
32
32
  formatador (>= 0.2.4)
@@ -42,7 +42,7 @@ GEM
42
42
  guard (~> 2.1)
43
43
  guard-compat (~> 1.1)
44
44
  rspec (>= 2.99.0, < 4.0)
45
- html2doc (0.9.1)
45
+ html2doc (0.9.2)
46
46
  asciimath (~> 1.0.9)
47
47
  htmlentities (~> 4.3.4)
48
48
  image_size
@@ -58,7 +58,7 @@ GEM
58
58
  rb-fsevent (~> 0.10, >= 0.10.3)
59
59
  rb-inotify (~> 0.9, >= 0.9.10)
60
60
  lumberjack (1.0.13)
61
- metanorma (0.3.16)
61
+ metanorma (0.3.17)
62
62
  asciidoctor
63
63
  htmlentities
64
64
  method_source (0.9.2)
@@ -72,7 +72,7 @@ GEM
72
72
  notiffany (0.1.3)
73
73
  nenv (~> 0.1)
74
74
  shellany (~> 0.0)
75
- parallel (1.18.0)
75
+ parallel (1.19.0)
76
76
  parser (2.6.5.0)
77
77
  ast (~> 2.4.0)
78
78
  powerpack (0.1.2)
@@ -0,0 +1,31 @@
1
+ div.table_container {
2
+ margin-bottom: 14pt;
3
+ }
4
+
5
+ ol
6
+ {margin-bottom:0cm;}
7
+ ul
8
+ {margin-bottom:0cm;}
9
+
10
+ table.MsoISOTable tr
11
+ {page-break-inside:avoid;}
12
+
13
+ td { page-break-inside:avoid; }
14
+ tr { page-break-after:avoid; }
15
+
16
+ span.stem
17
+ {font-family:"Cambria Math",serif;
18
+ mso-ascii-font-family:"Cambria Math";
19
+ font-style:italic;}
20
+
21
+ dt
22
+ {page-break-inside:avoid;
23
+ page-break-after:avoid}
24
+
25
+ br.section
26
+ {page-break-before:always;
27
+ mso-break-type:section-break;}
28
+ br.pagebreak
29
+ {page-break-before:always;
30
+ mso-special-character:line-break;}
31
+
@@ -21,6 +21,10 @@ dl {
21
21
  }
22
22
  }
23
23
 
24
+ b, strong {
25
+ font-weight: bold;
26
+ }
27
+
24
28
  @mixin bodyStyle1($fontSize, $lineHeight, $colorText, $colorBackground, $fontWeight: 400) {
25
29
  margin-left: auto;
26
30
  margin-right: auto;
@@ -1,6 +1,7 @@
1
1
  require "isodoc/common"
2
2
  require "sassc"
3
3
  require "fileutils"
4
+ require "tempfile"
4
5
 
5
6
  module IsoDoc
6
7
  class Convert < ::IsoDoc::Common
@@ -31,6 +32,7 @@ module IsoDoc
31
32
  merge!(default_file_locations(options)) { |_, old, new| old || new }
32
33
  @options = options
33
34
  @files_to_delete = []
35
+ @tempfile_cache = []
34
36
  @htmlstylesheet_name = options[:htmlstylesheet]
35
37
  @wordstylesheet_name = options[:wordstylesheet]
36
38
  @standardstylesheet_name = options[:standardstylesheet]
@@ -129,10 +131,15 @@ module IsoDoc
129
131
  "lib", "isodoc")
130
132
  SassC.load_paths << File.dirname(filename)
131
133
  engine = SassC::Engine.new(fontheader + stylesheet, syntax: :scss)
132
- outname = File.basename(filename, ".*") + ".css"
133
- File.open(outname, "w:UTF-8") { |f| f.write(engine.render) }
134
- @files_to_delete << outname
135
- outname
134
+ #outname = File.basename(filename, ".*") + ".css"
135
+ #File.open(outname, "w:UTF-8") { |f| f.write(engine.render) }
136
+ #@files_to_delete << outname
137
+ #outname
138
+ Tempfile.open([File.basename(filename, ".*"), "css"],
139
+ :encoding => "utf-8") do |f|
140
+ f.write(engine.render)
141
+ f
142
+ end
136
143
  end
137
144
 
138
145
  def convert1(docxml, filename, dir)
@@ -142,7 +149,7 @@ module IsoDoc
142
149
  html.parent.add_namespace("epub", "http://www.idpf.org/2007/ops")
143
150
  info docxml, nil
144
151
  populate_css()
145
- define_head html, filename, dir
152
+ html.head { |head| define_head head, filename, dir }
146
153
  make_body(html, docxml)
147
154
  end
148
155
  end.join("\n")
@@ -32,11 +32,8 @@ module IsoDoc::Function
32
32
  def note_parse(node, out)
33
33
  @note = true
34
34
  out.div **{ id: node["id"], class: "Note" } do |div|
35
- if node.first_element_child.name == "p"
36
- note_p_parse(node, div)
37
- else
38
- note_parse1(node, div)
39
- end
35
+ node.first_element_child.name == "p" ?
36
+ note_p_parse(node, div) : note_parse1(node, div)
40
37
  end
41
38
  @note = false
42
39
  end
@@ -75,9 +72,7 @@ module IsoDoc::Function
75
72
  @in_figure = true
76
73
  name = node.at(ns("./name"))
77
74
  out.div **attr_code(id: node["id"], class: "pseudocode") do |div|
78
- node.children.each do |n|
79
- parse(n, div) unless n.name == "name"
80
- end
75
+ node.children.each { |n| parse(n, div) unless n.name == "name" }
81
76
  sourcecode_name_parse(node, div, name) if name
82
77
  end
83
78
  @in_figure = false
@@ -149,9 +144,7 @@ module IsoDoc::Function
149
144
  name = node.at(ns("./name"))
150
145
  out.p **attr_code(id: node["id"], class: "Sourcecode") do |div|
151
146
  @sourcecode = true
152
- node.children.each do |n|
153
- parse(n, div) unless n.name == "name"
154
- end
147
+ node.children.each { |n| parse(n, div) unless n.name == "name" }
155
148
  @sourcecode = false
156
149
  end
157
150
  sourcecode_name_parse(node, out, name) if name
@@ -166,11 +159,8 @@ module IsoDoc::Function
166
159
  @annotation = true
167
160
  node.at("./preceding-sibling::*[local-name() = 'annotation']") or
168
161
  out << "<br/>"
169
- out << "<br/>"
170
- #out.span **{ class: "zzMoveToFollowing" } do |s|
171
- out << "&lt;#{node.at(ns("//callout[@target='#{node['id']}']")).text}&gt; "
172
- #end
173
- #node.children.each { |n| parse(n, out) }
162
+ callout = node.at(ns("//callout[@target='#{node['id']}']"))
163
+ out << "<br/>&lt;#{callout.text}&gt; "
174
164
  out << node&.children&.text&.strip
175
165
  @annotation = false
176
166
  end
@@ -192,9 +182,7 @@ module IsoDoc::Function
192
182
  name = admonition_name(node, type)
193
183
  out.div **{ class: admonition_class(node) } do |t|
194
184
  admonition_name_parse(node, t, name) if name
195
- node.children.each do |n|
196
- parse(n, t) unless n.name == "name"
197
- end
185
+ node.children.each { |n| parse(n, t) unless n.name == "name" }
198
186
  end
199
187
  end
200
188
 
@@ -235,10 +223,8 @@ module IsoDoc::Function
235
223
 
236
224
  def para_attrs(node)
237
225
  attrs = { class: para_class(node), id: node["id"] }
238
- unless node["align"].nil?
239
- #attrs[:align] = node["align"] unless node["align"] == "justify"
226
+ node["align"].nil? or
240
227
  attrs[:style] = "text-align:#{node['align']};"
241
- end
242
228
  attrs
243
229
  end
244
230
 
@@ -272,23 +258,5 @@ module IsoDoc::Function
272
258
  quote_attribution(node, out)
273
259
  end
274
260
  end
275
-
276
- def image_title_parse(out, caption)
277
- unless caption.nil?
278
- out.p **{ class: "FigureTitle", style: "text-align:center;" } do |p|
279
- p.b { |b| b << caption.to_s }
280
- end
281
- end
282
- end
283
-
284
- def image_parse(node, out, caption)
285
- attrs = { src: node["src"],
286
- height: node["height"] || "auto",
287
- width: node["width"] || "auto",
288
- title: node["title"],
289
- alt: node["alt"] }
290
- out.img **attr_code(attrs)
291
- image_title_parse(out, caption)
292
- end
293
261
  end
294
262
  end
@@ -90,6 +90,24 @@ module IsoDoc::Function
90
90
  end
91
91
  end
92
92
 
93
+ def image_title_parse(out, caption)
94
+ unless caption.nil?
95
+ out.p **{ class: "FigureTitle", style: "text-align:center;" } do |p|
96
+ p.b { |b| b << caption.to_s }
97
+ end
98
+ end
99
+ end
100
+
101
+ def image_parse(node, out, caption)
102
+ attrs = { src: node["src"],
103
+ height: node["height"] || "auto",
104
+ width: node["width"] || "auto",
105
+ title: node["title"],
106
+ alt: node["alt"] }
107
+ out.img **attr_code(attrs)
108
+ image_title_parse(out, caption)
109
+ end
110
+
93
111
  def error_parse(node, out)
94
112
  text = node.to_xml.gsub(/</, "&lt;").gsub(/>/, "&gt;")
95
113
  out.para do |p|
@@ -40,14 +40,14 @@ module IsoDoc::Function
40
40
 
41
41
  # isodoc.css overrides any CSS injected by Html2Doc, which
42
42
  # is inserted before this CSS.
43
- def define_head(html, filename, _dir)
44
- html.head do |head|
45
- if @standardstylesheet
46
- head.style do |style|
47
- stylesheet = File.read(@standardstylesheet, encoding: "utf-8").
48
- gsub("FILENAME", File.basename(filename))
49
- style.comment "\n#{stylesheet}\n"
50
- end
43
+ def define_head(head, filename, _dir)
44
+ if @standardstylesheet
45
+ head.style do |style|
46
+ #stylesheet = File.read(@standardstylesheet, encoding: "utf-8").
47
+ @standardstylesheet.open
48
+ stylesheet = @standardstylesheet.read.
49
+ gsub("FILENAME", File.basename(filename))
50
+ style.comment "\n#{stylesheet}\n"
51
51
  end
52
52
  end
53
53
  end
@@ -149,7 +149,7 @@ module IsoDoc::Function
149
149
  node.children.each { |n| parse(n, e) }
150
150
  end
151
151
  end
152
-
152
+
153
153
  def strong_parse(node, out)
154
154
  out.b do |e|
155
155
  node.children.each { |n| parse(n, e) }
@@ -200,7 +200,7 @@ module IsoDoc::Function
200
200
  when "callout" then callout_parse(node, out)
201
201
  when "stem" then stem_parse(node, out)
202
202
  when "clause" then clause_parse(node, out)
203
- #when "appendix" then clause_parse(node, out)
203
+ #when "appendix" then clause_parse(node, out)
204
204
  when "xref" then xref_parse(node, out)
205
205
  when "eref" then eref_parse(node, out)
206
206
  when "origin" then eref_parse(node, out)
@@ -152,12 +152,19 @@ module IsoDoc::Function
152
152
 
153
153
  def save_dataimage(uri, relative_dir = true)
154
154
  %r{^data:image/(?<imgtype>[^;]+);base64,(?<imgdata>.+)$} =~ uri
155
- uuid = UUIDTools::UUID.random_create.to_s
156
- fname = "#{uuid}.#{imgtype}"
157
- new_file = File.join(tmpimagedir, fname)
158
- @files_to_delete << new_file
159
- File.open(new_file, "wb") { |f| f.write(Base64.strict_decode64(imgdata)) }
160
- File.join(relative_dir ? rel_tmpimagedir : tmpimagedir, fname)
155
+ #uuid = UUIDTools::UUID.random_create.to_s
156
+ #fname = "#{uuid}.#{imgtype}"
157
+ #new_file = File.join(tmpimagedir, fname)
158
+ #@files_to_delete << new_file
159
+ #File.open(new_file, "wb") { |f| f.write(Base64.strict_decode64(imgdata)) }
160
+ #File.join(relative_dir ? rel_tmpimagedir : tmpimagedir, fname)
161
+ imgtype = "png" unless /^[a-z0-9]+$/.match imgtype
162
+ Tempfile.open(["image", ".#{imgtype}"]) do |f|
163
+ f.binmode
164
+ f.write(Base64.strict_decode64(imgdata))
165
+ @tempfile_cache << f #persist to the end
166
+ f.path
167
+ end
161
168
  end
162
169
  end
163
170
  end
@@ -0,0 +1,66 @@
1
+ require "singleton"
2
+
3
+ module IsoDoc::Function
4
+ module XrefGen
5
+ class Seen_Anchor
6
+ include Singleton
7
+
8
+ def initialize
9
+ @seen = {}
10
+ end
11
+
12
+ def seen(x)
13
+ @seen.has_key?(x)
14
+ end
15
+
16
+ def add(x)
17
+ @seen[x] = true
18
+ end
19
+ end
20
+
21
+ @anchors = {}
22
+
23
+ def get_anchors
24
+ @anchors
25
+ end
26
+
27
+ def anchor(id, lbl, warning = true)
28
+ unless @anchors[id]
29
+ if warning
30
+ @seen ||= Seen_Anchor.instance
31
+ @seen.seen(id) or warn "No label has been processed for ID #{id}"
32
+ @seen.add(id)
33
+ return "[#{id}]"
34
+ end
35
+ end
36
+ @anchors.dig(id, lbl)
37
+ end
38
+
39
+ def anchor_struct_label(lbl, elem)
40
+ case elem
41
+ when @appendix_lbl then l10n("#{elem} #{lbl}")
42
+ else
43
+ lbl.to_s
44
+ end
45
+ end
46
+
47
+ def anchor_struct_xref(lbl, elem)
48
+ case elem
49
+ when @formula_lbl then l10n("#{elem} (#{lbl})")
50
+ when @inequality_lbl then l10n("#{elem} (#{lbl})")
51
+ else
52
+ l10n("#{elem} #{lbl}")
53
+ end
54
+ end
55
+
56
+ def anchor_struct(lbl, container, elem, type, unnumbered = false)
57
+ ret = {}
58
+ ret[:label] = unnumbered == "true" ? nil : anchor_struct_label(lbl, elem)
59
+ ret[:xref] = anchor_struct_xref(unnumbered == "true" ? "(??)" : lbl, elem)
60
+ ret[:xref].gsub!(/ $/, "")
61
+ ret[:container] = get_clause_id(container) unless container.nil?
62
+ ret[:type] = type
63
+ ret
64
+ end
65
+ end
66
+ end
@@ -1,23 +1,8 @@
1
- require "roman-numerals"
2
1
  require_relative "xref_counter"
2
+ require_relative "xref_anchor"
3
3
 
4
4
  module IsoDoc::Function
5
5
  module XrefGen
6
-
7
- @anchors = {}
8
-
9
- def get_anchors
10
- @anchors
11
- end
12
-
13
- def anchor(id, lbl, warning = true)
14
- unless @anchors[id]
15
- warning and warn "No label has been processed for ID #{id}"
16
- return "[#{id}]"
17
- end
18
- @anchors.dig(id, lbl)
19
- end
20
-
21
6
  def termnote_label(n)
22
7
  @termnote_lbl.gsub(/%/, n.to_s)
23
8
  end
@@ -29,8 +14,7 @@ module IsoDoc::Function
29
14
  return if n["id"].nil? || n["id"].empty?
30
15
  c.increment(n)
31
16
  @anchors[n["id"]] =
32
- { label: termnote_label(c.print),
33
- type: "termnote",
17
+ { label: termnote_label(c.print), type: "termnote",
34
18
  xref: l10n("#{anchor(t['id'], :xref)}, "\
35
19
  "#{@note_xref_lbl} #{c.print}") }
36
20
  end
@@ -46,8 +30,8 @@ module IsoDoc::Function
46
30
  c.increment(n)
47
31
  idx = examples.size == 1 ? "" : c.print
48
32
  @anchors[n["id"]] = {
49
- type: "termexample",
50
- label: idx, xref: l10n("#{anchor(t['id'], :xref)}, "\
33
+ type: "termexample", label: idx,
34
+ xref: l10n("#{anchor(t['id'], :xref)}, "\
51
35
  "#{@example_xref_lbl} #{c.print}") }
52
36
  end
53
37
  end
@@ -120,9 +104,9 @@ module IsoDoc::Function
120
104
  label = c.increment(li).listlabel(depth)
121
105
  label = "#{prev_label}.#{label}" unless prev_label.empty?
122
106
  label = "#{list_anchor[:xref]} #{label}" if refer_list
123
- li["id"] and @anchors[li["id"]] = { xref: "#{label})",
124
- type: "listitem",
125
- container: list_anchor[:container] }
107
+ li["id"] and @anchors[li["id"]] =
108
+ { xref: "#{label})", type: "listitem",
109
+ container: list_anchor[:container] }
126
110
  li.xpath(ns("./ol")).each do |ol|
127
111
  list_item_anchor_names(ol, list_anchor, depth + 1, label, false)
128
112
  end
@@ -156,33 +140,6 @@ module IsoDoc::Function
156
140
  end
157
141
  end
158
142
 
159
- def anchor_struct_label(lbl, elem)
160
- case elem
161
- when @appendix_lbl then l10n("#{elem} #{lbl}")
162
- else
163
- lbl.to_s
164
- end
165
- end
166
-
167
- def anchor_struct_xref(lbl, elem)
168
- case elem
169
- when @formula_lbl then l10n("#{elem} (#{lbl})")
170
- when @inequality_lbl then l10n("#{elem} (#{lbl})")
171
- else
172
- l10n("#{elem} #{lbl}")
173
- end
174
- end
175
-
176
- def anchor_struct(lbl, container, elem, type, unnumbered = false)
177
- ret = {}
178
- ret[:label] = unnumbered == "true" ? nil : anchor_struct_label(lbl, elem)
179
- ret[:xref] = anchor_struct_xref(unnumbered == "true" ? "(??)" : lbl, elem)
180
- ret[:xref].gsub!(/ $/, "")
181
- ret[:container] = get_clause_id(container) unless container.nil?
182
- ret[:type] = type
183
- ret
184
- end
185
-
186
143
  def sequential_table_names(clause)
187
144
  c = Counter.new
188
145
  clause.xpath(ns(".//table")).each do |t|
@@ -203,7 +160,8 @@ module IsoDoc::Function
203
160
  end
204
161
  end
205
162
 
206
- FIRST_LVL_REQ = "[not(ancestor::permission or ancestor::requirement or ancestor::recommendation)]".freeze
163
+ FIRST_LVL_REQ = "[not(ancestor::permission or ancestor::requirement or "\
164
+ "ancestor::recommendation)]".freeze
207
165
 
208
166
  def sequential_permission_names(clause, klass, label)
209
167
  c = Counter.new
@@ -213,7 +171,8 @@ module IsoDoc::Function
213
171
  @anchors[t["id"]] = anchor_struct(id, t, label, klass, t["unnumbered"])
214
172
  sequential_permission_names1(t, id, "permission", @permission_lbl)
215
173
  sequential_permission_names1(t, id, "requirement", @requirement_lbl)
216
- sequential_permission_names1(t, id, "recommendation", @recommendation_lbl)
174
+ sequential_permission_names1(t, id, "recommendation",
175
+ @recommendation_lbl)
217
176
  end
218
177
  end
219
178
 
@@ -225,7 +184,8 @@ module IsoDoc::Function
225
184
  @anchors[t["id"]] = anchor_struct(id, t, label, klass, t["unnumbered"])
226
185
  sequential_permission_names1(t, id, "permission", @permission_lbl)
227
186
  sequential_permission_names1(t, id, "requirement", @requirement_lbl)
228
- sequential_permission_names1(t, id, "recommendation", @recommendation_lbl)
187
+ sequential_permission_names1(t, id, "recommendation",
188
+ @recommendation_lbl)
229
189
  end
230
190
  end
231
191
 
@@ -278,8 +238,10 @@ module IsoDoc::Function
278
238
  hierarchical_figure_names(clause, num)
279
239
  hierarchical_formula_names(clause, num)
280
240
  hierarchical_permission_names(clause, num, "permission", @permission_lbl)
281
- hierarchical_permission_names(clause, num, "requirement", @requirement_lbl)
282
- hierarchical_permission_names(clause, num, "recommendation", @recommendation_lbl)
241
+ hierarchical_permission_names(clause, num, "requirement",
242
+ @requirement_lbl)
243
+ hierarchical_permission_names(clause, num, "recommendation",
244
+ @recommendation_lbl)
283
245
  end
284
246
 
285
247
  def hierarchical_formula_names(clause, num)
@@ -301,7 +263,8 @@ module IsoDoc::Function
301
263
  @anchors[t["id"]] = anchor_struct(lbl, t, label, klass, t["unnumbered"])
302
264
  sequential_permission_names1(t, lbl, "permission", @permission_lbl)
303
265
  sequential_permission_names1(t, lbl, "requirement", @requirement_lbl)
304
- sequential_permission_names1(t, lbl, "recommendation", @recommendation_lbl)
266
+ sequential_permission_names1(t, lbl, "recommendation",
267
+ @recommendation_lbl)
305
268
  end
306
269
  end
307
270
  end
@@ -183,9 +183,12 @@ module IsoDoc::HtmlFunction
183
183
  end
184
184
 
185
185
  def htmlstylesheet
186
- stylesheet = File.read(@htmlstylesheet, encoding: "UTF-8")
186
+ #stylesheet = File.read(@htmlstylesheet, encoding: "UTF-8")
187
+ @htmlstylesheet.open
188
+ stylesheet = @htmlstylesheet.read
187
189
  xml = Nokogiri::XML("<style/>")
188
190
  xml.children.first << Nokogiri::XML::Comment.new(xml, "\n#{stylesheet}\n")
191
+ @htmlstylesheet.close!
189
192
  xml.root.to_s
190
193
  end
191
194
 
@@ -257,6 +260,8 @@ module IsoDoc::HtmlFunction
257
260
  def image_localfile(i)
258
261
  if /^data:image/.match i["src"]
259
262
  save_dataimage(i["src"], false)
263
+ elsif %r{^([A-Z]:)?/}.match i["src"]
264
+ i["src"]
260
265
  else
261
266
  File.join(@localdir, i["src"])
262
267
  end
@@ -269,10 +274,18 @@ module IsoDoc::HtmlFunction
269
274
  i["src"] = "data:image/#{type};base64,#{data}"
270
275
  end
271
276
 
272
- def move_image1(i)
277
+ def image_suffix(i)
278
+ type = i["mimetype"]&.sub(%r{^[^/*]+/}, "")
273
279
  matched = /\.(?<suffix>[^. \r\n\t]+)$/.match i["src"]
280
+ type and !type.empty? and return type
281
+ !matched.nil? and matched[:suffix] and return matched[:suffix]
282
+ "png"
283
+ end
284
+
285
+ def move_image1(i)
286
+ suffix = image_suffix(i)
274
287
  uuid = UUIDTools::UUID.random_create.to_s
275
- fname = "#{uuid}.#{matched[:suffix]}"
288
+ fname = "#{uuid}.#{suffix}"
276
289
  new_full_filename = File.join(tmpimagedir, fname)
277
290
  local_filename = image_localfile(i)
278
291
  FileUtils.cp local_filename, new_full_filename
@@ -1,3 +1,3 @@
1
1
  module IsoDoc
2
- VERSION = "1.0.7".freeze
2
+ VERSION = "1.0.8".freeze
3
3
  end
@@ -1,5 +1,15 @@
1
1
  module IsoDoc::WordFunction
2
2
  module Body
3
+ def define_head(head, filename, _dir)
4
+ head.style do |style|
5
+ loc = File.join(File.dirname(__FILE__), "..", "base_style",
6
+ "metanorma_word.scss")
7
+ stylesheet = File.read(loc, encoding: "utf-8")
8
+ style.comment "\n#{stylesheet}\n"
9
+ end
10
+ super
11
+ end
12
+
3
13
  def anchor_names(docxml)
4
14
  super
5
15
  renumber_footnotes(docxml)
@@ -56,7 +66,7 @@ module IsoDoc::WordFunction
56
66
  classtype = "MsoCommentText" if in_comment
57
67
  classtype = "Sourcecode" if @annotation
58
68
  classtype
59
- end
69
+ end
60
70
 
61
71
  def remove_bottom_border(td)
62
72
  td["style"] =
@@ -72,7 +82,8 @@ module IsoDoc::WordFunction
72
82
  t.at(".//tr").xpath("./td | ./th").each do |td|
73
83
  cols += (td["colspan"] ? td["colspan"].to_i : 1)
74
84
  end
75
- style = %{border-top:0pt;mso-border-top-alt:0pt;border-bottom:#{SW1} 1.5pt;mso-border-bottom-alt:#{SW1} 1.5pt;}
85
+ style = "border-top:0pt;mso-border-top-alt:0pt;"\
86
+ "border-bottom:#{SW1} 1.5pt;mso-border-bottom-alt:#{SW1} 1.5pt;"
76
87
  tfoot.add_child("<tr><td colspan='#{cols}' style='#{style}'/></tr>")
77
88
  tfoot.xpath(".//td").last
78
89
  end
@@ -81,10 +92,10 @@ module IsoDoc::WordFunction
81
92
  style = td.name == "th" ? "font-weight:bold;" : ""
82
93
  rowmax = td["rowspan"] ? row + td["rowspan"].to_i - 1 : row
83
94
  style += <<~STYLE
84
- border-top:#{row.zero? ? "#{SW1} 1.5pt;" : 'none;'}
85
- mso-border-top-alt:#{row.zero? ? "#{SW1} 1.5pt;" : 'none;'}
86
- border-bottom:#{SW1} #{rowmax == totalrows ? '1.5' : '1.0'}pt;
87
- mso-border-bottom-alt:#{SW1} #{rowmax == totalrows ? '1.5' : '1.0'}pt;
95
+ border-top:#{row.zero? ? "#{SW1} 1.5pt;" : 'none;'}
96
+ mso-border-top-alt:#{row.zero? ? "#{SW1} 1.5pt;" : 'none;'}
97
+ border-bottom:#{SW1} #{rowmax == totalrows ? '1.5' : '1.0'}pt;
98
+ mso-border-bottom-alt:#{SW1} #{rowmax == totalrows ? '1.5' : '1.0'}pt;
88
99
  STYLE
89
100
  { rowspan: td["rowspan"], colspan: td["colspan"],
90
101
  align: td["align"], style: style.gsub(/\n/, "") }
@@ -99,7 +110,8 @@ module IsoDoc::WordFunction
99
110
  def page_break(out)
100
111
  out.p do |p|
101
112
  p.br **{ clear: "all",
102
- style: "mso-special-character:line-break;page-break-before:always" }
113
+ style: "mso-special-character:line-break;"\
114
+ "page-break-before:always" }
103
115
  end
104
116
  end
105
117
 
@@ -233,8 +245,8 @@ module IsoDoc::WordFunction
233
245
  def example_table_attr(node)
234
246
  super.merge({
235
247
  style: "mso-table-lspace:15.0cm;margin-left:423.0pt;"\
236
- "mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-bspace:14.2pt;"\
237
- "mso-table-anchor-vertical:paragraph;mso-table-anchor-horizontal:column;"\
248
+ "mso-table-rspace:15.0cm;margin-right:423.0pt;"\
249
+ "mso-table-anchor-horizontal:column;"\
238
250
  "mso-table-overlap:never;border-collapse:collapse;"
239
251
  })
240
252
  end
@@ -243,8 +255,8 @@ module IsoDoc::WordFunction
243
255
  super.merge(attr_code({
244
256
  summary: node["summary"],
245
257
  style: "mso-table-lspace:15.0cm;margin-left:423.0pt;"\
246
- "mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-bspace:14.2pt;"\
247
- "mso-table-anchor-vertical:paragraph;mso-table-anchor-horizontal:column;"\
258
+ "mso-table-rspace:15.0cm;margin-right:423.0pt;"\
259
+ "mso-table-anchor-horizontal:column;"\
248
260
  "mso-table-overlap:never;border-spacing:0;border-width:1px;"
249
261
  }))
250
262
  end
@@ -252,7 +264,7 @@ module IsoDoc::WordFunction
252
264
  def table_parse(node, out)
253
265
  @in_table = true
254
266
  table_title_parse(node, out)
255
- out.div **{ align: "center" } do |div|
267
+ out.div **{ align: "center", class: "table_container" } do |div|
256
268
  div.table **make_table_attr(node) do |t|
257
269
  thead_parse(node, t)
258
270
  tbody_parse(node, t)
@@ -40,10 +40,12 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
40
40
  def toWord(result, filename, dir, header)
41
41
  result = populate_template(result, :word)
42
42
  result = from_xhtml(word_cleanup(to_xhtml(result)))
43
- Html2Doc.process(result, filename: filename, stylesheet: @wordstylesheet,
44
- header_file: header, dir: dir,
43
+ Html2Doc.process(result, filename: filename, stylesheet: @wordstylesheet&.path,
44
+ header_file: header&.path, dir: dir,
45
45
  asciimathdelims: [@openmathdelim, @closemathdelim],
46
46
  liststyles: { ul: @ulstyle, ol: @olstyle })
47
+ header&.unlink
48
+ @wordstylesheet&.unlink
47
49
  end
48
50
 
49
51
  def word_admonition_images(docxml)
@@ -90,9 +92,9 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
90
92
  def list_add(xpath, lvl)
91
93
  xpath.each do |list|
92
94
  (list.xpath(".//li") - list.xpath(".//ol//li | .//ul//li")).each do |l|
93
- l.xpath("./p | ./div/p").each_with_index do |p, i|
94
- next if p == 0
95
- p["class"] = "ListContLevel#{lvl}"
95
+ l.xpath("./p | ./div").each_with_index do |p, i|
96
+ next if i == 0
97
+ p.wrap(%{<div class="ListContLevel#{lvl}"/>})
96
98
  end
97
99
  list_add(l.xpath(".//ul") - l.xpath(".//ul//ul | .//ol//ul"), lvl + 1)
98
100
  list_add(l.xpath(".//ol") - l.xpath(".//ul//ol | .//ol//ol"), lvl + 1)
@@ -107,16 +109,20 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
107
109
  end
108
110
  end
109
111
 
112
+ =begin
110
113
  EMPTY_PARA = "<p style='margin-top:0cm;margin-right:0cm;"\
111
114
  "margin-bottom:0cm;margin-left:0.0pt;margin-bottom:.0001pt;"\
112
115
  "line-height:1.0pt;mso-line-height-rule:exactly'>"\
113
116
  "<span lang=EN-GB style='display:none;mso-hide:all'>&nbsp;</span></p>"
114
117
 
115
- def word_table_separator(docxml)
116
- docxml.xpath("//table").each do |t|
117
- next unless t&.next_element&.name == "table"
118
+ def table_after_table(docxml)
119
+ docxml.xpath("//table[following-sibling::*[1]/self::table]").each do |t|
118
120
  t.add_next_sibling(EMPTY_PARA)
119
121
  end
122
+ end
123
+ =end
124
+
125
+ def word_table_separator(docxml)
120
126
  docxml.xpath("//p[@class = 'TableTitle']").each do |t|
121
127
  next unless t.children.empty?
122
128
  t["style"] = t["style"].sub(/;?$/, ";font-size:0pt;")
@@ -171,10 +177,14 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
171
177
  meta = @meta.get
172
178
  meta[:filename] = filename
173
179
  params = meta.map { |k, v| [k.to_s, v] }.to_h
174
- headerfile = "header.html"
175
- File.open(headerfile, "w:UTF-8") { |f| f.write(template.render(params)) }
176
- @files_to_delete << headerfile
177
- headerfile
180
+ #headerfile = "header.html"
181
+ #File.open(headerfile, "w:UTF-8") { |f| f.write(template.render(params)) }
182
+ #@files_to_delete << headerfile
183
+ #headerfile
184
+ Tempfile.open(%w(header html), :encoding => "utf-8") do |f|
185
+ f.write(template.render(params))
186
+ f
187
+ end
178
188
  end
179
189
 
180
190
  def word_toc_entry(toclevel, heading)
Binary file
@@ -37,7 +37,7 @@ RSpec.describe IsoDoc do
37
37
  </iso-standard>
38
38
  INPUT
39
39
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
40
- <head/>
40
+ <head><style/></head>
41
41
  <body lang="EN-US" link="blue" vlink="#954F72">
42
42
  <div class="WordSection1">
43
43
  <p>&#160;</p>
@@ -195,7 +195,7 @@ INPUT
195
195
  </iso-standard>
196
196
  INPUT
197
197
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
198
- <head/>
198
+ <head><style/></head>
199
199
  <body lang="EN-US" link="blue" vlink="#954F72">
200
200
  <div class="WordSection1">
201
201
  <p>&#160;</p>
@@ -283,7 +283,7 @@ B</pre>
283
283
  end
284
284
 
285
285
  it "processes figures (Word)" do
286
- expect(xmlpp(strip_guid(IsoDoc::WordConvert.new({}).convert("test", <<~"INPUT", true)))).to be_equivalent_to xmlpp(<<~"OUTPUT")
286
+ expect(xmlpp(strip_guid(IsoDoc::WordConvert.new({}).convert("test", <<~"INPUT", true).sub(/['"][^'".]+\.gif['"]/, "'_.gif'")))).to be_equivalent_to xmlpp(<<~"OUTPUT")
287
287
  <iso-standard xmlns="http://riboseinc.com/isoxml">
288
288
  <preface><foreword>
289
289
  <figure id="figureA-1">
@@ -307,7 +307,7 @@ B</pre>
307
307
  </iso-standard>
308
308
  INPUT
309
309
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
310
- <head/>
310
+ <head><style/></head>
311
311
  <body lang="EN-US" link="blue" vlink="#954F72">
312
312
  <div class="WordSection1">
313
313
  <p>&#160;</p>
@@ -321,7 +321,7 @@ B</pre>
321
321
 
322
322
  <img src="rice_images/rice_image1.png" height="20" width="30" alt="alttext" title="titletext"/>
323
323
  <img src="rice_images/rice_image1.png"/>
324
- <img src="test_images/_.gif"/>
324
+ <img src="_.gif"/>
325
325
  <a href="#_" class="TableFootnoteRef">a</a><aside><div id="ftn_"><span><span id="_" class="TableFootnoteRef">a</span><span style="mso-tab-count:1">&#160; </span></span>
326
326
  <p id="_">The time <span class="stem">(#(t_90)#)</span> was estimated to be 18,2 min for this example.</p>
327
327
  </div></aside>
@@ -449,7 +449,7 @@ B</pre>
449
449
  </iso-standard>
450
450
  INPUT
451
451
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
452
- <head/>
452
+ <head><style/></head>
453
453
  <body lang="EN-US" link="blue" vlink="#954F72">
454
454
  <div class="WordSection1">
455
455
  <p>&#160;</p>
@@ -668,7 +668,7 @@ World</p>
668
668
  </iso-standard>
669
669
  INPUT
670
670
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
671
- <head/>
671
+ <head><style/></head>
672
672
  <body lang="EN-US" link="blue" vlink="#954F72">
673
673
  <div class="WordSection1">
674
674
  <p>&#160;</p>
@@ -60,7 +60,7 @@ RSpec.describe IsoDoc do
60
60
  </iso-standard>
61
61
  INPUT
62
62
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
63
- <head/>
63
+ <head><style/></head>
64
64
  <body lang="EN-US" link="blue" vlink="#954F72">
65
65
  <div class="WordSection1">
66
66
  <p>&#160;</p>
@@ -194,7 +194,7 @@ RSpec.describe IsoDoc do
194
194
  </iso-standard>
195
195
  INPUT
196
196
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
197
- <head/>
197
+ <head><style/></head>
198
198
  <body lang="EN-US" link="blue" vlink="#954F72">
199
199
  <div class="WordSection1">
200
200
  <p>&#160;</p>
@@ -60,6 +60,7 @@ RSpec.describe IsoDoc do
60
60
  expect(File.exist?("test.doc")).to be true
61
61
  word = File.read("test.doc")
62
62
  expect(word).to match(/one empty stylesheet/)
63
+ expect(word).to match(/div\.table_container/)
63
64
  end
64
65
 
65
66
  it "generates HTML output docs with null configuration from file" do
@@ -552,6 +553,7 @@ TOCLEVEL
552
553
  <preface><foreword>
553
554
  <figure id="_">
554
555
  <name>Split-it-right sample divider</name>
556
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
555
557
  <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
556
558
  <image src="spec/assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
557
559
  <image src="spec/assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
@@ -570,6 +572,7 @@ TOCLEVEL
570
572
  <h1 class="ForewordTitle">Foreword</h1>
571
573
  <div id="_" class="figure">
572
574
  <img src="test_htmlimages/_.png" height="776" width="922" />
575
+ <img src="test_htmlimages/_.png" height="776" width="922" />
573
576
  <img src="test_htmlimages/_.png" height="800" width="53" />
574
577
  <img src="test_htmlimages/_.png" height="83" width="99" />
575
578
  <img src="" height="800" width="800" />
@@ -581,6 +584,43 @@ TOCLEVEL
581
584
 
582
585
  end
583
586
 
587
+
588
+ it "moves images in HTML with no file suffix" do
589
+ FileUtils.rm_f "test.html"
590
+ FileUtils.rm_rf "test_htmlimages"
591
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.css"}).convert("test", <<~"INPUT", false)
592
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
593
+ <preface><foreword>
594
+ <figure id="_">
595
+ <name>Split-it-right sample divider</name>
596
+ <image src="spec/assets/rice_image1" id="_" mimetype="image/png"/>
597
+ <image src="spec/assets/rice_image1" id="_" mimetype="image/*"/>
598
+ <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
599
+ </figure>
600
+ </foreword></preface>
601
+ </iso-standard>
602
+ INPUT
603
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
604
+ sub(%r{</main>.*$}m, "</main>")
605
+ expect(`ls test_htmlimages`).to match(/\.png$/)
606
+ expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
607
+ <main class='main-section'>
608
+ <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
609
+ <br/>
610
+ <div>
611
+ <h1 class='ForewordTitle'>Foreword</h1>
612
+ <div id='_' class='figure'>
613
+ <img src='test_htmlimages/_.png' height='776' width='922'/>
614
+ <img src='test_htmlimages/_.png' height='776' width='922'/>
615
+ <img src='' height='800' width='800'/>
616
+ <p class='FigureTitle' style='text-align:center;'>Figure 1&#xA0;&#x2014; Split-it-right sample divider</p>
617
+ </div>
618
+ </div>
619
+ <p class='zzSTDTitle1'/>
620
+ </main>
621
+ OUTPUT
622
+ end
623
+
584
624
  it "moves images in HTML, using relative file location" do
585
625
  FileUtils.rm_f "spec/test.html"
586
626
  FileUtils.rm_rf "spec/test_htmlimages"
@@ -755,7 +795,8 @@ TOCLEVEL
755
795
  <li><p>A</p>
756
796
  <p>B</p></li>
757
797
  <li><ol><li><p>C</p>
758
- <p>D</p></li>
798
+ <p>D</p>
799
+ <sourcecode>E</sourcecode></li>
759
800
  </ol></li>
760
801
  </ul>
761
802
  <ol>
@@ -773,33 +814,57 @@ TOCLEVEL
773
814
  word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
774
815
  sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
775
816
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
776
- <div class="WordSection2" xmlns:m="m">
777
- <p class="MsoNormal">
778
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
817
+ <div class='WordSection2' xmlns:m='m'>
818
+ <p class='MsoNormal'>
819
+ <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
820
+ </p>
821
+ <div>
822
+ <h1 class='ForewordTitle'>Foreword</h1>
823
+ <p class='MsoListParagraphCxSpFirst'>
824
+ A
825
+ <div class='ListContLevel1'>
826
+ <p class='MsoNormal'>B</p>
827
+ </div>
828
+ </p>
829
+ <p class='MsoListParagraphCxSpLast'>
830
+ <p class='MsoListParagraphCxSpFirst'>
831
+ C
832
+ <div class='ListContLevel2'>
833
+ <p class='MsoNormal'>D</p>
834
+ </div>
835
+ <div class='ListContLevel2'>
836
+ <p class='Sourcecode'>E</p>
837
+ </div>
779
838
  </p>
780
- <div>
781
- <h1 class="ForewordTitle">Foreword</h1>
782
-
783
- <p class="MsoListParagraphCxSpFirst">A
784
- <p class="ListContLevel1">B</p></p>
785
- <p class="MsoListParagraphCxSpLast"><p class="MsoListParagraphCxSpFirst">C
786
- <p class="ListContLevel2">D</p></p>
787
- </p>
788
-
789
-
790
- <p class="MsoListParagraphCxSpFirst">A1
791
- <p class="ListContLevel1">B1</p></p>
792
- <p class="MsoListParagraphCxSpLast">C1
793
- <div class="formula"><a name="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62" id="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62"></a><p class="ListContLevel2"><span class="stem"><m:oMath>
794
- <m:r><m:t>D1</m:t></m:r>
795
-
796
- </m:oMath>
797
- </span><span style="mso-tab-count:1">&#xA0; </span>(1)</p></div>
798
- </p>
799
-
839
+ </p>
840
+ <p class='MsoListParagraphCxSpFirst'>
841
+ A1
842
+ <div class='ListContLevel1'>
843
+ <p class='MsoNormal'>B1</p>
800
844
  </div>
801
- <p class="MsoNormal">&#xA0;</p>
802
- </div>
845
+ </p>
846
+ <p class='MsoListParagraphCxSpLast'>
847
+ C1
848
+ <div class='ListContLevel2'>
849
+ <div class='formula'>
850
+ <a name='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62' id='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62'/>
851
+ <p class='MsoNormal'>
852
+ <span class='stem'>
853
+ <m:oMath>
854
+ <m:r>
855
+ <m:t>D1</m:t>
856
+ </m:r>
857
+ </m:oMath>
858
+ </span>
859
+ <span style='mso-tab-count:1'>&#xA0; </span>
860
+ (1)
861
+ </p>
862
+ </div>
863
+ </div>
864
+ </p>
865
+ </div>
866
+ <p class='MsoNormal'>&#xA0;</p>
867
+ </div>
803
868
  OUTPUT
804
869
  end
805
870
 
@@ -953,8 +1018,8 @@ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="
953
1018
  <div>
954
1019
  <h1 class="ForewordTitle">Foreword</h1>
955
1020
  <p class="TableTitle" style="text-align:center;font-size:0pt;">&#xA0;</p>
956
- <div align="center">
957
- <table class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-bspace:14.2pt;mso-table-anchor-vertical:paragraph;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;"><a name="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7"></a>
1021
+ <div align="center" class="table_container">
1022
+ <table class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;"><a name="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7"></a>
958
1023
  <thead>
959
1024
  <tr>
960
1025
  <td rowspan="2" style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;">
@@ -1008,8 +1073,8 @@ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="
1008
1073
  <div>
1009
1074
  <h1 class='ForewordTitle'>Foreword</h1>
1010
1075
  <p class='TableTitle' style='text-align:center;font-size:0pt;'>&#xA0;</p>
1011
- <div align='center'>
1012
- <table class='MsoISOTable' style='mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-bspace:14.2pt;mso-table-anchor-vertical:paragraph;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1076
+ <div align='center' class="table_container">
1077
+ <table class='MsoISOTable' style='mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1013
1078
  <a name='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7' id='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7'/>
1014
1079
  <thead>
1015
1080
  <tr>
@@ -247,7 +247,7 @@ OUTPUT
247
247
  </iso-standard>
248
248
  INPUT
249
249
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
250
- <head/>
250
+ <head><style/></head>
251
251
  <body lang="EN-US" link="blue" vlink="#954F72">
252
252
  <div class="WordSection1">
253
253
  <p>&#160;</p>
@@ -199,7 +199,7 @@ RSpec.describe IsoDoc do
199
199
  </iso-standard>
200
200
  INPUT
201
201
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
202
- <head/>
202
+ <head><style/></head>
203
203
  <body lang="EN-US" link="blue" vlink="#954F72">
204
204
  <div class="WordSection1">
205
205
  <p>&#160;</p>
@@ -210,8 +210,8 @@ RSpec.describe IsoDoc do
210
210
  <div>
211
211
  <h1 class="ForewordTitle">Foreword</h1>
212
212
  <p class="TableTitle" style="text-align:center;">Table 1</p>
213
- <div align="center">
214
- <table id="tableD-0" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-bspace:14.2pt;mso-table-anchor-vertical:paragraph;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;">
213
+ <div align="center" class="table_container">
214
+ <table id="tableD-0" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;">
215
215
  <tbody>
216
216
  <tr>
217
217
  <td style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;">A</td>
@@ -220,8 +220,8 @@ RSpec.describe IsoDoc do
220
220
  </table>
221
221
  </div>
222
222
  <p class="TableTitle" style="text-align:center;">Table 2&#160;&#8212; Repeatability and reproducibility of husked rice yield</p>
223
- <div align="center">
224
- <table id="tableD-1" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-bspace:14.2pt;mso-table-anchor-vertical:paragraph;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;" title="tool tip" summary="long desc">
223
+ <div align="center" class="table_container">
224
+ <table id="tableD-1" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;" title="tool tip" summary="long desc">
225
225
  <thead>
226
226
  <tr>
227
227
  <td rowspan="2" align="left" style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;">Description</td>
@@ -55,7 +55,12 @@ END
55
55
 
56
56
  WORD_HDR = <<~END
57
57
  <html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
58
- <head/>
58
+ <head>
59
+ <style>
60
+ <!--
61
+ -->
62
+ </style>
63
+ </head>
59
64
  <body lang="EN-US" link="blue" vlink="#954F72">
60
65
  <div class="WordSection1">
61
66
  <p>&#160;</p>
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: isodoc
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.7
4
+ version: 1.0.8
5
5
  platform: ruby
6
6
  authors:
7
7
  - Ribose Inc.
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2019-11-08 00:00:00.000000000 Z
11
+ date: 2019-11-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: asciimath
@@ -326,6 +326,7 @@ files:
326
326
  - lib/isodoc/base_style/blocks.scss
327
327
  - lib/isodoc/base_style/coverpage.scss
328
328
  - lib/isodoc/base_style/defaults.scss
329
+ - lib/isodoc/base_style/metanorma_word.scss
329
330
  - lib/isodoc/base_style/nav.scss
330
331
  - lib/isodoc/base_style/reset.scss
331
332
  - lib/isodoc/base_style/typography.scss
@@ -345,6 +346,7 @@ files:
345
346
  - lib/isodoc/function/terms.rb
346
347
  - lib/isodoc/function/to_word_html.rb
347
348
  - lib/isodoc/function/utils.rb
349
+ - lib/isodoc/function/xref_anchor.rb
348
350
  - lib/isodoc/function/xref_counter.rb
349
351
  - lib/isodoc/function/xref_gen.rb
350
352
  - lib/isodoc/function/xref_sect_gen.rb
@@ -369,6 +371,7 @@ files:
369
371
  - spec/assets/htmlintro.html
370
372
  - spec/assets/i18n.yaml
371
373
  - spec/assets/iso.xml
374
+ - spec/assets/rice_image1
372
375
  - spec/assets/rice_image1.png
373
376
  - spec/assets/scripts.html
374
377
  - spec/assets/std.css