hexapdf 0.16.0 → 0.17.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (216) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +62 -0
  3. data/LICENSE +1 -1
  4. data/README.md +11 -2
  5. data/Rakefile +2 -1
  6. data/examples/002-graphics.rb +4 -4
  7. data/lib/hexapdf/cli/batch.rb +1 -1
  8. data/lib/hexapdf/cli/command.rb +10 -1
  9. data/lib/hexapdf/cli/files.rb +1 -1
  10. data/lib/hexapdf/cli/fonts.rb +145 -0
  11. data/lib/hexapdf/cli/form.rb +27 -26
  12. data/lib/hexapdf/cli/image2pdf.rb +1 -1
  13. data/lib/hexapdf/cli/images.rb +1 -10
  14. data/lib/hexapdf/cli/info.rb +1 -1
  15. data/lib/hexapdf/cli/inspect.rb +1 -1
  16. data/lib/hexapdf/cli/merge.rb +1 -1
  17. data/lib/hexapdf/cli/modify.rb +1 -1
  18. data/lib/hexapdf/cli/optimize.rb +1 -1
  19. data/lib/hexapdf/cli/split.rb +1 -1
  20. data/lib/hexapdf/cli/watermark.rb +1 -1
  21. data/lib/hexapdf/cli.rb +3 -1
  22. data/lib/hexapdf/composer.rb +1 -1
  23. data/lib/hexapdf/configuration.rb +10 -1
  24. data/lib/hexapdf/content/canvas.rb +653 -166
  25. data/lib/hexapdf/content/color_space.rb +18 -2
  26. data/lib/hexapdf/content/graphic_object/arc.rb +111 -12
  27. data/lib/hexapdf/content/graphic_object/endpoint_arc.rb +67 -1
  28. data/lib/hexapdf/content/graphic_object/geom2d.rb +14 -1
  29. data/lib/hexapdf/content/graphic_object/solid_arc.rb +1 -1
  30. data/lib/hexapdf/content/graphic_object.rb +1 -1
  31. data/lib/hexapdf/content/graphics_state.rb +1 -1
  32. data/lib/hexapdf/content/operator.rb +1 -1
  33. data/lib/hexapdf/content/parser.rb +1 -1
  34. data/lib/hexapdf/content/processor.rb +1 -1
  35. data/lib/hexapdf/content/transformation_matrix.rb +1 -1
  36. data/lib/hexapdf/content.rb +1 -1
  37. data/lib/hexapdf/data_dir.rb +1 -1
  38. data/lib/hexapdf/dictionary.rb +1 -1
  39. data/lib/hexapdf/dictionary_fields.rb +8 -3
  40. data/lib/hexapdf/document/files.rb +3 -3
  41. data/lib/hexapdf/document/fonts.rb +1 -1
  42. data/lib/hexapdf/document/images.rb +1 -1
  43. data/lib/hexapdf/document/pages.rb +1 -1
  44. data/lib/hexapdf/document.rb +1 -1
  45. data/lib/hexapdf/encryption/aes.rb +1 -1
  46. data/lib/hexapdf/encryption/arc4.rb +1 -1
  47. data/lib/hexapdf/encryption/fast_aes.rb +1 -1
  48. data/lib/hexapdf/encryption/fast_arc4.rb +1 -1
  49. data/lib/hexapdf/encryption/identity.rb +1 -1
  50. data/lib/hexapdf/encryption/ruby_aes.rb +1 -1
  51. data/lib/hexapdf/encryption/ruby_arc4.rb +1 -1
  52. data/lib/hexapdf/encryption/security_handler.rb +1 -1
  53. data/lib/hexapdf/encryption/standard_security_handler.rb +1 -1
  54. data/lib/hexapdf/encryption.rb +1 -1
  55. data/lib/hexapdf/error.rb +1 -1
  56. data/lib/hexapdf/filter/ascii85_decode.rb +1 -1
  57. data/lib/hexapdf/filter/ascii_hex_decode.rb +1 -1
  58. data/lib/hexapdf/filter/crypt.rb +1 -1
  59. data/lib/hexapdf/filter/encryption.rb +1 -1
  60. data/lib/hexapdf/filter/flate_decode.rb +1 -1
  61. data/lib/hexapdf/filter/lzw_decode.rb +1 -1
  62. data/lib/hexapdf/filter/pass_through.rb +1 -1
  63. data/lib/hexapdf/filter/predictor.rb +1 -1
  64. data/lib/hexapdf/filter/run_length_decode.rb +1 -1
  65. data/lib/hexapdf/filter.rb +1 -1
  66. data/lib/hexapdf/font/cmap/parser.rb +1 -1
  67. data/lib/hexapdf/font/cmap/writer.rb +1 -1
  68. data/lib/hexapdf/font/cmap.rb +1 -1
  69. data/lib/hexapdf/font/encoding/base.rb +1 -1
  70. data/lib/hexapdf/font/encoding/difference_encoding.rb +1 -1
  71. data/lib/hexapdf/font/encoding/glyph_list.rb +1 -1
  72. data/lib/hexapdf/font/encoding/mac_expert_encoding.rb +1 -1
  73. data/lib/hexapdf/font/encoding/mac_roman_encoding.rb +1 -1
  74. data/lib/hexapdf/font/encoding/standard_encoding.rb +1 -1
  75. data/lib/hexapdf/font/encoding/symbol_encoding.rb +1 -1
  76. data/lib/hexapdf/font/encoding/win_ansi_encoding.rb +1 -1
  77. data/lib/hexapdf/font/encoding/zapf_dingbats_encoding.rb +1 -1
  78. data/lib/hexapdf/font/encoding.rb +1 -1
  79. data/lib/hexapdf/font/invalid_glyph.rb +1 -1
  80. data/lib/hexapdf/font/true_type/builder.rb +1 -1
  81. data/lib/hexapdf/font/true_type/font.rb +1 -1
  82. data/lib/hexapdf/font/true_type/optimizer.rb +1 -1
  83. data/lib/hexapdf/font/true_type/subsetter.rb +1 -1
  84. data/lib/hexapdf/font/true_type/table/cmap.rb +1 -1
  85. data/lib/hexapdf/font/true_type/table/cmap_subtable.rb +1 -1
  86. data/lib/hexapdf/font/true_type/table/directory.rb +1 -1
  87. data/lib/hexapdf/font/true_type/table/glyf.rb +1 -1
  88. data/lib/hexapdf/font/true_type/table/head.rb +1 -1
  89. data/lib/hexapdf/font/true_type/table/hhea.rb +1 -1
  90. data/lib/hexapdf/font/true_type/table/hmtx.rb +1 -1
  91. data/lib/hexapdf/font/true_type/table/kern.rb +1 -1
  92. data/lib/hexapdf/font/true_type/table/loca.rb +1 -1
  93. data/lib/hexapdf/font/true_type/table/maxp.rb +1 -1
  94. data/lib/hexapdf/font/true_type/table/name.rb +1 -1
  95. data/lib/hexapdf/font/true_type/table/os2.rb +1 -1
  96. data/lib/hexapdf/font/true_type/table/post.rb +1 -1
  97. data/lib/hexapdf/font/true_type/table.rb +1 -1
  98. data/lib/hexapdf/font/true_type.rb +1 -1
  99. data/lib/hexapdf/font/true_type_wrapper.rb +1 -1
  100. data/lib/hexapdf/font/type1/afm_parser.rb +1 -1
  101. data/lib/hexapdf/font/type1/character_metrics.rb +1 -1
  102. data/lib/hexapdf/font/type1/font.rb +1 -1
  103. data/lib/hexapdf/font/type1/font_metrics.rb +1 -1
  104. data/lib/hexapdf/font/type1/pfb_parser.rb +1 -1
  105. data/lib/hexapdf/font/type1.rb +1 -1
  106. data/lib/hexapdf/font/type1_wrapper.rb +1 -1
  107. data/lib/hexapdf/font_loader/from_configuration.rb +1 -1
  108. data/lib/hexapdf/font_loader/from_file.rb +1 -1
  109. data/lib/hexapdf/font_loader/standard14.rb +1 -1
  110. data/lib/hexapdf/font_loader.rb +1 -1
  111. data/lib/hexapdf/image_loader/jpeg.rb +1 -1
  112. data/lib/hexapdf/image_loader/pdf.rb +1 -1
  113. data/lib/hexapdf/image_loader/png.rb +1 -1
  114. data/lib/hexapdf/image_loader.rb +1 -1
  115. data/lib/hexapdf/importer.rb +1 -1
  116. data/lib/hexapdf/layout/box.rb +4 -2
  117. data/lib/hexapdf/layout/frame.rb +1 -1
  118. data/lib/hexapdf/layout/image_box.rb +1 -1
  119. data/lib/hexapdf/layout/inline_box.rb +1 -1
  120. data/lib/hexapdf/layout/line.rb +1 -1
  121. data/lib/hexapdf/layout/numeric_refinements.rb +1 -1
  122. data/lib/hexapdf/layout/style.rb +40 -2
  123. data/lib/hexapdf/layout/text_box.rb +1 -1
  124. data/lib/hexapdf/layout/text_fragment.rb +1 -1
  125. data/lib/hexapdf/layout/text_layouter.rb +1 -1
  126. data/lib/hexapdf/layout/text_shaper.rb +1 -1
  127. data/lib/hexapdf/layout/width_from_polygon.rb +2 -2
  128. data/lib/hexapdf/layout.rb +1 -1
  129. data/lib/hexapdf/name_tree_node.rb +1 -1
  130. data/lib/hexapdf/number_tree_node.rb +1 -1
  131. data/lib/hexapdf/object.rb +1 -1
  132. data/lib/hexapdf/parser.rb +4 -1
  133. data/lib/hexapdf/pdf_array.rb +1 -1
  134. data/lib/hexapdf/rectangle.rb +1 -1
  135. data/lib/hexapdf/reference.rb +1 -1
  136. data/lib/hexapdf/revision.rb +1 -1
  137. data/lib/hexapdf/revisions.rb +1 -1
  138. data/lib/hexapdf/serializer.rb +1 -1
  139. data/lib/hexapdf/stream.rb +1 -1
  140. data/lib/hexapdf/task/dereference.rb +1 -1
  141. data/lib/hexapdf/task/optimize.rb +1 -1
  142. data/lib/hexapdf/task.rb +1 -1
  143. data/lib/hexapdf/tokenizer.rb +1 -1
  144. data/lib/hexapdf/type/acro_form/appearance_generator.rb +14 -7
  145. data/lib/hexapdf/type/acro_form/button_field.rb +53 -28
  146. data/lib/hexapdf/type/acro_form/choice_field.rb +1 -1
  147. data/lib/hexapdf/type/acro_form/field.rb +21 -2
  148. data/lib/hexapdf/type/acro_form/form.rb +48 -29
  149. data/lib/hexapdf/type/acro_form/text_field.rb +2 -2
  150. data/lib/hexapdf/type/acro_form/variable_text_field.rb +17 -9
  151. data/lib/hexapdf/type/acro_form.rb +1 -1
  152. data/lib/hexapdf/type/action.rb +1 -1
  153. data/lib/hexapdf/type/actions/go_to.rb +1 -1
  154. data/lib/hexapdf/type/actions/go_to_r.rb +1 -1
  155. data/lib/hexapdf/type/actions/launch.rb +1 -1
  156. data/lib/hexapdf/type/actions/uri.rb +1 -1
  157. data/lib/hexapdf/type/actions.rb +1 -1
  158. data/lib/hexapdf/type/annotation.rb +1 -1
  159. data/lib/hexapdf/type/annotations/link.rb +1 -1
  160. data/lib/hexapdf/type/annotations/markup_annotation.rb +1 -1
  161. data/lib/hexapdf/type/annotations/text.rb +1 -1
  162. data/lib/hexapdf/type/annotations/widget.rb +2 -2
  163. data/lib/hexapdf/type/annotations.rb +1 -1
  164. data/lib/hexapdf/type/catalog.rb +1 -1
  165. data/lib/hexapdf/type/cid_font.rb +1 -1
  166. data/lib/hexapdf/type/embedded_file.rb +1 -1
  167. data/lib/hexapdf/type/file_specification.rb +1 -1
  168. data/lib/hexapdf/type/font.rb +1 -1
  169. data/lib/hexapdf/type/font_descriptor.rb +1 -1
  170. data/lib/hexapdf/type/font_simple.rb +1 -1
  171. data/lib/hexapdf/type/font_true_type.rb +1 -1
  172. data/lib/hexapdf/type/font_type0.rb +1 -1
  173. data/lib/hexapdf/type/font_type1.rb +1 -1
  174. data/lib/hexapdf/type/font_type3.rb +1 -1
  175. data/lib/hexapdf/type/form.rb +1 -1
  176. data/lib/hexapdf/type/graphics_state_parameter.rb +1 -1
  177. data/lib/hexapdf/type/icon_fit.rb +1 -1
  178. data/lib/hexapdf/type/image.rb +1 -1
  179. data/lib/hexapdf/type/info.rb +1 -1
  180. data/lib/hexapdf/type/names.rb +1 -1
  181. data/lib/hexapdf/type/object_stream.rb +1 -1
  182. data/lib/hexapdf/type/page.rb +15 -1
  183. data/lib/hexapdf/type/page_tree_node.rb +1 -1
  184. data/lib/hexapdf/type/resources.rb +1 -1
  185. data/lib/hexapdf/type/trailer.rb +1 -1
  186. data/lib/hexapdf/type/viewer_preferences.rb +1 -1
  187. data/lib/hexapdf/type/xref_stream.rb +1 -1
  188. data/lib/hexapdf/type.rb +1 -1
  189. data/lib/hexapdf/utils/bit_field.rb +1 -1
  190. data/lib/hexapdf/utils/bit_stream.rb +1 -1
  191. data/lib/hexapdf/utils/graphics_helpers.rb +1 -1
  192. data/lib/hexapdf/utils/lru_cache.rb +1 -1
  193. data/lib/hexapdf/utils/math_helpers.rb +1 -1
  194. data/lib/hexapdf/utils/object_hash.rb +1 -1
  195. data/lib/hexapdf/utils/pdf_doc_encoding.rb +1 -1
  196. data/lib/hexapdf/utils/sorted_tree_node.rb +1 -1
  197. data/lib/hexapdf/version.rb +2 -2
  198. data/lib/hexapdf/writer.rb +1 -1
  199. data/lib/hexapdf/xref_section.rb +1 -1
  200. data/lib/hexapdf.rb +1 -1
  201. data/test/hexapdf/content/graphic_object/test_arc.rb +16 -7
  202. data/test/hexapdf/content/test_canvas.rb +63 -0
  203. data/test/hexapdf/layout/test_box.rb +2 -0
  204. data/test/hexapdf/layout/test_style.rb +11 -0
  205. data/test/hexapdf/layout/test_width_from_polygon.rb +1 -0
  206. data/test/hexapdf/test_dictionary_fields.rb +9 -0
  207. data/test/hexapdf/test_parser.rb +11 -0
  208. data/test/hexapdf/test_writer.rb +2 -2
  209. data/test/hexapdf/type/acro_form/test_appearance_generator.rb +2 -1
  210. data/test/hexapdf/type/acro_form/test_button_field.rb +19 -13
  211. data/test/hexapdf/type/acro_form/test_field.rb +12 -0
  212. data/test/hexapdf/type/acro_form/test_form.rb +4 -0
  213. data/test/hexapdf/type/acro_form/test_text_field.rb +6 -0
  214. data/test/hexapdf/type/acro_form/test_variable_text_field.rb +15 -4
  215. data/test/hexapdf/type/test_page.rb +11 -0
  216. metadata +4 -3
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -247,14 +247,33 @@ module HexaPDF
247
247
  #
