@signiphi/pdf-signer 0.1.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 (192) hide show
  1. package/INSTALLING_LOCALLY.md +184 -0
  2. package/LICENSE +2 -0
  3. package/README.md +1093 -0
  4. package/assets/viewer.html +314 -0
  5. package/dist/__tests__/helpers/fixtures.d.ts +43 -0
  6. package/dist/__tests__/helpers/fixtures.d.ts.map +1 -0
  7. package/dist/__tests__/helpers/mocks.d.ts +333 -0
  8. package/dist/__tests__/helpers/mocks.d.ts.map +1 -0
  9. package/dist/__tests__/setup.d.ts +6 -0
  10. package/dist/__tests__/setup.d.ts.map +1 -0
  11. package/dist/components/AttachmentUpload.d.ts +17 -0
  12. package/dist/components/AttachmentUpload.d.ts.map +1 -0
  13. package/dist/components/EditableFieldsPanel.d.ts +30 -0
  14. package/dist/components/EditableFieldsPanel.d.ts.map +1 -0
  15. package/dist/components/ErrorBoundary.d.ts +67 -0
  16. package/dist/components/ErrorBoundary.d.ts.map +1 -0
  17. package/dist/components/FormFieldsView.d.ts +42 -0
  18. package/dist/components/FormFieldsView.d.ts.map +1 -0
  19. package/dist/components/PdfViewerStyled.d.ts +16 -0
  20. package/dist/components/PdfViewerStyled.d.ts.map +1 -0
  21. package/dist/components/PoweredBySigniphi.d.ts +11 -0
  22. package/dist/components/PoweredBySigniphi.d.ts.map +1 -0
  23. package/dist/components/SignatureCanvas.d.ts +12 -0
  24. package/dist/components/SignatureCanvas.d.ts.map +1 -0
  25. package/dist/components/SignatureInitialsBox.d.ts +23 -0
  26. package/dist/components/SignatureInitialsBox.d.ts.map +1 -0
  27. package/dist/components/SignatureModal.d.ts +22 -0
  28. package/dist/components/SignatureModal.d.ts.map +1 -0
  29. package/dist/components/SigningInstructions.d.ts +12 -0
  30. package/dist/components/SigningInstructions.d.ts.map +1 -0
  31. package/dist/components/SubmissionForm.d.ts +52 -0
  32. package/dist/components/SubmissionForm.d.ts.map +1 -0
  33. package/dist/components/ViewToggleToolbar.d.ts +30 -0
  34. package/dist/components/ViewToggleToolbar.d.ts.map +1 -0
  35. package/dist/components/form-fields/CheckboxRenderer.d.ts +10 -0
  36. package/dist/components/form-fields/CheckboxRenderer.d.ts.map +1 -0
  37. package/dist/components/form-fields/DateFieldRenderer.d.ts +14 -0
  38. package/dist/components/form-fields/DateFieldRenderer.d.ts.map +1 -0
  39. package/dist/components/form-fields/DropdownRenderer.d.ts +14 -0
  40. package/dist/components/form-fields/DropdownRenderer.d.ts.map +1 -0
  41. package/dist/components/form-fields/FormFieldRenderer.d.ts +20 -0
  42. package/dist/components/form-fields/FormFieldRenderer.d.ts.map +1 -0
  43. package/dist/components/form-fields/InitialsFieldRenderer.d.ts +14 -0
  44. package/dist/components/form-fields/InitialsFieldRenderer.d.ts.map +1 -0
  45. package/dist/components/form-fields/RadioGroupRenderer.d.ts +10 -0
  46. package/dist/components/form-fields/RadioGroupRenderer.d.ts.map +1 -0
  47. package/dist/components/form-fields/SignatureFieldRenderer.d.ts +16 -0
  48. package/dist/components/form-fields/SignatureFieldRenderer.d.ts.map +1 -0
  49. package/dist/components/form-fields/TextFieldRenderer.d.ts +14 -0
  50. package/dist/components/form-fields/TextFieldRenderer.d.ts.map +1 -0
  51. package/dist/components/form-fields/TextLabelRenderer.d.ts +14 -0
  52. package/dist/components/form-fields/TextLabelRenderer.d.ts.map +1 -0
  53. package/dist/components/form-fields/index.d.ts +14 -0
  54. package/dist/components/form-fields/index.d.ts.map +1 -0
  55. package/dist/components/index.d.ts +14 -0
  56. package/dist/components/index.d.ts.map +1 -0
  57. package/dist/components/index.js +6297 -0
  58. package/dist/components/index.js.map +1 -0
  59. package/dist/components/index.mjs +6248 -0
  60. package/dist/components/index.mjs.map +1 -0
  61. package/dist/core/PdfViewerCore.d.ts +19 -0
  62. package/dist/core/PdfViewerCore.d.ts.map +1 -0
  63. package/dist/core/SignatureCaptureCore.d.ts +37 -0
  64. package/dist/core/SignatureCaptureCore.d.ts.map +1 -0
  65. package/dist/core/index.d.ts +3 -0
  66. package/dist/core/index.d.ts.map +1 -0
  67. package/dist/core/index.js +907 -0
  68. package/dist/core/index.js.map +1 -0
  69. package/dist/core/index.mjs +884 -0
  70. package/dist/core/index.mjs.map +1 -0
  71. package/dist/hooks/index.d.ts +8 -0
  72. package/dist/hooks/index.d.ts.map +1 -0
  73. package/dist/hooks/index.js +2167 -0
  74. package/dist/hooks/index.js.map +1 -0
  75. package/dist/hooks/index.mjs +2139 -0
  76. package/dist/hooks/index.mjs.map +1 -0
  77. package/dist/hooks/useAttachments.d.ts +25 -0
  78. package/dist/hooks/useAttachments.d.ts.map +1 -0
  79. package/dist/hooks/useFieldFiltering.d.ts +29 -0
  80. package/dist/hooks/useFieldFiltering.d.ts.map +1 -0
  81. package/dist/hooks/useFormFields.d.ts +23 -0
  82. package/dist/hooks/useFormFields.d.ts.map +1 -0
  83. package/dist/hooks/useMultiSignerContext.d.ts +25 -0
  84. package/dist/hooks/useMultiSignerContext.d.ts.map +1 -0
  85. package/dist/hooks/usePdfViewer.d.ts +52 -0
  86. package/dist/hooks/usePdfViewer.d.ts.map +1 -0
  87. package/dist/hooks/useSignatureCapture.d.ts +17 -0
  88. package/dist/hooks/useSignatureCapture.d.ts.map +1 -0
  89. package/dist/hooks/useSignatures.d.ts +25 -0
  90. package/dist/hooks/useSignatures.d.ts.map +1 -0
  91. package/dist/index.css +4929 -0
  92. package/dist/index.css.map +1 -0
  93. package/dist/index.d.ts +17 -0
  94. package/dist/index.d.ts.map +1 -0
  95. package/dist/index.js +7220 -0
  96. package/dist/index.js.map +1 -0
  97. package/dist/index.mjs +7093 -0
  98. package/dist/index.mjs.map +1 -0
  99. package/dist/integrations/index.d.ts +6 -0
  100. package/dist/integrations/index.d.ts.map +1 -0
  101. package/dist/integrations/index.js +242 -0
  102. package/dist/integrations/index.js.map +1 -0
  103. package/dist/integrations/index.mjs +218 -0
  104. package/dist/integrations/index.mjs.map +1 -0
  105. package/dist/integrations/next-config.d.ts +46 -0
  106. package/dist/integrations/next-config.d.ts.map +1 -0
  107. package/dist/integrations/vite-plugin.d.ts +48 -0
  108. package/dist/integrations/vite-plugin.d.ts.map +1 -0
  109. package/dist/lib/index.d.ts +3 -0
  110. package/dist/lib/index.d.ts.map +1 -0
  111. package/dist/lib/ui/alert.d.ts +9 -0
  112. package/dist/lib/ui/alert.d.ts.map +1 -0
  113. package/dist/lib/ui/button.d.ts +12 -0
  114. package/dist/lib/ui/button.d.ts.map +1 -0
  115. package/dist/lib/ui/calendar.d.ts +10 -0
  116. package/dist/lib/ui/calendar.d.ts.map +1 -0
  117. package/dist/lib/ui/card.d.ts +9 -0
  118. package/dist/lib/ui/card.d.ts.map +1 -0
  119. package/dist/lib/ui/checkbox.d.ts +5 -0
  120. package/dist/lib/ui/checkbox.d.ts.map +1 -0
  121. package/dist/lib/ui/dialog.d.ts +20 -0
  122. package/dist/lib/ui/dialog.d.ts.map +1 -0
  123. package/dist/lib/ui/index.d.ts +12 -0
  124. package/dist/lib/ui/index.d.ts.map +1 -0
  125. package/dist/lib/ui/input.d.ts +6 -0
  126. package/dist/lib/ui/input.d.ts.map +1 -0
  127. package/dist/lib/ui/label.d.ts +6 -0
  128. package/dist/lib/ui/label.d.ts.map +1 -0
  129. package/dist/lib/ui/popover.d.ts +7 -0
  130. package/dist/lib/ui/popover.d.ts.map +1 -0
  131. package/dist/lib/ui/radio-group.d.ts +6 -0
  132. package/dist/lib/ui/radio-group.d.ts.map +1 -0
  133. package/dist/lib/ui/select.d.ts +14 -0
  134. package/dist/lib/ui/select.d.ts.map +1 -0
  135. package/dist/lib/utils.d.ts +7 -0
  136. package/dist/lib/utils.d.ts.map +1 -0
  137. package/dist/styles/index.css +5004 -0
  138. package/dist/types/index.d.ts +265 -0
  139. package/dist/types/index.d.ts.map +1 -0
  140. package/dist/types/index.js +26 -0
  141. package/dist/types/index.js.map +1 -0
  142. package/dist/types/index.mjs +23 -0
  143. package/dist/types/index.mjs.map +1 -0
  144. package/dist/utils/attachment-validators.d.ts +118 -0
  145. package/dist/utils/attachment-validators.d.ts.map +1 -0
  146. package/dist/utils/audit-trail.d.ts +27 -0
  147. package/dist/utils/audit-trail.d.ts.map +1 -0
  148. package/dist/utils/date-validation.d.ts +30 -0
  149. package/dist/utils/date-validation.d.ts.map +1 -0
  150. package/dist/utils/errors.d.ts +106 -0
  151. package/dist/utils/errors.d.ts.map +1 -0
  152. package/dist/utils/field-extraction.d.ts +27 -0
  153. package/dist/utils/field-extraction.d.ts.map +1 -0
  154. package/dist/utils/field-visibility.d.ts +104 -0
  155. package/dist/utils/field-visibility.d.ts.map +1 -0
  156. package/dist/utils/index.d.ts +17 -0
  157. package/dist/utils/index.d.ts.map +1 -0
  158. package/dist/utils/index.js +2501 -0
  159. package/dist/utils/index.js.map +1 -0
  160. package/dist/utils/index.mjs +2404 -0
  161. package/dist/utils/index.mjs.map +1 -0
  162. package/dist/utils/logger.d.ts +16 -0
  163. package/dist/utils/logger.d.ts.map +1 -0
  164. package/dist/utils/pdf-field-type-helpers.d.ts +78 -0
  165. package/dist/utils/pdf-field-type-helpers.d.ts.map +1 -0
  166. package/dist/utils/pdf-helpers.d.ts +38 -0
  167. package/dist/utils/pdf-helpers.d.ts.map +1 -0
  168. package/dist/utils/pdf-lib-loader.d.ts +45 -0
  169. package/dist/utils/pdf-lib-loader.d.ts.map +1 -0
  170. package/dist/utils/pdf-manipulation.d.ts +93 -0
  171. package/dist/utils/pdf-manipulation.d.ts.map +1 -0
  172. package/dist/utils/pdf-validators.d.ts +149 -0
  173. package/dist/utils/pdf-validators.d.ts.map +1 -0
  174. package/dist/utils/pdf-viewer-filter.d.ts +35 -0
  175. package/dist/utils/pdf-viewer-filter.d.ts.map +1 -0
  176. package/dist/utils/pdf-widget-helpers.d.ts +98 -0
  177. package/dist/utils/pdf-widget-helpers.d.ts.map +1 -0
  178. package/dist/utils/pdfjs-config.d.ts +56 -0
  179. package/dist/utils/pdfjs-config.d.ts.map +1 -0
  180. package/dist/utils/pdfjs-version-check.d.ts +28 -0
  181. package/dist/utils/pdfjs-version-check.d.ts.map +1 -0
  182. package/dist/utils/performance-monitor.d.ts +172 -0
  183. package/dist/utils/performance-monitor.d.ts.map +1 -0
  184. package/dist/utils/tracking.d.ts +89 -0
  185. package/dist/utils/tracking.d.ts.map +1 -0
  186. package/package.json +180 -0
  187. package/scripts/analyze-bundle.js +271 -0
  188. package/scripts/copy-utils.js +227 -0
  189. package/scripts/copy-utils.test.js +164 -0
  190. package/scripts/postinstall.js +109 -0
  191. package/scripts/setup.js +108 -0
  192. package/src/styles/index.css +139 -0
