@superdoc-dev/esign 1.2.0-next.2 → 1.2.0

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.
package/dist/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
- import ue, { forwardRef as de, useState as D, useRef as U, useEffect as K, useCallback as F, useImperativeHandle as fe } from "react";
2
- var ee = { exports: {} }, q = {};
1
+ import ce, { forwardRef as ue, useState as N, useRef as Z, useCallback as P, useEffect as re, useImperativeHandle as de } from "react";
2
+ var Q = { exports: {} }, $ = {};
3
3
  /**
4
4
  * @license React
5
5
  * react-jsx-runtime.production.js
@@ -9,29 +9,29 @@ var ee = { exports: {} }, q = {};
9
9
  * This source code is licensed under the MIT license found in the
10
10
  * LICENSE file in the root directory of this source tree.
11
11
  */
12
- var oe;
13
- function me() {
14
- if (oe) return q;
15
- oe = 1;
16
- var p = Symbol.for("react.transitional.element"), v = Symbol.for("react.fragment");
17
- function m(s, o, f) {
18
- var h = null;
19
- if (f !== void 0 && (h = "" + f), o.key !== void 0 && (h = "" + o.key), "key" in o) {
20
- f = {};
21
- for (var S in o)
22
- S !== "key" && (f[S] = o[S]);
23
- } else f = o;
24
- return o = f.ref, {
25
- $$typeof: p,
26
- type: s,
27
- key: h,
12
+ var ne;
13
+ function fe() {
14
+ if (ne) return $;
15
+ ne = 1;
16
+ var m = Symbol.for("react.transitional.element"), g = Symbol.for("react.fragment");
17
+ function f(a, o, u) {
18
+ var b = null;
19
+ if (u !== void 0 && (b = "" + u), o.key !== void 0 && (b = "" + o.key), "key" in o) {
20
+ u = {};
21
+ for (var _ in o)
22
+ _ !== "key" && (u[_] = o[_]);
23
+ } else u = o;
24
+ return o = u.ref, {
25
+ $$typeof: m,
26
+ type: a,
27
+ key: b,
28
28
  ref: o !== void 0 ? o : null,
29
- props: f
29
+ props: u
30
30
  };
31
31
  }
32
- return q.Fragment = v, q.jsx = m, q.jsxs = m, q;
32
+ return $.Fragment = g, $.jsx = f, $.jsxs = f, $;
33
33
  }
34
- var L = {};
34
+ var q = {};
35
35
  /**
36
36
  * @license React
37
37
  * react-jsx-runtime.development.js
@@ -41,126 +41,126 @@ var L = {};
41
41
  * This source code is licensed under the MIT license found in the
42
42
  * LICENSE file in the root directory of this source tree.
43
43
  */
44
- var ae;
45
- function pe() {
46
- return ae || (ae = 1, process.env.NODE_ENV !== "production" && (function() {
47
- function p(e) {
44
+ var oe;
45
+ function me() {
46
+ return oe || (oe = 1, process.env.NODE_ENV !== "production" && (function() {
47
+ function m(e) {
48
48
  if (e == null) return null;
49
49
  if (typeof e == "function")
50
- return e.$$typeof === re ? null : e.displayName || e.name || null;
50
+ return e.$$typeof === ee ? null : e.displayName || e.name || null;
51
51
  if (typeof e == "string") return e;
52
52
  switch (e) {
53
- case _:
53
+ case x:
54
54
  return "Fragment";
55
- case b:
55
+ case v:
56
56
  return "Profiler";
57
- case B:
57
+ case V:
58
58
  return "StrictMode";
59
- case T:
59
+ case S:
60
60
  return "Suspense";
61
- case G:
61
+ case J:
62
62
  return "SuspenseList";
63
- case Z:
63
+ case H:
64
64
  return "Activity";
65
65
  }
66
66
  if (typeof e == "object")
67
67
  switch (typeof e.tag == "number" && console.error(
68
68
  "Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."
69
69
  ), e.$$typeof) {
70
- case te:
70
+ case K:
71
71
  return "Portal";
72
- case A:
72
+ case w:
73
73
  return e.displayName || "Context";
74
- case J:
74
+ case z:
75
75
  return (e._context.displayName || "Context") + ".Consumer";
76
- case H:
76
+ case B:
77
77
  var n = e.render;
78
78
  return e = e.displayName, e || (e = n.displayName || n.name || "", e = e !== "" ? "ForwardRef(" + e + ")" : "ForwardRef"), e;
79
- case X:
80
- return n = e.displayName || null, n !== null ? n : p(e.type) || "Memo";
81
- case N:
79
+ case I:
80
+ return n = e.displayName || null, n !== null ? n : m(e.type) || "Memo";
81
+ case C:
82
82
  n = e._payload, e = e._init;
83
83
  try {
84
- return p(e(n));
84
+ return m(e(n));
85
85
  } catch {
86
86
  }
87
87
  }
88
88
  return null;
89
89
  }
90
- function v(e) {
90
+ function g(e) {
91
91
  return "" + e;
92
92
  }
93
- function m(e) {
93
+ function f(e) {
94
94
  try {
95
- v(e);
95
+ g(e);
96
96
  var n = !1;
97
97
  } catch {
98
98
  n = !0;
99
99
  }
100
100
  if (n) {
101
101
  n = console;
102
- var c = n.error, u = typeof Symbol == "function" && Symbol.toStringTag && e[Symbol.toStringTag] || e.constructor.name || "Object";
103
- return c.call(
102
+ var l = n.error, c = typeof Symbol == "function" && Symbol.toStringTag && e[Symbol.toStringTag] || e.constructor.name || "Object";
103
+ return l.call(
104
104
  n,
105
105
  "The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",
106
- u
107
- ), v(e);
106
+ c
107
+ ), g(e);
108
108
  }
109
109
  }
110
- function s(e) {
111
- if (e === _) return "<>";
112
- if (typeof e == "object" && e !== null && e.$$typeof === N)
110
+ function a(e) {
111
+ if (e === x) return "<>";
112
+ if (typeof e == "object" && e !== null && e.$$typeof === C)
113
113
  return "<...>";
114
114
  try {
115
- var n = p(e);
115
+ var n = m(e);
116
116
  return n ? "<" + n + ">" : "<...>";
117
117
  } catch {
118
118
  return "<...>";
119
119
  }
120
120
  }
121
121
  function o() {
122
- var e = w.A;
122
+ var e = T.A;
123
123
  return e === null ? null : e.getOwner();
124
124
  }
125
- function f() {
125
+ function u() {
126
126
  return Error("react-stack-top-frame");
127
127
  }
128
- function h(e) {
129
- if (x.call(e, "key")) {
128
+ function b(e) {
129
+ if (y.call(e, "key")) {
130
130
  var n = Object.getOwnPropertyDescriptor(e, "key").get;
131
131
  if (n && n.isReactWarning) return !1;
132
132
  }
133
133
  return e.key !== void 0;
134
134
  }
135
- function S(e, n) {
136
- function c() {
135
+ function _(e, n) {
136
+ function l() {
137
137
  k || (k = !0, console.error(
138
138
  "%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",
139
139
  n
140
140
  ));
141
141
  }
142
- c.isReactWarning = !0, Object.defineProperty(e, "key", {
143
- get: c,
142
+ l.isReactWarning = !0, Object.defineProperty(e, "key", {
143
+ get: l,
144
144
  configurable: !0
145
145
  });
146
146
  }
147
- function W() {
148
- var e = p(this.type);
149
- return C[e] || (C[e] = !0, console.error(
147
+ function L() {
148
+ var e = m(this.type);
149
+ return G[e] || (G[e] = !0, console.error(
150
150
  "Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release."
151
151
  )), e = this.props.ref, e !== void 0 ? e : null;
152
152
  }
153
- function V(e, n, c, u, P, $) {
154
- var d = c.ref;
153
+ function W(e, n, l, c, O, Y) {
154
+ var t = l.ref;
155
155
  return e = {
156
- $$typeof: z,
156
+ $$typeof: U,
157
157
  type: e,
158
158
  key: n,
159
- props: c,
160
- _owner: u
161
- }, (d !== void 0 ? d : null) !== null ? Object.defineProperty(e, "ref", {
159
+ props: l,
160
+ _owner: c
161
+ }, (t !== void 0 ? t : null) !== null ? Object.defineProperty(e, "ref", {
162
162
  enumerable: !1,
163
- get: W
163
+ get: L
164
164
  }) : Object.defineProperty(e, "ref", { enumerable: !1, value: null }), e._store = {}, Object.defineProperty(e._store, "validated", {
165
165
  configurable: !1,
166
166
  enumerable: !1,
@@ -175,169 +175,162 @@ function pe() {
175
175
  configurable: !1,
176
176
  enumerable: !1,
177
177
  writable: !0,
178
- value: P
178
+ value: O
179
179
  }), Object.defineProperty(e, "_debugTask", {
180
180
  configurable: !1,
181
181
  enumerable: !1,
182
182
  writable: !0,
183
- value: $
183
+ value: Y
184
184
  }), Object.freeze && (Object.freeze(e.props), Object.freeze(e)), e;
185
185
  }
186
- function I(e, n, c, u, P, $) {
187
- var d = n.children;
188
- if (d !== void 0)
189
- if (u)
190
- if (ne(d)) {
191
- for (u = 0; u < d.length; u++)
192
- M(d[u]);
193
- Object.freeze && Object.freeze(d);
186
+ function D(e, n, l, c, O, Y) {
187
+ var t = n.children;
188
+ if (t !== void 0)
189
+ if (c)
190
+ if (te(t)) {
191
+ for (c = 0; c < t.length; c++)
192
+ F(t[c]);
193
+ Object.freeze && Object.freeze(t);
194
194
  } else
195
195
  console.error(
196
196
  "React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead."
197
197
  );
198
- else M(d);
199
- if (x.call(n, "key")) {
200
- d = p(e);
201
- var t = Object.keys(n).filter(function(a) {
202
- return a !== "key";
198
+ else F(t);
199
+ if (y.call(n, "key")) {
200
+ t = m(e);
201
+ var r = Object.keys(n).filter(function(d) {
202
+ return d !== "key";
203
203
  });
204
- u = 0 < t.length ? "{key: someKey, " + t.join(": ..., ") + ": ...}" : "{key: someKey}", j[d + u] || (t = 0 < t.length ? "{" + t.join(": ..., ") + ": ...}" : "{}", console.error(
204
+ c = 0 < r.length ? "{key: someKey, " + r.join(": ..., ") + ": ...}" : "{key: someKey}", X[t + c] || (r = 0 < r.length ? "{" + r.join(": ..., ") + ": ...}" : "{}", console.error(
205
205
  `A props object containing a "key" prop is being spread into JSX:
206
206
  let props = %s;
207
207
  <%s {...props} />
208
208
  React keys must be passed directly to JSX without using spread:
209
209
  let props = %s;
210
210
  <%s key={someKey} {...props} />`,
211
- u,
212
- d,
211
+ c,
213
212
  t,
214
- d
215
- ), j[d + u] = !0);
213
+ r,
214
+ t
215
+ ), X[t + c] = !0);
216
216
  }
217
- if (d = null, c !== void 0 && (m(c), d = "" + c), h(n) && (m(n.key), d = "" + n.key), "key" in n) {
218
- c = {};
219
- for (var r in n)
220
- r !== "key" && (c[r] = n[r]);
221
- } else c = n;
222
- return d && S(
223
- c,
217
+ if (t = null, l !== void 0 && (f(l), t = "" + l), b(n) && (f(n.key), t = "" + n.key), "key" in n) {
218
+ l = {};
219
+ for (var s in n)
220
+ s !== "key" && (l[s] = n[s]);
221
+ } else l = n;
222
+ return t && _(
223
+ l,
224
224
  typeof e == "function" ? e.displayName || e.name || "Unknown" : e
225
- ), V(
225
+ ), W(
226
226
  e,
227
- d,
228
- c,
227
+ t,
228
+ l,
229
229
  o(),
230
- P,
231
- $
230
+ O,
231
+ Y
232
232
  );
233
233
  }
234
- function M(e) {
235
- E(e) ? e._store && (e._store.validated = 1) : typeof e == "object" && e !== null && e.$$typeof === N && (e._payload.status === "fulfilled" ? E(e._payload.value) && e._payload.value._store && (e._payload.value._store.validated = 1) : e._store && (e._store.validated = 1));
234
+ function F(e) {
235
+ h(e) ? e._store && (e._store.validated = 1) : typeof e == "object" && e !== null && e.$$typeof === C && (e._payload.status === "fulfilled" ? h(e._payload.value) && e._payload.value._store && (e._payload.value._store.validated = 1) : e._store && (e._store.validated = 1));
236
236
  }
237
- function E(e) {
238
- return typeof e == "object" && e !== null && e.$$typeof === z;
237
+ function h(e) {
238
+ return typeof e == "object" && e !== null && e.$$typeof === U;
239
239
  }
240
- var O = ue, z = Symbol.for("react.transitional.element"), te = Symbol.for("react.portal"), _ = Symbol.for("react.fragment"), B = Symbol.for("react.strict_mode"), b = Symbol.for("react.profiler"), J = Symbol.for("react.consumer"), A = Symbol.for("react.context"), H = Symbol.for("react.forward_ref"), T = Symbol.for("react.suspense"), G = Symbol.for("react.suspense_list"), X = Symbol.for("react.memo"), N = Symbol.for("react.lazy"), Z = Symbol.for("react.activity"), re = Symbol.for("react.client.reference"), w = O.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, x = Object.prototype.hasOwnProperty, ne = Array.isArray, y = console.createTask ? console.createTask : function() {
240
+ var A = ce, U = Symbol.for("react.transitional.element"), K = Symbol.for("react.portal"), x = Symbol.for("react.fragment"), V = Symbol.for("react.strict_mode"), v = Symbol.for("react.profiler"), z = Symbol.for("react.consumer"), w = Symbol.for("react.context"), B = Symbol.for("react.forward_ref"), S = Symbol.for("react.suspense"), J = Symbol.for("react.suspense_list"), I = Symbol.for("react.memo"), C = Symbol.for("react.lazy"), H = Symbol.for("react.activity"), ee = Symbol.for("react.client.reference"), T = A.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, y = Object.prototype.hasOwnProperty, te = Array.isArray, E = console.createTask ? console.createTask : function() {
241
241
  return null;
242
242
  };
243
- O = {
243
+ A = {
244
244
  react_stack_bottom_frame: function(e) {
245
245
  return e();
246
246
  }
247
247
  };
248
- var k, C = {}, Q = O.react_stack_bottom_frame.bind(
249
- O,
250
- f
251
- )(), Y = y(s(f)), j = {};
252
- L.Fragment = _, L.jsx = function(e, n, c) {
253
- var u = 1e4 > w.recentlyCreatedOwnerStacks++;
254
- return I(
248
+ var k, G = {}, M = A.react_stack_bottom_frame.bind(
249
+ A,
250
+ u
251
+ )(), j = E(a(u)), X = {};
252
+ q.Fragment = x, q.jsx = function(e, n, l) {
253
+ var c = 1e4 > T.recentlyCreatedOwnerStacks++;
254
+ return D(
255
255
  e,
256
256
  n,
257
- c,
257
+ l,
258
258
  !1,
259
- u ? Error("react-stack-top-frame") : Q,
260
- u ? y(s(e)) : Y
259
+ c ? Error("react-stack-top-frame") : M,
260
+ c ? E(a(e)) : j
261
261
  );
262
- }, L.jsxs = function(e, n, c) {
263
- var u = 1e4 > w.recentlyCreatedOwnerStacks++;
264
- return I(
262
+ }, q.jsxs = function(e, n, l) {
263
+ var c = 1e4 > T.recentlyCreatedOwnerStacks++;
264
+ return D(
265
265
  e,
266
266
  n,
267
- c,
267
+ l,
268
268
  !0,
269
- u ? Error("react-stack-top-frame") : Q,
270
- u ? y(s(e)) : Y
269
+ c ? Error("react-stack-top-frame") : M,
270
+ c ? E(a(e)) : j
271
271
  );
272
272
  };
273
- })()), L;
273
+ })()), q;
274
274
  }
275
- var se;
276
- function ge() {
277
- return se || (se = 1, process.env.NODE_ENV === "production" ? ee.exports = me() : ee.exports = pe()), ee.exports;
275
+ var ae;
276
+ function pe() {
277
+ return ae || (ae = 1, process.env.NODE_ENV === "production" ? Q.exports = fe() : Q.exports = me()), Q.exports;
278
278
  }
279
- var g = ge();
280
- const ve = ({
281
- value: p,
282
- onChange: v,
283
- isDisabled: m,
284
- label: s
285
- }) => /* @__PURE__ */ g.jsxs(
286
- "div",
287
- {
288
- className: "superdoc-esign-signature-input",
289
- style: { display: "flex", flexDirection: "column", gap: "8px" },
290
- children: [
291
- s && /* @__PURE__ */ g.jsx("label", { children: s }),
292
- /* @__PURE__ */ g.jsx(
293
- "input",
294
- {
295
- type: "text",
296
- value: String(p || ""),
297
- onChange: (o) => v(o.target.value),
298
- disabled: m,
299
- placeholder: "Type your full name",
300
- style: {
301
- fontFamily: "cursive",
302
- fontSize: "18px"
303
- }
304
- }
305
- )
306
- ]
307
- }
308
- ), be = ({
309
- value: p,
310
- onChange: v,
311
- isDisabled: m,
312
- label: s
313
- }) => /* @__PURE__ */ g.jsxs(
279
+ var p = pe();
280
+ const ge = ({
281
+ value: m,
282
+ onChange: g,
283
+ isDisabled: f,
284
+ label: a
285
+ }) => /* @__PURE__ */ p.jsxs("div", { className: "superdoc-esign-signature-input", style: { display: "flex", flexDirection: "column", gap: "8px" }, children: [
286
+ a && /* @__PURE__ */ p.jsx("label", { children: a }),
287
+ /* @__PURE__ */ p.jsx(
288
+ "input",
289
+ {
290
+ type: "text",
291
+ value: String(m || ""),
292
+ onChange: (o) => g(o.target.value),
293
+ disabled: f,
294
+ placeholder: "Type your full name",
295
+ style: {
296
+ fontFamily: "cursive",
297
+ fontSize: "18px"
298
+ }
299
+ }
300
+ )
301
+ ] }), ve = ({
302
+ value: m,
303
+ onChange: g,
304
+ isDisabled: f,
305
+ label: a
306
+ }) => /* @__PURE__ */ p.jsxs(
314
307
  "label",
315
308
  {
316
309
  className: "superdoc-esign-checkbox-input",
317
310
  style: { display: "flex", gap: "8px" },
318
311
  children: [
319
- /* @__PURE__ */ g.jsx(
312
+ /* @__PURE__ */ p.jsx(
320
313
  "input",
321
314
  {
322
315
  type: "checkbox",
323
- checked: !!p,
324
- onChange: (o) => v(o.target.checked),
325
- disabled: m
316
+ checked: !!m,
317
+ onChange: (o) => g(o.target.checked),
318
+ disabled: f
326
319
  }
327
320
  ),
328
- /* @__PURE__ */ g.jsx("span", { children: s })
321
+ /* @__PURE__ */ p.jsx("span", { children: a })
329
322
  ]
330
323
  }
331
- ), he = (p) => ({
332
- onClick: m,
333
- fileName: s,
324
+ ), be = (m) => ({
325
+ onClick: f,
326
+ fileName: a,
334
327
  isDisabled: o
335
328
  }) => {
336
- const f = p?.label || "Download";
337
- return /* @__PURE__ */ g.jsxs(
329
+ const u = m?.label || "Download";
330
+ return /* @__PURE__ */ p.jsxs(
338
331
  "button",
339
332
  {
340
- onClick: m,
333
+ onClick: f,
341
334
  disabled: o,
342
335
  className: "superdoc-esign-btn",
343
336
  style: {
@@ -352,24 +345,24 @@ const ve = ({
352
345
  fontWeight: "bold"
353
346
  },
354
347
  children: [
355
- f,
348
+ u,
356
349
  " ",
357
- s && `(${s})`
350
+ a && `(${a})`
358
351
  ]
359
352
  }
360
353
  );
361
- }, Ee = (p) => ({
362
- onClick: m,
363
- isValid: s,
354
+ }, he = (m) => ({
355
+ onClick: f,
356
+ isValid: a,
364
357
  isDisabled: o,
365
- isSubmitting: f
358
+ isSubmitting: u
366
359
  }) => {
367
- const h = () => p?.label || "Submit";
368
- return /* @__PURE__ */ g.jsx(
360
+ const b = () => m?.label || "Submit";
361
+ return /* @__PURE__ */ p.jsx(
369
362
  "button",
370
363
  {
371
- onClick: m,
372
- disabled: !s || o || f,
364
+ onClick: f,
365
+ disabled: !a || o || u,
373
366
  className: "superdoc-esign-btn",
374
367
  style: {
375
368
  padding: "12px 24px",
@@ -377,314 +370,286 @@ const ve = ({
377
370
  border: "none",
378
371
  background: "#007bff",
379
372
  color: "#fff",
380
- cursor: !s || o ? "not-allowed" : "pointer",
381
- opacity: !s || o ? 0.5 : 1,
373
+ cursor: !a || o ? "not-allowed" : "pointer",
374
+ opacity: !a || o ? 0.5 : 1,
382
375
  fontSize: "16px",
383
376
  fontWeight: "bold"
384
377
  },
385
- children: h()
378
+ children: b()
386
379
  }
387
380
  );
388
- }, xe = de((p, v) => {
389
- const {
390
- eventId: m,
391
- document: s,
392
- fields: o = {},
393
- download: f,
394
- submit: h,
395
- onSubmit: S,
396
- onDownload: W,
397
- onStateChange: V,
398
- onFieldChange: I,
399
- onFieldsDiscovered: M,
400
- isDisabled: E = !1,
401
- className: O,
402
- style: z,
403
- documentHeight: te = "600px"
404
- } = p, [_, B] = D(
405
- !s.validation?.scroll?.required
406
- ), [b, J] = D(
407
- /* @__PURE__ */ new Map()
408
- ), [A, H] = D(!1), [T, G] = D(!1), [X, N] = D([]), [Z, re] = D(!1), w = U(null), x = U(null), ne = U(Date.now()), y = U(o), k = U([]);
409
- y.current = o, K(() => {
410
- k.current = X;
411
- }, [X]);
412
- const C = F((t) => {
413
- if (!x.current?.activeEditor) return;
414
- const r = x.current.activeEditor, a = y.current.signer?.find(
415
- (i) => i.id === t.id
416
- );
417
- let l;
418
- a?.type === "signature" && t.value ? l = {
419
- json: {
420
- type: "image",
421
- attrs: { src: typeof t.value == "string" && t.value.startsWith("data:image/") ? t.value : Q(String(t.value)), alt: "Signature" }
422
- }
423
- } : l = { text: String(t.value ?? "") }, t.id && r.commands.updateStructuredContentById(t.id, l);
424
- }, []);
425
- function Q(t) {
426
- const r = globalThis.document.createElement("canvas"), a = r.getContext("2d"), l = 30;
427
- a.font = `italic ${l}px cursive`;
428
- const R = a.measureText(t).width, ie = l * 1.3, ce = 4, le = 6;
429
- return r.width = Math.ceil(R + ce * 2) + 20, r.height = Math.ceil(ie + le * 2), a.font = `italic ${l}px cursive`, a.fillStyle = "black", a.textAlign = "center", a.textBaseline = "middle", a.fillText(t, r.width / 2, r.height / 2), r.toDataURL("image/png");
430
- }
431
- const Y = F(
432
- (t) => {
433
- if (!t) return;
434
- const r = t.helpers.structuredContentCommands.getStructuredContentTags(
435
- t.state
436
- ), a = /* @__PURE__ */ new Map();
437
- y.current.document?.forEach((i) => {
438
- i.id && a.set(i.id, i.value);
439
- }), y.current.signer?.forEach((i) => {
440
- i.value !== void 0 && a.set(i.id, i.value);
441
- });
442
- const l = r.map(({ node: i }) => ({
443
- id: i.attrs.id,
444
- label: i.attrs.label,
445
- value: a.get(i.attrs.id) ?? i.textContent ?? ""
446
- })).filter((i) => i.id);
447
- l.length > 0 && (M?.(l), [
448
- ...y.current.document || [],
449
- ...y.current.signer || []
450
- ].filter((R) => R.value !== void 0).forEach(
451
- (R) => C({
452
- id: R.id,
453
- value: R.value
454
- })
455
- ));
456
- },
457
- [M, C]
458
- ), j = (t) => {
459
- const r = {
460
- ...t,
461
- timestamp: (/* @__PURE__ */ new Date()).toISOString()
462
- }, a = globalThis?.__SUPERDOC_AUDIT_MOCK__;
463
- a && a(r);
464
- const l = [...k.current, r];
465
- return k.current = l, N(l), l;
466
- };
467
- K(() => w.current ? ((async () => {
468
- const { SuperDoc: r } = await import("./superdoc.es-CqejOF1J.js").then((l) => l.D), a = new r({
469
- selector: w.current,
470
- document: s.source,
471
- documentMode: "viewing",
472
- onReady: () => {
473
- a.activeEditor && Y(a.activeEditor), j({ type: "ready" }), re(!0);
474
- }
475
- });
476
- x.current = a;
477
- })(), () => {
478
- x.current && (typeof x.current.destroy == "function" && x.current.destroy(), x.current = null);
479
- }) : void 0, [s.source, s.mode, Y]), K(() => {
480
- if (!s.validation?.scroll?.required || !Z) return;
481
- const t = w.current;
482
- if (!t) return;
483
- const r = () => {
484
- const { scrollTop: a, scrollHeight: l, clientHeight: i } = t, R = a / (l - i);
485
- (R >= 0.95 || l <= i) && (B(!0), j({
486
- type: "scroll",
487
- data: { percent: Math.round(R * 100) }
488
- }));
381
+ }, Ee = ue(
382
+ (m, g) => {
383
+ const {
384
+ eventId: f,
385
+ document: a,
386
+ fields: o = {},
387
+ download: u,
388
+ submit: b,
389
+ onSubmit: _,
390
+ onDownload: L,
391
+ onStateChange: W,
392
+ onFieldChange: D,
393
+ onFieldsDiscovered: F,
394
+ isDisabled: h = !1,
395
+ className: A,
396
+ style: U,
397
+ documentHeight: K = "600px"
398
+ } = m, [x, V] = N(
399
+ !a.validation?.scroll?.required
400
+ ), [v, z] = N(/* @__PURE__ */ new Map()), [w, B] = N(!1), [S, J] = N(!1), [I, C] = N([]), [H, ee] = N(!1), T = Z(null), y = Z(null), te = Z(Date.now()), E = Z(o);
401
+ E.current = o;
402
+ const k = P((t) => {
403
+ if (!y.current?.activeEditor) return;
404
+ const r = y.current.activeEditor, s = E.current.signer?.find((i) => i.id === t.id);
405
+ let d;
406
+ s?.type === "signature" && t.value ? d = {
407
+ json: {
408
+ type: "image",
409
+ attrs: { src: typeof t.value == "string" && t.value.startsWith("data:image/") ? t.value : G(String(t.value)), alt: "Signature" }
410
+ }
411
+ } : d = { text: String(t.value ?? "") }, t.id && r.commands.updateStructuredContentById(
412
+ t.id,
413
+ d
414
+ );
415
+ }, []);
416
+ function G(t) {
417
+ const r = globalThis.document.createElement("canvas"), s = r.getContext("2d"), d = 30;
418
+ s.font = `italic ${d}px cursive`;
419
+ const R = s.measureText(t).width, se = d * 1.3, ie = 4, le = 6;
420
+ return r.width = Math.ceil(R + ie * 2) + 20, r.height = Math.ceil(se + le * 2), s.font = `italic ${d}px cursive`, s.fillStyle = "black", s.textAlign = "center", s.textBaseline = "middle", s.fillText(
421
+ t,
422
+ r.width / 2,
423
+ r.height / 2
424
+ ), r.toDataURL("image/png");
425
+ }
426
+ const M = P(
427
+ (t) => {
428
+ if (!t) return;
429
+ const r = t.helpers.structuredContentCommands.getStructuredContentTags(
430
+ t.state
431
+ ), s = /* @__PURE__ */ new Map();
432
+ E.current.document?.forEach((i) => {
433
+ i.id && s.set(i.id, i.value);
434
+ }), E.current.signer?.forEach((i) => {
435
+ i.value !== void 0 && s.set(i.id, i.value);
436
+ });
437
+ const d = r.map(({ node: i }) => ({
438
+ id: i.attrs.id,
439
+ label: i.attrs.label,
440
+ value: s.get(i.attrs.id) ?? i.textContent ?? ""
441
+ })).filter((i) => i.id);
442
+ d.length > 0 && (F?.(d), [
443
+ ...E.current.document || [],
444
+ ...E.current.signer || []
445
+ ].filter((R) => R.value !== void 0).forEach(
446
+ (R) => k({
447
+ id: R.id,
448
+ value: R.value
449
+ })
450
+ ));
451
+ },
452
+ [F, k]
453
+ ), j = (t) => {
454
+ const r = {
455
+ ...t,
456
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
457
+ };
458
+ C((s) => [...s, r]);
489
459
  };
490
- return t.addEventListener("scroll", r), r(), () => t.removeEventListener("scroll", r);
491
- }, [s.validation?.scroll?.required, Z]);
492
- const e = F(
493
- (t, r) => {
494
- J((a) => {
495
- const l = a.get(t), i = new Map(a);
496
- return i.set(t, r), C({
497
- id: t,
498
- value: r
499
- }), j({
500
- type: "field_change",
501
- data: { fieldId: t, value: r, previousValue: l }
502
- }), I?.({
503
- id: t,
504
- value: r,
505
- previousValue: l
506
- }), i;
460
+ re(() => T.current ? ((async () => {
461
+ const { SuperDoc: r } = await import("./superdoc.es-CqejOF1J.js").then((d) => d.D), s = new r({
462
+ selector: T.current,
463
+ document: a.source,
464
+ documentMode: "viewing",
465
+ onReady: () => {
466
+ s.activeEditor && M(s.activeEditor), j({ type: "ready" }), ee(!0);
467
+ }
507
468
  });
508
- },
509
- [I, C]
510
- ), n = F(() => s.validation?.scroll?.required && !_ ? !1 : (o.signer || []).every((t) => {
511
- if (!t.validation?.required) return !0;
512
- const r = b.get(t.id);
513
- return r && (typeof r != "string" || r.trim());
514
- }), [
515
- _,
516
- o.signer,
517
- b,
518
- s.validation?.scroll?.required
519
- ]);
520
- K(() => {
521
- const t = n();
522
- H(t), V?.({
523
- scrolled: _,
524
- fields: b,
525
- isValid: t,
526
- isSubmitting: T
527
- });
528
- }, [_, b, T, n, V]);
529
- const c = F(async () => {
530
- if (E) return;
531
- const t = {
532
- eventId: m,
533
- documentSource: s.source,
534
- fields: {
535
- document: o.document || [],
536
- signer: (o.signer || []).map((r) => ({
537
- id: r.id,
538
- value: b.get(r.id) ?? null
539
- }))
469
+ y.current = s;
470
+ })(), () => {
471
+ y.current && (y.current.destroy(), y.current = null);
472
+ }) : void 0, [a.source, a.mode, M]), re(() => {
473
+ if (!a.validation?.scroll?.required || !H) return;
474
+ const t = T.current;
475
+ if (!t) return;
476
+ const r = () => {
477
+ const { scrollTop: s, scrollHeight: d, clientHeight: i } = t, R = s / (d - i);
478
+ (R >= 0.95 || d <= i) && (V(!0), j({
479
+ type: "scroll",
480
+ data: { percent: Math.round(R * 100) }
481
+ }));
482
+ };
483
+ return t.addEventListener("scroll", r), r(), () => t.removeEventListener("scroll", r);
484
+ }, [a.validation?.scroll?.required, H]);
485
+ const X = P(
486
+ (t, r) => {
487
+ z((s) => {
488
+ const d = s.get(t), i = new Map(s);
489
+ return i.set(t, r), k({
490
+ id: t,
491
+ value: r
492
+ }), j({
493
+ type: "field_change",
494
+ data: { fieldId: t, value: r, previousValue: d }
495
+ }), D?.({
496
+ id: t,
497
+ value: r,
498
+ previousValue: d
499
+ }), i;
500
+ });
540
501
  },
541
- fileName: f?.fileName || "document.pdf"
542
- };
543
- await W?.(t);
544
- }, [
545
- E,
546
- m,
547
- s.source,
548
- o,
549
- b,
550
- f,
551
- W
552
- ]), u = F(async () => {
553
- if (!A || E || T) return;
554
- G(!0), j({ type: "submit" });
555
- const t = j({ type: "submit" }), r = {
556
- eventId: m,
557
- timestamp: (/* @__PURE__ */ new Date()).toISOString(),
558
- duration: Math.floor((Date.now() - ne.current) / 1e3),
559
- auditTrail: t,
560
- documentFields: o.document || [],
561
- signerFields: (o.signer || []).map((a) => ({
562
- id: a.id,
563
- value: b.get(a.id) ?? null
564
- })),
565
- isFullyCompleted: A
502
+ [D, k]
503
+ ), e = P(() => a.validation?.scroll?.required && !x ? !1 : (o.signer || []).every((t) => {
504
+ if (!t.validation?.required) return !0;
505
+ const r = v.get(t.id);
506
+ return r && (typeof r != "string" || r.trim());
507
+ }), [x, o.signer, v, a.validation?.scroll?.required]);
508
+ re(() => {
509
+ const t = e();
510
+ B(t), W?.({
511
+ scrolled: x,
512
+ fields: v,
513
+ isValid: t,
514
+ isSubmitting: S
515
+ });
516
+ }, [x, v, S, e, W]);
517
+ const n = P(async () => {
518
+ if (h) return;
519
+ const t = {
520
+ eventId: f,
521
+ documentSource: a.source,
522
+ fields: {
523
+ document: o.document || [],
524
+ signer: (o.signer || []).map((r) => ({
525
+ id: r.id,
526
+ value: v.get(r.id) ?? null
527
+ }))
528
+ },
529
+ fileName: u?.fileName || "document.pdf"
530
+ };
531
+ await L?.(t);
532
+ }, [h, f, a.source, o, v, u, L]), l = P(async () => {
533
+ if (!w || h || S) return;
534
+ J(!0), j({ type: "submit" });
535
+ const t = {
536
+ eventId: f,
537
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
538
+ duration: Math.floor((Date.now() - te.current) / 1e3),
539
+ auditTrail: I,
540
+ documentFields: o.document || [],
541
+ signerFields: (o.signer || []).map((r) => ({
542
+ id: r.id,
543
+ value: v.get(r.id) ?? null
544
+ })),
545
+ isFullyCompleted: w
546
+ };
547
+ try {
548
+ await _(t);
549
+ } finally {
550
+ J(!1);
551
+ }
552
+ }, [
553
+ w,
554
+ h,
555
+ S,
556
+ f,
557
+ I,
558
+ o,
559
+ v,
560
+ _
561
+ ]), c = (t) => {
562
+ const r = t.component || O(t.type);
563
+ return /* @__PURE__ */ p.jsx(
564
+ r,
565
+ {
566
+ value: v.get(t.id) ?? null,
567
+ onChange: (s) => X(t.id, s),
568
+ isDisabled: h,
569
+ label: t.label
570
+ },
571
+ t.id
572
+ );
573
+ }, O = (t) => {
574
+ switch (t) {
575
+ case "signature":
576
+ case "text":
577
+ return ge;
578
+ case "checkbox":
579
+ return ve;
580
+ }
581
+ }, Y = () => {
582
+ const t = u?.component || be(u), r = b?.component || he(b);
583
+ return /* @__PURE__ */ p.jsxs(
584
+ "div",
585
+ {
586
+ className: "superdoc-esign-actions",
587
+ style: { display: "flex", gap: "10px" },
588
+ children: [
589
+ a.mode !== "download" && /* @__PURE__ */ p.jsx(
590
+ r,
591
+ {
592
+ onClick: l,
593
+ isValid: w,
594
+ isDisabled: h,
595
+ isSubmitting: S
596
+ }
597
+ ),
598
+ /* @__PURE__ */ p.jsx(
599
+ t,
600
+ {
601
+ onClick: n,
602
+ fileName: u?.fileName,
603
+ isDisabled: h
604
+ }
605
+ )
606
+ ]
607
+ }
608
+ );
566
609
  };
567
- try {
568
- await S(r);
569
- } finally {
570
- G(!1);
571
- }
572
- }, [
573
- A,
574
- E,
575
- T,
576
- m,
577
- o,
578
- b,
579
- S
580
- ]), P = (t) => {
581
- const r = t.component || $(t.type);
582
- return /* @__PURE__ */ g.jsx(
583
- r,
584
- {
585
- value: b.get(t.id) ?? null,
586
- onChange: (a) => e(t.id, a),
587
- isDisabled: E,
588
- label: t.label
589
- },
590
- t.id
591
- );
592
- }, $ = (t) => {
593
- switch (t) {
594
- case "signature":
595
- case "text":
596
- return ve;
597
- case "checkbox":
598
- return be;
599
- }
600
- }, d = () => {
601
- const t = f?.component || he(f), r = h?.component || Ee(h);
602
- return /* @__PURE__ */ g.jsxs(
610
+ return de(g, () => ({
611
+ getState: () => ({
612
+ scrolled: x,
613
+ fields: v,
614
+ isValid: w,
615
+ isSubmitting: S
616
+ }),
617
+ getAuditTrail: () => I,
618
+ reset: () => {
619
+ V(!a.validation?.scroll?.required), z(/* @__PURE__ */ new Map()), B(!1), C([]);
620
+ }
621
+ })), /* @__PURE__ */ p.jsxs(
603
622
  "div",
604
623
  {
605
- className: "superdoc-esign-actions",
606
- style: { display: "flex", gap: "10px" },
624
+ className: `superdoc-esign-container ${A || ""}`,
625
+ style: U,
607
626
  children: [
608
- s.mode !== "download" && /* @__PURE__ */ g.jsx(
609
- r,
610
- {
611
- onClick: u,
612
- isValid: A,
613
- isDisabled: E,
614
- isSubmitting: T
615
- }
616
- ),
617
- /* @__PURE__ */ g.jsx(
618
- t,
627
+ /* @__PURE__ */ p.jsx("div", { className: "superdoc-esign-document", children: /* @__PURE__ */ p.jsx(
628
+ "div",
619
629
  {
620
- onClick: c,
621
- fileName: f?.fileName,
622
- isDisabled: E
630
+ ref: T,
631
+ style: { height: K, overflow: "auto" }
623
632
  }
624
- )
625
- ]
626
- }
627
- );
628
- };
629
- return fe(v, () => ({
630
- getState: () => ({
631
- scrolled: _,
632
- fields: b,
633
- isValid: A,
634
- isSubmitting: T
635
- }),
636
- getAuditTrail: () => k.current,
637
- reset: () => {
638
- B(!s.validation?.scroll?.required), J(/* @__PURE__ */ new Map()), H(!1), k.current = [], N([]);
639
- }
640
- })), /* @__PURE__ */ g.jsxs(
641
- "div",
642
- {
643
- className: `superdoc-esign-container ${O || ""}`,
644
- style: z,
645
- children: [
646
- /* @__PURE__ */ g.jsx(
647
- "div",
648
- {
649
- className: "superdoc-esign-document",
650
- "data-testid": "superdoc-esign-document",
651
- children: /* @__PURE__ */ g.jsx(
633
+ ) }),
634
+ /* @__PURE__ */ p.jsxs("div", { className: "superdoc-esign-controls", style: { marginTop: "20px" }, children: [
635
+ o.signer && o.signer.length > 0 && /* @__PURE__ */ p.jsx(
652
636
  "div",
653
637
  {
654
- ref: w,
655
- "data-testid": "superdoc-scroll-container",
656
- style: { height: te, overflow: "auto" }
638
+ className: "superdoc-esign-fields",
639
+ style: { marginBottom: "20px" },
640
+ children: o.signer.map(c)
657
641
  }
658
- )
659
- }
660
- ),
661
- /* @__PURE__ */ g.jsxs(
662
- "div",
663
- {
664
- className: "superdoc-esign-controls",
665
- style: { marginTop: "20px" },
666
- "data-testid": "superdoc-esign-controls",
667
- children: [
668
- o.signer && o.signer.length > 0 && /* @__PURE__ */ g.jsx(
669
- "div",
670
- {
671
- className: "superdoc-esign-fields",
672
- style: { marginBottom: "20px" },
673
- "data-testid": "superdoc-esign-fields",
674
- children: o.signer.map(P)
675
- }
676
- ),
677
- d()
678
- ]
679
- }
680
- )
681
- ]
682
- }
683
- );
684
- });
685
- xe.displayName = "SuperDocESign";
642
+ ),
643
+ Y()
644
+ ] })
645
+ ]
646
+ }
647
+ );
648
+ }
649
+ );
650
+ Ee.displayName = "SuperDocESign";
686
651
  export {
687
- be as CheckboxInput,
688
- ve as SignatureInput,
689
- xe as default
652
+ ve as CheckboxInput,
653
+ ge as SignatureInput,
654
+ Ee as default
690
655
  };