248
248
  # Yields each widget, i.e. visual representation, of this field.
249
249
  #
250
+ # Widgets can be associated to the field in three ways:
251
+ #
252
+ # 1. The widget can be embedded in the field itself.
253
+ # 2. One or more widgets are defined as children of this field.
254
+ # 3. Widgets of *another field instance with the same full field name*.
255
+ #
256
+ # Because of possibility 3 all fields of the form have to be searched to check whether there
257
+ # is another field with the same full field name.
258
+ #
250
259
  # See: HexaPDF::Type::Annotations::Widget
251
- def each_widget # :yields: widget
260
+ def each_widget(direct_only: false, &block) # :yields: widget
252
261
  return to_enum(__method__) unless block_given?
262
+
253
263
  if embedded_widget?
254
264
  yield(document.wrap(self))
255
265
  elsif terminal_field?
256
266
  self[:Kids]&.each {|kid| yield(document.wrap(kid)) }
257
267
  end
268
+
269
+ unless direct_only
270
+ my_name = full_field_name
271
+ document.acro_form&.each_field do |field|
272
+ next if field.full_field_name != my_name || field == self
273
+ field.each_widget(direct_only: true, &block)
274
+ end
275
+ end
276
+
258
277
  self
259
278
  end
260
279
 
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -96,7 +96,7 @@ module HexaPDF
96
96
  def find_root_fields
