@pdfme/pdf-lib 6.0.3 → 6.0.5-dev.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (449) hide show
  1. package/{src/api/Embeddable.ts → dist/api/Embeddable.d.ts} +1 -1
  2. package/dist/api/PDFDocument.d.ts +778 -0
  3. package/dist/api/PDFDocumentOptions.d.ts +38 -0
  4. package/dist/api/PDFEmbeddedFile.d.ts +38 -0
  5. package/dist/api/PDFEmbeddedPage.d.ts +73 -0
  6. package/dist/api/PDFFont.d.ts +94 -0
  7. package/dist/api/PDFImage.d.ts +95 -0
  8. package/dist/api/PDFJavaScript.d.ts +38 -0
  9. package/dist/api/PDFPage.d.ts +910 -0
  10. package/dist/api/PDFPageOptions.d.ts +172 -0
  11. package/dist/api/StandardFonts.d.ts +16 -0
  12. package/dist/api/colors.d.ts +34 -0
  13. package/dist/api/errors.d.ts +42 -0
  14. package/dist/api/form/PDFButton.d.ts +137 -0
  15. package/dist/api/form/PDFCheckBox.d.ts +142 -0
  16. package/dist/api/form/PDFDropdown.d.ts +402 -0
  17. package/dist/api/form/PDFField.d.ts +203 -0
  18. package/dist/api/form/PDFForm.d.ts +411 -0
  19. package/dist/api/form/PDFOptionList.d.ts +335 -0
  20. package/dist/api/form/PDFRadioGroup.d.ts +252 -0
  21. package/dist/api/form/PDFSignature.d.ts +29 -0
  22. package/dist/api/form/PDFTextField.d.ts +537 -0
  23. package/dist/api/form/appearances.d.ts +41 -0
  24. package/dist/api/image/alignment.d.ts +5 -0
  25. package/dist/api/objects.d.ts +4 -0
  26. package/dist/api/operations.d.ts +226 -0
  27. package/dist/api/operators.d.ts +90 -0
  28. package/dist/api/rotations.d.ts +38 -0
  29. package/dist/api/sizes.d.ts +52 -0
  30. package/dist/api/svg.d.ts +70 -0
  31. package/dist/api/svgPath.d.ts +2 -0
  32. package/dist/api/text/alignment.d.ts +5 -0
  33. package/dist/api/text/layout.d.ts +54 -0
  34. package/dist/core/PDFContext.d.ts +84 -0
  35. package/dist/core/PDFObjectCopier.d.ts +37 -0
  36. package/dist/core/acroform/PDFAcroButton.d.ts +21 -0
  37. package/dist/core/acroform/PDFAcroCheckBox.d.ts +13 -0
  38. package/dist/core/acroform/PDFAcroChoice.d.ts +20 -0
  39. package/dist/core/acroform/PDFAcroComboBox.d.ts +9 -0
  40. package/dist/core/acroform/PDFAcroField.d.ts +36 -0
  41. package/dist/core/acroform/PDFAcroForm.d.ts +20 -0
  42. package/dist/core/acroform/PDFAcroListBox.d.ts +9 -0
  43. package/dist/core/acroform/PDFAcroNonTerminal.d.ts +13 -0
  44. package/dist/core/acroform/PDFAcroPushButton.d.ts +9 -0
  45. package/dist/core/acroform/PDFAcroRadioButton.d.ts +13 -0
  46. package/{src/core/acroform/PDFAcroSignature.ts → dist/core/acroform/PDFAcroSignature.d.ts} +2 -4
  47. package/dist/core/acroform/PDFAcroTerminal.d.ts +16 -0
  48. package/dist/core/acroform/PDFAcroText.d.ts +22 -0
  49. package/dist/core/acroform/flags.d.ts +141 -0
  50. package/dist/core/acroform/utils.d.ts +6 -0
  51. package/dist/core/annotation/AppearanceCharacteristics.d.ts +33 -0
  52. package/dist/core/annotation/BorderStyle.d.ts +11 -0
  53. package/dist/core/annotation/PDFAnnotation.d.ts +51 -0
  54. package/dist/core/annotation/PDFWidgetAnnotation.d.ts +26 -0
  55. package/dist/core/annotation/flags.d.ts +79 -0
  56. package/dist/core/crypto.d.ts +95 -0
  57. package/dist/core/document/PDFCrossRefSection.d.ts +27 -0
  58. package/dist/core/document/PDFHeader.d.ts +10 -0
  59. package/dist/core/document/PDFTrailer.d.ts +9 -0
  60. package/dist/core/document/PDFTrailerDict.d.ts +10 -0
  61. package/dist/core/embedders/CMap.d.ts +3 -0
  62. package/dist/core/embedders/CustomFontEmbedder.d.ts +44 -0
  63. package/dist/core/embedders/CustomFontSubsetEmbedder.d.ts +20 -0
  64. package/dist/core/embedders/FileEmbedder.d.ts +33 -0
  65. package/dist/core/embedders/FontFlags.d.ts +13 -0
  66. package/dist/core/embedders/JavaScriptEmbedder.d.ts +10 -0
  67. package/dist/core/embedders/JpegEmbedder.d.ts +23 -0
  68. package/dist/core/embedders/PDFPageEmbedder.d.ts +37 -0
  69. package/dist/core/embedders/PngEmbedder.d.ts +19 -0
  70. package/dist/core/embedders/StandardFontEmbedder.d.ts +36 -0
  71. package/dist/core/errors.d.ts +94 -0
  72. package/{src/core/index.ts → dist/core/index.d.ts} +1 -17
  73. package/dist/core/interactive/ViewerPreferences.d.ts +347 -0
  74. package/dist/core/objects/PDFArray.d.ts +63 -0
  75. package/dist/core/objects/PDFBool.d.ts +13 -0
  76. package/dist/core/objects/PDFDict.d.ts +62 -0
  77. package/dist/core/objects/PDFHexString.d.ts +16 -0
  78. package/dist/core/objects/PDFInvalidObject.d.ts +11 -0
  79. package/dist/core/objects/PDFName.d.ts +41 -0
  80. package/dist/core/objects/PDFNull.d.ts +10 -0
  81. package/dist/core/objects/PDFNumber.d.ts +15 -0
  82. package/dist/core/objects/PDFObject.d.ts +8 -0
  83. package/dist/core/objects/PDFRawStream.d.ts +16 -0
  84. package/dist/core/objects/PDFRef.d.ts +13 -0
  85. package/dist/core/objects/PDFStream.d.ts +16 -0
  86. package/dist/core/objects/PDFString.d.ts +16 -0
  87. package/dist/core/operators/PDFOperator.d.ts +19 -0
  88. package/dist/core/operators/PDFOperatorNames.d.ts +76 -0
  89. package/dist/core/parser/BaseParser.d.ts +14 -0
  90. package/dist/core/parser/ByteStream.d.ts +26 -0
  91. package/dist/core/parser/PDFObjectParser.d.ts +31 -0
  92. package/dist/core/parser/PDFObjectStreamParser.d.ts +13 -0
  93. package/dist/core/parser/PDFParser.d.ts +46 -0
  94. package/dist/core/parser/PDFXRefStreamParser.d.ts +21 -0
  95. package/dist/core/streams/Ascii85Stream.d.ts +9 -0
  96. package/dist/core/streams/AsciiHexStream.d.ts +9 -0
  97. package/dist/core/streams/DecodeStream.d.ts +26 -0
  98. package/dist/core/streams/DecryptStream.d.ts +12 -0
  99. package/dist/core/streams/FlateStream.d.ts +13 -0
  100. package/dist/core/streams/LZWStream.d.ts +12 -0
  101. package/dist/core/streams/RunLengthStream.d.ts +8 -0
  102. package/dist/core/streams/Stream.d.ts +34 -0
  103. package/dist/core/streams/decode.d.ts +3 -0
  104. package/dist/core/structures/PDFCatalog.d.ts +27 -0
  105. package/dist/core/structures/PDFContentStream.d.ts +15 -0
  106. package/dist/core/structures/PDFCrossRefStream.d.ts +53 -0
  107. package/dist/core/structures/PDFFlateStream.d.ts +13 -0
  108. package/dist/core/structures/PDFObjectStream.d.ts +20 -0
  109. package/dist/core/structures/PDFPageLeaf.d.ts +54 -0
  110. package/dist/core/structures/PDFPageTree.d.ts +41 -0
  111. package/dist/core/syntax/CharCodes.d.ts +61 -0
  112. package/dist/core/syntax/Delimiters.d.ts +1 -0
  113. package/dist/core/syntax/Irregular.d.ts +1 -0
  114. package/dist/core/syntax/Keywords.d.ts +22 -0
  115. package/dist/core/syntax/Numeric.d.ts +3 -0
  116. package/dist/core/syntax/Whitespace.d.ts +1 -0
  117. package/dist/core/writers/PDFStreamWriter.d.ts +19 -0
  118. package/dist/core/writers/PDFWriter.d.ts +29 -0
  119. package/dist/index.js +19124 -0
  120. package/dist/index.js.map +1 -0
  121. package/dist/types/fontkit.d.ts +597 -0
  122. package/{src/types/index.ts → dist/types/index.d.ts} +8 -13
  123. package/{src/types/matrix.ts → dist/types/matrix.d.ts} +1 -2
  124. package/dist/utils/Cache.d.ts +10 -0
  125. package/dist/utils/arrays.d.ts +16 -0
  126. package/dist/utils/async.d.ts +5 -0
  127. package/dist/utils/base64.d.ts +10 -0
  128. package/dist/utils/elements/Arc.d.ts +22 -0
  129. package/dist/utils/elements/Circle.d.ts +14 -0
  130. package/dist/utils/elements/Ellipse.d.ts +20 -0
  131. package/dist/utils/elements/GraphElement.d.ts +6 -0
  132. package/dist/utils/elements/Line.d.ts +23 -0
  133. package/dist/utils/elements/Plot.d.ts +11 -0
  134. package/dist/utils/elements/Point.d.ts +18 -0
  135. package/dist/utils/elements/Rectangle.d.ts +21 -0
  136. package/dist/utils/elements/Segment.d.ts +19 -0
  137. package/dist/utils/errors.d.ts +1 -0
  138. package/dist/utils/intersections.d.ts +9 -0
  139. package/dist/utils/maths.d.ts +45 -0
  140. package/dist/utils/numbers.d.ts +23 -0
  141. package/dist/utils/objects.d.ts +15 -0
  142. package/dist/utils/pdfDocEncoding.d.ts +7 -0
  143. package/dist/utils/png.d.ts +17 -0
  144. package/dist/utils/rng.d.ts +13 -0
  145. package/dist/utils/strings.d.ts +25 -0
  146. package/{src/utils/unicode.ts → dist/utils/unicode.d.ts} +8 -195
  147. package/dist/utils/validators.d.ts +26 -0
  148. package/package.json +6 -1
  149. package/__tests__/api/PDFDocument.spec.ts +0 -576
  150. package/__tests__/api/PDFImage.spec.ts +0 -60
  151. package/__tests__/api/PDFPage.spec.ts +0 -151
  152. package/__tests__/api/form/PDFCheckBox.spec.ts +0 -71
  153. package/__tests__/api/form/PDFDropdown.spec.ts +0 -118
  154. package/__tests__/api/form/PDFForm.spec.ts +0 -370
  155. package/__tests__/api/form/PDFOptionList.spec.ts +0 -104
  156. package/__tests__/api/form/PDFRadioGroup.spec.ts +0 -183
  157. package/__tests__/api/form/PDFTextField.spec.ts +0 -148
  158. package/__tests__/api/svgPath.spec.ts +0 -153
  159. package/__tests__/api/text/layout.spec.ts +0 -166
  160. package/__tests__/core/PDFContext.spec.ts +0 -194
  161. package/__tests__/core/PDFObjectCopier.spec.ts +0 -421
  162. package/__tests__/core/acroform/PDFAcroField.spec.ts +0 -98
  163. package/__tests__/core/acroform/PDFAcroTerminal.spec.ts +0 -39
  164. package/__tests__/core/annotation/PDFWidgetAnnotation.spec.ts +0 -40
  165. package/__tests__/core/document/PDFCrossRefSection.spec.ts +0 -88
  166. package/__tests__/core/document/PDFHeader.spec.ts +0 -22
  167. package/__tests__/core/document/PDFTrailer.spec.ts +0 -28
  168. package/__tests__/core/document/PDFTrailerDict.spec.ts +0 -24
  169. package/__tests__/core/embedders/CMap.spec.ts +0 -47
  170. package/__tests__/core/embedders/CustomFontEmbedder.spec.ts +0 -96
  171. package/__tests__/core/embedders/CustomFontSubsetEmbedder.spec.ts +0 -62
  172. package/__tests__/core/embedders/FileEmbedder.spec.ts +0 -54
  173. package/__tests__/core/embedders/JpegEmbedder.spec.ts +0 -67
  174. package/__tests__/core/embedders/PDFPageEmbedder.spec.ts +0 -65
  175. package/__tests__/core/embedders/PngEmbedder.spec.ts +0 -87
  176. package/__tests__/core/embedders/StandardFontEmbedder.spec.ts +0 -79
  177. package/__tests__/core/embedders/data/SourceHanSerifJP-Regular.otf.cmap +0 -16096
  178. package/__tests__/core/embedders/data/Ubuntu-R.ttf.cmap +0 -1211
  179. package/__tests__/core/objects/PDFArray.spec.ts +0 -134
  180. package/__tests__/core/objects/PDFBool.spec.ts +0 -42
  181. package/__tests__/core/objects/PDFDict.spec.ts +0 -195
  182. package/__tests__/core/objects/PDFHexString.spec.ts +0 -168
  183. package/__tests__/core/objects/PDFInvalidObject.spec.ts +0 -32
  184. package/__tests__/core/objects/PDFName.spec.ts +0 -122
  185. package/__tests__/core/objects/PDFNull.spec.ts +0 -30
  186. package/__tests__/core/objects/PDFNumber.spec.ts +0 -50
  187. package/__tests__/core/objects/PDFObject.spec.ts +0 -29
  188. package/__tests__/core/objects/PDFRawStream.spec.ts +0 -45
  189. package/__tests__/core/objects/PDFRef.spec.ts +0 -60
  190. package/__tests__/core/objects/PDFString.spec.ts +0 -237
  191. package/__tests__/core/operators/PDFOperator.spec.ts +0 -77
  192. package/__tests__/core/parser/PDFObjectParser.spec.ts +0 -730
  193. package/__tests__/core/parser/PDFObjectStreamParser.spec.ts +0 -158
  194. package/__tests__/core/parser/PDFParser.spec.ts +0 -398
  195. package/__tests__/core/parser/PDFXRefStreamParser.spec.ts +0 -187
  196. package/__tests__/core/parser/data/object-stream-invalid +0 -2
  197. package/__tests__/core/parser/data/object-stream1 +0 -16
  198. package/__tests__/core/parser/data/object-stream2 +0 -10
  199. package/__tests__/core/parser/data/object-stream3 +0 -0
  200. package/__tests__/core/parser/data/object-stream4 +0 -0
  201. package/__tests__/core/parser/data/xref-stream1 +0 -0
  202. package/__tests__/core/parser/data/xref-stream2 +0 -0
  203. package/__tests__/core/parser/data/xref-stream3 +0 -0
  204. package/__tests__/core/parser/data/xref-stream4 +0 -0
  205. package/__tests__/core/streams/Ascii85Stream.spec.ts +0 -20
  206. package/__tests__/core/streams/AsciiHexStream.spec.ts +0 -20
  207. package/__tests__/core/streams/FlateStream.spec.ts +0 -20
  208. package/__tests__/core/streams/LZWStream.spec.ts +0 -20
  209. package/__tests__/core/streams/RunLengthStream.spec.ts +0 -20
  210. package/__tests__/core/streams/Stream.spec.ts +0 -128
  211. package/__tests__/core/streams/data/ascii85/1.decoded +0 -0
  212. package/__tests__/core/streams/data/ascii85/1.encoded +0 -43
  213. package/__tests__/core/streams/data/asciihex/1.decoded +0 -1
  214. package/__tests__/core/streams/data/asciihex/1.encoded +0 -1
  215. package/__tests__/core/streams/data/asciihex/2.decoded +0 -7
  216. package/__tests__/core/streams/data/asciihex/2.encoded +0 -1
  217. package/__tests__/core/streams/data/flate/1.corrupt.encoded +0 -1
  218. package/__tests__/core/streams/data/flate/1.decoded +0 -0
  219. package/__tests__/core/streams/data/flate/1.encoded +0 -2
  220. package/__tests__/core/streams/data/flate/2.decoded +0 -33
  221. package/__tests__/core/streams/data/flate/2.encoded +0 -0
  222. package/__tests__/core/streams/data/flate/3.decoded +0 -15
  223. package/__tests__/core/streams/data/flate/3.encoded +0 -0
  224. package/__tests__/core/streams/data/flate/4.decoded +0 -16
  225. package/__tests__/core/streams/data/flate/4.encoded +0 -0
  226. package/__tests__/core/streams/data/flate/5.decoded +0 -0
  227. package/__tests__/core/streams/data/flate/5.encoded +0 -0
  228. package/__tests__/core/streams/data/flate/6.decoded +0 -17
  229. package/__tests__/core/streams/data/flate/6.encoded +0 -0
  230. package/__tests__/core/streams/data/flate/7.decoded +0 -20
  231. package/__tests__/core/streams/data/flate/7.encoded +0 -1
  232. package/__tests__/core/streams/data/lzw/1.decoded +0 -0
  233. package/__tests__/core/streams/data/lzw/1.encoded +0 -0
  234. package/__tests__/core/streams/data/lzw/2.decoded +0 -0
  235. package/__tests__/core/streams/data/lzw/2.encoded +0 -0
  236. package/__tests__/core/streams/data/lzw/3.decoded +0 -14
  237. package/__tests__/core/streams/data/lzw/3.encoded +0 -2
  238. package/__tests__/core/streams/data/lzw/4.decoded +0 -14
  239. package/__tests__/core/streams/data/lzw/4.encoded +0 -2
  240. package/__tests__/core/streams/data/runlength/1.decoded +0 -1
  241. package/__tests__/core/streams/data/runlength/1.encoded +0 -1
  242. package/__tests__/core/streams/data/runlength/2.decoded +0 -1
  243. package/__tests__/core/streams/data/runlength/2.encoded +0 -1
  244. package/__tests__/core/streams/data/runlength/3.decoded +0 -0
  245. package/__tests__/core/streams/data/runlength/3.encoded +0 -0
  246. package/__tests__/core/streams/data/runlength/4.decoded +0 -1
  247. package/__tests__/core/streams/data/runlength/4.encoded +0 -1
  248. package/__tests__/core/streams/data/runlength/5.decoded +0 -1
  249. package/__tests__/core/streams/data/runlength/5.encoded +0 -1
  250. package/__tests__/core/streams/data/runlength/empty.encoded +0 -1
  251. package/__tests__/core/structures/PDFCatalog.spec.ts +0 -108
  252. package/__tests__/core/structures/PDFContentStream.spec.ts +0 -117
  253. package/__tests__/core/structures/PDFCrossRefStream.spec.ts +0 -145
  254. package/__tests__/core/structures/PDFObjectStream.spec.ts +0 -138
  255. package/__tests__/core/structures/PDFPageLeaf.spec.ts +0 -355
  256. package/__tests__/core/structures/PDFPageTree.spec.ts +0 -592
  257. package/__tests__/core/writers/PDFStreamWriter.spec.ts +0 -71
  258. package/__tests__/core/writers/PDFWriter.spec.ts +0 -144
  259. package/__tests__/core/writers/data/stream-writer-1.pdf +0 -0
  260. package/__tests__/index.test.ts +0 -12
  261. package/__tests__/utils/base64.spec.ts +0 -61
  262. package/__tests__/utils/data/simple.pdf +0 -201
  263. package/__tests__/utils/data/simple.pdf.base64 +0 -1
  264. package/__tests__/utils/pdfDocEncoding.spec.ts +0 -82
  265. package/__tests__/utils/png.spec.ts +0 -53
  266. package/__tests__/utils/rng.spec.ts +0 -14
  267. package/__tests__/utils/strings.spec.ts +0 -98
  268. package/__tests__/utils/unicode.spec.ts +0 -337
  269. package/assets/fonts/source_hans_jp/SourceHanSerifJP-Regular.otf +0 -0
  270. package/assets/fonts/ubuntu/Ubuntu-B.ttf +0 -0
  271. package/assets/fonts/ubuntu/Ubuntu-R.ttf +0 -0
  272. package/assets/images/cat_riding_unicorn.jpg +0 -0
  273. package/assets/images/cmyk_colorspace.jpg +0 -0
  274. package/assets/images/greyscale_bird.png +0 -0
  275. package/assets/images/minions_banana_alpha.png +0 -0
  276. package/assets/images/minions_banana_no_alpha.png +0 -0
  277. package/assets/images/minions_laughing.jpg +0 -0
  278. package/assets/pdfs/bixby_guide.pdf +0 -0
  279. package/assets/pdfs/encrypted_new.pdf +0 -0
  280. package/assets/pdfs/encrypted_old.pdf +0 -0
  281. package/assets/pdfs/fancy_fields.pdf +0 -0
  282. package/assets/pdfs/giraffe.pdf +0 -0
  283. package/assets/pdfs/invalid_root_ref.pdf +0 -0
  284. package/assets/pdfs/just_metadata.pdf +0 -49
  285. package/assets/pdfs/missing_endobj_keyword.pdf +0 -70
  286. package/assets/pdfs/missing_xref_trailer_dict.pdf +0 -141
  287. package/assets/pdfs/normal.pdf +0 -0
  288. package/assets/pdfs/pdf20examples/PDF 2.0 with offset start.pdf +0 -179
  289. package/assets/pdfs/stuff_following_header.pdf +0 -0
  290. package/assets/pdfs/us_constitution.pdf +0 -0
  291. package/assets/pdfs/with_comments.pdf +0 -0
  292. package/assets/pdfs/with_invalid_objects.pdf +0 -53
  293. package/assets/pdfs/with_invalid_stream_EOL.pdf +0 -0
  294. package/assets/pdfs/with_null_parent_entry.pdf +0 -0
  295. package/assets/pdfs/with_signature.pdf +0 -0
  296. package/assets/pdfs/with_update_sections.pdf +0 -0
  297. package/assets/pdfs/with_viewer_prefs.pdf +0 -0
  298. package/assets/pdfs/with_xfa_fields.pdf +0 -0
  299. package/src/api/PDFDocument.ts +0 -1389
  300. package/src/api/PDFDocumentOptions.ts +0 -45
  301. package/src/api/PDFEmbeddedFile.ts +0 -87
  302. package/src/api/PDFEmbeddedPage.ts +0 -100
  303. package/src/api/PDFFont.ts +0 -149
  304. package/src/api/PDFImage.ts +0 -143
  305. package/src/api/PDFJavaScript.ts +0 -75
  306. package/src/api/PDFPage.ts +0 -1604
  307. package/src/api/PDFPageOptions.ts +0 -175
  308. package/src/api/StandardFonts.ts +0 -16
  309. package/src/api/colors.ts +0 -109
  310. package/src/api/errors.ts +0 -110
  311. package/src/api/form/PDFButton.ts +0 -242
  312. package/src/api/form/PDFCheckBox.ts +0 -247
  313. package/src/api/form/PDFDropdown.ts +0 -637
  314. package/src/api/form/PDFField.ts +0 -491
  315. package/src/api/form/PDFForm.ts +0 -842
  316. package/src/api/form/PDFOptionList.ts +0 -555
  317. package/src/api/form/PDFRadioGroup.ts +0 -455
  318. package/src/api/form/PDFSignature.ts +0 -44
  319. package/src/api/form/PDFTextField.ts +0 -811
  320. package/src/api/form/appearances.ts +0 -655
  321. package/src/api/image/alignment.ts +0 -5
  322. package/src/api/objects.ts +0 -10
  323. package/src/api/operations.ts +0 -873
  324. package/src/api/operators.ts +0 -335
  325. package/src/api/rotations.ts +0 -84
  326. package/src/api/sizes.ts +0 -52
  327. package/src/api/svg.ts +0 -888
  328. package/src/api/svgPath.ts +0 -460
  329. package/src/api/text/alignment.ts +0 -5
  330. package/src/api/text/layout.ts +0 -328
  331. package/src/core/PDFContext.ts +0 -274
  332. package/src/core/PDFObjectCopier.ts +0 -142
  333. package/src/core/acroform/PDFAcroButton.ts +0 -104
  334. package/src/core/acroform/PDFAcroCheckBox.ts +0 -48
  335. package/src/core/acroform/PDFAcroChoice.ts +0 -143
  336. package/src/core/acroform/PDFAcroComboBox.ts +0 -21
  337. package/src/core/acroform/PDFAcroField.ts +0 -168
  338. package/src/core/acroform/PDFAcroForm.ts +0 -96
  339. package/src/core/acroform/PDFAcroListBox.ts +0 -19
  340. package/src/core/acroform/PDFAcroNonTerminal.ts +0 -33
  341. package/src/core/acroform/PDFAcroPushButton.ts +0 -21
  342. package/src/core/acroform/PDFAcroRadioButton.ts +0 -57
  343. package/src/core/acroform/PDFAcroTerminal.ts +0 -70
  344. package/src/core/acroform/PDFAcroText.ts +0 -76
  345. package/src/core/acroform/flags.ts +0 -162
  346. package/src/core/acroform/utils.ts +0 -129
  347. package/src/core/annotation/AppearanceCharacteristics.ts +0 -133
  348. package/src/core/annotation/BorderStyle.ts +0 -31
  349. package/src/core/annotation/PDFAnnotation.ts +0 -148
  350. package/src/core/annotation/PDFWidgetAnnotation.ts +0 -111
  351. package/src/core/annotation/flags.ts +0 -90
  352. package/src/core/crypto.ts +0 -1844
  353. package/src/core/document/PDFCrossRefSection.ts +0 -161
  354. package/src/core/document/PDFHeader.ts +0 -48
  355. package/src/core/document/PDFTrailer.ts +0 -48
  356. package/src/core/document/PDFTrailerDict.ts +0 -39
  357. package/src/core/embedders/CMap.ts +0 -65
  358. package/src/core/embedders/CustomFontEmbedder.ts +0 -237
  359. package/src/core/embedders/CustomFontSubsetEmbedder.ts +0 -89
  360. package/src/core/embedders/FileEmbedder.ts +0 -77
  361. package/src/core/embedders/FontFlags.ts +0 -45
  362. package/src/core/embedders/JavaScriptEmbedder.ts +0 -34
  363. package/src/core/embedders/JpegEmbedder.ts +0 -118
  364. package/src/core/embedders/PDFPageEmbedder.ts +0 -139
  365. package/src/core/embedders/PngEmbedder.ts +0 -69
  366. package/src/core/embedders/StandardFontEmbedder.ts +0 -121
  367. package/src/core/errors.ts +0 -226
  368. package/src/core/interactive/ViewerPreferences.ts +0 -565
  369. package/src/core/objects/PDFArray.ts +0 -179
  370. package/src/core/objects/PDFBool.ts +0 -53
  371. package/src/core/objects/PDFDict.ts +0 -220
  372. package/src/core/objects/PDFHexString.ts +0 -94
  373. package/src/core/objects/PDFInvalidObject.ts +0 -34
  374. package/src/core/objects/PDFName.ts +0 -152
  375. package/src/core/objects/PDFNull.ts +0 -30
  376. package/src/core/objects/PDFNumber.ts +0 -44
  377. package/src/core/objects/PDFObject.ts +0 -22
  378. package/src/core/objects/PDFRawStream.ts +0 -41
  379. package/src/core/objects/PDFRef.ts +0 -51
  380. package/src/core/objects/PDFStream.ts +0 -87
  381. package/src/core/objects/PDFString.ts +0 -118
  382. package/src/core/operators/PDFOperator.ts +0 -72
  383. package/src/core/operators/PDFOperatorNames.ts +0 -92
  384. package/src/core/parser/BaseParser.ts +0 -119
  385. package/src/core/parser/ByteStream.ts +0 -76
  386. package/src/core/parser/PDFObjectParser.ts +0 -302
  387. package/src/core/parser/PDFObjectStreamParser.ts +0 -65
  388. package/src/core/parser/PDFParser.ts +0 -363
  389. package/src/core/parser/PDFXRefStreamParser.ts +0 -129
  390. package/src/core/streams/Ascii85Stream.ts +0 -97
  391. package/src/core/streams/AsciiHexStream.ts +0 -77
  392. package/src/core/streams/DecodeStream.ts +0 -188
  393. package/src/core/streams/DecryptStream.ts +0 -49
  394. package/src/core/streams/FlateStream.ts +0 -397
  395. package/src/core/streams/LZWStream.ts +0 -157
  396. package/src/core/streams/RunLengthStream.ts +0 -55
  397. package/src/core/streams/Stream.ts +0 -126
  398. package/src/core/streams/decode.ts +0 -70
  399. package/src/core/structures/PDFCatalog.ts +0 -81
  400. package/src/core/structures/PDFContentStream.ts +0 -58
  401. package/src/core/structures/PDFCrossRefStream.ts +0 -238
  402. package/src/core/structures/PDFFlateStream.ts +0 -40
  403. package/src/core/structures/PDFObjectStream.ts +0 -91
  404. package/src/core/structures/PDFPageLeaf.ts +0 -244
  405. package/src/core/structures/PDFPageTree.ts +0 -192
  406. package/src/core/syntax/CharCodes.ts +0 -62
  407. package/src/core/syntax/Delimiters.ts +0 -14
  408. package/src/core/syntax/Irregular.ts +0 -10
  409. package/src/core/syntax/Keywords.ts +0 -57
  410. package/src/core/syntax/Numeric.ts +0 -26
  411. package/src/core/syntax/Whitespace.ts +0 -10
  412. package/src/core/writers/PDFStreamWriter.ts +0 -114
  413. package/src/core/writers/PDFWriter.ts +0 -146
  414. package/src/types/fontkit.ts +0 -643
  415. package/src/utils/Cache.ts +0 -26
  416. package/src/utils/arrays.ts +0 -153
  417. package/src/utils/async.ts +0 -8
  418. package/src/utils/base64.ts +0 -98
  419. package/src/utils/elements/Arc.ts +0 -97
  420. package/src/utils/elements/Circle.ts +0 -47
  421. package/src/utils/elements/Ellipse.ts +0 -117
  422. package/src/utils/elements/GraphElement.ts +0 -14
  423. package/src/utils/elements/Line.ts +0 -83
  424. package/src/utils/elements/Plot.ts +0 -50
  425. package/src/utils/elements/Point.ts +0 -37
  426. package/src/utils/elements/Rectangle.ts +0 -65
  427. package/src/utils/elements/Segment.ts +0 -81
  428. package/src/utils/errors.ts +0 -3
  429. package/src/utils/intersections.ts +0 -237
  430. package/src/utils/maths.ts +0 -96
  431. package/src/utils/numbers.ts +0 -55
  432. package/src/utils/objects.ts +0 -13
  433. package/src/utils/pdfDocEncoding.ts +0 -69
  434. package/src/utils/png.ts +0 -100
  435. package/src/utils/rng.ts +0 -21
  436. package/src/utils/strings.ts +0 -191
  437. package/src/utils/validators.ts +0 -192
  438. package/tsconfig.build.json +0 -14
  439. package/tsconfig.json +0 -15
  440. package/vite.config.mts +0 -39
  441. /package/{src/api/form/index.ts → dist/api/form/index.d.ts} +0 -0
  442. /package/{src/api/image/index.ts → dist/api/image/index.d.ts} +0 -0
  443. /package/{src/api/index.ts → dist/api/index.d.ts} +0 -0
  444. /package/{src/api/text/index.ts → dist/api/text/index.d.ts} +0 -0
  445. /package/{src/core/acroform/index.ts → dist/core/acroform/index.d.ts} +0 -0
  446. /package/{src/core/annotation/index.ts → dist/core/annotation/index.d.ts} +0 -0
  447. /package/{src/index.ts → dist/index.d.ts} +0 -0
  448. /package/{src/utils/elements/index.ts → dist/utils/elements/index.d.ts} +0 -0
  449. /package/{src/utils/index.ts → dist/utils/index.d.ts} +0 -0