@@ -0,0 +1,184 @@
1
+ # Installing @signiphi/pdf-signer Locally
2
+
3
+ This guide covers installing the package from a local directory (useful for testing or development).
4
+
5
+ ## The Issue with Local Installations
6
+
7
+ When installing packages using `file:` protocol (e.g., `npm install file:../pdf-signer` or `npm install ./local-package`), **npm may not run postinstall scripts**. This is a known npm behavior for local file dependencies.
8
+
9
+ Since @signiphi/pdf-signer relies on a postinstall script to copy PDF.js viewer files to your `public/` directory, you need to run an additional setup step after installation.
10
+
11
+ ## Installation Steps
12
+
13
+ ### 1. Install the Package
14
+
15
+ ```bash
16
+ # From your project directory
17
+ npm install file:path/to/pdf-signer
18
+
19
+ # Or with a relative path in package.json
20
+ npm install
21
+ ```
22
+
23
+ **Expected behavior:** Package installs but postinstall script may not run.
24
+
25
+ ### 2. Run the Setup Script
26
+
27
+ After installation, manually run the setup script:
28
+
29
+ ```bash
30
+ npx signiphi-setup
31
+ ```
32
+
33
+ Or explicitly:
34
+
35
+ ```bash
36
+ node node_modules/@signiphi/pdf-signer/scripts/postinstall.js
37
+ ```
38
+
39
+ **Expected output:**
40
+ ```
41
+ ✓ @signiphi/pdf-signer: PDF.js files copied to C:\Your\Project\public\pdfjs
42
+ ```
43
+
44
+ ### 3. Verify Installation
45
+
46
+ Check that the viewer files exist:
47
+
48
+ ```bash
49
+ ls public/pdfjs/web/viewer.html
50
+ ```
51
+
52
+ You should see:
53
+ ```
54
+ public/
55
+ pdfjs/
56
+ build/
57
+ pdf.worker.mjs
58
+ pdf.mjs
59
+ ...
60
+ web/
61
+ viewer.html ← Custom viewer for PDF.js 5.x
62
+ pdf_viewer.mjs
63
+ pdf_viewer.css
64
+ images/
65
+ .version
66
+ ```
67
+
68
+ ## Alternative: Use Integration Plugins
69
+
70
+ For Vite or Next.js projects, use the build-time integration plugins which handle file copying automatically:
71
+
72
+ ### Vite
73
+
74
+ ```typescript
75
+ // vite.config.ts
76
+ import { defineConfig } from 'vite';
77
+ import { signiphiPdfJs } from '@signiphi/pdf-signer/vite';
78
+
79
+ export default defineConfig({
80
+ plugins: [signiphiPdfJs()],
81
+ });
82
+ ```
83
+
84
+ ### Next.js
85
+
86
+ ```javascript
87
+ // next.config.js
88
+ const { withSigniphiPdfJs } = require('@signiphi/pdf-signer/next');
89
+
90
+ module.exports = withSigniphiPdfJs({
91
+ // your next.js config
92
+ });
93
+ ```
94
+
95
+ ## Why This Happens
96
+
97
+ npm treats `file:` dependencies differently from registry packages:
98
+
99
+ 1. **Registry packages** (from npmjs.com): postinstall scripts run automatically
100
+ 2. **Local file: packages**: npm may skip lifecycle scripts to avoid side effects during local development
101
+
102
+ This is by design to prevent accidentally running scripts when symlinking or linking local packages during development.
103
+
104
+ ## Production Installations
105
+
106
+ When your package is published to npm and users install it normally, the postinstall script **will run automatically**:
107
+
108
+ ```bash
109
+ npm install @signiphi/pdf-signer
110
+ # ✓ Postinstall runs automatically
111
+ # ✓ PDF.js files copied to public/pdfjs/
112
+ ```
113
+
114
+ ## Troubleshooting
115
+
116
+ ### postinstall didn't run
117
+
118
+ **Solution:** Run manually with `npx signiphi-setup`
119
+
120
+ ### "viewer.html not found" error
121
+
122
+ This means the PDF.js files weren't copied. Run:
123
+
124
+ ```bash
125
+ npx signiphi-setup --force
126
+ ```
127
+
128
+ ### Files copied to wrong location
129
+
130
+ Specify the target directory:
131
+
132
+ ```bash
133
+ npx signiphi-setup public/my-custom-path
134
+ ```
135
+
136
+ Then configure your app:
137
+
138
+ ```typescript
139
+ import { setPdfJsConfig } from '@signiphi/pdf-signer';
140
+
141
+ setPdfJsConfig({
142
+ viewerBasePath: '/my-custom-path'
143
+ });
144
+ ```
145
+
146
+ ### Still not working?
147
+
148
+ 1. Check that pdfjs-dist is installed:
149
+ ```bash
150
+ ls node_modules/pdfjs-dist
151
+ ```
152
+
153
+ 2. Verify the assets directory exists in the package:
154
+ ```bash
155
+ ls node_modules/@signiphi/pdf-signer/assets/viewer.html
156
+ ```
157
+
158
+ 3. Check for errors:
159
+ ```bash
160
+ node node_modules/@signiphi/pdf-signer/scripts/postinstall.js
161
+ ```
162
+
163
+ 4. Check the runtime error message in your browser console for specific guidance
164
+
165
+ ## Testing After Installation
166
+
167
+ Create a simple test to verify everything works:
168
+
169
+ ```tsx
170
+ import { PdfViewerStyled } from '@signiphi/pdf-signer';
171
+ import '@signiphi/pdf-signer/styles';
172
+
173
+ function App() {
174
+ return (
175
+ <PdfViewerStyled
176
+ pdfUrl="/path/to/test.pdf"
177
+ onLoad={() => console.log('PDF loaded successfully!')}
178
+ onError={(error) => console.error('PDF load error:', error)}
179
+ />
180
+ );
181
+ }
182
+ ```
183
+
184
+ If you see the PDF render, everything is working correctly!
package/LICENSE ADDED
@@ -0,0 +1,2 @@
1
+
2
+ Copyright (c) 2025 Xigniphi