97
97
  result = []
98
98
  document.pages.each do |page|
99
- page[:Annots]&.each do |annot|
99
+ page.each_annotation do |annot|
100
100
  if !annot.key?(:Parent) && annot.key?(:FT)
101
101
  result << document.wrap(annot, type: :XXAcroFormField, subtype: annot[:FT])
102
102
  elsif annot.key?(:Parent)
@@ -157,18 +157,27 @@ module HexaPDF
157
157
  # The optional keyword arguments allow setting often used properties of the field:
158
158
  #
159
159
  # +font+::
160
- # The font that should be used for the text of the field. If +font_size+ is specified
161
- # but +font+ isn't, the font Helvetica is used.
160
+ # The font that should be used for the text of the field. If +font_size+ or
161
+ # +font_options+ is specified but +font+ isn't, the font Helvetica is used.
162
+ #
163
+ # If no font is set on the text field, the default font properties of the AcroForm form
164
+ # are used. Note that field specific or form specific font properties have to be set.
165
+ # Otherwise there will be an error when trying to generate a visual representation of
166
+ # the field value.
167
+ #
168
+ # +font_options+::
169
+ # A hash with font options like :variant that should be used.
162
170
  #
163
171
  # +font_size+::
164
- # The font size that should be used. If +font+ is specified but +font_size+ isn't, font
165
- # size defaults to 0 (= auto-sizing).
172
+ # The font size that should be used. If +font+ or +font_options+ is specified but
173
+ # +font_size+ isn't, font size defaults to 0 (= auto-sizing).
166
174
  #