@@ -0,0 +1,172 @@
1
+ import { Color } from './colors';
2
+ import PDFFont from './PDFFont';
3
+ import { Rotation } from './rotations';
4
+ import { FillRule, LineCapStyle } from './operators';
5
+ import type { Space, TransformationMatrix } from '../types';
6
+ interface SvgOptions {
7
+ matrix?: TransformationMatrix;
8
+ clipSpaces?: Space[];
9
+ }
10
+ export declare enum BlendMode {
11
+ Normal = "Normal",
12
+ Multiply = "Multiply",
13
+ Screen = "Screen",
14
+ Overlay = "Overlay",
15
+ Darken = "Darken",
16
+ Lighten = "Lighten",
17
+ ColorDodge = "ColorDodge",
18
+ ColorBurn = "ColorBurn",
19
+ HardLight = "HardLight",
20
+ SoftLight = "SoftLight",
21
+ Difference = "Difference",
22
+ Exclusion = "Exclusion"
23
+ }
24
+ export interface PDFPageDrawTextOptions extends SvgOptions {
25
+ color?: Color;
26
+ opacity?: number;
27
+ blendMode?: BlendMode;
28
+ font?: PDFFont;
29
+ size?: number;
30
+ rotate?: Rotation;
31
+ xSkew?: Rotation;
32
+ ySkew?: Rotation;
33
+ x?: number;
34
+ y?: number;
35
+ lineHeight?: number;
36
+ maxWidth?: number;
37
+ wordBreaks?: string[];
38
+ }
39
+ export interface PDFPageDrawImageOptions extends SvgOptions {
40
+ x?: number;
41
+ y?: number;
42
+ width?: number;
43
+ height?: number;
44
+ rotate?: Rotation;
45
+ xSkew?: Rotation;
46
+ ySkew?: Rotation;
47
+ opacity?: number;
48
+ blendMode?: BlendMode;
49
+ }
50
+ export interface PDFPageDrawPageOptions {
51
+ x?: number;
52
+ y?: number;
53
+ xScale?: number;
54
+ yScale?: number;
55
+ width?: number;
56
+ height?: number;
57
+ rotate?: Rotation;
58
+ xSkew?: Rotation;
59
+ ySkew?: Rotation;
60
+ opacity?: number;
61
+ blendMode?: BlendMode;
62
+ }
63
+ export interface PDFPageDrawSVGOptions extends SvgOptions {
64
+ x?: number;
65
+ y?: number;
66
+ scale?: number;
67
+ rotate?: Rotation;
68
+ borderWidth?: number;
69
+ color?: Color;
70
+ opacity?: number;
71
+ borderColor?: Color;
72
+ borderOpacity?: number;
73
+ borderDashArray?: number[];
74
+ borderDashPhase?: number;
75
+ borderLineCap?: LineCapStyle;
76
+ blendMode?: BlendMode;
77
+ fillRule?: FillRule;
78
+ }
79
+ export interface PDFPageDrawLineOptions extends SvgOptions {
80
+ start: {
81
+ x: number;
82
+ y: number;
83
+ };
84
+ end: {
85
+ x: number;
86
+ y: number;
87
+ };
88
+ thickness?: number;
89
+ color?: Color;
90
+ opacity?: number;
91
+ lineCap?: LineCapStyle;
92
+ dashArray?: number[];
93
+ dashPhase?: number;
94
+ blendMode?: BlendMode;
95
+ }
96
+ export interface PDFPageDrawRectangleOptions extends SvgOptions {
97
+ x?: number;
98
+ y?: number;
99
+ width?: number;
100
+ height?: number;
101
+ rotate?: Rotation;
102
+ xSkew?: Rotation;
103
+ ySkew?: Rotation;
104
+ borderWidth?: number;
105
+ color?: Color;
106
+ opacity?: number;
107
+ borderColor?: Color;
108
+ borderOpacity?: number;
109
+ borderDashArray?: number[];
110
+ borderDashPhase?: number;
111
+ borderLineCap?: LineCapStyle;
112
+ blendMode?: BlendMode;
113
+ radius?: number;
114
+ }
115
+ export interface PDFPageDrawSquareOptions extends SvgOptions {
116
+ x?: number;
117
+ y?: number;
118
+ size?: number;
119
+ rotate?: Rotation;
120
+ xSkew?: Rotation;
121
+ ySkew?: Rotation;
122
+ borderWidth?: number;
123
+ color?: Color;
124
+ opacity?: number;
125
+ borderColor?: Color;
126
+ borderOpacity?: number;
127
+ borderDashArray?: number[];
128
+ borderDashPhase?: number;
129
+ borderLineCap?: LineCapStyle;
130
+ blendMode?: BlendMode;
131
+ }
132
+ export interface PDFPageDrawEllipseOptions extends SvgOptions {
133
+ x?: number;
134
+ y?: number;
135
+ xScale?: number;
136
+ yScale?: number;
137
+ rotate?: Rotation;
138
+ color?: Color;
139
+ opacity?: number;
140
+ borderColor?: Color;
141
+ borderOpacity?: number;
142
+ borderWidth?: number;
143
+ borderDashArray?: number[];
144
+ borderDashPhase?: number;
145
+ borderLineCap?: LineCapStyle;
146
+ blendMode?: BlendMode;
147
+ }
148
+ export interface PDFPageDrawCircleOptions extends SvgOptions {
149
+ x?: number;
150
+ y?: number;
151
+ size?: number;
152
+ color?: Color;
153
+ opacity?: number;
154
+ borderColor?: Color;
155
+ borderOpacity?: number;
156
+ borderWidth?: number;
157
+ borderDashArray?: number[];
158
+ borderDashPhase?: number;
159
+ borderLineCap?: LineCapStyle;
160
+ blendMode?: BlendMode;
161
+ }
162
+ export interface PDFPageDrawSVGElementOptions {
163
+ x?: number;
164
+ y?: number;
165
+ width?: number;
166
+ height?: number;
167
+ fontSize?: number;
168
+ fonts?: {
169
+ [fontName: string]: PDFFont;
170
+ };
171
+ }
172
+ export {};
@@ -0,0 +1,16 @@
1
+ export declare enum StandardFonts {
2
+ Courier = "Courier",
3
+ CourierBold = "Courier-Bold",
4
+ CourierOblique = "Courier-Oblique",
5
+ CourierBoldOblique = "Courier-BoldOblique",
6
+ Helvetica = "Helvetica",
7
+ HelveticaBold = "Helvetica-Bold",
8
+ HelveticaOblique = "Helvetica-Oblique",
9
+ HelveticaBoldOblique = "Helvetica-BoldOblique",
10
+ TimesRoman = "Times-Roman",
11
+ TimesRomanBold = "Times-Bold",
12
+ TimesRomanItalic = "Times-Italic",
13
+ TimesRomanBoldItalic = "Times-BoldItalic",
14
+ Symbol = "Symbol",
15
+ ZapfDingbats = "ZapfDingbats"
16
+ }
@@ -0,0 +1,34 @@
1
+ export declare enum ColorTypes {
2
+ Grayscale = "Grayscale",
3
+ RGB = "RGB",
4
+ CMYK = "CMYK"
5
+ }
6
+ export interface Grayscale {
7
+ type: ColorTypes.Grayscale;
8
+ gray: number;
9
+ }
10
+ export interface RGB {
11
+ type: ColorTypes.RGB;
12
+ red: number;
13
+ green: number;
14
+ blue: number;
15
+ }
16
+ export interface CMYK {
17
+ type: ColorTypes.CMYK;
18
+ cyan: number;
19
+ magenta: number;
20
+ yellow: number;
21
+ key: number;
22
+ }
23
+ export type Color = Grayscale | RGB | CMYK;
24
+ export declare const grayscale: (gray: number) => Grayscale;
25
+ export declare const rgb: (red: number, green: number, blue: number) => RGB;
26
+ export declare const cmyk: (cyan: number, magenta: number, yellow: number, key: number) => CMYK;
27
+ export declare const colorString: (color: string) => {
28
+ rgb: Color;
29
+ alpha?: number;
30
+ };
31
+ export declare const setFillingColor: (color: Color) => import("..").PDFOperator;
32
+ export declare const setStrokingColor: (color: Color) => import("..").PDFOperator;
33
+ export declare const componentsToColor: (comps?: number[], scale?: number) => Grayscale | RGB | CMYK | undefined;
34
+ export declare const colorToComponents: (color: Color) => number[];
@@ -0,0 +1,42 @@
1
+ export declare class EncryptedPDFError extends Error {
2
+ constructor();
3
+ }
4
+ export declare class FontkitNotRegisteredError extends Error {
5
+ constructor();
6
+ }
7
+ export declare class ForeignPageError extends Error {
8
+ constructor();
9
+ }
10
+ export declare class RemovePageFromEmptyDocumentError extends Error {
11
+ constructor();
12
+ }
13
+ export declare class NoSuchFieldError extends Error {
14
+ constructor(name: string);
15
+ }
16
+ export declare class UnexpectedFieldTypeError extends Error {
17
+ constructor(name: string, expected: any, actual: any);
18
+ }
19
+ export declare class MissingOnValueCheckError extends Error {
20
+ constructor(onValue: any);
21
+ }
22
+ export declare class FieldAlreadyExistsError extends Error {
23
+ constructor(name: string);
24
+ }
25
+ export declare class InvalidFieldNamePartError extends Error {
26
+ constructor(namePart: string);
27
+ }
28
+ export declare class FieldExistsAsNonTerminalError extends Error {
29
+ constructor(name: string);
30
+ }
31
+ export declare class RichTextFieldReadError extends Error {
32
+ constructor(fieldName: string);
33
+ }
34
+ export declare class CombedTextLayoutError extends Error {
35
+ constructor(lineLength: number, cellCount: number);
36
+ }
37
+ export declare class ExceededMaxLengthError extends Error {
38
+ constructor(textLength: number, maxLength: number, name: string);
39
+ }
40
+ export declare class InvalidMaxLengthError extends Error {
41
+ constructor(textLength: number, maxLength: number, name: string);
42
+ }
@@ -0,0 +1,137 @@
1
+ import PDFDocument from '../PDFDocument';
2
+ import PDFPage from '../PDFPage';
3
+ import PDFFont from '../PDFFont';
4
+ import PDFImage from '../PDFImage';
5
+ import { ImageAlignment } from '../image/alignment';
6
+ import { AppearanceProviderFor } from './appearances';
7
+ import PDFField, { FieldAppearanceOptions } from './PDFField';
8
+ import { PDFRef, PDFAcroPushButton } from '../../core';
9
+ /**
10
+ * Represents a button field of a [[PDFForm]].
11
+ *
12
+ * [[PDFButton]] fields are interactive controls that users can click with their
13
+ * mouse. This type of [[PDFField]] is not stateful. The purpose of a button
14
+ * is to perform an action when the user clicks on it, such as opening a print
15
+ * modal or resetting the form. Buttons are typically rectangular in shape and
16
+ * have a text label describing the action that they perform when clicked.
17
+ */
18
+ export default class PDFButton extends PDFField {
19
+ /**
20
+ * > **NOTE:** You probably don't want to call this method directly. Instead,
21
+ * > consider using the [[PDFForm.getButton]] method, which will create an
22
+ * > instance of [[PDFButton]] for you.
23
+ *
24
+ * Create an instance of [[PDFButton]] from an existing acroPushButton and ref
25
+ *
26
+ * @param acroPushButton The underlying `PDFAcroPushButton` for this button.
27
+ * @param ref The unique reference for this button.
28
+ * @param doc The document to which this button will belong.
29
+ */
30
+ static of: (acroPushButton: PDFAcroPushButton, ref: PDFRef, doc: PDFDocument) => PDFButton;
31
+ /** The low-level PDFAcroPushButton wrapped by this button. */
32
+ readonly acroField: PDFAcroPushButton;
33
+ private constructor();
34
+ /**
35
+ * Display an image inside the bounds of this button's widgets. For example:
36
+ * ```js
37
+ * const pngImage = await pdfDoc.embedPng(...)
38
+ * const button = form.getButton('some.button.field')
39
+ * button.setImage(pngImage, ImageAlignment.Center)
40
+ * ```
41
+ * This will update the appearances streams for each of this button's widgets.
42
+ * @param image The image that should be displayed.
43
+ * @param alignment The alignment of the image.
44
+ */
45
+ setImage(image: PDFImage, alignment?: ImageAlignment): void;
46
+ /**
47
+ * Set the font size for this field. Larger font sizes will result in larger
48
+ * text being displayed when PDF readers render this button. Font sizes may
49
+ * be integer or floating point numbers. Supplying a negative font size will
50
+ * cause this method to throw an error.
51
+ *
52
+ * For example:
53
+ * ```js
54
+ * const button = form.getButton('some.button.field')
55
+ * button.setFontSize(4)
56
+ * button.setFontSize(15.7)
57
+ * ```
58
+ *
59
+ * > This method depends upon the existence of a default appearance
60
+ * > (`/DA`) string. If this field does not have a default appearance string,
61
+ * > or that string does not contain a font size (via the `Tf` operator),
62
+ * > then this method will throw an error.
63
+ *
64
+ * @param fontSize The font size to be used when rendering text in this field.
65
+ */
66
+ setFontSize(fontSize: number): void;
67
+ /**
68
+ * Show this button on the specified page with the given text. For example:
69
+ * ```js
70
+ * const ubuntuFont = await pdfDoc.embedFont(ubuntuFontBytes)
71
+ * const page = pdfDoc.addPage()
72
+ *
73
+ * const form = pdfDoc.getForm()
74
+ * const button = form.createButton('some.button.field')
75
+ *
76
+ * button.addToPage('Do Stuff', page, {
77
+ * x: 50,
78
+ * y: 75,
79
+ * width: 200,
80
+ * height: 100,
81
+ * textColor: rgb(1, 0, 0),
82
+ * backgroundColor: rgb(0, 1, 0),
83
+ * borderColor: rgb(0, 0, 1),
84
+ * borderWidth: 2,
85
+ * rotate: degrees(90),
86
+ * font: ubuntuFont,
87
+ * })
88
+ * ```
89
+ * This will create a new widget for this button field.
90
+ * @param text The text to be displayed for this button widget.
91
+ * @param page The page to which this button widget should be added.
92
+ * @param options The options to be used when adding this button widget.
93
+ */
94
+ addToPage(text: string, page: PDFPage, options?: FieldAppearanceOptions): void;
95
+ /**
96
+ * Returns `true` if this button has been marked as dirty, or if any of this
97
+ * button's widgets do not have an appearance stream. For example:
98
+ * ```js
99
+ * const button = form.getButton('some.button.field')
100
+ * if (button.needsAppearancesUpdate()) console.log('Needs update')
101
+ * ```
102
+ * @returns Whether or not this button needs an appearance update.
103
+ */
104
+ needsAppearancesUpdate(): boolean;
105
+ /**
106
+ * Update the appearance streams for each of this button's widgets using
107
+ * the default appearance provider for buttons. For example:
108
+ * ```js
109
+ * const helvetica = await pdfDoc.embedFont(StandardFonts.Helvetica)
110
+ * const button = form.getButton('some.button.field')
111
+ * button.defaultUpdateAppearances(helvetica)
112
+ * ```
113
+ * @param font The font to be used for creating the appearance streams.
114
+ */
115
+ defaultUpdateAppearances(font: PDFFont): void;
116
+ /**
117
+ * Update the appearance streams for each of this button's widgets using
118
+ * the given appearance provider. If no `provider` is passed, the default
119
+ * appearance provider for buttons will be used. For example:
120
+ * ```js
121
+ * const helvetica = await pdfDoc.embedFont(StandardFonts.Helvetica)
122
+ * const button = form.getButton('some.button.field')
123
+ * button.updateAppearances(helvetica, (field, widget, font) => {
124
+ * ...
125
+ * return {
126
+ * normal: drawButton(...),
127
+ * down: drawButton(...),
128
+ * }
129
+ * })
130
+ * ```
131
+ * @param font The font to be used for creating the appearance streams.
132
+ * @param provider Optionally, the appearance provider to be used for
133
+ * generating the contents of the appearance streams.
134
+ */
135
+ updateAppearances(font: PDFFont, provider?: AppearanceProviderFor<PDFButton>): void;
136
+ private updateWidgetAppearance;
137
+ }
@@ -0,0 +1,142 @@
1
+ import PDFDocument from '../PDFDocument';
2
+ import PDFPage from '../PDFPage';
3
+ import { AppearanceProviderFor } from './appearances';
4
+ import PDFField, { FieldAppearanceOptions } from './PDFField';
5
+ import { PDFRef, PDFAcroCheckBox } from '../../core';
6
+ /**
7
+ * Represents a check box field of a [[PDFForm]].
8
+ *
9
+ * [[PDFCheckBox]] fields are interactive boxes that users can click with their
10
+ * mouse. This type of [[PDFField]] has two states: `on` and `off`. The purpose
11
+ * of a check box is to enable users to select from one or more options, where
12
+ * each option is represented by a single check box. Check boxes are typically
13
+ * square in shape and display a check mark when they are in the `on` state.
14
+ */
15
+ export default class PDFCheckBox extends PDFField {
16
+ /**
17
+ * > **NOTE:** You probably don't want to call this method directly. Instead,
18
+ * > consider using the [[PDFForm.getCheckBox]] method, which will create an
19
+ * > instance of [[PDFCheckBox]] for you.
20
+ *
21
+ * Create an instance of [[PDFCheckBox]] from an existing acroCheckBox and ref
22
+ *
23
+ * @param acroCheckBox The underlying `PDFAcroCheckBox` for this check box.
24
+ * @param ref The unique reference for this check box.
25
+ * @param doc The document to which this check box will belong.
26
+ */
27
+ static of: (acroCheckBox: PDFAcroCheckBox, ref: PDFRef, doc: PDFDocument) => PDFCheckBox;
28
+ /** The low-level PDFAcroCheckBox wrapped by this check box. */
29
+ readonly acroField: PDFAcroCheckBox;
30
+ private constructor();
31
+ /**
32
+ * Mark this check box. This operation is analogous to a human user clicking
33
+ * a check box to fill it in a PDF reader. This method will update the
34
+ * underlying state of the check box field to indicate it has been selected.
35
+ * PDF libraries and readers will be able to extract this value from the
36
+ * saved document and determine that it was selected.
37
+ *
38
+ * For example:
39
+ * ```js
40
+ * const checkBox = form.getCheckBox('some.checkBox.field')
41
+ * checkBox.check()
42
+ * ```
43
+ *
44
+ * This method will mark this check box as dirty, causing its appearance
45
+ * streams to be updated when either [[PDFDocument.save]] or
46
+ * [[PDFForm.updateFieldAppearances]] is called. The updated appearance
47
+ * streams will display a check mark inside the widgets of this check box
48
+ * field.
49
+ */
50
+ check(): void;
51
+ /**
52
+ * Clears this check box. This operation is analogous to a human user clicking
53
+ * a check box to unmark it in a PDF reader. This method will update the
54
+ * underlying state of the check box field to indicate it has been deselected.
55
+ * PDF libraries and readers will be able to extract this value from the
56
+ * saved document and determine that it was not selected.
57
+ *
58
+ * For example:
59
+ * ```js
60
+ * const checkBox = form.getCheckBox('some.checkBox.field')
61
+ * checkBox.uncheck()
62
+ * ```
63
+ *
64
+ * This method will mark this check box as dirty. See [[PDFCheckBox.check]]
65
+ * for more details about what this means.
66
+ */
67
+ uncheck(): void;
68
+ /**
69
+ * Returns `true` if this check box is selected (either by a human user via
70
+ * a PDF reader, or else programmatically via software). For example:
71
+ * ```js
72
+ * const checkBox = form.getCheckBox('some.checkBox.field')
73
+ * if (checkBox.isChecked()) console.log('check box is selected')
74
+ * ```
75
+ * @returns Whether or not this check box is selected.
76
+ */
77
+ isChecked(): boolean;
78
+ /**
79
+ * Show this check box on the specified page. For example:
80
+ * ```js
81
+ * const helvetica = await pdfDoc.embedFont(StandardFonts.Helvetica)
82
+ * const page = pdfDoc.addPage()
83
+ *
84
+ * const form = pdfDoc.getForm()
85
+ * const checkBox = form.createCheckBox('some.checkBox.field')
86
+ *
87
+ * checkBox.addToPage(page, {
88
+ * x: 50,
89
+ * y: 75,
90
+ * width: 25,
91
+ * height: 25,
92
+ * textColor: rgb(1, 0, 0),
93
+ * backgroundColor: rgb(0, 1, 0),
94
+ * borderColor: rgb(0, 0, 1),
95
+ * borderWidth: 2,
96
+ * rotate: degrees(90),
97
+ * })
98
+ * ```
99
+ * This will create a new widget for this check box field.
100
+ * @param page The page to which this check box widget should be added.
101
+ * @param options The options to be used when adding this check box widget.
102
+ */
103
+ addToPage(page: PDFPage, options?: FieldAppearanceOptions): void;
104
+ /**
105
+ * Returns `true` if any of this check box's widgets do not have an
106
+ * appearance stream for its current state. For example:
107
+ * ```js
108
+ * const checkBox = form.getCheckBox('some.checkBox.field')
109
+ * if (checkBox.needsAppearancesUpdate()) console.log('Needs update')
110
+ * ```
111
+ * @returns Whether or not this check box needs an appearance update.
112
+ */
113
+ needsAppearancesUpdate(): boolean;
114
+ /**
115
+ * Update the appearance streams for each of this check box's widgets using
116
+ * the default appearance provider for check boxes. For example:
117
+ * ```js
118
+ * const checkBox = form.getCheckBox('some.checkBox.field')
119
+ * checkBox.defaultUpdateAppearances()
120
+ * ```
121
+ */
122
+ defaultUpdateAppearances(): void;
123
+ /**
124
+ * Update the appearance streams for each of this check box's widgets using
125
+ * the given appearance provider. If no `provider` is passed, the default
126
+ * appearance provider for check boxs will be used. For example:
127
+ * ```js
128
+ * const checkBox = form.getCheckBox('some.checkBox.field')
129
+ * checkBox.updateAppearances((field, widget) => {
130
+ * ...
131
+ * return {
132
+ * normal: { on: drawCheckBox(...), off: drawCheckBox(...) },
133
+ * down: { on: drawCheckBox(...), off: drawCheckBox(...) },
134
+ * }
135
+ * })
136
+ * ```
137
+ * @param provider Optionally, the appearance provider to be used for
138
+ * generating the contents of the appearance streams.
139
+ */
140
+ updateAppearances(provider?: AppearanceProviderFor<PDFCheckBox>): void;
141
+ private updateWidgetAppearance;
142
+ }