167
175
  # +align+::
168
176
  # The alignment of the text, either :left, :center or :right.
169
- def create_text_field(name, font: nil, font_size: nil, align: nil)
177
+ def create_text_field(name, font: nil, font_options: nil, font_size: nil, align: nil)
170
178
  create_field(name, :Tx) do |field|
171
- apply_variable_text_properties(field, font: font, font_size: font_size, align: align)
179
+ apply_variable_text_properties(field, font: font, font_options: font_options,
180
+ font_size: font_size, align: align)
172
181
  end
173
182
  end
174
183
 
@@ -179,10 +188,12 @@ module HexaPDF
179
188
  #
180
189
  # The optional keyword arguments allow setting often used properties of the field, see
181
190
  # #create_text_field for details.
182
- def create_multiline_text_field(name, font: nil, font_size: nil, align: nil)
191
+ def create_multiline_text_field(name, font: nil, font_options: nil, font_size: nil,
192
+ align: nil)
183
193
  create_field(name, :Tx) do |field|
184
194
  field.initialize_as_multiline_text_field
185
- apply_variable_text_properties(field, font: font, font_size: font_size, align: align)
195
+ apply_variable_text_properties(field, font: font, font_options: font_options,
196
+ font_size: font_size, align: align)
186
197
  end
187
198
  end
188
199
 
@@ -196,10 +207,12 @@ module HexaPDF
196
207
  #
197
208
  # The optional keyword arguments allow setting often used properties of the field, see
198
209
  # #create_text_field for details.
199
- def create_comb_text_field(name, max_chars:, font: nil, font_size: nil, align: nil)
210
+ def create_comb_text_field(name, max_chars:, font: nil, font_options: nil, font_size: nil,
211
+ align: nil)
200
212
  create_field(name, :Tx) do |field|
201
213
  field.initialize_as_comb_text_field
202
- apply_variable_text_properties(field, font: font, font_size: font_size, align: align)
214
+ apply_variable_text_properties(field, font: font, font_options: font_options,
215
+ font_size: font_size, align: align)
203
216
  field[:MaxLen] = max_chars
204
217
  end
205
218
  end
@@ -211,10 +224,11 @@ module HexaPDF
211
224
  #
212
225
  # The optional keyword arguments allow setting often used properties of the field, see
213
226
  # #create_text_field for details.
214
- def create_file_select_field(name, font: nil, font_size: nil, align: nil)
227
+ def create_file_select_field(name, font: nil, font_options: nil, font_size: nil, align: nil)
215
228
  create_field(name, :Tx) do |field|
216
229
  field.initialize_as_file_select_field
217
- apply_variable_text_properties(field, font: font, font_size: font_size, align: align)
230
+ apply_variable_text_properties(field, font: font, font_options: font_options,
231
+ font_size: font_size, align: align)
218
232
  end
219
233
  end
220
234
 
@@ -225,10 +239,11 @@ module HexaPDF
225
239
  #
226
240
  # The optional keyword arguments allow setting often used properties of the field, see
227
241
  # #create_text_field for details.
228
- def create_password_field(name, font: nil, font_size: nil, align: nil)
242
+ def create_password_field(name, font: nil, font_options: nil, font_size: nil, align: nil)
229
243
  create_field(name, :Tx) do |field|
230
244
  field.initialize_as_password_field
231
- apply_variable_text_properties(field, font: font, font_size: font_size, align: align)
245
+ apply_variable_text_properties(field, font: font, font_options: font_options,
246
+ font_size: font_size, align: align)
232
247
  end
233
248
  end
234
249
 
@@ -262,15 +277,16 @@ module HexaPDF
262
277
  # If set to +true+, the combo box allows entering an arbitrary value in addition to
263
278
  # selecting one of the provided option items.
264
279
  #
265
- # +font+, +font_size+ and +align+::
280
+ # +font+, +font_options+, +font_size+ and +align+::
266
281
  # See #create_text_field
267
- def create_combo_box(name, option_items: nil, editable: nil, font: nil, font_size: nil,
268
- align: nil)
282
+ def create_combo_box(name, option_items: nil, editable: nil, font: nil,
283
+ font_options: nil, font_size: nil, align: nil)
269
284
  create_field(name, :Ch) do |field|
270
285
  field.initialize_as_combo_box
271
286
  field.option_items = option_items if option_items
272
287
  field.flag(:edit) if editable
273
- apply_variable_text_properties(field, font: font, font_size: font_size, align: align)
288
+ apply_variable_text_properties(field, font: font, font_options: font_options,
289
+ font_size: font_size, align: align)
274
290
  end
275
291
  end
276
292
 
@@ -287,15 +303,16 @@ module HexaPDF
287
303
  # +multi_select+::
288
304
  # If set to +true+, the list box allows selecting multiple items instead of only one.
289
305
  #
290
- # +font+, +font_size+ and +align+::
306
+ # +font+, +font_options+, +font_size+ and +align+::
291
307
  # See #create_text_field.
292
- def create_list_box(name, option_items: nil, multi_select: nil, font: nil, font_size: nil,
293
- align: nil)
308
+ def create_list_box(name, option_items: nil, multi_select: nil, font: nil,
309
+ font_options: nil, font_size: nil, align: nil)
294
310
  create_field(name, :Ch) do |field|
295
311
  field.initialize_as_list_box
296
312
  field.option_items = option_items if option_items
297
313
  field.flag(:multi_select) if multi_select
298
- apply_variable_text_properties(field, font: font, font_size: font_size, align: align)
314
+ apply_variable_text_properties(field, font: font, font_options: font_options,
315
+ font_size: font_size, align: align)
299
316
  end
300
317
  end
301
318
 
@@ -402,9 +419,12 @@ module HexaPDF
402
419
  end
403
420
 
404
421
  # Applies the given variable field properties to the field.
405
- def apply_variable_text_properties(field, font: nil, font_size: nil, align: nil)
406
- if font || font_size
407
- field.set_default_appearance_string(font: font || 'Helvetica', font_size: font_size || 0)
422
+ def apply_variable_text_properties(field, font: nil, font_options: nil, font_size: nil,
423
+ align: nil)
424
+ if font || font_options || font_size
425
+ field.set_default_appearance_string(font: font || 'Helvetica',
426
+ font_options: font_options || {},
427
+ font_size: font_size || 0)
408
428
  end
409
429
  field.text_alignment(align) if align
410
430
  end
@@ -417,8 +437,7 @@ module HexaPDF
417
437
  yield("When the field /DA is present, the field /DR must also be present")
418
438
  return
419
439
  end
420
- font_name = nil
421
- HexaPDF::Content::Parser.parse(da) {|obj, params| font_name = params[0] if obj == :Tf }
440
+ font_name, _ = VariableTextField.parse_appearance_string(da)
422
441
  if font_name && !(self[:DR][:Font] && self[:DR][:Font][font_name])
423
442
  yield("The font specified in /DA is not in the /DR resource dictionary")
424
443
  end
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -165,7 +165,7 @@ module HexaPDF
165
165
  if flagged?(:password)
166
166
  raise HexaPDF::Error, "Storing a field value for a password field is not allowed"
167
167
  end
168
- str = str.gsub(/[[:space:]]/, ' ') if concrete_field_type == :single_line_text_field
168
+ str = str.gsub(/[[:space:]]/, ' ') if str && concrete_field_type == :single_line_text_field
169
169
  self[:V] = str
170
170
  update_widgets
171
171
  end
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -61,6 +61,16 @@ module HexaPDF
61
61
 
62
62
  UNSET_ARG = ::Object.new # :nodoc:
63
63
 
64
+ # Parses the given appearance string. If no block is given, the appearance string is
65
+ # searched for font name and font size both of which are returend. Otherwise the block is
66
+ # called with each found content stream operator and has to handle them themselves.
67
+ def self.parse_appearance_string(appearance_string, &block) # :yield: obj, params
68
+ font_params = nil
69
+ block ||= lambda {|obj, params| font_params = params.dup if obj == :Tf }
70
+ HexaPDF::Content::Parser.parse(appearance_string.sub(/\/\//, '/'), &block)
71
+ font_params
72
+ end
73
+
64
74
  # :call-seq:
65
75
  # field.text_alignment -> alignment
66
76
  # field.text_alignment(alignment) -> field
@@ -93,9 +103,12 @@ module HexaPDF
93
103
  #
94
104
  # The default argument values are a sane default. If +font_size+ is set to 0, the font size
95
105
  # is calculated using the height/width of the field.
96
- def set_default_appearance_string(font: 'Helvetica', font_size: 0)
106
+ #
107
+ # Use the +font_options+ hash to provide font options like :variant, see
108
+ # HexaPDF::Document::Fonts#add.
109
+ def set_default_appearance_string(font: 'Helvetica', font_options: {}, font_size: 0)
97
110
  name = document.acro_form(create: true).default_resources.
98
- add_font(document.fonts.add(font).pdf_object)
111
+ add_font(document.fonts.add(font, **font_options).pdf_object)
99
112
  self[:DA] = "0 g /#{name} #{font_size} Tf"
100
113
  end
101
114
 
@@ -107,12 +120,7 @@ module HexaPDF
107
120
  def parse_default_appearance_string
108
121
  da = self[:DA] || (document.acro_form && document.acro_form[:DA])
109
122
  raise HexaPDF::Error, "No default appearance string set" unless da
110
-
111
- font_params = nil
112
- HexaPDF::Content::Parser.parse(da) do |obj, params|
113
- font_params = params.dup if obj == :Tf
114
- end
115
- font_params
123
+ self.class.parse_appearance_string(da)
116
124
  end
117
125
 
118
126
  end
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -308,7 +308,7 @@ module HexaPDF
308
308
  size = 0
309
309
  color = [0]
310
310
  if (da = self[:DA] || field[:DA])
311
- HexaPDF::Content::Parser.parse(da) do |obj, params|
311
+ HexaPDF::Type::AcroForm::VariableTextField.parse_appearance_string(da) do |obj, params|
312
312
  case obj
313
313
  when :rg, :g, :k then color = params.dup
314
314
  when :Tf then size = params[1]
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -4,7 +4,7 @@
4
4
  # This file is part of HexaPDF.
5
5
  #
6
6
  # HexaPDF - A Versatile PDF Creation and Manipulation Library For Ruby
7
- # Copyright (C) 2014-2020 Thomas Leitner
7
+ # Copyright (C) 2014-2021 Thomas Leitner
8
8
  #
9
9
  # HexaPDF is free software: you can redistribute it and/or modify it
10
10
  # under the terms of the GNU Affero General Public License version 3 as
@@ -465,6 +465,20 @@ module HexaPDF
465
465
  document.wrap(dict, stream: stream)
466
466
  end
467
467
 
468
+ # :call-seq:
469
+ # page.each_annotation {|annotation| block} -> page
470
+ # page.each_annotation -> Enumerator
471
+ #
472
+ # Yields each annotation of this page.
473
+ def each_annotation
474
+ return to_enum(__method__) unless block_given?
475
+ self[:Annots]&.each do |annotation|
476
+ next unless annotation
477
+ yield(document.wrap(annotation, type: :Annot))
478
+ end
479
+ self
480
+ end
481
+
468
482
  # Flattens all or the given annotations of the page. Returns an array with all the annotations
469
483
  # that couldn't be flattened because they don't have an appearance stream.
470
484
  #