@signosoft/signpad-js 0.0.1 → 0.1.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.
@@ -1,5 +1,5 @@
1
1
  import { unsafeCSS as Bg, LitElement as Qg, html as t } from "lit";
2
- import { property as l, query as Eg, state as cA, customElement as ig } from "lit/decorators.js";
2
+ import { property as l, query as Eg, state as v, customElement as ig } from "lit/decorators.js";
3
3
  class Dg {
4
4
  constructor(A, C = {
5
5
  minThickness: 1,
@@ -19,8 +19,8 @@ class Dg {
19
19
  * allowing subsequent drawing operations to use logical (CSS) pixel coordinates.
20
20
  */
21
21
  configureCanvasForDPI() {
22
- const A = window.devicePixelRatio || 1, C = this.canvas.getBoundingClientRect(), B = C.width, i = C.height;
23
- this.canvas.width = B * A, this.canvas.height = i * A, this.ctx.scale(A, A);
22
+ const A = window.devicePixelRatio || 1, C = this.canvas.getBoundingClientRect(), B = C.width, D = C.height;
23
+ this.canvas.width = B * A, this.canvas.height = D * A, this.ctx.scale(A, A);
24
24
  }
25
25
  /**
26
26
  * Applies drawing styles to the canvas context.
@@ -42,8 +42,8 @@ class Dg {
42
42
  * @param penData - The pen data (x, y, pressure, inContact), normalized (0-1).
43
43
  */
44
44
  drawSegment(A) {
45
- const C = this.ctx, B = this.canvas, i = this.currentDrawingOptions, U = A.x * B.width / (window.devicePixelRatio || 1), N = A.y * B.height / (window.devicePixelRatio || 1), h = i.minThickness + (i.maxThickness - i.minThickness) * A.pressure;
46
- C.strokeStyle = i.color, C.lineWidth = h, A.inContact ? this.lastDrawPoint ? (C.beginPath(), C.moveTo(this.lastDrawPoint.x, this.lastDrawPoint.y), C.lineTo(U, N), C.stroke(), this.lastDrawPoint = { x: U, y: N }) : this.lastDrawPoint = { x: U, y: N } : this.lastDrawPoint = null;
45
+ const C = this.ctx, B = this.canvas, D = this.currentDrawingOptions, U = A.x * B.width / (window.devicePixelRatio || 1), w = A.y * B.height / (window.devicePixelRatio || 1), h = D.minThickness + (D.maxThickness - D.minThickness) * A.pressure;
46
+ C.strokeStyle = D.color, C.lineWidth = h, A.inContact ? this.lastDrawPoint ? (C.beginPath(), C.moveTo(this.lastDrawPoint.x, this.lastDrawPoint.y), C.lineTo(U, w), C.stroke(), this.lastDrawPoint = { x: U, y: w }) : this.lastDrawPoint = { x: U, y: w } : this.lastDrawPoint = null;
47
47
  }
48
48
  /**
49
49
  * Clears the entire drawing surface of the canvas.
@@ -76,10 +76,10 @@ class og {
76
76
  * @param inContact Whether the mouse button is currently down.
77
77
  */
78
78
  _processMouseEvent(A, C) {
79
- const B = this.canvas.getBoundingClientRect(), i = (A.clientX - B.left) / B.width, U = (A.clientY - B.top) / B.height;
79
+ const B = this.canvas.getBoundingClientRect(), D = (A.clientX - B.left) / B.width, U = (A.clientY - B.top) / B.height;
80
80
  this.sessionStartTime === null && (this.sessionStartTime = Date.now());
81
81
  const h = (Date.now() - this.sessionStartTime) / 1e3, y = {
82
- x: i,
82
+ x: D,
83
83
  y: U,
84
84
  pressure: C ? 0.5 : 0,
85
85
  inContact: C,
@@ -117,7 +117,7 @@ class og {
117
117
  this.removeListeners(), this.resetSession();
118
118
  }
119
119
  }
120
- const Ug = ":host{--sign-top-bar-bg-base: #e3e4fc;--sign-top-bar-text-base: #4e56ea;--sign-canvas-bg-base: #f1f2fd;--sign-line-height-base: 22px;--sign-line-border-base: #7178ee;--sign-line-additional-text-color: #333e4a;--sign-bottom-bar-bg-base: #e3e4fc;--sign-button-primary-bg-base: #4e56ea;--sign-button-primary-bg-hover: #7178ee;--sign-button-primary-bg-disabled: #b5b9be;--sign-button-primary-text-base: #ffffff;--sign-button-primary-text-hover: #ffffff;--sign-button-primary-text-disabled: white;--sign-button-link-bg-base: transparent;--sign-button-link-bg-hover: #e3e4fc;--sign-button-link-bg-disabled: transparent;--sign-button-link-text-base: #4e56ea;--sign-button-link-text-hover: #7178ee;--sign-button-link-text-disabled: #b5b9be;--sign-button-link-border-base: 1px solid #4e56ea;--sign-button-link-border-hover: 1px solid #7178ee;--sign-button-link-border-disabled: 1px solid #b5b9be;--sign-device-state-text-color-connected: green;--sign-device-state-text-color-disconnected: red}html{font-family:Arial,Helvetica,sans-serif!important}.signpad-canvas-container{display:flex;flex-direction:column;width:100%;height:100%}.signpad-top-bar{display:flex;justify-content:space-between;padding:16px 32px;min-height:48px;background-color:var(--sign-top-bar-bg-base);color:var(--sign-top-bar-text-base)}.signpad-canvas-wrapper{position:relative;width:100%;padding-top:16px;padding-bottom:56.25%;height:0;background-color:var(--sign-canvas-bg-base);box-sizing:border-box;overflow:hidden}.signpad-canvas{position:absolute;width:100%;height:calc(100% - var(--sign-line-height-base));left:0;top:0}.signpad-canvas-line-container{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;height:var(--sign-line-height-base);border-top:2px solid var(--sign-line-border-base);box-sizing:border-box;padding-top:6px;margin:16px 32px}.signpad-canvas-line-additional-text{font-size:12px;color:var(--sign-line-additional-text-color);margin:0}.signpad-bottom-bar{display:flex;flex-direction:row;gap:12px;padding:16px 32px;min-height:50px;background-color:var(--sign-bottom-bar-bg-base)}.btn{font-family:inherit;min-height:44px;padding:14px 16px;margin:0;border:none;font-weight:500;font-size:16px;border-radius:8px;transition:background-color .3s ease,color .3s ease,transform .1s ease}.btn:hover:not(:disabled){cursor:pointer}.btn:focus:not(:disabled){outline:none}.ok-button,.clear-button,.cancel-button{width:100%}.btn-primary{background-color:var(--sign-button-primary-bg-base);color:var(--sign-button-primary-text-base)}.btn-primary:hover:not(:disabled){background-color:var(--sign-button-primary-bg-hover);color:var(--sign-button-primary-text-hover)}.btn-primary:disabled{background-color:var(--sign-button-primary-bg-disabled);color:var(--sign-button-primary-text-disabled)}.btn-link{background-color:var(--sign-button-link-bg-base);color:var(--sign-button-link-text-base);border:var(--sign-button-link-border-base)}.btn-link:hover:not(:disabled){background-color:var(--sign-button-link-bg-hover);color:var(--sign-button-link-text-hover);border:var(--sign-button-link-border-hover)}.btn-link:disabled{background-color:var(--sign-button-link-bg-disabled);color:var(--sign-button-link-text-disabled);border:var(--sign-button-link-border-disabled)}.signpad-canvas-line-state{font-size:12px;color:var(--sign-device-state-text-color-disconnected);margin:0}.signpad-canvas-line-state.connected{color:var(--sign-device-state-text-color-connected)}";
120
+ const Ug = ":host{--sign-font-family: Arial, Helvetica, sans-serif;--sign-top-bar-bg-base: #e3e4fc;--sign-top-bar-text-base: #4e56ea;--sign-canvas-bg-base: #f1f2fd;--sign-line-height-base: 22px;--sign-line-border-base: #7178ee;--sign-line-additional-text-color: #333e4a;--sign-bottom-bar-bg-base: #e3e4fc;--sign-button-primary-bg-base: #4e56ea;--sign-button-primary-bg-hover: #7178ee;--sign-button-primary-bg-disabled: #b5b9be;--sign-button-primary-text-base: #ffffff;--sign-button-primary-text-hover: #ffffff;--sign-button-primary-text-disabled: white;--sign-button-link-bg-base: transparent;--sign-button-link-bg-hover: #e3e4fc;--sign-button-link-bg-disabled: transparent;--sign-button-link-text-base: #4e56ea;--sign-button-link-text-hover: #7178ee;--sign-button-link-text-disabled: #b5b9be;--sign-button-link-border-base: 1px solid #4e56ea;--sign-button-link-border-hover: 1px solid #7178ee;--sign-button-link-border-disabled: 1px solid #b5b9be;--sign-device-state-text-color-connected: green;--sign-device-state-text-color-disconnected: red;--sign-loading-overlay-bg-color: rgba(255, 255, 255, .8);--sign-loading-overlay-text-color: #333e4a;--sign-loading-overlay-spinner-color: #4e56ea;--sign-loading-overlay-spinner-border-color: rgba(78, 86, 234, .1);--sign-loading-overlay-spinner-size: 30px}html{font-family:var(--sign-font-family)!important}.signpad-canvas-container{display:flex;flex-direction:column;width:100%;height:100%}.signpad-top-bar{display:flex;justify-content:space-between;padding:16px 32px;min-height:48px;background-color:var(--sign-top-bar-bg-base);color:var(--sign-top-bar-text-base)}.signpad-canvas-wrapper{position:relative;width:100%;padding-top:16px;padding-bottom:56.25%;height:0;background-color:var(--sign-canvas-bg-base);box-sizing:border-box;overflow:hidden}.signpad-canvas{position:absolute;width:100%;height:calc(100% - var(--sign-line-height-base));left:0;top:0}.signpad-canvas-line-container{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;height:var(--sign-line-height-base);border-top:2px solid var(--sign-line-border-base);box-sizing:border-box;padding-top:6px;margin:16px 32px}.signpad-canvas-line-additional-text{font-size:12px;color:var(--sign-line-additional-text-color);margin:0}.signpad-bottom-bar{display:flex;flex-direction:row;gap:12px;padding:16px 32px;min-height:50px;background-color:var(--sign-bottom-bar-bg-base)}.btn{font-family:inherit;min-height:44px;padding:14px 16px;margin:0;border:none;font-weight:500;font-size:16px;border-radius:8px;transition:background-color .3s ease,color .3s ease,transform .1s ease}.btn:hover:not(:disabled){cursor:pointer}.btn:focus:not(:disabled){outline:none}.ok-button,.clear-button,.cancel-button{width:100%}.btn-primary{background-color:var(--sign-button-primary-bg-base);color:var(--sign-button-primary-text-base)}.btn-primary:hover:not(:disabled){background-color:var(--sign-button-primary-bg-hover);color:var(--sign-button-primary-text-hover)}.btn-primary:disabled{background-color:var(--sign-button-primary-bg-disabled);color:var(--sign-button-primary-text-disabled)}.btn-link{background-color:var(--sign-button-link-bg-base);color:var(--sign-button-link-text-base);border:var(--sign-button-link-border-base)}.btn-link:hover:not(:disabled){background-color:var(--sign-button-link-bg-hover);color:var(--sign-button-link-text-hover);border:var(--sign-button-link-border-hover)}.btn-link:disabled{background-color:var(--sign-button-link-bg-disabled);color:var(--sign-button-link-text-disabled);border:var(--sign-button-link-border-disabled)}.signpad-canvas-line-state{font-size:12px;color:var(--sign-device-state-text-color-disconnected);margin:0}.signpad-canvas-line-state.connected{color:var(--sign-device-state-text-color-connected)}.signpad-loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:var(--sign-loading-overlay-bg-color);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:10;color:var(--sign-loading-overlay-text-color);font-size:16px;text-align:center;gap:10px}.signpad-loading-overlay .spinner{border:4px solid var(--sign-loading-overlay-spinner-border-color);border-left-color:var(--sign-loading-overlay-spinner-color);border-radius:50%;width:var(--sign-loading-overlay-spinner-size);height:var(--sign-loading-overlay-spinner-size);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}";
121
121
  let rA = class {
122
122
  constructor() {
123
123
  this.device = null, this.isWasmInitialized = !1, this.Module = null, this.eventCallbacks = /* @__PURE__ */ new Map(), this.callbackToHandle = /* @__PURE__ */ new Map(), this.masterCallback = null, this.penAspectCorrector = null;
@@ -125,27 +125,27 @@ let rA = class {
125
125
  };
126
126
  typeof module < "u" && module.exports && (module.exports = { WacomTablet: rA });
127
127
  typeof rA < "u" && (window.WacomTablet = rA);
128
- var UA = (() => {
129
- var D = typeof document < "u" ? document.currentScript?.src : void 0;
128
+ var SA = (() => {
129
+ var i = typeof document < "u" ? document.currentScript?.src : void 0;
130
130
  return (async function(A = {}) {
131
- var C, B = A, i, U, N = new Promise((I, g) => {
132
- i = I, U = g;
131
+ var C, B = A, D, U, w = new Promise((I, g) => {
132
+ D = I, U = g;
133
133
  }), h = typeof window == "object", y = typeof WorkerGlobalScope < "u", W = typeof process == "object" && process.versions?.node && process.type != "renderer";
134
- typeof __filename < "u" ? D = __filename : y && (D = self.location.href);
134
+ typeof __filename < "u" ? i = __filename : y && (i = self.location.href);
135
135
  var p = "", m, x;
136
136
  if (W) {
137
- var $ = require("fs");
138
- require("path"), p = __dirname + "/", x = (I) => (I = FA(I) ? new URL(I) : I, $.readFileSync(I)), m = async (I) => (I = FA(I) ? new URL(I) : I, $.readFileSync(I, void 0)), process.argv.slice(2);
137
+ var AA = require("fs");
138
+ require("path"), p = __dirname + "/", x = (I) => (I = RA(I) ? new URL(I) : I, AA.readFileSync(I)), m = async (I) => (I = RA(I) ? new URL(I) : I, AA.readFileSync(I, void 0)), process.argv.slice(2);
139
139
  } else if (h || y) {
140
140
  try {
141
- p = new URL(".", D).href;
141
+ p = new URL(".", i).href;
142
142
  } catch {
143
143
  }
144
144
  y && (x = (I) => {
145
145
  var g = new XMLHttpRequest();
146
146
  return g.open("GET", I, !1), g.responseType = "arraybuffer", g.send(null), new Uint8Array(g.response);
147
147
  }), m = async (I) => {
148
- if (FA(I)) return new Promise((Q, E) => {
148
+ if (RA(I)) return new Promise((Q, E) => {
149
149
  var o = new XMLHttpRequest();
150
150
  o.open("GET", I, !0), o.responseType = "arraybuffer", o.onload = () => {
151
151
  o.status == 200 || o.status == 0 && o.response ? Q(o.response) : E(o.status);
@@ -157,23 +157,23 @@ var UA = (() => {
157
157
  };
158
158
  }
159
159
  console.log.bind(console);
160
- var O = console.error.bind(console), AA, SA, jA = !1, IA, Z, gA, b, f, c, mA, LA, OA, bA, FA = (I) => I.startsWith("file://");
160
+ var O = console.error.bind(console), IA, FA, jA = !1, gA, Z, CA, b, f, c, mA, LA, OA, bA, RA = (I) => I.startsWith("file://");
161
161
  function fA() {
162
- var I = SA.buffer;
163
- IA = new Int8Array(I), gA = new Int16Array(I), B.HEAPU8 = Z = new Uint8Array(I), b = new Uint16Array(I), f = new Int32Array(I), c = new Uint32Array(I), mA = new Float32Array(I), bA = new Float64Array(I), LA = new BigInt64Array(I), OA = new BigUint64Array(I);
162
+ var I = FA.buffer;
163
+ gA = new Int8Array(I), CA = new Int16Array(I), B.HEAPU8 = Z = new Uint8Array(I), b = new Uint16Array(I), f = new Int32Array(I), c = new Uint32Array(I), mA = new Float32Array(I), bA = new Float64Array(I), LA = new BigInt64Array(I), OA = new BigUint64Array(I);
164
164
  }
165
- var X = 0, CA = null;
165
+ var X = 0, BA = null;
166
166
  function XA(I) {
167
167
  throw B.onAbort?.(I), I = "Aborted(" + I + ")", O(I), jA = !0, I = new WebAssembly.RuntimeError(I + ". Build with -sASSERTIONS for more info."), U(I), I;
168
168
  }
169
169
  var tA;
170
170
  async function LI(I) {
171
- if (!AA) try {
171
+ if (!IA) try {
172
172
  var g = await m(I);
173
173
  return new Uint8Array(g);
174
174
  } catch {
175
175
  }
176
- if (I == tA && AA) I = new Uint8Array(AA);
176
+ if (I == tA && IA) I = new Uint8Array(IA);
177
177
  else if (x) I = x(I);
178
178
  else throw "both async and sync fetching of the wasm failed";
179
179
  return I;
@@ -188,7 +188,7 @@ var UA = (() => {
188
188
  }
189
189
  async function lI(I) {
190
190
  var g = tA;
191
- if (!AA && typeof WebAssembly.instantiateStreaming == "function" && !FA(g) && !W) try {
191
+ if (!IA && typeof WebAssembly.instantiateStreaming == "function" && !RA(g) && !W) try {
192
192
  var Q = fetch(g, { credentials: "same-origin" });
193
193
  return await WebAssembly.instantiateStreaming(Q, I);
194
194
  } catch (E) {
@@ -207,59 +207,59 @@ var UA = (() => {
207
207
  this.Z = g - 24;
208
208
  }
209
209
  }
210
- var vA = 0, RA = {}, lA = (I) => {
210
+ var vA = 0, wA = {}, lA = (I) => {
211
211
  for (; I.length; ) {
212
212
  var g = I.pop();
213
213
  I.pop()(g);
214
214
  }
215
215
  };
216
- function BA(I) {
216
+ function QA(I) {
217
217
  return this.fromWireType(c[I >> 2]);
218
218
  }
219
- var v = {}, z = {}, NA = {}, wA = class extends Error {
219
+ var _ = {}, z = {}, NA = {}, JA = class extends Error {
220
220
  constructor(I) {
221
221
  super(I), this.name = "InternalError";
222
222
  }
223
- }, QA = (I, g, Q) => {
223
+ }, EA = (I, g, Q) => {
224
224
  function E(R) {
225
- if (R = Q(R), R.length !== I.length) throw new wA("Mismatched type converter count");
226
- for (var k = 0; k < I.length; ++k) T(I[k], R[k]);
225
+ if (R = Q(R), R.length !== I.length) throw new JA("Mismatched type converter count");
226
+ for (var k = 0; k < I.length; ++k) e(I[k], R[k]);
227
227
  }
228
228
  I.forEach((R) => NA[R] = g);
229
229
  var o = Array(g.length), S = [], F = 0;
230
230
  g.forEach((R, k) => {
231
- z.hasOwnProperty(R) ? o[k] = z[R] : (S.push(R), v.hasOwnProperty(R) || (v[R] = []), v[R].push(() => {
231
+ z.hasOwnProperty(R) ? o[k] = z[R] : (S.push(R), _.hasOwnProperty(R) || (_[R] = []), _[R].push(() => {
232
232
  o[k] = z[R], ++F, F === S.length && E(o);
233
233
  }));
234
234
  }), S.length === 0 && E(o);
235
235
  }, _A, L = (I) => {
236
236
  for (var g = ""; Z[I]; ) g += _A[Z[I++]];
237
237
  return g;
238
- }, M = class extends Error {
238
+ }, s = class extends Error {
239
239
  constructor(I) {
240
240
  super(I), this.name = "BindingError";
241
241
  }
242
242
  }, VI = (I) => {
243
- throw new M(I);
243
+ throw new s(I);
244
244
  };
245
- function qI(I, g, Q = {}) {
245
+ function nI(I, g, Q = {}) {
246
246
  var E = g.name;
247
- if (!I) throw new M(`type "${E}" must have a positive integer typeid pointer`);
247
+ if (!I) throw new s(`type "${E}" must have a positive integer typeid pointer`);
248
248
  if (z.hasOwnProperty(I)) {
249
249
  if (Q.Ga) return;
250
- throw new M(`Cannot register type '${E}' twice`);
250
+ throw new s(`Cannot register type '${E}' twice`);
251
251
  }
252
- z[I] = g, delete NA[I], v.hasOwnProperty(I) && (g = v[I], delete v[I], g.forEach((o) => o()));
252
+ z[I] = g, delete NA[I], _.hasOwnProperty(I) && (g = _[I], delete _[I], g.forEach((o) => o()));
253
253
  }
254
- function T(I, g, Q = {}) {
255
- return qI(I, g, Q);
254
+ function e(I, g, Q = {}) {
255
+ return nI(I, g, Q);
256
256
  }
257
257
  var $A = (I, g, Q) => {
258
258
  switch (g) {
259
259
  case 1:
260
- return Q ? (E) => IA[E] : (E) => Z[E];
260
+ return Q ? (E) => gA[E] : (E) => Z[E];
261
261
  case 2:
262
- return Q ? (E) => gA[E >> 1] : (E) => b[E >> 1];
262
+ return Q ? (E) => CA[E >> 1] : (E) => b[E >> 1];
263
263
  case 4:
264
264
  return Q ? (E) => f[E >> 2] : (E) => c[E >> 2];
265
265
  case 8:
@@ -268,37 +268,37 @@ var UA = (() => {
268
268
  throw new TypeError(`invalid integer width (${g}): ${I}`);
269
269
  }
270
270
  }, HA = (I) => {
271
- throw new M(I.Y.aa.$.name + " instance already deleted");
271
+ throw new s(I.Y.aa.$.name + " instance already deleted");
272
272
  }, dA = !1, AI = () => {
273
- }, EA = (I) => typeof FinalizationRegistry > "u" ? (EA = (g) => g, I) : (dA = new FinalizationRegistry((g) => {
273
+ }, iA = (I) => typeof FinalizationRegistry > "u" ? (iA = (g) => g, I) : (dA = new FinalizationRegistry((g) => {
274
274
  g = g.Y, --g.count.value, g.count.value === 0 && (g.da ? g.ha.ia(g.da) : g.aa.$.ia(g.Z));
275
- }), EA = (g) => {
275
+ }), iA = (g) => {
276
276
  var Q = g.Y;
277
277
  return Q.da && dA.register(g, { Y: Q }, g), g;
278
278
  }, AI = (g) => {
279
279
  dA.unregister(g);
280
- }, EA(I));
281
- function JA() {
280
+ }, iA(I));
281
+ function kA() {
282
282
  }
283
- var kA = (I, g) => Object.defineProperty(g, "name", { value: I }), II = {}, gI = (I, g, Q) => {
283
+ var hA = (I, g) => Object.defineProperty(g, "name", { value: I }), II = {}, gI = (I, g, Q) => {
284
284
  if (I[g].ba === void 0) {
285
285
  var E = I[g];
286
286
  I[g] = function(...o) {
287
- if (!I[g].ba.hasOwnProperty(o.length)) throw new M(`Function '${Q}' called with an invalid number of arguments (${o.length}) - expects one of (${I[g].ba})!`);
287
+ if (!I[g].ba.hasOwnProperty(o.length)) throw new s(`Function '${Q}' called with an invalid number of arguments (${o.length}) - expects one of (${I[g].ba})!`);
288
288
  return I[g].ba[o.length].apply(this, o);
289
289
  }, I[g].ba = [], I[g].ba[E.la] = E;
290
290
  }
291
291
  }, VA = (I, g, Q) => {
292
292
  if (B.hasOwnProperty(I)) {
293
- if (Q === void 0 || B[I].ba !== void 0 && B[I].ba[Q] !== void 0) throw new M(`Cannot register public name '${I}' twice`);
293
+ if (Q === void 0 || B[I].ba !== void 0 && B[I].ba[Q] !== void 0) throw new s(`Cannot register public name '${I}' twice`);
294
294
  if (gI(
295
295
  B,
296
296
  I,
297
297
  I
298
- ), B[I].ba.hasOwnProperty(Q)) throw new M(`Cannot register multiple overloads of a function with the same number of arguments (${Q})!`);
298
+ ), B[I].ba.hasOwnProperty(Q)) throw new s(`Cannot register multiple overloads of a function with the same number of arguments (${Q})!`);
299
299
  B[I].ba[Q] = g;
300
300
  } else B[I] = g, B[I].la = Q;
301
- }, nI = (I) => {
301
+ }, qI = (I) => {
302
302
  I = I.replace(/[^a-zA-Z0-9_]/g, "$");
303
303
  var g = I.charCodeAt(0);
304
304
  return 48 <= g && 57 >= g ? `_${I}` : I;
@@ -306,44 +306,44 @@ var UA = (() => {
306
306
  function ZI(I, g, Q, E, o, S, F, R) {
307
307
  this.name = I, this.constructor = g, this.ka = Q, this.ia = E, this.ea = o, this.Ba = S, this.oa = F, this.za = R, this.Ja = [];
308
308
  }
309
- var qA = (I, g, Q) => {
309
+ var nA = (I, g, Q) => {
310
310
  for (; g !== Q; ) {
311
- if (!g.oa) throw new M(`Expected null or instance of ${Q.name}, got an instance of ${g.name}`);
311
+ if (!g.oa) throw new s(`Expected null or instance of ${Q.name}, got an instance of ${g.name}`);
312
312
  I = g.oa(I), g = g.ea;
313
313
  }
314
314
  return I;
315
- }, nA = (I) => {
315
+ }, qA = (I) => {
316
316
  if (I === null) return "null";
317
317
  var g = typeof I;
318
318
  return g === "object" || g === "array" || g === "function" ? I.toString() : "" + I;
319
319
  };
320
- function TI(I, g) {
320
+ function eI(I, g) {
321
321
  if (g === null) {
322
- if (this.ra) throw new M(`null is not a valid ${this.name}`);
322
+ if (this.ra) throw new s(`null is not a valid ${this.name}`);
323
323
  return 0;
324
324
  }
325
- if (!g.Y) throw new M(`Cannot pass "${nA(g)}" as a ${this.name}`);
326
- if (!g.Y.Z) throw new M(`Cannot pass deleted object as a pointer of type ${this.name}`);
327
- return qA(g.Y.Z, g.Y.aa.$, this.$);
325
+ if (!g.Y) throw new s(`Cannot pass "${qA(g)}" as a ${this.name}`);
326
+ if (!g.Y.Z) throw new s(`Cannot pass deleted object as a pointer of type ${this.name}`);
327
+ return nA(g.Y.Z, g.Y.aa.$, this.$);
328
328
  }
329
- function eI(I, g) {
329
+ function TI(I, g) {
330
330
  if (g === null) {
331
- if (this.ra) throw new M(`null is not a valid ${this.name}`);
331
+ if (this.ra) throw new s(`null is not a valid ${this.name}`);
332
332
  if (this.qa) {
333
333
  var Q = this.sa();
334
334
  return I !== null && I.push(this.ia, Q), Q;
335
335
  }
336
336
  return 0;
337
337
  }
338
- if (!g || !g.Y) throw new M(`Cannot pass "${nA(g)}" as a ${this.name}`);
339
- if (!g.Y.Z) throw new M(`Cannot pass deleted object as a pointer of type ${this.name}`);
340
- if (!this.pa && g.Y.aa.pa) throw new M(`Cannot convert argument of type ${g.Y.ha ? g.Y.ha.name : g.Y.aa.name} to parameter type ${this.name}`);
341
- if (Q = qA(g.Y.Z, g.Y.aa.$, this.$), this.qa) {
342
- if (g.Y.da === void 0) throw new M("Passing raw pointer to smart pointer is illegal");
338
+ if (!g || !g.Y) throw new s(`Cannot pass "${qA(g)}" as a ${this.name}`);
339
+ if (!g.Y.Z) throw new s(`Cannot pass deleted object as a pointer of type ${this.name}`);
340
+ if (!this.pa && g.Y.aa.pa) throw new s(`Cannot convert argument of type ${g.Y.ha ? g.Y.ha.name : g.Y.aa.name} to parameter type ${this.name}`);
341
+ if (Q = nA(g.Y.Z, g.Y.aa.$, this.$), this.qa) {
342
+ if (g.Y.da === void 0) throw new s("Passing raw pointer to smart pointer is illegal");
343
343
  switch (this.Oa) {
344
344
  case 0:
345
345
  if (g.Y.ha === this) Q = g.Y.da;
346
- else throw new M(`Cannot convert argument of type ${g.Y.ha ? g.Y.ha.name : g.Y.aa.name} to parameter type ${this.name}`);
346
+ else throw new s(`Cannot convert argument of type ${g.Y.ha ? g.Y.ha.name : g.Y.aa.name} to parameter type ${this.name}`);
347
347
  break;
348
348
  case 1:
349
349
  Q = g.Y.da;
@@ -352,44 +352,44 @@ var UA = (() => {
352
352
  if (g.Y.ha === this) Q = g.Y.da;
353
353
  else {
354
354
  var E = g.clone();
355
- Q = this.Ka(Q, e(() => E.delete())), I !== null && I.push(this.ia, Q);
355
+ Q = this.Ka(Q, T(() => E.delete())), I !== null && I.push(this.ia, Q);
356
356
  }
357
357
  break;
358
358
  default:
359
- throw new M("Unsupporting sharing policy");
359
+ throw new s("Unsupporting sharing policy");
360
360
  }
361
361
  }
362
362
  return Q;
363
363
  }
364
364
  function WI(I, g) {
365
365
  if (g === null) {
366
- if (this.ra) throw new M(`null is not a valid ${this.name}`);
366
+ if (this.ra) throw new s(`null is not a valid ${this.name}`);
367
367
  return 0;
368
368
  }
369
- if (!g.Y) throw new M(`Cannot pass "${nA(g)}" as a ${this.name}`);
370
- if (!g.Y.Z) throw new M(`Cannot pass deleted object as a pointer of type ${this.name}`);
371
- if (g.Y.aa.pa) throw new M(`Cannot convert argument of type ${g.Y.aa.name} to parameter type ${this.name}`);
372
- return qA(g.Y.Z, g.Y.aa.$, this.$);
369
+ if (!g.Y) throw new s(`Cannot pass "${qA(g)}" as a ${this.name}`);
370
+ if (!g.Y.Z) throw new s(`Cannot pass deleted object as a pointer of type ${this.name}`);
371
+ if (g.Y.aa.pa) throw new s(`Cannot convert argument of type ${g.Y.aa.name} to parameter type ${this.name}`);
372
+ return nA(g.Y.Z, g.Y.aa.$, this.$);
373
373
  }
374
374
  var CI = (I, g, Q) => g === Q ? I : Q.ea === void 0 ? null : (I = CI(I, g, Q.ea), I === null ? null : Q.za(I)), rI = {}, pI = (I, g) => {
375
- if (g === void 0) throw new M("ptr should not be undefined");
375
+ if (g === void 0) throw new s("ptr should not be undefined");
376
376
  for (; I.ea; ) g = I.oa(g), I = I.ea;
377
377
  return rI[g];
378
- }, hA = (I, g) => {
379
- if (!g.aa || !g.Z) throw new wA("makeClassHandle requires ptr and ptrType");
380
- if (!!g.ha != !!g.da) throw new wA("Both smartPtrType and smartPtr must be specified");
381
- return g.count = { value: 1 }, EA(Object.create(I, { Y: { value: g, writable: !0 } }));
378
+ }, sA = (I, g) => {
379
+ if (!g.aa || !g.Z) throw new JA("makeClassHandle requires ptr and ptrType");
380
+ if (!!g.ha != !!g.da) throw new JA("Both smartPtrType and smartPtr must be specified");
381
+ return g.count = { value: 1 }, iA(Object.create(I, { Y: { value: g, writable: !0 } }));
382
382
  };
383
- function MA(I, g, Q, E, o, S, F, R, k, w, J) {
384
- this.name = I, this.$ = g, this.ra = Q, this.pa = E, this.qa = o, this.Ia = S, this.Oa = F, this.xa = R, this.sa = k, this.Ka = w, this.ia = J, o || g.ea !== void 0 ? this.toWireType = eI : (this.toWireType = E ? TI : WI, this.fa = null);
383
+ function MA(I, g, Q, E, o, S, F, R, k, N, J) {
384
+ this.name = I, this.$ = g, this.ra = Q, this.pa = E, this.qa = o, this.Ia = S, this.Oa = F, this.xa = R, this.sa = k, this.Ka = N, this.ia = J, o || g.ea !== void 0 ? this.toWireType = TI : (this.toWireType = E ? eI : WI, this.fa = null);
385
385
  }
386
386
  var BI = (I, g, Q) => {
387
- if (!B.hasOwnProperty(I)) throw new wA("Replacing nonexistent public symbol");
387
+ if (!B.hasOwnProperty(I)) throw new JA("Replacing nonexistent public symbol");
388
388
  B[I].ba !== void 0 && Q !== void 0 ? B[I].ba[Q] = g : (B[I] = g, B[I].la = Q);
389
389
  }, QI = [], EI, r = (I, g) => {
390
390
  I = L(I);
391
391
  var Q;
392
- if ((Q = QI[g]) || (QI[g] = Q = EI.get(g)), typeof Q != "function") throw new M(`unknown function pointer with signature ${I}: ${g}`);
392
+ if ((Q = QI[g]) || (QI[g] = Q = EI.get(g)), typeof Q != "function") throw new s(`unknown function pointer with signature ${I}: ${g}`);
393
393
  return Q;
394
394
  };
395
395
  class xI extends Error {
@@ -411,31 +411,31 @@ var UA = (() => {
411
411
  }
412
412
  function oI(I, g, Q, E, o, S) {
413
413
  var F = g.length;
414
- if (2 > F) throw new M("argTypes array size mismatch! Must at least get return value and 'this' types!");
414
+ if (2 > F) throw new s("argTypes array size mismatch! Must at least get return value and 'this' types!");
415
415
  var R = g[1] !== null && Q !== null, k = DI(g);
416
416
  for (Q = g[0].name !== "void", E = [I, VI, E, o, lA, g[0], g[1]], o = 0; o < F - 2; ++o) E.push(g[o + 2]);
417
417
  if (!k) for (o = R ? 1 : 2; o < g.length; ++o) g[o].fa !== null && E.push(g[o].fa);
418
418
  k = DI(g), o = g.length - 2;
419
- var w = [], J = ["fn"];
420
- for (R && J.push("thisWired"), F = 0; F < o; ++F) w.push(`arg${F}`), J.push(`arg${F}Wired`);
421
- w = w.join(","), J = J.join(","), w = `return function (${w}) {
422
- `, k && (w += `var destructors = [];
419
+ var N = [], J = ["fn"];
420
+ for (R && J.push("thisWired"), F = 0; F < o; ++F) N.push(`arg${F}`), J.push(`arg${F}Wired`);
421
+ N = N.join(","), J = J.join(","), N = `return function (${N}) {
422
+ `, k && (N += `var destructors = [];
423
423
  `);
424
- var s = k ? "destructors" : "null", Y = "humanName throwBindingError invoker fn runDestructors retType classParam".split(" ");
425
- for (R && (w += `var thisWired = classParam['toWireType'](${s}, this);
426
- `), F = 0; F < o; ++F) w += `var arg${F}Wired = argType${F}['toWireType'](${s}, arg${F});
424
+ var a = k ? "destructors" : "null", Y = "humanName throwBindingError invoker fn runDestructors retType classParam".split(" ");
425
+ for (R && (N += `var thisWired = classParam['toWireType'](${a}, this);
426
+ `), F = 0; F < o; ++F) N += `var arg${F}Wired = argType${F}['toWireType'](${a}, arg${F});
427
427
  `, Y.push(`argType${F}`);
428
- if (w += (Q || S ? "var rv = " : "") + `invoker(${J});
429
- `, k) w += `runDestructors(destructors);
428
+ if (N += (Q || S ? "var rv = " : "") + `invoker(${J});
429
+ `, k) N += `runDestructors(destructors);
430
430
  `;
431
- else for (F = R ? 1 : 2; F < g.length; ++F) S = F === 1 ? "thisWired" : "arg" + (F - 2) + "Wired", g[F].fa !== null && (w += `${S}_dtor(${S});
431
+ else for (F = R ? 1 : 2; F < g.length; ++F) S = F === 1 ? "thisWired" : "arg" + (F - 2) + "Wired", g[F].fa !== null && (N += `${S}_dtor(${S});
432
432
  `, Y.push(`${S}_dtor`));
433
- Q && (w += `var ret = retType['fromWireType'](rv);
433
+ Q && (N += `var ret = retType['fromWireType'](rv);
434
434
  return ret;
435
435
  `);
436
- let [H, K] = [Y, w + `}
436
+ let [H, K] = [Y, N + `}
437
437
  `];
438
- return g = new Function(...H, K)(...E), kA(I, g);
438
+ return g = new Function(...H, K)(...E), hA(I, g);
439
439
  }
440
440
  for (var UI = (I, g) => {
441
441
  for (var Q = [], E = 0; E < I; E++) Q.push(c[g + 4 * E >> 2]);
@@ -444,12 +444,12 @@ return ret;
444
444
  I = I.trim();
445
445
  const g = I.indexOf("(");
446
446
  return g === -1 ? I : I.slice(0, g);
447
- }, FI = [], u = [0, 1, , 1, null, 1, !0, 1, !1, 1], TA = (I) => {
447
+ }, FI = [], u = [0, 1, , 1, null, 1, !0, 1, !1, 1], eA = (I) => {
448
448
  9 < I && --u[I + 1] === 0 && (u[I] = void 0, FI.push(I));
449
449
  }, V = (I) => {
450
- if (!I) throw new M(`Cannot use deleted val. handle = ${I}`);
450
+ if (!I) throw new s(`Cannot use deleted val. handle = ${I}`);
451
451
  return u[I];
452
- }, e = (I) => {
452
+ }, T = (I) => {
453
453
  switch (I) {
454
454
  case void 0:
455
455
  return 2;
@@ -465,18 +465,18 @@ return ret;
465
465
  }
466
466
  }, jI = { name: "emscripten::val", fromWireType: (I) => {
467
467
  var g = V(I);
468
- return TA(I), g;
469
- }, toWireType: (I, g) => e(g), ga: 8, readValueFromPointer: BA, fa: null }, mI = (I, g, Q) => {
468
+ return eA(I), g;
469
+ }, toWireType: (I, g) => T(g), ga: 8, readValueFromPointer: QA, fa: null }, mI = (I, g, Q) => {
470
470
  switch (g) {
471
471
  case 1:
472
472
  return Q ? function(E) {
473
- return this.fromWireType(IA[E]);
473
+ return this.fromWireType(gA[E]);
474
474
  } : function(E) {
475
475
  return this.fromWireType(Z[E]);
476
476
  };
477
477
  case 2:
478
478
  return Q ? function(E) {
479
- return this.fromWireType(gA[E >> 1]);
479
+ return this.fromWireType(CA[E >> 1]);
480
480
  } : function(E) {
481
481
  return this.fromWireType(b[E >> 1]);
482
482
  };
@@ -489,9 +489,9 @@ return ret;
489
489
  default:
490
490
  throw new TypeError(`invalid integer width (${g}): ${I}`);
491
491
  }
492
- }, sA = (I, g) => {
492
+ }, GA = (I, g) => {
493
493
  var Q = z[I];
494
- if (Q === void 0) throw I = `${g} has unknown type ${iI(I)}`, new M(I);
494
+ if (Q === void 0) throw I = `${g} has unknown type ${iI(I)}`, new s(I);
495
495
  return Q;
496
496
  }, OI = (I, g) => {
497
497
  switch (g) {
@@ -506,7 +506,7 @@ return ret;
506
506
  default:
507
507
  throw new TypeError(`invalid float width (${g}): ${I}`);
508
508
  }
509
- }, _ = (I, g, Q) => {
509
+ }, $ = (I, g, Q) => {
510
510
  var E = Z;
511
511
  if (0 < Q) {
512
512
  Q = g + Q - 1;
@@ -544,10 +544,10 @@ return ret;
544
544
  127 >= E ? g++ : 2047 >= E ? g += 2 : 55296 <= E && 57343 >= E ? (g += 4, ++Q) : g += 3;
545
545
  }
546
546
  return g;
547
- }, NI = typeof TextDecoder < "u" ? new TextDecoder() : void 0, iA = (I = 0, g = NaN) => {
547
+ }, wI = typeof TextDecoder < "u" ? new TextDecoder() : void 0, DA = (I = 0, g = NaN) => {
548
548
  var Q = Z, E = I + g;
549
549
  for (g = I; Q[g] && !(g >= E); ) ++g;
550
- if (16 < g - I && Q.buffer && NI) return NI.decode(Q.subarray(
550
+ if (16 < g - I && Q.buffer && wI) return wI.decode(Q.subarray(
551
551
  I,
552
552
  g
553
553
  ));
@@ -563,10 +563,10 @@ return ret;
563
563
  } else E += String.fromCharCode(o);
564
564
  }
565
565
  return E;
566
- }, wI = typeof TextDecoder < "u" ? new TextDecoder("utf-16le") : void 0, bI = (I, g) => {
566
+ }, NI = typeof TextDecoder < "u" ? new TextDecoder("utf-16le") : void 0, bI = (I, g) => {
567
567
  I >>= 1, g = I + g / 2;
568
568
  for (var Q = I; !(Q >= g) && b[Q]; ) ++Q;
569
- if (16 < Q - I && wI) return wI.decode(b.subarray(
569
+ if (16 < Q - I && NI) return NI.decode(b.subarray(
570
570
  I,
571
571
  Q
572
572
  ));
@@ -581,8 +581,8 @@ return ret;
581
581
  Q -= 2;
582
582
  var E = g;
583
583
  Q = Q < 2 * I.length ? Q / 2 : I.length;
584
- for (var o = 0; o < Q; ++o) gA[g >> 1] = I.charCodeAt(o), g += 2;
585
- return gA[g >> 1] = 0, g - E;
584
+ for (var o = 0; o < Q; ++o) CA[g >> 1] = I.charCodeAt(o), g += 2;
585
+ return CA[g >> 1] = 0, g - E;
586
586
  }, XI = (I) => 2 * I.length, zI = (I, g) => {
587
587
  for (var Q = 0, E = ""; !(Q >= g / 4); ) {
588
588
  var o = f[I + 4 * Q >> 2];
@@ -611,21 +611,21 @@ return ret;
611
611
  return g;
612
612
  }, JI = (I, g, Q) => {
613
613
  var E = [];
614
- return I = I.toWireType(E, Q), E.length && (c[g >> 2] = e(E)), I;
615
- }, GA = [], vI = {}, aA = (I) => {
614
+ return I = I.toWireType(E, Q), E.length && (c[g >> 2] = T(E)), I;
615
+ }, aA = [], vI = {}, yA = (I) => {
616
616
  var g = vI[I];
617
617
  return g === void 0 ? L(I) : g;
618
618
  }, kI = () => typeof globalThis == "object" ? globalThis : Function("return this")(), _I = (I) => {
619
- var g = GA.length;
620
- return GA.push(I), g;
619
+ var g = aA.length;
620
+ return aA.push(I), g;
621
621
  }, $I = (I, g) => {
622
- for (var Q = Array(I), E = 0; E < I; ++E) Q[E] = sA(c[g + 4 * E >> 2], `parameter ${E}`);
622
+ for (var Q = Array(I), E = 0; E < I; ++E) Q[E] = GA(c[g + 4 * E >> 2], `parameter ${E}`);
623
623
  return Q;
624
- }, hI = Array(256), yA = 0; 256 > yA; ++yA) hI[yA] = String.fromCharCode(yA);
624
+ }, hI = Array(256), KA = 0; 256 > KA; ++KA) hI[KA] = String.fromCharCode(KA);
625
625
  _A = hI, (() => {
626
- let I = JA.prototype;
626
+ let I = kA.prototype;
627
627
  Object.assign(I, { isAliasOf: function(Q) {
628
- if (!(this instanceof JA && Q instanceof JA)) return !1;
628
+ if (!(this instanceof kA && Q instanceof kA)) return !1;
629
629
  var E = this.Y.aa.$, o = this.Y.Z;
630
630
  Q.Y = Q.Y;
631
631
  var S = Q.Y.aa.$;
@@ -634,17 +634,17 @@ return ret;
634
634
  return E === S && o === Q;
635
635
  }, clone: function() {
636
636
  if (this.Y.Z || HA(this), this.Y.na) return this.Y.count.value += 1, this;
637
- var Q = EA, E = Object, o = E.create, S = Object.getPrototypeOf(this), F = this.Y;
637
+ var Q = iA, E = Object, o = E.create, S = Object.getPrototypeOf(this), F = this.Y;
638
638
  return Q = Q(o.call(E, S, { Y: { value: { count: F.count, ma: F.ma, na: F.na, Z: F.Z, aa: F.aa, da: F.da, ha: F.ha } } })), Q.Y.count.value += 1, Q.Y.ma = !1, Q;
639
639
  }, delete() {
640
- if (this.Y.Z || HA(this), this.Y.ma && !this.Y.na) throw new M("Object already scheduled for deletion");
640
+ if (this.Y.Z || HA(this), this.Y.ma && !this.Y.na) throw new s("Object already scheduled for deletion");
641
641
  AI(this);
642
642
  var Q = this.Y;
643
643
  --Q.count.value, Q.count.value === 0 && (Q.da ? Q.ha.ia(Q.da) : Q.aa.$.ia(Q.Z)), this.Y.na || (this.Y.da = void 0, this.Y.Z = void 0);
644
644
  }, isDeleted: function() {
645
645
  return !this.Y.Z;
646
646
  }, deleteLater: function() {
647
- if (this.Y.Z || HA(this), this.Y.ma && !this.Y.na) throw new M("Object already scheduled for deletion");
647
+ if (this.Y.Z || HA(this), this.Y.ma && !this.Y.na) throw new s("Object already scheduled for deletion");
648
648
  return this.Y.ma = !0, this;
649
649
  } });
650
650
  const g = Symbol.dispose;
@@ -653,9 +653,9 @@ return ret;
653
653
  return this.xa && (I = this.xa(I)), I;
654
654
  }, va(I) {
655
655
  this.ia?.(I);
656
- }, ga: 8, readValueFromPointer: BA, fromWireType: function(I) {
656
+ }, ga: 8, readValueFromPointer: QA, fromWireType: function(I) {
657
657
  function g() {
658
- return this.qa ? hA(this.$.ka, { aa: this.Ia, Z: Q, ha: this, da: I }) : hA(this.$.ka, { aa: this, Z: I });
658
+ return this.qa ? sA(this.$.ka, { aa: this.Ia, Z: Q, ha: this, da: I }) : sA(this.$.ka, { aa: this, Z: I });
659
659
  }
660
660
  var Q = this.Ca(I);
661
661
  if (!Q) return this.va(I), null;
@@ -669,19 +669,19 @@ return ret;
669
669
  this.$,
670
670
  E.$
671
671
  );
672
- return o === null ? g.call(this) : this.qa ? hA(E.$.ka, { aa: E, Z: o, ha: this, da: I }) : hA(E.$.ka, { aa: E, Z: o });
673
- } }), B.printErr && (O = B.printErr), B.wasmBinary && (AA = B.wasmBinary), B.ccall = (I, g, Q, E) => {
674
- var o = { string: (w) => {
672
+ return o === null ? g.call(this) : this.qa ? sA(E.$.ka, { aa: E, Z: o, ha: this, da: I }) : sA(E.$.ka, { aa: E, Z: o });
673
+ } }), B.printErr && (O = B.printErr), B.wasmBinary && (IA = B.wasmBinary), B.ccall = (I, g, Q, E) => {
674
+ var o = { string: (N) => {
675
675
  var J = 0;
676
- if (w != null && w !== 0) {
677
- J = RI(w) + 1;
678
- var s = sI(J);
679
- _(w, s, J), J = s;
676
+ if (N != null && N !== 0) {
677
+ J = RI(N) + 1;
678
+ var a = MI(J);
679
+ $(N, a, J), J = a;
680
680
  }
681
681
  return J;
682
- }, array: (w) => {
683
- var J = sI(w.length);
684
- return IA.set(w, J), J;
682
+ }, array: (N) => {
683
+ var J = MI(N.length);
684
+ return gA.set(N, J), J;
685
685
  } };
686
686
  I = B["_" + I];
687
687
  var S = [], F = 0;
@@ -689,8 +689,8 @@ return ret;
689
689
  var k = o[Q[R]];
690
690
  k ? (F === 0 && (F = Cg()), S[R] = k(E[R])) : S[R] = E[R];
691
691
  }
692
- return Q = I(...S), Q = (function(w) {
693
- return F !== 0 && gg(F), g === "string" ? w ? iA(w) : "" : g === "boolean" ? !!w : w;
692
+ return Q = I(...S), Q = (function(N) {
693
+ return F !== 0 && gg(F), g === "string" ? N ? DA(N) : "" : g === "boolean" ? !!N : N;
694
694
  })(Q);
695
695
  };
696
696
  var Ag = {
@@ -700,27 +700,27 @@ return ret;
700
700
  },
701
701
  F: () => XA(""),
702
702
  x: (I) => {
703
- var g = RA[I];
704
- delete RA[I];
703
+ var g = wA[I];
704
+ delete wA[I];
705
705
  var Q = g.sa, E = g.ia, o = g.wa, S = o.map((F) => F.Fa).concat(o.map((F) => F.Ma));
706
- QA([I], S, (F) => {
706
+ EA([I], S, (F) => {
707
707
  var R = {};
708
- return o.forEach((k, w) => {
709
- var J = F[w], s = k.Da, Y = k.Ea, H = F[w + o.length], K = k.La, n = k.Na;
710
- R[k.Aa] = { read: (j) => J.fromWireType(s(Y, j)), write: (j, DA) => {
708
+ return o.forEach((k, N) => {
709
+ var J = F[N], a = k.Da, Y = k.Ea, H = F[N + o.length], K = k.La, q = k.Na;
710
+ R[k.Aa] = { read: (j) => J.fromWireType(a(Y, j)), write: (j, oA) => {
711
711
  var d = [];
712
- K(n, j, H.toWireType(d, DA)), lA(d);
713
- }, optional: F[w].optional };
712
+ K(q, j, H.toWireType(d, oA)), lA(d);
713
+ }, optional: F[N].optional };
714
714
  }), [{ name: g.name, fromWireType: (k) => {
715
- var w = {}, J;
716
- for (J in R) w[J] = R[J].read(k);
717
- return E(k), w;
718
- }, toWireType: (k, w) => {
719
- for (var J in R) if (!(J in w || R[J].optional)) throw new TypeError(`Missing field: "${J}"`);
720
- var s = Q();
721
- for (J in R) R[J].write(s, w[J]);
722
- return k !== null && k.push(E, s), s;
723
- }, ga: 8, readValueFromPointer: BA, fa: E }];
715
+ var N = {}, J;
716
+ for (J in R) N[J] = R[J].read(k);
717
+ return E(k), N;
718
+ }, toWireType: (k, N) => {
719
+ for (var J in R) if (!(J in N || R[J].optional)) throw new TypeError(`Missing field: "${J}"`);
720
+ var a = Q();
721
+ for (J in R) R[J].write(a, N[J]);
722
+ return k !== null && k.push(E, a), a;
723
+ }, ga: 8, readValueFromPointer: QA, fa: E }];
724
724
  });
725
725
  },
726
726
  v: (I, g, Q, E, o) => {
@@ -730,10 +730,10 @@ return ret;
730
730
  const F = 8 * Q;
731
731
  S = (R) => BigInt.asUintN(F, R), o = S(o);
732
732
  }
733
- T(I, { name: g, fromWireType: S, toWireType: (F, R) => (typeof R == "number" && (R = BigInt(R)), R), ga: 8, readValueFromPointer: $A(g, Q, !E), fa: null });
733
+ e(I, { name: g, fromWireType: S, toWireType: (F, R) => (typeof R == "number" && (R = BigInt(R)), R), ga: 8, readValueFromPointer: $A(g, Q, !E), fa: null });
734
734
  },
735
735
  K: (I, g, Q, E) => {
736
- g = L(g), T(I, {
736
+ g = L(g), e(I, {
737
737
  name: g,
738
738
  fromWireType: function(o) {
739
739
  return !!o;
@@ -748,66 +748,66 @@ return ret;
748
748
  fa: null
749
749
  });
750
750
  },
751
- M: (I, g, Q, E, o, S, F, R, k, w, J, s, Y) => {
752
- J = L(J), S = r(o, S), R &&= r(F, R), w &&= r(k, w), Y = r(s, Y);
753
- var H = nI(J);
751
+ M: (I, g, Q, E, o, S, F, R, k, N, J, a, Y) => {
752
+ J = L(J), S = r(o, S), R &&= r(F, R), N &&= r(k, N), Y = r(a, Y);
753
+ var H = qI(J);
754
754
  VA(H, function() {
755
755
  ZA(`Cannot construct ${J} due to unbound types`, [E]);
756
- }), QA([I, g, Q], E ? [E] : [], (K) => {
756
+ }), EA([I, g, Q], E ? [E] : [], (K) => {
757
757
  if (K = K[0], E)
758
- var n = K.$, j = n.ka;
759
- else j = JA.prototype;
760
- K = kA(J, function(...WA) {
761
- if (Object.getPrototypeOf(this) !== DA) throw new M(`Use 'new' to construct ${J}`);
762
- if (d.ja === void 0) throw new M(`${J} has no accessible constructor`);
758
+ var q = K.$, j = q.ka;
759
+ else j = kA.prototype;
760
+ K = hA(J, function(...WA) {
761
+ if (Object.getPrototypeOf(this) !== oA) throw new s(`Use 'new' to construct ${J}`);
762
+ if (d.ja === void 0) throw new s(`${J} has no accessible constructor`);
763
763
  var GI = d.ja[WA.length];
764
- if (GI === void 0) throw new M(`Tried to invoke ctor of ${J} with invalid number of parameters (${WA.length}) - expected (${Object.keys(d.ja).toString()}) parameters instead!`);
764
+ if (GI === void 0) throw new s(`Tried to invoke ctor of ${J} with invalid number of parameters (${WA.length}) - expected (${Object.keys(d.ja).toString()}) parameters instead!`);
765
765
  return GI.apply(this, WA);
766
766
  });
767
- var DA = Object.create(j, { constructor: { value: K } });
768
- K.prototype = DA;
769
- var d = new ZI(J, K, DA, Y, n, S, R, w);
767
+ var oA = Object.create(j, { constructor: { value: K } });
768
+ K.prototype = oA;
769
+ var d = new ZI(J, K, oA, Y, q, S, R, N);
770
770
  if (d.ea) {
771
- var oA;
772
- (oA = d.ea).ua ?? (oA.ua = []), d.ea.ua.push(d);
771
+ var UA;
772
+ (UA = d.ea).ua ?? (UA.ua = []), d.ea.ua.push(d);
773
773
  }
774
- return n = new MA(J, d, !0, !1, !1), oA = new MA(J + "*", d, !1, !1, !1), j = new MA(J + " const*", d, !1, !0, !1), II[I] = { pointerType: oA, ya: j }, BI(H, K), [n, oA, j];
774
+ return q = new MA(J, d, !0, !1, !1), UA = new MA(J + "*", d, !1, !1, !1), j = new MA(J + " const*", d, !1, !0, !1), II[I] = { pointerType: UA, ya: j }, BI(H, K), [q, UA, j];
775
775
  });
776
776
  },
777
777
  w: (I, g, Q, E, o, S, F, R, k) => {
778
- var w = UI(Q, E);
779
- g = L(g), g = SI(g), S = r(o, S), QA([], [I], (J) => {
780
- function s() {
781
- ZA(`Cannot call ${Y} due to unbound types`, w);
778
+ var N = UI(Q, E);
779
+ g = L(g), g = SI(g), S = r(o, S), EA([], [I], (J) => {
780
+ function a() {
781
+ ZA(`Cannot call ${Y} due to unbound types`, N);
782
782
  }
783
783
  J = J[0];
784
784
  var Y = `${J.name}.${g}`;
785
785
  g.startsWith("@@") && (g = Symbol[g.substring(2)]), R && J.$.Ja.push(g);
786
786
  var H = J.$.ka, K = H[g];
787
- return K === void 0 || K.ba === void 0 && K.className !== J.name && K.la === Q - 2 ? (s.la = Q - 2, s.className = J.name, H[g] = s) : (gI(H, g, Y), H[g].ba[Q - 2] = s), QA([], w, (n) => (n = oI(Y, n, J, S, F, k), H[g].ba === void 0 ? (n.la = Q - 2, H[g] = n) : H[g].ba[Q - 2] = n, [])), [];
787
+ return K === void 0 || K.ba === void 0 && K.className !== J.name && K.la === Q - 2 ? (a.la = Q - 2, a.className = J.name, H[g] = a) : (gI(H, g, Y), H[g].ba[Q - 2] = a), EA([], N, (q) => (q = oI(Y, q, J, S, F, k), H[g].ba === void 0 ? (q.la = Q - 2, H[g] = q) : H[g].ba[Q - 2] = q, [])), [];
788
788
  });
789
789
  },
790
- I: (I) => T(I, jI),
790
+ I: (I) => e(I, jI),
791
791
  z: (I, g, Q, E) => {
792
792
  function o() {
793
793
  }
794
- g = L(g), o.values = {}, T(I, { name: g, constructor: o, fromWireType: function(S) {
794
+ g = L(g), o.values = {}, e(I, { name: g, constructor: o, fromWireType: function(S) {
795
795
  return this.constructor.values[S];
796
796
  }, toWireType: (S, F) => F.value, ga: 8, readValueFromPointer: mI(g, Q, E), fa: null }), VA(g, o);
797
797
  },
798
798
  m: (I, g, Q) => {
799
- var E = sA(I, "enum");
800
- g = L(g), I = E.constructor, E = Object.create(E.constructor.prototype, { value: { value: Q }, constructor: { value: kA(`${E.name}_${g}`, function() {
799
+ var E = GA(I, "enum");
800
+ g = L(g), I = E.constructor, E = Object.create(E.constructor.prototype, { value: { value: Q }, constructor: { value: hA(`${E.name}_${g}`, function() {
801
801
  }) } }), I.values[Q] = E, I[g] = E;
802
802
  },
803
803
  u: (I, g, Q) => {
804
- g = L(g), T(I, { name: g, fromWireType: (E) => E, toWireType: (E, o) => o, ga: 8, readValueFromPointer: OI(g, Q), fa: null });
804
+ g = L(g), e(I, { name: g, fromWireType: (E) => E, toWireType: (E, o) => o, ga: 8, readValueFromPointer: OI(g, Q), fa: null });
805
805
  },
806
806
  e: (I, g, Q, E, o, S, F) => {
807
807
  var R = UI(g, Q);
808
808
  I = L(I), I = SI(I), o = r(E, o), VA(I, function() {
809
809
  ZA(`Cannot call ${I} due to unbound types`, R);
810
- }, g - 1), QA([], R, (k) => (k = [k[0], null].concat(k.slice(1)), BI(I, oI(I, k, null, o, S, F), g - 1), []));
810
+ }, g - 1), EA([], R, (k) => (k = [k[0], null].concat(k.slice(1)), BI(I, oI(I, k, null, o, S, F), g - 1), []));
811
811
  },
812
812
  o: (I, g, Q, E, o) => {
813
813
  g = L(g);
@@ -816,11 +816,11 @@ return ret;
816
816
  var F = 32 - 8 * Q;
817
817
  S = (R) => R << F >>> F, o = S(o);
818
818
  }
819
- T(I, { name: g, fromWireType: S, toWireType: (R, k) => k, ga: 8, readValueFromPointer: $A(g, Q, E !== 0), fa: null });
819
+ e(I, { name: g, fromWireType: S, toWireType: (R, k) => k, ga: 8, readValueFromPointer: $A(g, Q, E !== 0), fa: null });
820
820
  },
821
821
  f: (I, g, Q) => {
822
822
  function E(S) {
823
- return new o(IA.buffer, c[S + 4 >> 2], c[S >> 2]);
823
+ return new o(gA.buffer, c[S + 4 >> 2], c[S >> 2]);
824
824
  }
825
825
  var o = [
826
826
  Int8Array,
@@ -834,22 +834,22 @@ return ret;
834
834
  BigInt64Array,
835
835
  BigUint64Array
836
836
  ][g];
837
- Q = L(Q), T(I, { name: Q, fromWireType: E, ga: 8, readValueFromPointer: E }, { Ga: !0 });
837
+ Q = L(Q), e(I, { name: Q, fromWireType: E, ga: 8, readValueFromPointer: E }, { Ga: !0 });
838
838
  },
839
839
  J: (I, g) => {
840
- g = L(g), T(I, { name: g, fromWireType: function(Q) {
840
+ g = L(g), e(I, { name: g, fromWireType: function(Q) {
841
841
  for (var E = c[Q >> 2], o = Q + 4, S, F = o, R = 0; R <= E; ++R) {
842
842
  var k = o + R;
843
- (R == E || Z[k] == 0) && (F = F ? iA(F, k - F) : "", S === void 0 ? S = F : (S += "\0", S += F), F = k + 1);
843
+ (R == E || Z[k] == 0) && (F = F ? DA(F, k - F) : "", S === void 0 ? S = F : (S += "\0", S += F), F = k + 1);
844
844
  }
845
845
  return P(Q), S;
846
846
  }, toWireType: function(Q, E) {
847
847
  E instanceof ArrayBuffer && (E = new Uint8Array(E));
848
848
  var o = typeof E == "string";
849
- if (!(o || ArrayBuffer.isView(E) && E.BYTES_PER_ELEMENT == 1)) throw new M("Cannot pass non-string to std::string");
850
- var S = o ? RI(E) : E.length, F = MI(4 + S + 1), R = F + 4;
851
- return c[F >> 2] = S, o ? _(E, R, S + 1) : Z.set(E, R), Q !== null && Q.push(P, F), F;
852
- }, ga: 8, readValueFromPointer: BA, fa(Q) {
849
+ if (!(o || ArrayBuffer.isView(E) && E.BYTES_PER_ELEMENT == 1)) throw new s("Cannot pass non-string to std::string");
850
+ var S = o ? RI(E) : E.length, F = sI(4 + S + 1), R = F + 4;
851
+ return c[F >> 2] = S, o ? $(E, R, S + 1) : Z.set(E, R), Q !== null && Q.push(P, F), F;
852
+ }, ga: 8, readValueFromPointer: QA, fa(Q) {
853
853
  P(Q);
854
854
  } });
855
855
  },
@@ -857,36 +857,36 @@ return ret;
857
857
  if (Q = L(Q), g === 2)
858
858
  var E = bI, o = fI, S = XI, F = (R) => b[R >> 1];
859
859
  else g === 4 && (E = zI, o = uI, S = PI, F = (R) => c[R >> 2]);
860
- T(I, { name: Q, fromWireType: (R) => {
861
- for (var k = c[R >> 2], w, J = R + 4, s = 0; s <= k; ++s) {
862
- var Y = R + 4 + s * g;
863
- (s == k || F(Y) == 0) && (J = E(J, Y - J), w === void 0 ? w = J : (w += "\0", w += J), J = Y + g);
860
+ e(I, { name: Q, fromWireType: (R) => {
861
+ for (var k = c[R >> 2], N, J = R + 4, a = 0; a <= k; ++a) {
862
+ var Y = R + 4 + a * g;
863
+ (a == k || F(Y) == 0) && (J = E(J, Y - J), N === void 0 ? N = J : (N += "\0", N += J), J = Y + g);
864
864
  }
865
- return P(R), w;
865
+ return P(R), N;
866
866
  }, toWireType: (R, k) => {
867
- if (typeof k != "string") throw new M(`Cannot pass non-string to C++ string type ${Q}`);
868
- var w = S(k), J = MI(4 + w + g);
869
- return c[J >> 2] = w / g, o(k, J + 4, w + g), R !== null && R.push(P, J), J;
870
- }, ga: 8, readValueFromPointer: BA, fa(R) {
867
+ if (typeof k != "string") throw new s(`Cannot pass non-string to C++ string type ${Q}`);
868
+ var N = S(k), J = sI(4 + N + g);
869
+ return c[J >> 2] = N / g, o(k, J + 4, N + g), R !== null && R.push(P, J), J;
870
+ }, ga: 8, readValueFromPointer: QA, fa(R) {
871
871
  P(R);
872
872
  } });
873
873
  },
874
874
  y: (I, g, Q, E, o, S) => {
875
- RA[I] = { name: L(g), sa: r(Q, E), ia: r(o, S), wa: [] };
875
+ wA[I] = { name: L(g), sa: r(Q, E), ia: r(o, S), wa: [] };
876
876
  },
877
- p: (I, g, Q, E, o, S, F, R, k, w) => {
878
- RA[I].wa.push({ Aa: L(g), Fa: Q, Da: r(E, o), Ea: S, Ma: F, La: r(R, k), Na: w });
877
+ p: (I, g, Q, E, o, S, F, R, k, N) => {
878
+ wA[I].wa.push({ Aa: L(g), Fa: Q, Da: r(E, o), Ea: S, Ma: F, La: r(R, k), Na: N });
879
879
  },
880
880
  L: (I, g) => {
881
- g = L(g), T(I, { Ha: !0, name: g, ga: 0, fromWireType: () => {
881
+ g = L(g), e(I, { Ha: !0, name: g, ga: 0, fromWireType: () => {
882
882
  }, toWireType: () => {
883
883
  } });
884
884
  },
885
- k: (I, g, Q) => (I = V(I), g = sA(g, "emval::as"), JI(g, Q, I)),
886
- q: (I, g, Q, E) => (I = GA[I], g = V(g), I(null, g, Q, E)),
887
- n: (I, g, Q, E, o) => (I = GA[I], g = V(g), Q = aA(Q), I(g, g[Q], E, o)),
888
- a: TA,
889
- l: (I) => I === 0 ? e(kI()) : (I = aA(I), e(kI()[I])),
885
+ k: (I, g, Q) => (I = V(I), g = GA(g, "emval::as"), JI(g, Q, I)),
886
+ q: (I, g, Q, E) => (I = aA[I], g = V(g), I(null, g, Q, E)),
887
+ n: (I, g, Q, E, o) => (I = aA[I], g = V(g), Q = yA(Q), I(g, g[Q], E, o)),
888
+ a: eA,
889
+ l: (I) => I === 0 ? T(kI()) : (I = yA(I), T(kI()[I])),
890
890
  h: (I, g, Q) => {
891
891
  g = $I(I, g);
892
892
  var E = g.shift();
@@ -894,36 +894,36 @@ return ret;
894
894
  var o = `return function (obj, func, destructorsRef, args) {
895
895
  `, S = 0, F = [];
896
896
  Q === 0 && F.push("obj");
897
- for (var R = ["retType"], k = [E], w = 0; w < I; ++w) F.push(`arg${w}`), R.push(`argType${w}`), k.push(g[w]), o += ` var arg${w} = argType${w}.readValueFromPointer(args${S ? "+" + S : ""});
898
- `, S += g[w].ga;
897
+ for (var R = ["retType"], k = [E], N = 0; N < I; ++N) F.push(`arg${N}`), R.push(`argType${N}`), k.push(g[N]), o += ` var arg${N} = argType${N}.readValueFromPointer(args${S ? "+" + S : ""});
898
+ `, S += g[N].ga;
899
899
  return o += ` var rv = ${Q === 1 ? "new func" : "func.call"}(${F.join(", ")});
900
900
  `, E.Ha || (R.push("emval_returnValue"), k.push(JI), o += ` return emval_returnValue(retType, destructorsRef, rv);
901
901
  `), I = new Function(...R, o + `};
902
- `)(...k), Q = `methodCaller<(${g.map((J) => J.name).join(", ")}) => ${E.name}>`, _I(kA(Q, I));
902
+ `)(...k), Q = `methodCaller<(${g.map((J) => J.name).join(", ")}) => ${E.name}>`, _I(hA(Q, I));
903
903
  },
904
- A: (I) => (I = aA(I), e(B[I])),
905
- g: (I, g) => (I = V(I), g = V(g), e(I[g])),
904
+ A: (I) => (I = yA(I), T(B[I])),
905
+ g: (I, g) => (I = V(I), g = V(g), T(I[g])),
906
906
  d: (I) => {
907
907
  9 < I && (u[I + 1] += 1);
908
908
  },
909
909
  t: (I, g) => (I = V(I), g = V(g), I instanceof g),
910
- B: () => e([]),
911
- c: (I) => e(aA(I)),
912
- N: () => e({}),
910
+ B: () => T([]),
911
+ c: (I) => T(yA(I)),
912
+ N: () => T({}),
913
913
  b: (I) => {
914
914
  var g = V(I);
915
- lA(g), TA(I);
915
+ lA(g), eA(I);
916
916
  },
917
917
  r: (I, g, Q) => {
918
918
  I = V(I), g = V(g), Q = V(Q), I[g] = Q;
919
919
  },
920
- j: (I, g) => (I = sA(I, "_emval_take_value"), I = I.readValueFromPointer(g), e(I)),
920
+ j: (I, g) => (I = GA(I, "_emval_take_value"), I = I.readValueFromPointer(g), T(I)),
921
921
  C: (I, g, Q, E) => {
922
922
  var o = (/* @__PURE__ */ new Date()).getFullYear(), S = new Date(o, 0, 1).getTimezoneOffset();
923
923
  o = new Date(o, 6, 1).getTimezoneOffset(), c[I >> 2] = 60 * Math.max(S, o), f[g >> 2] = +(S != o), g = (F) => {
924
924
  var R = Math.abs(F);
925
925
  return `UTC${0 <= F ? "-" : "+"}${String(Math.floor(R / 60)).padStart(2, "0")}${String(R % 60).padStart(2, "0")}`;
926
- }, I = g(S), g = g(o), o < S ? (_(I, Q, 17), _(g, E, 17)) : (_(I, E, 17), _(g, Q, 17));
926
+ }, I = g(S), g = g(o), o < S ? ($(I, Q, 17), $(g, E, 17)) : ($(I, E, 17), $(g, Q, 17));
927
927
  },
928
928
  D: function(I, g, Q) {
929
929
  return 0 <= I && 3 >= I ? (LA[Q >> 3] = BigInt(Math.round(1e6 * (I === 0 ? Date.now() : performance.now()))), 0) : 28;
@@ -935,9 +935,9 @@ return ret;
935
935
  var E = g * (1 + 0.2 / Q);
936
936
  E = Math.min(E, I + 100663296);
937
937
  A: {
938
- E = (Math.min(2147483648, 65536 * Math.ceil(Math.max(I, E) / 65536)) - SA.buffer.byteLength + 65535) / 65536 | 0;
938
+ E = (Math.min(2147483648, 65536 * Math.ceil(Math.max(I, E) / 65536)) - FA.buffer.byteLength + 65535) / 65536 | 0;
939
939
  try {
940
- SA.grow(E), fA();
940
+ FA.grow(E), fA();
941
941
  var o = 1;
942
942
  break A;
943
943
  } catch {
@@ -949,16 +949,16 @@ return ret;
949
949
  return !1;
950
950
  },
951
951
  G: function(I, g, Q, E) {
952
- const o = g ? iA(g) : "", S = Q ? iA(Q) : "", F = E ? iA(E) : "";
952
+ const o = g ? DA(g) : "", S = Q ? DA(Q) : "", F = E ? DA(E) : "";
953
953
  globalThis.ja("Starting async RSA verification with server key fetch, callbackId: " + I), (async () => {
954
954
  try {
955
955
  const R = F + "/public-key";
956
956
  globalThis.ja("Fetching public key from: " + R);
957
957
  const k = await fetch(R, { method: "GET", headers: { Accept: "text/plain;charset=UTF-8" } });
958
958
  if (!k.ok) throw Error(`HTTP ${k.status}: ${k.statusText}`);
959
- const w = await k.text(), J = globalThis.ta(w), s = await crypto.subtle.importKey("spki", J, { name: "RSASSA-PKCS1-v1_5", hash: "SHA-256" }, !1, ["verify"]);
959
+ const N = await k.text(), J = globalThis.ta(N), a = await crypto.subtle.importKey("spki", J, { name: "RSASSA-PKCS1-v1_5", hash: "SHA-256" }, !1, ["verify"]);
960
960
  globalThis.ja("Public key imported successfully");
961
- const Y = new TextEncoder().encode(o), H = globalThis.ta(S), K = await crypto.subtle.verify("RSASSA-PKCS1-v1_5", s, H, Y);
961
+ const Y = new TextEncoder().encode(o), H = globalThis.ta(S), K = await crypto.subtle.verify("RSASSA-PKCS1-v1_5", a, H, Y);
962
962
  globalThis.ja("RSA verification result: " + K), B.ccall(
963
963
  "on_rsa_verification_complete",
964
964
  "void",
@@ -983,9 +983,9 @@ return ret;
983
983
  }
984
984
  }, globalThis.ja("Crypto helper functions initialized");
985
985
  }
986
- }, q = await (async function() {
986
+ }, n = await (async function() {
987
987
  function I(E) {
988
- return q = E.exports, SA = q.O, fA(), EI = q.R, X--, B.monitorRunDependencies?.(X), X == 0 && CA && (E = CA, CA = null, E()), q;
988
+ return n = E.exports, FA = n.O, fA(), EI = n.R, X--, B.monitorRunDependencies?.(X), X == 0 && BA && (E = BA, BA = null, E()), n;
989
989
  }
990
990
  X++, B.monitorRunDependencies?.(X);
991
991
  var g = { a: Ag };
@@ -1001,47 +1001,47 @@ return ret;
1001
1001
  } catch (E) {
1002
1002
  return U(E), Promise.reject(E);
1003
1003
  }
1004
- })(), Ig = q.Q, MI = q.S, P = q.T;
1005
- B._on_rsa_verification_complete = q.U;
1006
- var gg = q.V, sI = q.W, Cg = q.X;
1007
- function eA() {
1004
+ })(), Ig = n.Q, sI = n.S, P = n.T;
1005
+ B._on_rsa_verification_complete = n.U;
1006
+ var gg = n.V, MI = n.W, Cg = n.X;
1007
+ function TA() {
1008
1008
  function I() {
1009
1009
  if (B.calledRun = !0, !jA) {
1010
- if (q.P(), i(B), B.onRuntimeInitialized?.(), B.postRun) for (typeof B.postRun == "function" && (B.postRun = [B.postRun]); B.postRun.length; ) {
1010
+ if (n.P(), D(B), B.onRuntimeInitialized?.(), B.postRun) for (typeof B.postRun == "function" && (B.postRun = [B.postRun]); B.postRun.length; ) {
1011
1011
  var g = B.postRun.shift();
1012
1012
  uA.push(g);
1013
1013
  }
1014
1014
  zA(uA);
1015
1015
  }
1016
1016
  }
1017
- if (0 < X) CA = eA;
1017
+ if (0 < X) BA = TA;
1018
1018
  else {
1019
1019
  if (B.preRun) for (typeof B.preRun == "function" && (B.preRun = [B.preRun]); B.preRun.length; ) HI();
1020
- zA(PA), 0 < X ? CA = eA : B.setStatus ? (B.setStatus("Running..."), setTimeout(() => {
1020
+ zA(PA), 0 < X ? BA = TA : B.setStatus ? (B.setStatus("Running..."), setTimeout(() => {
1021
1021
  setTimeout(() => B.setStatus(""), 1), I();
1022
1022
  }, 1)) : I();
1023
1023
  }
1024
1024
  }
1025
1025
  if (B.preInit) for (typeof B.preInit == "function" && (B.preInit = [B.preInit]); 0 < B.preInit.length; ) B.preInit.shift()();
1026
- return eA(), C = N, C;
1026
+ return TA(), C = w, C;
1027
1027
  });
1028
1028
  })();
1029
- typeof exports == "object" && typeof module == "object" ? (module.exports = UA, module.exports.default = UA) : typeof define == "function" && define.amd && define([], () => UA);
1030
- typeof UA < "u" && (window.DriversModule = UA);
1031
- window.WacomTablet.prototype.initialize = async function(D) {
1029
+ typeof exports == "object" && typeof module == "object" ? (module.exports = SA, module.exports.default = SA) : typeof define == "function" && define.amd && define([], () => SA);
1030
+ typeof SA < "u" && (window.DriversModule = SA);
1031
+ window.WacomTablet.prototype.initialize = async function(i) {
1032
1032
  if (this.isWasmInitialized)
1033
1033
  return;
1034
- if (!D)
1034
+ if (!i)
1035
1035
  throw new Error("Server response is required for initialization");
1036
- this.Module = await window.DriversModule(), this.isWasmInitialized = !0, console.log("[JS] WASM module loaded"), console.log("[JS] Initializing licence..."), console.log("[JS] Server response keys:", Object.keys(D)), console.log("[JS] Server response:", D);
1037
- const A = D.licenceData, C = D.licenceSignature;
1038
- console.log("[JS] Initializing licence with async WASM crypto verification (server key fetch)..."), await new Promise((B, i) => {
1036
+ this.Module = await window.DriversModule(), this.isWasmInitialized = !0, console.log("[JS] WASM module loaded"), console.log("[JS] Initializing licence..."), console.log("[JS] Server response keys:", Object.keys(i)), console.log("[JS] Server response:", i);
1037
+ const A = i.licenceData, C = i.licenceSignature;
1038
+ console.log("[JS] Initializing licence with async WASM crypto verification (server key fetch)..."), await new Promise((B, D) => {
1039
1039
  try {
1040
1040
  this.Module.initializeSignedLicenseAsync(A, C, (U) => {
1041
- console.log("[JS] Async WASM licence validation completed:", U), U ? (console.log("[JS] ✓ Async WASM licence validation successful"), B()) : (console.error("[JS] ✗ Async WASM licence validation failed"), i(new Error("WASM async licence validation failed - signature verification or licence validation failed")));
1041
+ console.log("[JS] Async WASM licence validation completed:", U), U ? (console.log("[JS] ✓ Async WASM licence validation successful"), B()) : (console.error("[JS] ✗ Async WASM licence validation failed"), D(new Error("WASM async licence validation failed - signature verification or licence validation failed")));
1042
1042
  });
1043
1043
  } catch (U) {
1044
- console.error("[JS] Error setting up async licence validation:", U), i(new Error(`Failed to start async licence validation: ${U.message || U}`));
1044
+ console.error("[JS] Error setting up async licence validation:", U), D(new Error(`Failed to start async licence validation: ${U.message || U}`));
1045
1045
  }
1046
1046
  }), console.log("[JS] Async licence validation completed successfully"), console.log("[JS] Licence initialized successfully"), console.log("[JS] Available InputTypes (now strings):", [
1047
1047
  "Pen",
@@ -1066,27 +1066,27 @@ window.WacomTablet.prototype.initialize = async function(D) {
1066
1066
  Other: this.Module.DataLogFlag.Other
1067
1067
  });
1068
1068
  };
1069
- window.WacomTablet.prototype._tryAutoConnect = async function(D) {
1069
+ window.WacomTablet.prototype._tryAutoConnect = async function(i) {
1070
1070
  console.log("[JS] Attempting auto-connect...");
1071
1071
  let A = await navigator.hid.getDevices();
1072
1072
  console.log("[JS] Already granted devices:", A.length);
1073
- const C = A.filter((B) => D.some((i) => B.vendorId !== i.vendorId || B.productId !== i.productId ? !1 : i.usagePage !== void 0 || i.usage !== void 0 ? !B.collections || B.collections.length === 0 ? !1 : B.collections.some((U) => {
1074
- const N = i.usagePage === void 0 || U.usagePage === i.usagePage, h = i.usage === void 0 || U.usage === i.usage;
1075
- return N && h;
1073
+ const C = A.filter((B) => i.some((D) => B.vendorId !== D.vendorId || B.productId !== D.productId ? !1 : D.usagePage !== void 0 || D.usage !== void 0 ? !B.collections || B.collections.length === 0 ? !1 : B.collections.some((U) => {
1074
+ const w = D.usagePage === void 0 || U.usagePage === D.usagePage, h = D.usage === void 0 || U.usage === D.usage;
1075
+ return w && h;
1076
1076
  }) : !0));
1077
1077
  return C.length > 0 ? (console.log("[JS] Using already granted compatible device"), C[0]) : (console.log("[JS] No compatible granted devices found"), null);
1078
1078
  };
1079
- window.WacomTablet.prototype._requestConnect = async function(D) {
1079
+ window.WacomTablet.prototype._requestConnect = async function(i) {
1080
1080
  console.log("[JS] Showing device selection dialog...");
1081
- const A = await navigator.hid.requestDevice({ filters: D });
1081
+ const A = await navigator.hid.requestDevice({ filters: i });
1082
1082
  return A.length ? A[0] : null;
1083
1083
  };
1084
- window.WacomTablet.prototype._describeDevice = async function(D) {
1085
- console.log("[JS] Selected device:", D), console.log(`[JS] VID: 0x${D.vendorId.toString(16).padStart(4, "0").toUpperCase()}`), console.log(`[JS] PID: 0x${D.productId.toString(16).padStart(4, "0").toUpperCase()}`), console.log(`[JS] Serial Number: ${D.serialNumber || "N/A"}`), D.collections && D.collections.length > 0 && (console.log(`[JS] Device has ${D.collections.length} collections:`), D.collections.forEach((A, C) => {
1084
+ window.WacomTablet.prototype._describeDevice = async function(i) {
1085
+ console.log("[JS] Selected device:", i), console.log(`[JS] VID: 0x${i.vendorId.toString(16).padStart(4, "0").toUpperCase()}`), console.log(`[JS] PID: 0x${i.productId.toString(16).padStart(4, "0").toUpperCase()}`), console.log(`[JS] Serial Number: ${i.serialNumber || "N/A"}`), i.collections && i.collections.length > 0 && (console.log(`[JS] Device has ${i.collections.length} collections:`), i.collections.forEach((A, C) => {
1086
1086
  A.usagePage !== void 0 && A.usage !== void 0 && console.log(`[JS] Collection ${C}: UsagePage=0x${A.usagePage.toString(16).padStart(2, "0").toUpperCase()} Usage=0x${A.usage.toString(16).padStart(2, "0").toUpperCase()}`);
1087
1087
  }));
1088
1088
  };
1089
- window.WacomTablet.prototype.connect = async function(D = !1) {
1089
+ window.WacomTablet.prototype.connect = async function(i = !1) {
1090
1090
  if (!this.isWasmInitialized)
1091
1091
  throw new Error("Not initialized. Call initialize() first.");
1092
1092
  this.device !== null && await this.disconnect();
@@ -1094,13 +1094,13 @@ window.WacomTablet.prototype.connect = async function(D = !1) {
1094
1094
  const A = this.Module.getSupportedDevices();
1095
1095
  console.log("[JS] Supported devices:", A);
1096
1096
  let C = null;
1097
- if (D ? C = await this._tryAutoConnect(A) : C = await this._requestConnect(A, D), !C)
1097
+ if (i ? C = await this._tryAutoConnect(A) : C = await this._requestConnect(A, i), !C)
1098
1098
  return console.log("[JS] No HID device selected, initializing DefaultDriver with pointer events"), await this._initializeDefaultDriver(), !0;
1099
1099
  if (this.device = C, this._describeDevice(this.device), await this.device.open(), this._setupDisconnectDetection(), console.log("[JS] Initializing driver..."), !this.Module.initializeDriver(this.device))
1100
1100
  throw await this.device.close(), this.device = null, new Error("Failed to initialize device driver - licence may be invalid or expired");
1101
1101
  this._setupMasterCallback(), console.log("[JS] Device initialized successfully"), console.log("[JS] Driver name:", this.device.productName), console.log("[JS] Device ready:", this.Module.isInitialized());
1102
- const i = this.Module.getSupportedCommands();
1103
- return console.log("[JS] Supported commands:", i), this._configurePenAspectCorrection(), !0;
1102
+ const D = this.Module.getSupportedCommands();
1103
+ return console.log("[JS] Supported commands:", D), this._configurePenAspectCorrection(), !0;
1104
1104
  } catch (A) {
1105
1105
  return console.error("[JS] HID connection error:", A), console.log("[JS] HID connection failed, attempting DefaultDriver fallback"), await this._initializeDefaultDriver(), !0;
1106
1106
  }
@@ -1127,8 +1127,8 @@ window.WacomTablet.prototype._initializeDefaultDriver = async function() {
1127
1127
  window.WacomTablet.prototype._setupDisconnectDetection = function() {
1128
1128
  console.log("[JS] Setting up automatic disconnect detection..."), navigator.hid.addEventListener("disconnect", this._handleUnexpectedDisconnect);
1129
1129
  };
1130
- window.WacomTablet.prototype._handleUnexpectedDisconnect = function(D) {
1131
- this.device && D.device === this.device && (console.log("[JS] Processing unexpected disconnect..."), this._performDisconnectCleanup(), this.device = null, console.log("[JS] Unexpected disconnect handling complete"));
1130
+ window.WacomTablet.prototype._handleUnexpectedDisconnect = function(i) {
1131
+ this.device && i.device === this.device && (console.log("[JS] Processing unexpected disconnect..."), this._performDisconnectCleanup(), this.device = null, console.log("[JS] Unexpected disconnect handling complete"));
1132
1132
  };
1133
1133
  window.WacomTablet.prototype._performDisconnectCleanup = function() {
1134
1134
  this._cleanupEventSystem(), this.Module && this.Module.disconnectDriver && (console.log("[JS] Calling WASM disconnectDriver..."), this.Module.disconnectDriver()), this.penAspectCorrector = null, this._disconnectHandler && navigator.hid && (navigator.hid.removeEventListener("disconnect", this._disconnectHandler), this._disconnectHandler = null);
@@ -1140,7 +1140,7 @@ window.WacomTablet.prototype.isConnected = function() {
1140
1140
  return this.device !== null && this.isWasmInitialized && this.Module.isInitialized();
1141
1141
  };
1142
1142
  window.WacomTablet.prototype.getDriverInfo = function() {
1143
- const D = {
1143
+ const i = {
1144
1144
  name: "Not initialized",
1145
1145
  ready: !1,
1146
1146
  aspectRatio: 0,
@@ -1148,15 +1148,15 @@ window.WacomTablet.prototype.getDriverInfo = function() {
1148
1148
  supportedCommands: "",
1149
1149
  serialNumber: null
1150
1150
  };
1151
- return this.isWasmInitialized && (D.name = this.device && this.device.productName ? this.device.productName : "Unknown Device", D.ready = this.Module.isInitialized(), D.supportedCommands = this.Module.getSupportedCommands(), D.serialNumber = this.device && this.device.serialNumber ? this.device.serialNumber : null, this.Module.isInitialized() && (D.aspectRatio = this.Module.getAspectRatio(), D.isCanvasStyleTablet = this.Module.getIsCanvasStyleTablet(), D.isWebHIDInput = this.Module.getIsWebHIDInput())), D;
1151
+ return this.isWasmInitialized && (i.name = this.device && this.device.productName ? this.device.productName : "Unknown Device", i.ready = this.Module.isInitialized(), i.supportedCommands = this.Module.getSupportedCommands(), i.serialNumber = this.device && this.device.serialNumber ? this.device.serialNumber : null, this.Module.isInitialized() && (i.aspectRatio = this.Module.getAspectRatio(), i.isCanvasStyleTablet = this.Module.getIsCanvasStyleTablet(), i.isWebHIDInput = this.Module.getIsWebHIDInput())), i;
1152
1152
  };
1153
1153
  window.WacomTablet.prototype._configurePenAspectCorrection = function() {
1154
1154
  this.penAspectCorrector = null;
1155
- const D = this.Module.getAspectRatio();
1156
- if (this.Module.getIsCanvasStyleTablet() || !this.Module.getIsWebHIDInput() || D <= 0)
1155
+ const i = this.Module.getAspectRatio();
1156
+ if (this.Module.getIsCanvasStyleTablet() || !this.Module.getIsWebHIDInput() || i <= 0)
1157
1157
  return;
1158
1158
  const A = window.screen.width / window.screen.height;
1159
- if (Math.abs(D - A) < 1e-6) {
1159
+ if (Math.abs(i - A) < 1e-6) {
1160
1160
  console.log("[JS] AspectRatioCorrector not needed");
1161
1161
  return;
1162
1162
  }
@@ -1164,15 +1164,15 @@ window.WacomTablet.prototype._configurePenAspectCorrection = function() {
1164
1164
  console.warn("[JS] AspectRatioCorrector not available; skipping aspect correction");
1165
1165
  return;
1166
1166
  }
1167
- this.penAspectCorrector = new AspectRatioCorrector(A, D, "center"), console.log("[JS] Pen aspect correction enabled", {
1168
- tabletAspectRatio: D,
1167
+ this.penAspectCorrector = new AspectRatioCorrector(A, i, "center"), console.log("[JS] Pen aspect correction enabled", {
1168
+ tabletAspectRatio: i,
1169
1169
  screenAspectRatio: A
1170
1170
  });
1171
1171
  };
1172
1172
  typeof WacomTablet < "u" && (window.WacomTablet = WacomTablet);
1173
1173
  typeof AspectRatioCorrector < "u" && (window.AspectRatioCorrector = AspectRatioCorrector);
1174
1174
  typeof DriversModule < "u" && (window.DriversModule = DriversModule);
1175
- window.WacomTablet.prototype.sendCommand = function(D, A = null) {
1175
+ window.WacomTablet.prototype.sendCommand = function(i, A = null) {
1176
1176
  if (!this.isConnected())
1177
1177
  return Promise.reject(new Error("Device not connected"));
1178
1178
  let C = "";
@@ -1182,30 +1182,30 @@ window.WacomTablet.prototype.sendCommand = function(D, A = null) {
1182
1182
  C = A.build();
1183
1183
  else
1184
1184
  return Promise.reject(new Error("sendCommand only accepts CommandArgsBuilder objects. Use: new CommandArgsBuilder().addField(name, value)"));
1185
- return this.isCommandSupported(D) ? this.Module.sendCommand(D, C) : Promise.reject(new Error(`Command not supported: ${D}`));
1185
+ return this.isCommandSupported(i) ? this.Module.sendCommand(i, C) : Promise.reject(new Error(`Command not supported: ${i}`));
1186
1186
  };
1187
- window.WacomTablet.prototype.isCommandSupported = function(D) {
1188
- return this.isWasmInitialized ? this.Module.isCommandSupported(D) : !1;
1187
+ window.WacomTablet.prototype.isCommandSupported = function(i) {
1188
+ return this.isWasmInitialized ? this.Module.isCommandSupported(i) : !1;
1189
1189
  };
1190
- window.WacomTablet.prototype.disableDrawing = function(D = null) {
1191
- const A = D || new CommandArgsBuilder();
1190
+ window.WacomTablet.prototype.disableDrawing = function(i = null) {
1191
+ const A = i || new CommandArgsBuilder();
1192
1192
  return this.sendCommand("DisableDrawing", A);
1193
1193
  };
1194
- window.WacomTablet.prototype.enableDrawing = function(D = null) {
1195
- const A = D || new CommandArgsBuilder();
1194
+ window.WacomTablet.prototype.enableDrawing = function(i = null) {
1195
+ const A = i || new CommandArgsBuilder();
1196
1196
  return this.sendCommand("EnableDrawing", A);
1197
1197
  };
1198
- window.WacomTablet.prototype.wipeScreen = function(D = null) {
1199
- const A = D || new CommandArgsBuilder();
1198
+ window.WacomTablet.prototype.wipeScreen = function(i = null) {
1199
+ const A = i || new CommandArgsBuilder();
1200
1200
  return this.sendCommand("WipeScreen", A);
1201
1201
  };
1202
- window.WacomTablet.prototype.clearScreen = function(D = null) {
1203
- const A = D || new CommandArgsBuilder();
1202
+ window.WacomTablet.prototype.clearScreen = function(i = null) {
1203
+ const A = i || new CommandArgsBuilder();
1204
1204
  return this.sendCommand("ClearScreen", A);
1205
1205
  };
1206
- window.WacomTablet.prototype.displayImage = async function(D, A = {}) {
1206
+ window.WacomTablet.prototype.displayImage = async function(i, A = {}) {
1207
1207
  try {
1208
- const C = await ImageProcessor.processImageSource(D, A);
1208
+ const C = await ImageProcessor.processImageSource(i, A);
1209
1209
  if (!C)
1210
1210
  throw new Error("Failed to process image source");
1211
1211
  const B = new CommandArgsBuilder().addImage(C).addFields(A);
@@ -1214,54 +1214,54 @@ window.WacomTablet.prototype.displayImage = async function(D, A = {}) {
1214
1214
  throw console.error("Error displaying image:", C), C;
1215
1215
  }
1216
1216
  };
1217
- window.WacomTablet.prototype.displayText = async function(D, A = {}) {
1218
- const C = ImageProcessor.createTextImage(D, A);
1217
+ window.WacomTablet.prototype.displayText = async function(i, A = {}) {
1218
+ const C = ImageProcessor.createTextImage(i, A);
1219
1219
  return this.displayImage(C);
1220
1220
  };
1221
1221
  window.WacomTablet.prototype.getSupportedCommands = function() {
1222
1222
  if (!this.isWasmInitialized || !this.Module)
1223
1223
  return [];
1224
1224
  try {
1225
- const D = this.Module.getSupportedCommands();
1226
- return Array.from(D);
1227
- } catch (D) {
1228
- return console.error("Error getting supported commands:", D), [];
1225
+ const i = this.Module.getSupportedCommands();
1226
+ return Array.from(i);
1227
+ } catch (i) {
1228
+ return console.error("Error getting supported commands:", i), [];
1229
1229
  }
1230
1230
  };
1231
1231
  typeof WacomTablet < "u" && (window.WacomTablet = WacomTablet);
1232
1232
  typeof CommandArgsBuilder < "u" && (window.CommandArgsBuilder = CommandArgsBuilder);
1233
1233
  typeof ImageProcessor < "u" && (window.ImageProcessor = ImageProcessor);
1234
1234
  window.WacomTablet.prototype._setupMasterCallback = function() {
1235
- const D = this.Module.getInputEvent();
1236
- !D || this.masterCallback || (this.masterCallback = (A) => {
1235
+ const i = this.Module.getInputEvent();
1236
+ !i || this.masterCallback || (this.masterCallback = (A) => {
1237
1237
  const C = this.eventCallbacks.get(A.type);
1238
1238
  C && C.size > 0 && C.forEach((B) => {
1239
1239
  try {
1240
1240
  B(this._applyPenAspectCorrection(A.penData));
1241
- } catch (i) {
1242
- console.error(`Error in event callback for type ${A.type}:`, i);
1241
+ } catch (D) {
1242
+ console.error(`Error in event callback for type ${A.type}:`, D);
1243
1243
  }
1244
1244
  });
1245
- }, D.on(this.masterCallback), console.log("[JS] Master event callback registered"));
1245
+ }, i.on(this.masterCallback), console.log("[JS] Master event callback registered"));
1246
1246
  };
1247
1247
  window.WacomTablet.prototype._cleanupEventSystem = function() {
1248
1248
  if (this.masterCallback) {
1249
- const D = this.Module.getInputEvent();
1250
- D && D.off(this.masterCallback);
1249
+ const i = this.Module.getInputEvent();
1250
+ i && i.off(this.masterCallback);
1251
1251
  }
1252
1252
  this.eventCallbacks.clear(), this.callbackToHandle.clear(), this.masterCallback = null;
1253
1253
  };
1254
- window.WacomTablet.prototype._applyPenAspectCorrection = function(D) {
1254
+ window.WacomTablet.prototype._applyPenAspectCorrection = function(i) {
1255
1255
  if (!this.penAspectCorrector)
1256
- return D;
1257
- const A = this.penAspectCorrector.inverseCorrectCoordinates(D.x, D.y);
1256
+ return i;
1257
+ const A = this.penAspectCorrector.inverseCorrectCoordinates(i.x, i.y);
1258
1258
  return {
1259
- ...D,
1259
+ ...i,
1260
1260
  x: A.x,
1261
1261
  y: A.y
1262
1262
  };
1263
1263
  };
1264
- window.WacomTablet.prototype._validateInputType = function(D) {
1264
+ window.WacomTablet.prototype._validateInputType = function(i) {
1265
1265
  if (!this.isWasmInitialized)
1266
1266
  throw new Error("Not initialized. Call initialize() first.");
1267
1267
  const A = [
@@ -1274,68 +1274,68 @@ window.WacomTablet.prototype._validateInputType = function(D) {
1274
1274
  "Custom3",
1275
1275
  "Custom4"
1276
1276
  ];
1277
- if (!A.includes(D))
1278
- throw new Error(`Invalid input type: ${D}. Valid types: ${A.join(", ")}`);
1277
+ if (!A.includes(i))
1278
+ throw new Error(`Invalid input type: ${i}. Valid types: ${A.join(", ")}`);
1279
1279
  };
1280
- window.WacomTablet.prototype.on = function(D, A) {
1281
- if (this._validateInputType(D), typeof A != "function")
1280
+ window.WacomTablet.prototype.on = function(i, A) {
1281
+ if (this._validateInputType(i), typeof A != "function")
1282
1282
  throw new Error("Callback must be a function");
1283
- return this.eventCallbacks.has(D) || this.eventCallbacks.set(D, /* @__PURE__ */ new Set()), this.eventCallbacks.get(D).add(A), this.callbackToHandle.set(A, D), console.log(`[JS] Registered callback for input type: ${D}`), this.isConnected() && !this.masterCallback && this._setupMasterCallback(), A;
1283
+ return this.eventCallbacks.has(i) || this.eventCallbacks.set(i, /* @__PURE__ */ new Set()), this.eventCallbacks.get(i).add(A), this.callbackToHandle.set(A, i), console.log(`[JS] Registered callback for input type: ${i}`), this.isConnected() && !this.masterCallback && this._setupMasterCallback(), A;
1284
1284
  };
1285
- window.WacomTablet.prototype.off = function(D, A) {
1286
- if (this._validateInputType(D), typeof A != "function")
1285
+ window.WacomTablet.prototype.off = function(i, A) {
1286
+ if (this._validateInputType(i), typeof A != "function")
1287
1287
  throw new Error("Callback must be a function");
1288
- const C = this.eventCallbacks.get(D);
1289
- C && (C.delete(A), C.size === 0 && this.eventCallbacks.delete(D)), this.callbackToHandle.delete(A), console.log(`[JS] Unregistered callback for input type: ${D}`);
1288
+ const C = this.eventCallbacks.get(i);
1289
+ C && (C.delete(A), C.size === 0 && this.eventCallbacks.delete(i)), this.callbackToHandle.delete(A), console.log(`[JS] Unregistered callback for input type: ${i}`);
1290
1290
  };
1291
- window.WacomTablet.prototype.onPen = function(D) {
1292
- return this.on("Pen", D);
1291
+ window.WacomTablet.prototype.onPen = function(i) {
1292
+ return this.on("Pen", i);
1293
1293
  };
1294
- window.WacomTablet.prototype.offPen = function(D) {
1295
- this.off("Pen", D);
1294
+ window.WacomTablet.prototype.offPen = function(i) {
1295
+ this.off("Pen", i);
1296
1296
  };
1297
- window.WacomTablet.prototype.onOK = function(D) {
1298
- return this.on("OK", D);
1297
+ window.WacomTablet.prototype.onOK = function(i) {
1298
+ return this.on("OK", i);
1299
1299
  };
1300
- window.WacomTablet.prototype.offOK = function(D) {
1301
- this.off("OK", D);
1300
+ window.WacomTablet.prototype.offOK = function(i) {
1301
+ this.off("OK", i);
1302
1302
  };
1303
- window.WacomTablet.prototype.onCancel = function(D) {
1304
- return this.on("Cancel", D);
1303
+ window.WacomTablet.prototype.onCancel = function(i) {
1304
+ return this.on("Cancel", i);
1305
1305
  };
1306
- window.WacomTablet.prototype.offCancel = function(D) {
1307
- this.off("Cancel", D);
1306
+ window.WacomTablet.prototype.offCancel = function(i) {
1307
+ this.off("Cancel", i);
1308
1308
  };
1309
- window.WacomTablet.prototype.onClear = function(D) {
1310
- return this.on("Clear", D);
1309
+ window.WacomTablet.prototype.onClear = function(i) {
1310
+ return this.on("Clear", i);
1311
1311
  };
1312
- window.WacomTablet.prototype.offClear = function(D) {
1313
- this.off("Clear", D);
1312
+ window.WacomTablet.prototype.offClear = function(i) {
1313
+ this.off("Clear", i);
1314
1314
  };
1315
1315
  window.WacomTablet.prototype.getEventSubscriptions = function() {
1316
- const D = {};
1316
+ const i = {};
1317
1317
  return this.eventCallbacks.forEach((A, C) => {
1318
- D[C] = A.size;
1319
- }), D;
1318
+ i[C] = A.size;
1319
+ }), i;
1320
1320
  };
1321
1321
  typeof WacomTablet < "u" && (window.WacomTablet = WacomTablet);
1322
1322
  window.WacomTablet.prototype.getLogLevel = function() {
1323
1323
  return this.isWasmInitialized ? this.Module.getLogLevel() : null;
1324
1324
  };
1325
- window.WacomTablet.prototype.enableDataLog = function(D) {
1325
+ window.WacomTablet.prototype.enableDataLog = function(i) {
1326
1326
  if (!this.isWasmInitialized)
1327
1327
  throw new Error("Not initialized. Call initialize() first.");
1328
- this.Module.enableDataLog(D), console.log(`[JS] Enabled data log flag: ${D}`);
1328
+ this.Module.enableDataLog(i), console.log(`[JS] Enabled data log flag: ${i}`);
1329
1329
  };
1330
- window.WacomTablet.prototype.disableDataLog = function(D) {
1330
+ window.WacomTablet.prototype.disableDataLog = function(i) {
1331
1331
  if (!this.isWasmInitialized)
1332
1332
  throw new Error("Not initialized. Call initialize() first.");
1333
- this.Module.disableDataLog(D), console.log(`[JS] Disabled data log flag: ${D}`);
1333
+ this.Module.disableDataLog(i), console.log(`[JS] Disabled data log flag: ${i}`);
1334
1334
  };
1335
- window.WacomTablet.prototype.setDataLogFlags = function(D) {
1335
+ window.WacomTablet.prototype.setDataLogFlags = function(i) {
1336
1336
  if (!this.isWasmInitialized)
1337
1337
  throw new Error("Not initialized. Call initialize() first.");
1338
- this.Module.setDataLogFlags(D), console.log(`[JS] Data log flags set to: 0x${D.toString(16)}`);
1338
+ this.Module.setDataLogFlags(i), console.log(`[JS] Data log flags set to: 0x${i.toString(16)}`);
1339
1339
  };
1340
1340
  window.WacomTablet.prototype.getDataLogFlags = function() {
1341
1341
  return this.isWasmInitialized ? this.Module.getDataLogFlags() : 0;
@@ -1344,8 +1344,8 @@ window.WacomTablet.prototype.getLogStatusString = function() {
1344
1344
  return this.isWasmInitialized ? this.Module.getLogStatusString() : "Not initialized";
1345
1345
  };
1346
1346
  window.WacomTablet.prototype.enableAllDataLogs = function() {
1347
- const D = this.Module.DataLogFlag.Raw | this.Module.DataLogFlag.Parsed | this.Module.DataLogFlag.Normalized | this.Module.DataLogFlag.Command | this.Module.DataLogFlag.Other;
1348
- this.setDataLogFlags(D);
1347
+ const i = this.Module.DataLogFlag.Raw | this.Module.DataLogFlag.Parsed | this.Module.DataLogFlag.Normalized | this.Module.DataLogFlag.Command | this.Module.DataLogFlag.Other;
1348
+ this.setDataLogFlags(i);
1349
1349
  };
1350
1350
  window.WacomTablet.prototype.disableAllDataLogs = function() {
1351
1351
  this.setDataLogFlags(0);
@@ -1371,9 +1371,9 @@ window.WacomTablet.prototype.enableDebugMode = function() {
1371
1371
  window.WacomTablet.prototype.enableProductionMode = function() {
1372
1372
  this.disableAllDataLogs(), console.log("[JS] Production mode enabled - no data logging");
1373
1373
  };
1374
- window.WacomTablet.prototype.enableAnalysisMode = function(D = null) {
1375
- if (D !== null)
1376
- this.setDataLogFlags(D);
1374
+ window.WacomTablet.prototype.enableAnalysisMode = function(i = null) {
1375
+ if (i !== null)
1376
+ this.setDataLogFlags(i);
1377
1377
  else {
1378
1378
  const A = this.Module.DataLogFlag.Parsed | this.Module.DataLogFlag.Normalized;
1379
1379
  this.setDataLogFlags(A);
@@ -1381,7 +1381,7 @@ window.WacomTablet.prototype.enableAnalysisMode = function(D = null) {
1381
1381
  console.log("[JS] Analysis mode enabled");
1382
1382
  };
1383
1383
  typeof WacomTablet < "u" && (window.WacomTablet = WacomTablet);
1384
- let KA = class YI {
1384
+ let YA = class YI {
1385
1385
  /**
1386
1386
  * Create an aspect ratio corrector working in relative coordinate space (0-1)
1387
1387
  * @param {number} sourceAspectRatio - Source aspect ratio (width/height)
@@ -1442,10 +1442,10 @@ let KA = class YI {
1442
1442
  * @returns {Object} - {x, y} where x,y are target relative coordinates (0-1)
1443
1443
  */
1444
1444
  correctCoordinates(A, C) {
1445
- const B = A * this.mappedWidth + this.offsetX, i = C * this.mappedHeight + this.offsetY;
1445
+ const B = A * this.mappedWidth + this.offsetX, D = C * this.mappedHeight + this.offsetY;
1446
1446
  return {
1447
1447
  x: B,
1448
- y: i
1448
+ y: D
1449
1449
  };
1450
1450
  }
1451
1451
  /**
@@ -1455,10 +1455,10 @@ let KA = class YI {
1455
1455
  * @returns {Object} - {x, y} source coordinates (0-1)
1456
1456
  */
1457
1457
  inverseCorrectCoordinates(A, C) {
1458
- const B = (A - this.offsetX) / this.mappedWidth, i = (C - this.offsetY) / this.mappedHeight;
1458
+ const B = (A - this.offsetX) / this.mappedWidth, D = (C - this.offsetY) / this.mappedHeight;
1459
1459
  return {
1460
1460
  x: B,
1461
- y: i
1461
+ y: D
1462
1462
  };
1463
1463
  }
1464
1464
  /**
@@ -1513,9 +1513,9 @@ let KA = class YI {
1513
1513
  * @param {string|Array} anchor - Anchor point
1514
1514
  * @returns {AspectRatioCorrector} - Configured corrector for the hotspot
1515
1515
  */
1516
- static createHotspotCorrector(A, C, B, i, U = "center") {
1517
- const N = this.getHotspotAspectRatio(A, B, i);
1518
- return new YI(N, C, U);
1516
+ static createHotspotCorrector(A, C, B, D, U = "center") {
1517
+ const w = this.getHotspotAspectRatio(A, B, D);
1518
+ return new YI(w, C, U);
1519
1519
  }
1520
1520
  /**
1521
1521
  * Get recommended relative size that matches a given aspect ratio within bounds
@@ -1525,8 +1525,8 @@ let KA = class YI {
1525
1525
  * @returns {Object} - {width, height} of recommended relative size (0-1)
1526
1526
  */
1527
1527
  static getRecommendedSize(A, C, B) {
1528
- const i = A / C;
1529
- return B > i ? {
1528
+ const D = A / C;
1529
+ return B > D ? {
1530
1530
  width: A,
1531
1531
  height: A / B
1532
1532
  } : {
@@ -1535,11 +1535,11 @@ let KA = class YI {
1535
1535
  };
1536
1536
  }
1537
1537
  };
1538
- typeof window < "u" && (window.AspectRatioCorrector = KA);
1538
+ typeof window < "u" && (window.AspectRatioCorrector = YA);
1539
1539
  typeof module < "u" && module.exports && (module.exports = {
1540
- AspectRatioCorrector: KA
1540
+ AspectRatioCorrector: YA
1541
1541
  });
1542
- typeof KA < "u" && (window.AspectRatioCorrector = KA);
1542
+ typeof YA < "u" && (window.AspectRatioCorrector = YA);
1543
1543
  let pA = class cI {
1544
1544
  constructor() {
1545
1545
  this.args = {};
@@ -1646,33 +1646,33 @@ let aI = class {
1646
1646
  return this.tablet !== null;
1647
1647
  }
1648
1648
  // Add static hotspot with tablet coordinates (0-1)
1649
- addStaticHotspot(A, C, B, i, U, N) {
1649
+ addStaticHotspot(A, C, B, D, U, w) {
1650
1650
  if (!A || typeof A != "string")
1651
1651
  throw new Error("Hotspot name must be a non-empty string");
1652
- if (typeof N != "function")
1652
+ if (typeof w != "function")
1653
1653
  throw new Error("Hotspot callback must be a function");
1654
- if (C < 0 || C > 1 || B < 0 || B > 1 || i <= 0 || i > 1 || U <= 0 || U > 1 || C + i > 1 || B + U > 1)
1654
+ if (C < 0 || C > 1 || B < 0 || B > 1 || D <= 0 || D > 1 || U <= 0 || U > 1 || C + D > 1 || B + U > 1)
1655
1655
  throw new Error("Hotspot coordinates must be in range 0-1 and within tablet bounds");
1656
- return this._createHotspot(A, () => ({ x: C, y: B, width: i, height: U }), N);
1656
+ return this._createHotspot(A, () => ({ x: C, y: B, width: D, height: U }), w);
1657
1657
  }
1658
1658
  // Add element hotspot that tracks DOM element bounds
1659
- addElementHotspot(A, C, B, i = null) {
1659
+ addElementHotspot(A, C, B, D = null) {
1660
1660
  if (!A || typeof A != "string")
1661
1661
  throw new Error("Hotspot name must be a non-empty string");
1662
1662
  if (!C || typeof C.getBoundingClientRect != "function")
1663
1663
  throw new Error("Element must be a DOM element");
1664
1664
  if (typeof B != "function")
1665
1665
  throw new Error("Hotspot callback must be a function");
1666
- const U = i ? "(DOM element with container)" : "(DOM element)";
1666
+ const U = D ? "(DOM element with container)" : "(DOM element)";
1667
1667
  return this._createHotspot(
1668
1668
  A,
1669
- () => this._calculateElementBounds(C, i),
1669
+ () => this._calculateElementBounds(C, D),
1670
1670
  B,
1671
1671
  U
1672
1672
  );
1673
1673
  }
1674
1674
  // Add coordinate hotspot that tracks pixel coordinates within container
1675
- addCoordinateHotspot(A, C, B, i = null) {
1675
+ addCoordinateHotspot(A, C, B, D = null) {
1676
1676
  if (!A || typeof A != "string")
1677
1677
  throw new Error("Hotspot name must be a non-empty string");
1678
1678
  if (!C || typeof C != "object" || typeof C.x != "number" || typeof C.y != "number" || typeof C.width != "number" || typeof C.height != "number")
@@ -1681,7 +1681,7 @@ let aI = class {
1681
1681
  throw new Error("Hotspot callback must be a function");
1682
1682
  return this._createHotspot(
1683
1683
  A,
1684
- () => this._calculateCoordinateBounds(C, i),
1684
+ () => this._calculateCoordinateBounds(C, D),
1685
1685
  B
1686
1686
  );
1687
1687
  }
@@ -1697,18 +1697,18 @@ let aI = class {
1697
1697
  C,
1698
1698
  "(page with screen mapping)"
1699
1699
  );
1700
- return B.pressedElement = null, B.callback = (i, U, N) => {
1700
+ return B.pressedElement = null, B.callback = (D, U, w) => {
1701
1701
  if (U === "move" && B.isValidForClick) {
1702
- const h = this._getElementAtPenPoint(i);
1702
+ const h = this._getElementAtPenPoint(D);
1703
1703
  B.pressedElement !== h && (B.isValidForClick = !1, B.pressedElement = null);
1704
1704
  }
1705
- U === "down" && (B.pressedElement = this._getElementAtPenPoint(i)), C(i, U, N);
1705
+ U === "down" && (B.pressedElement = this._getElementAtPenPoint(D)), C(D, U, w);
1706
1706
  }, B;
1707
1707
  }
1708
1708
  // Internal method to create hotspot
1709
1709
  _createHotspot(A, C, B) {
1710
1710
  this.isAttached() || console.warn("[JS] HotspotManager: Adding hotspot without tablet attached. Call setTablet() first.");
1711
- const i = {
1711
+ const D = {
1712
1712
  name: A,
1713
1713
  getBounds: C,
1714
1714
  callback: B,
@@ -1716,24 +1716,24 @@ let aI = class {
1716
1716
  isPenInside: !1,
1717
1717
  isValidForClick: !1
1718
1718
  };
1719
- return this.hotspots.set(A, i), console.log(`[JS] HotspotManager: Hotspot '${A}' added`), i;
1719
+ return this.hotspots.set(A, D), console.log(`[JS] HotspotManager: Hotspot '${A}' added`), D;
1720
1720
  }
1721
1721
  // Helper method to calculate element bounds in tablet coordinate space (0-1)
1722
1722
  _calculateElementBounds(A, C) {
1723
1723
  const B = A.getBoundingClientRect();
1724
1724
  if (C) {
1725
- const i = C.getBoundingClientRect ? C.getBoundingClientRect() : { left: 0, top: 0, width: C.clientWidth || window.innerWidth, height: C.clientHeight || window.innerHeight };
1725
+ const D = C.getBoundingClientRect ? C.getBoundingClientRect() : { left: 0, top: 0, width: C.clientWidth || window.innerWidth, height: C.clientHeight || window.innerHeight };
1726
1726
  return {
1727
- x: (B.left - i.left) / i.width,
1728
- y: (B.top - i.top) / i.height,
1729
- width: B.width / i.width,
1730
- height: B.height / i.height
1727
+ x: (B.left - D.left) / D.width,
1728
+ y: (B.top - D.top) / D.height,
1729
+ width: B.width / D.width,
1730
+ height: B.height / D.height
1731
1731
  };
1732
1732
  } else {
1733
- const i = window.outerHeight - window.innerHeight, U = window.screenX - window.screen.availLeft + B.left, N = window.screenY - window.screen.availTop + i + B.top;
1733
+ const D = window.outerHeight - window.innerHeight, U = window.screenX - window.screen.availLeft + B.left, w = window.screenY - window.screen.availTop + D + B.top;
1734
1734
  return {
1735
1735
  x: U / window.screen.width,
1736
- y: N / window.screen.height,
1736
+ y: w / window.screen.height,
1737
1737
  width: B.width / window.screen.width,
1738
1738
  height: B.height / window.screen.height
1739
1739
  };
@@ -1741,18 +1741,18 @@ let aI = class {
1741
1741
  }
1742
1742
  // Helper method to calculate coordinate bounds once per call
1743
1743
  _calculateCoordinateBounds(A, C) {
1744
- const B = C || document.documentElement, i = B.getBoundingClientRect ? B.getBoundingClientRect() : { width: B.clientWidth || window.innerWidth, height: B.clientHeight || window.innerHeight };
1744
+ const B = C || document.documentElement, D = B.getBoundingClientRect ? B.getBoundingClientRect() : { width: B.clientWidth || window.innerWidth, height: B.clientHeight || window.innerHeight };
1745
1745
  return {
1746
- x: A.x / i.width,
1747
- y: A.y / i.height,
1748
- width: A.width / i.width,
1749
- height: A.height / i.height
1746
+ x: A.x / D.width,
1747
+ y: A.y / D.height,
1748
+ width: A.width / D.width,
1749
+ height: A.height / D.height
1750
1750
  };
1751
1751
  }
1752
1752
  // Calculate page bounds in tablet coordinate space (0-1)
1753
1753
  _calculatePageBounds() {
1754
- const A = window.outerHeight - window.innerHeight, C = window.screenX - window.screen.availLeft, B = window.screenY - window.screen.availTop + A, i = window.innerWidth, U = window.innerHeight, N = C / window.screen.width, h = B / window.screen.height, y = i / window.screen.width, W = U / window.screen.height;
1755
- return { x: N, y: h, width: y, height: W };
1754
+ const A = window.outerHeight - window.innerHeight, C = window.screenX - window.screen.availLeft, B = window.screenY - window.screen.availTop + A, D = window.innerWidth, U = window.innerHeight, w = C / window.screen.width, h = B / window.screen.height, y = D / window.screen.width, W = U / window.screen.height;
1755
+ return { x: w, y: h, width: y, height: W };
1756
1756
  }
1757
1757
  _getElementAtPenPoint(A) {
1758
1758
  if (typeof window > "u" || !window.document || typeof document.elementFromPoint != "function")
@@ -1798,13 +1798,13 @@ let aI = class {
1798
1798
  }
1799
1799
  _isPointInHotspot(A, C, B) {
1800
1800
  if (!B.active) return !1;
1801
- const i = B.getBounds();
1802
- return A >= i.x && A <= i.x + i.width && C >= i.y && C <= i.y + i.height;
1801
+ const D = B.getBounds();
1802
+ return A >= D.x && A <= D.x + D.width && C >= D.y && C <= D.y + D.height;
1803
1803
  }
1804
1804
  getHotspotsAtPoint(A, C) {
1805
1805
  const B = [];
1806
- for (const [i, U] of this.hotspots)
1807
- this._isPointInHotspot(A, C, U) && B.push(i);
1806
+ for (const [D, U] of this.hotspots)
1807
+ this._isPointInHotspot(A, C, U) && B.push(D);
1808
1808
  return B;
1809
1809
  }
1810
1810
  processHotspots(A) {
@@ -1814,29 +1814,29 @@ let aI = class {
1814
1814
  console.warn("[JS] HotspotManager: processHotspots() called without tablet attached");
1815
1815
  return;
1816
1816
  }
1817
- const C = A.x, B = A.y, i = A.inContact;
1818
- for (const [U, N] of this.hotspots) {
1819
- if (!N.active) continue;
1820
- const h = this._isPointInHotspot(C, B, N);
1821
- N.isPenInside && !h ? (N.isPenInside = !1, N.isValidForClick = !1, this._triggerHotspotEvent(U, "leave", A)) : !N.isPenInside && h && (N.isPenInside = !0, N.isValidForClick = !1, this._triggerHotspotEvent(U, "enter", A)), i && !this.penState.wasInContact && h ? (N.isValidForClick = !0, this._triggerHotspotEvent(U, "down", A)) : !i && this.penState.wasInContact ? (h && (this._triggerHotspotEvent(U, "up", A), N.isValidForClick && this._triggerHotspotEvent(U, "click", A)), N.isValidForClick = !1) : !i && this.penState.wasInContact && N.isValidForClick && (N.isValidForClick = !1), h && (C !== this.penState.lastX || B !== this.penState.lastY) && this._triggerHotspotEvent(U, "move", A), h && this._triggerHotspotEvent(U, "pen", A);
1817
+ const C = A.x, B = A.y, D = A.inContact;
1818
+ for (const [U, w] of this.hotspots) {
1819
+ if (!w.active) continue;
1820
+ const h = this._isPointInHotspot(C, B, w);
1821
+ w.isPenInside && !h ? (w.isPenInside = !1, w.isValidForClick = !1, this._triggerHotspotEvent(U, "leave", A)) : !w.isPenInside && h && (w.isPenInside = !0, w.isValidForClick = !1, this._triggerHotspotEvent(U, "enter", A)), D && !this.penState.wasInContact && h ? (w.isValidForClick = !0, this._triggerHotspotEvent(U, "down", A)) : !D && this.penState.wasInContact ? (h && (this._triggerHotspotEvent(U, "up", A), w.isValidForClick && this._triggerHotspotEvent(U, "click", A)), w.isValidForClick = !1) : !D && this.penState.wasInContact && w.isValidForClick && (w.isValidForClick = !1), h && (C !== this.penState.lastX || B !== this.penState.lastY) && this._triggerHotspotEvent(U, "move", A), h && this._triggerHotspotEvent(U, "pen", A);
1822
1822
  }
1823
- this.penState.lastX = C, this.penState.lastY = B, this.penState.wasInContact = i;
1823
+ this.penState.lastX = C, this.penState.lastY = B, this.penState.wasInContact = D;
1824
1824
  }
1825
1825
  _triggerHotspotEvent(A, C, B) {
1826
- const i = this.hotspots.get(A);
1827
- if (!(!i || !i.active))
1826
+ const D = this.hotspots.get(A);
1827
+ if (!(!D || !D.active))
1828
1828
  try {
1829
- const U = this._createRelativePenData(B, i);
1830
- i.callback(U, C, A);
1829
+ const U = this._createRelativePenData(B, D);
1830
+ D.callback(U, C, A);
1831
1831
  } catch (U) {
1832
1832
  console.error(`HotspotManager: Error in hotspot '${A}' callback for event '${C}':`, U);
1833
1833
  }
1834
1834
  }
1835
1835
  _createRelativePenData(A, C) {
1836
- const B = C.getBounds(), i = (A.x - B.x) / B.width, U = (A.y - B.y) / B.height, N = Math.max(0, Math.min(1, i)), h = Math.max(0, Math.min(1, U));
1836
+ const B = C.getBounds(), D = (A.x - B.x) / B.width, U = (A.y - B.y) / B.height, w = Math.max(0, Math.min(1, D)), h = Math.max(0, Math.min(1, U));
1837
1837
  return {
1838
1838
  ...A,
1839
- x: N,
1839
+ x: w,
1840
1840
  y: h
1841
1841
  };
1842
1842
  }
@@ -1868,56 +1868,56 @@ let xA = class {
1868
1868
  let B = A;
1869
1869
  if (C.width || C.height) {
1870
1870
  B = document.createElement("canvas");
1871
- const i = B.getContext("2d");
1872
- B.width = C.width || A.width, B.height = C.height || A.height, i.drawImage(A, 0, 0, B.width, B.height);
1871
+ const D = B.getContext("2d");
1872
+ B.width = C.width || A.width, B.height = C.height || A.height, D.drawImage(A, 0, 0, B.width, B.height);
1873
1873
  }
1874
1874
  return B.toDataURL("image/png");
1875
1875
  }
1876
1876
  // Process HTMLImageElement - returns base64 data URL
1877
1877
  static processImageElement(A, C = {}) {
1878
- const B = document.createElement("canvas"), i = B.getContext("2d");
1879
- return B.width = C.width || A.width, B.height = C.height || A.height, i.drawImage(A, 0, 0, B.width, B.height), B.toDataURL("image/png");
1878
+ const B = document.createElement("canvas"), D = B.getContext("2d");
1879
+ return B.width = C.width || A.width, B.height = C.height || A.height, D.drawImage(A, 0, 0, B.width, B.height), B.toDataURL("image/png");
1880
1880
  }
1881
1881
  // Process image file - returns base64 data URL
1882
1882
  static async processFile(A, C = {}) {
1883
- return new Promise((B, i) => {
1883
+ return new Promise((B, D) => {
1884
1884
  const U = new Image();
1885
1885
  U.onload = () => {
1886
1886
  const h = document.createElement("canvas"), y = h.getContext("2d");
1887
1887
  h.width = C.width || U.width, h.height = C.height || U.height, y.drawImage(U, 0, 0, h.width, h.height), B(h.toDataURL("image/png"));
1888
- }, U.onerror = () => i(new Error("Failed to load image file"));
1889
- const N = new FileReader();
1890
- N.onload = (h) => U.src = h.target.result, N.onerror = () => i(new Error("Failed to read file")), N.readAsDataURL(A);
1888
+ }, U.onerror = () => D(new Error("Failed to load image file"));
1889
+ const w = new FileReader();
1890
+ w.onload = (h) => U.src = h.target.result, w.onerror = () => D(new Error("Failed to read file")), w.readAsDataURL(A);
1891
1891
  });
1892
1892
  }
1893
1893
  // Process base64 data URL - returns base64 data URL (with optional resizing)
1894
1894
  static async processBase64DataUrl(A, C = {}) {
1895
- return !C.width && !C.height ? A : new Promise((B, i) => {
1895
+ return !C.width && !C.height ? A : new Promise((B, D) => {
1896
1896
  const U = new Image();
1897
1897
  U.onload = () => {
1898
- const N = document.createElement("canvas"), h = N.getContext("2d");
1899
- N.width = C.width || U.width, N.height = C.height || U.height, h.drawImage(U, 0, 0, N.width, N.height), B(N.toDataURL("image/png"));
1900
- }, U.onerror = () => i(new Error("Failed to load base64 image")), U.src = A;
1898
+ const w = document.createElement("canvas"), h = w.getContext("2d");
1899
+ w.width = C.width || U.width, w.height = C.height || U.height, h.drawImage(U, 0, 0, w.width, w.height), B(w.toDataURL("image/png"));
1900
+ }, U.onerror = () => D(new Error("Failed to load base64 image")), U.src = A;
1901
1901
  });
1902
1902
  }
1903
1903
  // Process image URL - returns base64 data URL
1904
1904
  static async processImageUrl(A, C = {}) {
1905
- return new Promise((B, i) => {
1905
+ return new Promise((B, D) => {
1906
1906
  const U = new Image();
1907
1907
  U.onload = () => {
1908
- const N = document.createElement("canvas"), h = N.getContext("2d");
1909
- N.width = C.width || U.width, N.height = C.height || U.height, h.drawImage(U, 0, 0, N.width, N.height), B(N.toDataURL("image/png"));
1910
- }, U.onerror = () => i(new Error(`Failed to load image from URL: ${A}`)), U.crossOrigin = "anonymous", U.src = A;
1908
+ const w = document.createElement("canvas"), h = w.getContext("2d");
1909
+ w.width = C.width || U.width, w.height = C.height || U.height, h.drawImage(U, 0, 0, w.width, w.height), B(w.toDataURL("image/png"));
1910
+ }, U.onerror = () => D(new Error(`Failed to load image from URL: ${A}`)), U.crossOrigin = "anonymous", U.src = A;
1911
1911
  });
1912
1912
  }
1913
1913
  // Process ImageData - returns base64 data URL
1914
1914
  static processImageData(A, C = {}) {
1915
- const B = document.createElement("canvas"), i = B.getContext("2d");
1915
+ const B = document.createElement("canvas"), D = B.getContext("2d");
1916
1916
  if (B.width = C.width || A.width, B.height = C.height || A.height, C.width || C.height) {
1917
- const U = document.createElement("canvas"), N = U.getContext("2d");
1918
- U.width = A.width, U.height = A.height, N.putImageData(A, 0, 0), i.drawImage(U, 0, 0, B.width, B.height);
1917
+ const U = document.createElement("canvas"), w = U.getContext("2d");
1918
+ U.width = A.width, U.height = A.height, w.putImageData(A, 0, 0), D.drawImage(U, 0, 0, B.width, B.height);
1919
1919
  } else
1920
- i.putImageData(A, 0, 0);
1920
+ D.putImageData(A, 0, 0);
1921
1921
  return B.toDataURL("image/png");
1922
1922
  }
1923
1923
  // =====================================================
@@ -1925,7 +1925,7 @@ let xA = class {
1925
1925
  // =====================================================
1926
1926
  // Create canvas with text - returns canvas element
1927
1927
  static createTextImage(A, C = {}) {
1928
- const B = document.createElement("canvas"), i = B.getContext("2d"), U = {
1928
+ const B = document.createElement("canvas"), D = B.getContext("2d"), U = {
1929
1929
  width: C.width || 800,
1930
1930
  height: C.height || 480,
1931
1931
  fontSize: C.fontSize || 24,
@@ -1937,25 +1937,25 @@ let xA = class {
1937
1937
  padding: C.padding || 20,
1938
1938
  lineHeight: C.lineHeight || 1.2
1939
1939
  };
1940
- B.width = U.width, B.height = U.height, i.fillStyle = U.backgroundColor, i.fillRect(0, 0, B.width, B.height), i.fillStyle = U.textColor, i.font = `${U.fontSize}px ${U.fontFamily}`, i.textAlign = U.textAlign === "center" ? "center" : U.textAlign === "right" ? "end" : "start";
1941
- const N = A.split(" "), h = [];
1940
+ B.width = U.width, B.height = U.height, D.fillStyle = U.backgroundColor, D.fillRect(0, 0, B.width, B.height), D.fillStyle = U.textColor, D.font = `${U.fontSize}px ${U.fontFamily}`, D.textAlign = U.textAlign === "center" ? "center" : U.textAlign === "right" ? "end" : "start";
1941
+ const w = A.split(" "), h = [];
1942
1942
  let y = "";
1943
- for (const m of N) {
1943
+ for (const m of w) {
1944
1944
  const x = y + (y ? " " : "") + m;
1945
- i.measureText(x).width > B.width - 2 * U.padding && y ? (h.push(y), y = m) : y = x;
1945
+ D.measureText(x).width > B.width - 2 * U.padding && y ? (h.push(y), y = m) : y = x;
1946
1946
  }
1947
1947
  y && h.push(y);
1948
1948
  const W = h.length * U.fontSize * U.lineHeight;
1949
1949
  let p;
1950
1950
  return U.verticalAlign === "top" ? p = U.padding + U.fontSize : U.verticalAlign === "bottom" ? p = B.height - U.padding - W + U.fontSize : p = (B.height - W) / 2 + U.fontSize, h.forEach((m, x) => {
1951
- const $ = U.textAlign === "center" ? B.width / 2 : U.textAlign === "right" ? B.width - U.padding : U.padding, O = p + x * U.fontSize * U.lineHeight;
1952
- i.fillText(m, $, O);
1951
+ const AA = U.textAlign === "center" ? B.width / 2 : U.textAlign === "right" ? B.width - U.padding : U.padding, O = p + x * U.fontSize * U.lineHeight;
1952
+ D.fillText(m, AA, O);
1953
1953
  }), B;
1954
1954
  }
1955
1955
  };
1956
1956
  typeof module < "u" && module.exports && (module.exports = xA);
1957
1957
  typeof xA < "u" && (window.ImageProcessor = xA);
1958
- class YA {
1958
+ class cA {
1959
1959
  static TEST_URL = "https://test.signosoft.com/api/v1/driver";
1960
1960
  static LOCAL_URL = "http://localhost:8080/api/v1/driver";
1961
1961
  /**
@@ -1965,7 +1965,7 @@ class YA {
1965
1965
  * @returns {Object} Test licence JSON object
1966
1966
  */
1967
1967
  static createTestLicense(A = "DEBUG", C = 24) {
1968
- const i = {
1968
+ const D = {
1969
1969
  DEBUG: {
1970
1970
  licenceKey: "DEBUG-licence-backend-key-VSCODE",
1971
1971
  port: 3e3
@@ -1988,9 +1988,9 @@ class YA {
1988
1988
  }
1989
1989
  }[A.toUpperCase()];
1990
1990
  return {
1991
- licenceKey: i.licenceKey,
1991
+ licenceKey: D.licenceKey,
1992
1992
  validityHours: C,
1993
- port: i.port
1993
+ port: D.port
1994
1994
  };
1995
1995
  }
1996
1996
  /**
@@ -1999,16 +1999,16 @@ class YA {
1999
1999
  * @param {string} [baseUrl='http://localhost:8080/api/v1/driver'] - Base server URL
2000
2000
  * @returns {Promise<Object>} Server response with licenseData, licenseSignature, publicKey
2001
2001
  */
2002
- static async createLease(A, C = YA.LOCAL_URL) {
2002
+ static async createLease(A, C = cA.LOCAL_URL) {
2003
2003
  try {
2004
- const B = `${C}/leases`, i = await fetch(B, {
2004
+ const B = `${C}/leases`, D = await fetch(B, {
2005
2005
  method: "POST",
2006
2006
  headers: { "Content-Type": "application/json" },
2007
2007
  body: JSON.stringify(A)
2008
2008
  });
2009
- if (!i.ok)
2010
- throw new Error(`HTTP ${i.status}: ${i.statusText}`);
2011
- return await i.json();
2009
+ if (!D.ok)
2010
+ throw new Error(`HTTP ${D.status}: ${D.statusText}`);
2011
+ return await D.json();
2012
2012
  } catch (B) {
2013
2013
  throw console.error("Failed to create lease:", B), B;
2014
2014
  }
@@ -2028,14 +2028,14 @@ class YA {
2028
2028
  });
2029
2029
  if (!B.ok)
2030
2030
  throw new Error(`HTTP ${B.status}: ${B.statusText}`);
2031
- const i = await B.text();
2032
- return console.log("Public key fetched successfully, length:", i.length), i;
2031
+ const D = await B.text();
2032
+ return console.log("Public key fetched successfully, length:", D.length), D;
2033
2033
  } catch (C) {
2034
2034
  throw console.error("Failed to fetch public key:", C), C;
2035
2035
  }
2036
2036
  }
2037
2037
  }
2038
- typeof YA < "u" && (window.LicenseUtility = YA);
2038
+ typeof cA < "u" && (window.LicenseUtility = cA);
2039
2039
  let yI = class {
2040
2040
  constructor(A = {}) {
2041
2041
  this._drawingCanvas = A.drawingCanvas || null, this.minDistance = 15, this.minVelocity = 0.02, this.minInertiaVelocity = 0.05, this.friction = 0.92, this._state = {
@@ -2058,8 +2058,8 @@ let yI = class {
2058
2058
  this._drawingCanvas = A;
2059
2059
  }
2060
2060
  handlePenEvent(A, C) {
2061
- const B = this._getPageCoordinates(A), i = document.elementFromPoint(B.x, B.y);
2062
- (!this._drawingCanvas || i != this._drawingCanvas) && (C === "down" ? this._startScroll(B) : C === "move" ? this._updateScroll(B, A.inContact) : C === "up" && this._endScroll(!1)), C === "click" && i && typeof i.click == "function" && i.click();
2061
+ const B = this._getPageCoordinates(A), D = document.elementFromPoint(B.x, B.y);
2062
+ (!this._drawingCanvas || D != this._drawingCanvas) && (C === "down" ? this._startScroll(B) : C === "move" ? this._updateScroll(B, A.inContact) : C === "up" && this._endScroll(!1)), C === "click" && D && typeof D.click == "function" && D.click();
2063
2063
  }
2064
2064
  reset() {
2065
2065
  this._endScroll(), this._cancelInertiaScroll(), this._state.target = null;
@@ -2070,14 +2070,14 @@ let yI = class {
2070
2070
  _updateScroll(A, C) {
2071
2071
  if (!this._state.active || !C)
2072
2072
  return;
2073
- const B = A.x - this._state.lastX, i = A.y - this._state.lastY, U = performance.now(), N = U - this._state.lastTime, h = Math.hypot(A.x - this._state.startX, A.y - this._state.startY);
2073
+ const B = A.x - this._state.lastX, D = A.y - this._state.lastY, U = performance.now(), w = U - this._state.lastTime, h = Math.hypot(A.x - this._state.startX, A.y - this._state.startY);
2074
2074
  if (!this._state.isDragging) {
2075
- const y = N > 0 ? h / N : 0;
2075
+ const y = w > 0 ? h / w : 0;
2076
2076
  if (h < this.minDistance && y < this.minVelocity)
2077
2077
  return;
2078
2078
  this._state.isDragging = !0;
2079
2079
  }
2080
- this._state.velocityX = N > 0 ? B / N : 0, this._state.velocityY = N > 0 ? i / N : 0, this._scrollTarget(this._state.target, B, i), this._state.initialScrollTop = this._state.target ? this._state.target.scrollTop : 0, this._state.initialScrollLeft = this._state.target ? this._state.target.scrollLeft : 0, this._state.lastTime = U, this._state.lastX = A.x, this._state.lastY = A.y, this._state.startX = A.x, this._state.startY = A.y;
2080
+ this._state.velocityX = w > 0 ? B / w : 0, this._state.velocityY = w > 0 ? D / w : 0, this._scrollTarget(this._state.target, B, D), this._state.initialScrollTop = this._state.target ? this._state.target.scrollTop : 0, this._state.initialScrollLeft = this._state.target ? this._state.target.scrollLeft : 0, this._state.lastTime = U, this._state.lastX = A.x, this._state.lastY = A.y, this._state.startX = A.x, this._state.startY = A.y;
2081
2081
  }
2082
2082
  _endScroll(A = !0) {
2083
2083
  this._state.active = !1, A && (this._state.isDragging = !1);
@@ -2093,8 +2093,8 @@ let yI = class {
2093
2093
  _findScrollableTarget(A) {
2094
2094
  let C = document.elementFromPoint(A.x, A.y);
2095
2095
  for (; C && C !== document.body && C !== document.documentElement; ) {
2096
- const B = window.getComputedStyle(C), i = B.overflowY, U = B.overflowX, N = (i === "auto" || i === "scroll") && C.scrollHeight > C.clientHeight;
2097
- if ((U === "auto" || U === "scroll") && C.scrollWidth > C.clientWidth || N)
2096
+ const B = window.getComputedStyle(C), D = B.overflowY, U = B.overflowX, w = (D === "auto" || D === "scroll") && C.scrollHeight > C.clientHeight;
2097
+ if ((U === "auto" || U === "scroll") && C.scrollWidth > C.clientWidth || w)
2098
2098
  return C;
2099
2099
  C = C.parentElement;
2100
2100
  }
@@ -2131,20 +2131,20 @@ let yI = class {
2131
2131
  return;
2132
2132
  }
2133
2133
  this._state.inertiaHandle && cancelAnimationFrame(this._state.inertiaHandle);
2134
- const i = (U) => {
2134
+ const D = (U) => {
2135
2135
  this._state.lastTime || (this._state.lastTime = U);
2136
- const N = U - this._state.lastTime;
2136
+ const w = U - this._state.lastTime;
2137
2137
  this._state.lastTime = U;
2138
- const h = this._state.velocityX * N, y = this._state.velocityY * N;
2138
+ const h = this._state.velocityX * w, y = this._state.velocityY * w;
2139
2139
  this._scrollTarget(this._state.target, h, y);
2140
- const W = Math.pow(this.friction, N / 16);
2140
+ const W = Math.pow(this.friction, w / 16);
2141
2141
  if (this._state.velocityX *= W, this._state.velocityY *= W, Math.max(Math.abs(this._state.velocityX), Math.abs(this._state.velocityY)) < this.minInertiaVelocity) {
2142
2142
  this._cancelInertiaScroll();
2143
2143
  return;
2144
2144
  }
2145
- this._state.inertiaHandle = requestAnimationFrame(i);
2145
+ this._state.inertiaHandle = requestAnimationFrame(D);
2146
2146
  };
2147
- this._state.lastTime = performance.now(), this._state.inertiaHandle = requestAnimationFrame(i);
2147
+ this._state.lastTime = performance.now(), this._state.inertiaHandle = requestAnimationFrame(D);
2148
2148
  }
2149
2149
  _cancelInertiaScroll() {
2150
2150
  this._state.inertiaHandle && (cancelAnimationFrame(this._state.inertiaHandle), this._state.inertiaHandle = null), this._state.velocityX = 0, this._state.velocityY = 0;
@@ -2213,8 +2213,8 @@ class KI {
2213
2213
  if (this.deviceInfo.isCanvasStyleTablet) {
2214
2214
  const C = this._supportedCommands.has("DisableDrawing"), B = this._supportedCommands.has("DisplayImage");
2215
2215
  if (C && (await this.tablet.disableDrawing(null), console.log("[SignatureLayer] Drawing disabled")), B && this.deviceConfig.images && this.deviceConfig.images.idle) {
2216
- const i = new CommandArgsBuilder().addImage(this.deviceConfig.images.idle);
2217
- await this.tablet.sendCommand("DisplayImage", i), console.log("[SignatureLayer] Idle image displayed");
2216
+ const D = new CommandArgsBuilder().addImage(this.deviceConfig.images.idle);
2217
+ await this.tablet.sendCommand("DisplayImage", D), console.log("[SignatureLayer] Idle image displayed");
2218
2218
  }
2219
2219
  this.hotspotManager.disableAllHotspots();
2220
2220
  } else
@@ -2240,17 +2240,17 @@ class KI {
2240
2240
  throw new Error("Tablet requires canvas; pass it to startSigning(canvas)");
2241
2241
  try {
2242
2242
  if (this.deviceInfo.isCanvasStyleTablet) {
2243
- const B = this._supportedCommands.has("DisplayImage"), i = this._supportedCommands.has("EnableDrawing");
2243
+ const B = this._supportedCommands.has("DisplayImage"), D = this._supportedCommands.has("EnableDrawing");
2244
2244
  if (B && this.deviceConfig.images && this.deviceConfig.images.signing) {
2245
2245
  const U = new CommandArgsBuilder().addImage(this.deviceConfig.images.signing);
2246
2246
  await this.tablet.sendCommand("DisplayImage", U), console.log("[SignatureLayer] Signing image displayed");
2247
2247
  }
2248
- i && (await this.tablet.enableDrawing(null), console.log("[SignatureLayer] Drawing enabled")), this.hotspotManager && this.hotspotManager.enableAllHotspots();
2248
+ D && (await this.tablet.enableDrawing(null), console.log("[SignatureLayer] Drawing enabled")), this.hotspotManager && this.hotspotManager.enableAllHotspots();
2249
2249
  } else
2250
2250
  this.hotspotManager.addElementHotspot(
2251
2251
  "drawingArea",
2252
2252
  A,
2253
- (B, i) => this._handleDrawingHotspot(B, i),
2253
+ (B, D) => this._handleDrawingHotspot(B, D),
2254
2254
  this._canvasContainer
2255
2255
  ), this.pageInputController.setDrawingCanvas(A);
2256
2256
  C && A && (this._configureDrawingAspectCorrection(A), this._setupDrawing(A, C), this.onPen((B) => this._handleDrawingPen(B))), this._resetPenDataLog(), this.isSigningMode = !0, console.log("[SignatureLayer] Signing started");
@@ -2348,14 +2348,14 @@ class KI {
2348
2348
  const h = this._drawingAspectCorrector.correctCoordinates(A.x, A.y);
2349
2349
  A.x = h.x, A.y = h.y;
2350
2350
  }
2351
- const B = this._drawingContext, i = this._drawingOptions.minThickness + (this._drawingOptions.maxThickness - this._drawingOptions.minThickness) * A.pressure, U = A.x * this._drawingCanvas.width, N = A.y * this._drawingCanvas.height;
2352
- B.strokeStyle = this._drawingOptions.color, B.lineWidth = i, A.inContact ? this._lastDrawPoint ? (B.beginPath(), B.moveTo(this._lastDrawPoint.x, this._lastDrawPoint.y), B.lineTo(U, N), B.stroke(), this._lastDrawPoint = { x: U, y: N }) : this._lastDrawPoint = { x: U, y: N } : this._lastDrawPoint = null;
2351
+ const B = this._drawingContext, D = this._drawingOptions.minThickness + (this._drawingOptions.maxThickness - this._drawingOptions.minThickness) * A.pressure, U = A.x * this._drawingCanvas.width, w = A.y * this._drawingCanvas.height;
2352
+ B.strokeStyle = this._drawingOptions.color, B.lineWidth = D, A.inContact ? this._lastDrawPoint ? (B.beginPath(), B.moveTo(this._lastDrawPoint.x, this._lastDrawPoint.y), B.lineTo(U, w), B.stroke(), this._lastDrawPoint = { x: U, y: w }) : this._lastDrawPoint = { x: U, y: w } : this._lastDrawPoint = null;
2353
2353
  }
2354
2354
  _clearDrawingCanvas() {
2355
2355
  this._drawingContext && this._drawingCanvas && (this._drawingContext.clearRect(0, 0, this._drawingCanvas.width, this._drawingCanvas.height), this._lastDrawPoint = null);
2356
2356
  }
2357
2357
  _configureDrawingAspectCorrection(A, C = "center") {
2358
- const B = this.deviceInfo.aspectRatio, i = this.deviceConfig.hotspots.drawingArea, U = A.width / A.height;
2358
+ const B = this.deviceInfo.aspectRatio, D = this.deviceConfig.hotspots.drawingArea, U = A.width / A.height;
2359
2359
  if (!this.deviceInfo.isCanvasStyleTablet || B <= 0) {
2360
2360
  this._drawingAspectCorrector = null;
2361
2361
  return;
@@ -2363,8 +2363,8 @@ class KI {
2363
2363
  this._drawingAspectCorrector = AspectRatioCorrector.createHotspotCorrector(
2364
2364
  B,
2365
2365
  U,
2366
- i.width,
2367
- i.height,
2366
+ D.width,
2367
+ D.height,
2368
2368
  C
2369
2369
  );
2370
2370
  }
@@ -2383,8 +2383,8 @@ class KI {
2383
2383
  try {
2384
2384
  const C = await (await fetch("data:application/json;base64,{
  "version": "1.0",
  "description": "Device-specific configurations for tablet signature capture",
  "devices": {
    "DTC121": {
      "name": "DTC121",
      "match": "DTC121",
      "images": {
        "idle": null,
        "signing": null
      },
      "hotspots": {}
    },
    "DTK1660E": {
      "name": "DTK1660E",
      "match": "DTK-1660E",
      "images": {
        "idle": null,
        "signing": null
      },
      "hotspots": {}
    },
    "DTU1031": {
      "name": "DTU1031",
      "match": "DTU-1031",
      "images": {
        "idle": null,
        "signing": null
      },
      "hotspots": {}
    },
    "DTU1141B": {
      "name": "DTU1141B",
      "match": "DTU-1141B",
      "images": {
        "idle": null,
        "signing": null
      },
      "hotspots": {}
    },
    "STU300": {
      "name": "STU-300",
      "match": "STU-300",
      "images": {
        "idle": "idle_stu300",
        "signing": "signing_stu300"
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 0.905,
          "height": 1
        },
        "okButton": {
          "x": 0.905,
          "y": 0,
          "width": 0.095,
          "height": 0.33
        },
        "clearButton": {
          "x": 0.905,
          "y": 0.335,
          "width": 0.095,
          "height": 0.33
        },
        "cancelButton": {
          "x": 0.905,
          "y": 0.67,
          "width": 0.095,
          "height": 0.33
        }
      }
    },
    "STU430": {
      "name": "STU-430",
      "match": "STU-430",
      "images": {
        "idle": "idle_stu430",
        "signing": "signing_stu430"
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 0.84
        },
        "okButton": {
          "x": 0,
          "y": 0.84,
          "width": 0.33,
          "height": 0.16
        },
        "clearButton": {
          "x": 0.335,
          "y": 0.84,
          "width": 0.33,
          "height": 0.16
        },
        "cancelButton": {
          "x": 0.67,
          "y": 0.84,
          "width": 0.33,
          "height": 0.16
        }
      }
    },
    "STU520": {
      "name": "STU-520",
      "match": "STU-520",
      "images": {
        "idle": "idle_stu5XX",
        "signing": "signing_stu5XX"
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 0.833
        },
        "okButton": {
          "x": 0,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "clearButton": {
          "x": 0.335,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "cancelButton": {
          "x": 0.67,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        }
      }
    },
    "STU530": {
      "name": "STU-530",
      "match": "STU-530",
      "images": {
        "idle": "idle_stu5XX",
        "signing": "signing_stu5XX"
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 0.833
        },
        "okButton": {
          "x": 0,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "clearButton": {
          "x": 0.335,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "cancelButton": {
          "x": 0.67,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        }
      }
    },
    "STU540": {
      "name": "STU-540",
      "match": "STU-540",
      "images": {
        "idle": "idle_stu5XX",
        "signing": "signing_stu5XX"
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 0.833
        },
        "okButton": {
          "x": 0,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "clearButton": {
          "x": 0.335,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "cancelButton": {
          "x": 0.67,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        }
      }
    },
    "STU541": {
      "name": "STU-541",
      "match": "STU-541",
      "images": {
        "idle": "idle_stu5XX",
        "signing": "signing_stu5XX"
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 0.833
        },
        "okButton": {
          "x": 0,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "clearButton": {
          "x": 0.335,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        },
        "cancelButton": {
          "x": 0.67,
          "y": 0.833,
          "width": 0.33,
          "height": 0.167
        }
      }
    },
    "UG05": {
      "name": "UG-05",
      "match": "UG05",
      "images": {
        "idle": null,
        "signing": null
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 1
        },
        "okButton": null,
        "clearButton": null,
        "cancelButton": null
      }
    },
    "UG0501DL": {
      "name": "UG-0501DL",
      "match": "UG-0501DL",
      "images": {
        "idle": null,
        "signing": null
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 1
        },
        "okButton": null,
        "clearButton": null,
        "cancelButton": null
      }
    },
    "UG1070H": {
      "name": "UG-1070H",
      "match": "UG-1070H",
      "images": {
        "idle": null,
        "signing": null
      },
      "hotspots": {}
    },
    "DefaultDriver": {
      "name": "Default",
      "match": null,
      "images": {
        "idle": "idle_stu5XX",
        "signing": "signing_stu5XX"
      },
      "hotspots": {
        "drawingArea": {
          "x": 0,
          "y": 0,
          "width": 1,
          "height": 1
        },
        "okButton": null,
        "clearButton": null,
        "cancelButton": null
      }
    }
  }
}
")).json();
2385
2385
  this._deviceConfigs = C.devices;
2386
- const i = await (await fetch("data:application/json;base64,{
  "version": "1.0",
  "description": "Reusable image assets for tablet screens (Base64 encoded)",
  "images": {
    "signing_stu300": {
      "format": "image/png",
      "data": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAABkCAIAAAAnqfEgAAACcklEQVR4nO3d22rjQBBFUcfk/z/ZGUMPQb7ImaiqZZ1hLfIQAhF+2pRabfXH5fJ1AkhwfvcHAPhXggXEECwghmABMQQLiCFYQAzBAmIIFhBDsIAYggXE+Hz3BwDinc8fXZd6/WVBwQIatHwr+cfwuSUEYggWEEOwgBiCBbzHhqV6wQLeYNuDRcEC3mPDg0XBAva2ed+WYAG7GrXatm9LsIB+r2eozbtMBQuY4rFZ179cfyp74gUL6LdWpeI3eAQLmGU5ZBVnq78XKf4/wFPLPLXU6iRYwGyNL58RLGCiyiaGJ1druQrAo9GprlqdBAuYqrFWJ8ECgnhFMtCgcWX9hZ5njQA7cEsIxBAsIIZgATEEC4ghWEAM2xqAKkfVA0kcVQ9wQ7CAGIIFxBAsIIZFd6Df8p3Id0vpTs0BDmd06rtWa/363TXrHwvgqbta1ZslWMBcy3vAYrMEC5jLGhaQpOu7O54SAv0mvcrYhAXsqnJSoWABMQQL2E/xIGhrWMB+imtbJiwghmABMQQLiGENC2jgqHqAG24JgRiCBcQQLCCGYAExPCUEqpz8DCRx8jPADcECYggWEEOwgBiCBfT7efncMV/AQVwuX9ckrVVpeZD9r9jWAEwxknTXpuIrkk1YwERj1Bq/j3hVdmyZsIC5vptV31xqwgL2sBy1NhMsYKKx9D5mq3qz3BICszw+DSzeHpqwgCnW9i6MdXf7sIADeT1DmbCA/5xgATEEC4ghWEAM2xqABk5+BrixOmHt00vg+I4z1ljDAmK4JQRimLCAGIIFxBAsIIZgATEEC4ghWEAMwQJiCBYQQ7CAGIIFxBAsIMYfYtquyxpbfFMAAAAASUVORK5CYII="
    },
    "idle_stu300": {
      "format": "image/png",
      "data": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAABkCAIAAAAnqfEgAAAgAElEQVR4nO2dCXRN1/7HI0grNJFIRKh5nkrUEKqCtqgQEUkERRAiCBJkMGYQYwxJRCKmqCkhQhLaV/V4bU0txfKwWkMMVU9J0IoqIf7fd+/63/999+yz7z7DTe59//1Zu1Zz7jl777OH7/7tffZQqazsjRWHw+FYAtYVHQEOh8NhhQsWh8OxGLhgcTgci4ELFofDsRi4YHE4HIuhSkVHgMPhWDb5+Xk3bty4f//+mzdv3n333enTZ5gurEp8WgOHw5HBlCkhJ06cuH379tOnTyFVuus1atTw9/fftGmzKQLlgsXhcKQxbdrUPXv2FBUVid1gbW2dmJg4c2aY6kHzMSwOhyMBD49eaWlpFLUCZWVl33zzjSlC52NYHA6HFXf3bj/88APLnegnmiIC3MLicDhM+Pv7MaoVqFLFJMYQFywOh2Ocbdsy8/Pz2e9v27atKaLBB905HI5xevTofvr0acabO3fu/MMPZ0wRDT6GZXJmzJh++fLlN2/etGzZcv36tIqODocjmVOnTl64cEHsV3t7+8aNGzs6OtaoUcPa2hrlfOnSZSaKCbewTEhGxob4+Phff/1Vd8XFxSUqKmrGjJkVGCsORypBQRO2bNkivF6pUiVvb+99+3Jl+InacefOHa0n7733np+fP8tTXLBMiItL7YcPHxpcrFmzJvLe23tohUSJw5FBz54fnDx5Uni9R48ex4+fkOFhr14fHj9+XPenjY1NQEBAZuY2ow/yQXdTMXy4v1CtwJMnT4iNFYdjtty+fVt4Eb2/cePGyfBt2rSp+moFXr58mZWVtX+/cUuNC5ap+Omnn8R+unTpUnnGhMNRSHFxsfAi+goTJgTJ8O3atWvCi9AslrmmXLBMxYsXL8R+evXqVXnGhMNRwqFDB0tLS4XXa9WqJc9D/YWHLNf1KY+vhHl5B1BFWWLDTr169bp376Gih6pTt27dq1evEn9ydXUt58hwOLIpKioqKysTXpctWEpQWbCys7PQO71+/fovv/yC93z27FmpBnXVCnz44YfffPOtun6qi6enJ5JCaEyh5z948OAKiRKHIwN01oj110Rz2emoE+Tnn2/Lzs6+cuXKnTt3VNcmC2XWrNlnzpzJycnRb50qVao0aNCg+fMXVGDEOBzLRalgxcbG7N279+eff379+rUqEfpvIisrOzo6Kjc3V7u3mYuLi5eX16pVqys6XhyOpSJfsNavT12/fj2sKhVj89/H0qXLTDfrl8P5/4ZMwRo2zOfQoUPo3KobGw6Hw6EgeVpDQUF+u3Zt9+/fz9WKw+GUM9IsrJ07d0RERPzrX/8yUWw45cOXX35x5MiRv/76q1KlSm3atJkyZWpFx4jDYULCWsKsrN0zZswgLjcpf0w0rSE5Oekf//jHzZs3Hz169Pz589LSUlTpatWq2dnZ1alT5/3334+KinJycmb3cNGihfn5+SUlJfj/t99+u0+fPsnJKQojCSP31KlTFy9eLCoqgs/amROVK1e2tbWtWbMmBMjd3X3EiJFij8+fPy85OVkbJSvNh8sBAwYcOvSF8M6YmEWff/45kkL7J/wfOHCg2OECKSnJ33///d27d58+fYooIT5INCcnJzc3t+DgYEmJJpu9e/cgZS5fvow4//nnn9oPQVWqVKlevXqtWrXat2/fvXt3U6ziTEtbjwagsLCwuLj42bNnaAmsNMn1zjvvODs7t27d2tPTk3Fxr1Q2bdp4+vTpGzduPHnyBOEi5ZGhNjY2NWrUqF27docOHXr06PHppwMl+RkaOg21AOVf+8UfyahdpWyAvb29o6Oj/hVra2vkeFBQkP4M+MjIiIKCAv0NSP/44w/ifqTII9QR3Z+IP0rOpEnB/3ETBIvFXbp06d1335X02iYFgsUYc0YXGBjo6uqKzKaHi6KPEpCSksLiZ3R0NOqt/uPwf8KECfJimJ2d7evr27hxY6PzX1BuXFxcIEOpqalCf1CFDO5HrOLi4gxuy83NhVIb3InXWbNmjf5tGzZs+OijjyCUlKSDPxCLmTNnqptlOpeRkTFo0KC6desapLYQ3NCgQYOhQ4du375dlaCnTp0KD5Hg9HCrVq2KhgStnVqvvGzZMjR+0AujJRZBN2/efNSoUYcOHWLxeeLEiUb9pAOZ3rVrl9a3hIQEo5lCwcHBwSDarILVqVMnJe+gOioKFmqgVC2GZHh4eNy4UUj3GU2r8NlGjRpJjeG2bdtgNKHZlJpK2h4fCrfOqx07dhCL47BhwwwCnTJlCtFPFH1drGBySiqOkNGQkBC1Mk6bd5BCGVUC1RhFOj09XXbQmZmZEAKp4SI7YLQqeWWoXpMmTaSGa6VpNlBoNRMDaf6jRZThuQGDBw/W+obWXaFX06ZN048ek2DB+lD+DuqilmChk/vWW2/JiwMsMnqJJ+og7F5JMYShJEOq9EH737lz56ysLPi2adMm4j0wOgzChSVIvDMgIAC/jhw5Una6tWrVauvWrQoz7sCBA+jfKWm9rf634Tlx4oTU0BcvXow+l7xA8aA8UwvGLJpAheYPZMvHx4cSCvp0SvzX0rNnT61vyg2dcePG6UfPuGDBuhN2DSocVQQrMjISLa2SaNjZ2Rl0kfSdQsFavXo1ujlKoqcPDPWwsDDlgoXi3rFjR+WRmT9/vpKMQydUYRx0IEcWLlzIHjpyvHr16kpCRKkLDQ2V9MqjR49WsRrCzIf8EQMSjhjIQFc9K0CwunTpovwFVEe5YKFzhGqjPCaoOegcqS5YMP30ByBVAaaWmInOLliyDSsDZFRarfP391doWAmBqTVmzBiW0B88eKDK2nW8/qJFixhfGQaLQsNKCDQ3OjpaGFbLli2Ve4480vrWt29fhV7Nnj1bgmChkTc6oKgKaD3QecbrMQanXLDQS1Ir8k2bNlVXsNAHV71O0mEXLBVBpZXaOfrkk09MF58hQ4YYjYCKC9fR1O3bt89oiO3atVMrRAOQ/gYjRHCwfBWuaq5du7ZueDc9Pd3W1la2V/Xr1zeInpGYwQwh7iyhCtD49u3bt2jRAtoxbVoorqxZs/ro0aMmCk6fjIwN58+fF/sVJQmxatiwIZL+r7/+KiwsvHbt2t27d8Xuv3HjxsiRI3bt2q1K3EJCJmvGZY0nOxLQ0dER/6L5ffHixe+///7o0SMLWnxeWlq6bt26Zs2ajR/PJI5eXoOPHDnCcqe9vb2Dg4O2D/X8+fPHjx8jcYw+lZ+f7+s7LCdnH+WeY8eOif2EmtmqVSsUG3TkkX137txBsUHZEFtm++TJkxUrVgwd6kMJzs2tI8t2jygAKAl4a9i/KADPnj1DScC/9KeQ/hAUyNPq1Wt0F+Pi4m1sbPbv3490092GtxA+jhR2cXExiAbMT4igbuR+0qRgXNy5cydeVnfb/fv3YagKPcRTuk4PnkJ7Dxvc8CaKtCMY0+0ggWq2fPlygxBhljM+rtDC6tevH9Fb2DVeXl7ER+bOnWuQPfrY2dmpYmElJCQY7XM5OztrFlGvEj6+Z88e9Plbt24t1UBTaGEhOJQ2WB8oYXM1hISEDBw4EClg1GRu3rw5S5ZNmTKF3i3Crw0aNBg+fPjGjRuFj2/atAk/QU3oniC2lI6qWJrATxTIvLw84SOpqanEj8W6dEtLSxMLbsCAAfSkw+PwHDm+d+9e4eOJiYkoJ0bHpCDrxLKkcxs2bCA+2KNHD3m17+OPPyZ6yDJEQBMsT09P+qvKBmql/61d59jHyxQKVqNGjYje0idJnT17lnI85NKlSw3ulypYBQUF9E3RnJycJk+ezPKCqCfvvfceY2JaKRAs1HDkmtgIrrbatGnThu6JwcCq0MEQoI/oQYkWLFjAkjKLFi2if7lHBYa6EZ/t1q0b8ZH+/fvTA6VIz/jx44mPzJo1i6L1kEj0TmCfsrwyGg+6bKEnAZNH7HGLEaw6depQXlI2RNtK6+rVq8foiULBIn4cZGnqka/EL3eoTn/7298MbpYqWN27dxd7XxTQXr16UUoV0c2YMYPx67s8wUKngPH72sSJEymWI7oz9MfRbRR7Fp0A4SQyo87f35/ygRjBEZ8iDrcbjbzWEb+XQZKI1g06p0hbseihBsn4XuHh4UGxLnv37i32oGUIVlJSkti7KQFpLbREdI79C5QSwUJXl+indoaRUYdmzaC1R7SJho8kwVq8eLFYi4o6GRgYKO9lMzIy0H4aTU8ZgoX2TDehmcXFxMRQPsx/9tlnYg9C7MSesrW1RfdTXspAaimzExCo8BFi/NGQsAR34sQJAzOHIrWUj2vwhNKLpDtYsmKDPOhdinUMLUOwUILFkkw2FNsKbvbs2exeKREsMS0ODw9n9CE4OFg7SKSdSi7WIZIkWC1atCDGCioWFBQk+2XLNBM4jA5kSBUsOzs7GTO2w8LCxESZsgBAbCojmo34+HglKbNs2TIxDSVmE3EGL30epr5buXKl7pMZuqUrVqwg3paZmSk2VRixUjjnFkVXLAtQkomPWIZgidUf2dBtq7i4OEnz4kxhYUnqWSQnJ8PqEStzWscuWKh4Yua6p6enkgKqdWvXrqUnr1TBmjVrlryYfPDBB0QP8fqbN28W3i+2ygL3T506VXnKoNcsVoGFI2tEi6xr167swe3ZsyckJCQhIYFyD/puxPjAkF+9erXyV/by8iL6L9Y/tQzBUjiX1wC6bRUbGyt1Fq/CMSxicA4ODizzYtgdu2CJTQiWsfBQzKHPRUlPSYIl1hSzuL1794oNn48cOVJ4v9gAubu7u1opg7JEDKJhw4YGd+KK8DZYQ6roiNbduFEoVvUYhyxYXNOmTYlBdOvWTXizWQkWuW3JzNxqdBIHO8iA+fPnz5kTQfx18eJ4WOa6SR/lA3H56OPHj9HebtlC3j7FpBBPXYURMXnyZLWC+Pzz7fXr11fFK7EmmoVhw3zbt29P/EmYCJs3b7p586bwTnSsIiMjZcfBgDlz5hA/Tdy+fXvjxgz9K61atRLe9vLlS7S4S5YkqBKZpKS1xKpXr149tSb6Wf17etQk4sSXy5cvqxWEiSAL1oULF9QKAGq1cOHCyMgo4q/x8XHoJ5azWllpvokQr9+9excy7+k5MDeXNntQXcLDw/7880/hdVTsiAjVqiXw9fVV7gnq9pIlS5X4INbluX//vsGVr7/+mnhnr169hgzxVhIHfQYNGixWHgzmqcIOJdbz33//PSYm5oMPekBhFUbm5MmTxOs+PrT5pVKB9UCcoFNSUjJ3brSKAakOWbCIzZoMzNC20pKSso5o3ltpJkZ/+eWX6J506PBeYODYrCzVmjUxLl68SLzev39/dQNatWq18qWtylfSdenShThsJLQsiJO88eyoUaMUxsGAsWPHEj+fGURg0qTgrl27En149erVqVOngoODmzdvNny4f3p6mryYEKtezZo1k5KS5XkoxpAhQ4jXxUqjuUDsKKIFU+6z0XErJYuMlK8lXLt2LcssClSPunXr9u3bV8Y4BeMYFvH7xjvvvKPWgAVLzrKPYamyTwYx5atVq2Zwm8GGllrQnTdFyhA3t7K3tze47eDBg4wbsKBtcHd3Z1/hrPWcaMGpvl2l1tnZ2QnDQmk0uM0CxrCUD2BBrebNm0e3rYj9oHJj+vQZ48aNM7qEpays7N69e0ePHp01a1b9+u+OHk0bupaHsCsETLS/q/LtPlRZlU38bG+wfLKo6CFxASBlEqkSiONT6CLl5+fpXxk40DMyMpLlk9TDhw9Pnz6NhtnZ2WnoUO/9+3ONPvLdd98RFx6q/sleC/GDBnGVn/lAFqzS0lIlnmrHraKiyJ1hVXqCquy2sX59GjSLcUusN2/e/Prrrzt37nR0dBgxIkB56DqIzYNaA+QGoDum+kYlJiI/P59Ye02UMsTVWojAb7/9ZnBx1qzZaIzZ9yYqLi7Oy8v77LPP+vfv9+WXhL3zdYgdmCA2F0QhDRo0EF7Ubkhvtqi/dYxR22rp0qXKbSu1Zl1kZGyMjo4mdj3EePLkSXZ2Nqyt5ctVOCF1166dxI0ZKAutlTBixEiF+5eWG8Qvp1aaBZWmCE4swYnnL6AxTkpKEluRSgQt9Ndffz1q1KiwsJli9xQVFQkvwqQNDBzHHhA76PAKL8JYKSjIN0VwqqCyYEFHFixYYFLbSgvLchNGYmJit2zZgg65pM4OrK1FixaNHcu6vYQY2jNvhJhOVogD3mZodomlDGWRnRLEdFCstwERKSy86ePjI2kKIVq7lJSUfv3Iu3oRmy7T7ZhCjDl6EmL74ZgDagqW1rYS+xKvlm2lRZVdH3V4eQ05fvzEqlWr3Nzc2GXr5cuXO3bs8PYmf21hRGyatVh1VQ6xVpTzfoEsiKUMy85WMhDzlp4yOTn7tm3b1rdvX3bZQvofOXKkc+f3Ge83XUkQOwu5fPbslIdqMSs328pKYw6ospGrAdOnz/jxx3ObN28eNGgQ2lsWowPNUUFBQWDgWNmBDhgwgFg+THT+Y07OXmIxVWW3aHURG1wn9puUIxyr0mL064evr9+RI3//4osvxowZg04io/SfO3eud2/D+WjEzYVg7+zaRV5MppA//vhDeBGmPdpvUwSnCuoIVnnaVlaaic5jxwaq5ZsBY8aMzc8vePDg4dq1a729vVu0aEG3yaFZWVlZqanr5AXn5ORMXKryyy+/yPOQzo8//kjcklSVowfUpWvXrkQpJw4qKef27dvCi4gA4yZLHh69MzO3oZO4a9euwMBAmOpGZ+18991306f/x46aYruhffut+mcGW2mmSQsvmvkQpwqCRbetEhIWqz47VGzOp7qEhk7Pzd3/008/79y508/PjzJ0Aptl3TqZgmWl2adFeJGyI7MSIFjE68rPj1OdTp3eJ9p9xO16lfPzzz8LL6Js07cwFuLn579ly1aY6iUlz0JCQohf4rSg5TBYh49cINr1xLgph5iSJvqmoRZKBQs5Onfu3HKzrbSoctYjOyiC2dl7iosf+fj4iM01RZFaunSJPP+J2xY+fvw4Pj5OnocUrly5IryIhn3wYPnLA00H8cvdzZs3s7Oz1A3o8OGvrl27JryucA/L1NT1t27dDg0NFTuUDLmsP7PPx2cY8cvdP//5TyXRILJqVSJCF1430TQ3tVAkWNqVN9HRc4m/am0rU8wO7dOnj+p+spCTsy82NlZsD0/G8xGEEKcsWmkmIsnzUIyFCxfcu3dPeJ1iBVQsxL2VX79+vX37dnUD2rp164sXLxgjIJWkpOS0tDSxIybPnDmj/yex9/Do0aPw8DDlMdEnJyeHODigyiubDvmCpbWtxFY1Q61MYVtZacyB8PBZqnvLCGzJ8PBw4tgK0XhhIT19A9Fwu3DhQlLSWnl+Etm9m7wu0t3dXcVQVESsZfr222/z8g6oGNDhw4eJ18XWaUtl+PCA5cuXE5u6W7du6f8ptm089EWVmGjJyNhw7tw54fVq1arpn6BjhsgULFtbW7ptZSK1Ah06dFDLqwUL5kdGRhQVSfseFxMTS1wqQfzmwgjRDocpsX79etl+GhAcPKmwsFB4HWW0HI4glEdo6HSiYVJSUpKYmKhWKAMHfkrsHLm6us6cSbBrlixJCAubybLURp9Roz4jitHLly/T0v4vlz09PYmt1927d1VcFpaSkkKcX2aKj+/qIkewoFbz5s0rf9vKSjOhQfk+GyhqgwZ5OjjUTEhIWLlyZfv27aWOiRBXh2jW65P3BjHKoEGDiNevXbvm56fCnjCbN2+CeUXsAnTu3LlTJ9Y5QeWP2KqUkydPUqaMsxMTs0isLy8MesSIgLp1XdFUJyUljR07dtkyadvsEHdhA0+fPtX9/+DBXm5ubsTb9u3bt359qqQQiYwZM5q47xUql5KdzsoJ4pJoyglRUCvKTseLFy9WsgeDURjPsKO4rVu3Cr/3dezYUZInPXv2FMYNDaPBbZL2dBcbSKpcufLMmTOVvHJBQYHYcURVq1YV25BezOyiHK/C7oif/4QJWKY5poi4qYCVxjZEe6MkGhs3bhTzHDE8e/YsPYPq1KkjKbgRI0YQwzJ4C5g/YjNpnJ2diUcQsjuYGmKLZ8W2tzWr3RqkCRbECJIk5ld8fLxJ1crq30NIEUpyq0zkhDhra2s0m+yeEKc4CDeEkSRYkZGRYlNVbWxsZsyYIe99s7OzKWPqlH1LzESw4EaOHCkWf/izZMkSeXGALlBOgYS46N8stvWrn58fe4jEjj8yXahBlAPf0PZozmOX88ooY5TjHcUOdrRUwYIYUQqHqW0rK5U2QhIbx0VLixLM4oPYEUzCjYSknktIGZ6DnYVuo9SXRaZQ6iReOTc3V+xZ8xEsOMoODXjK6DmsQjd9+nRKcUXGGdwvdiY5rJWwsDCWECG7xAaJeKwh+u+UAyXt7e0lta9a5+vrS5kC3alTJ7EHLVKwKty2ghEkuy3Vd7NmiX5hrF69utGDWCgbfQgbW6mClZWVRV8iA1uJ8Rg+NNq9evWiLxNBpaX4YFaChU4TfReg1q1b089b1zlUPzc3N8q6KwQk9GrTpk2UUyOHDBlCD3TgwIFij8OYIj4SHBxMeV/4Br1gPGktLi5ObPhMC5qu/fv3U1KM+JT5ClaF21ZWmg/MyuuJ1lGMDpTj5s2bCw8oRHkdPHiw2PQ/K00pF54qKlWwyjRGO30lEGLYsGHD0aNHb9++nehDVFRUly5d6Ae7A9iJ9FQyK8EqM3bqj5XGCG3ZsiX6bsSjjw4ePAiBbteundHkRdoSIyA2XU5LnTp18KBBtc/MzIRdQ5k7juAoR2eLHeejn2IQ34iIiEuXLgkfh5kWGBgIqaKvikXRFesMap2FCVaF21ZW0kc36W7sWONrlatVq4ac7tixIzp6MNqNLoQmDgbJECy4gACm3QHRxiJisCw6d+4MhUJ3EsExbkaIems0lcxNsMrEu/PClKldu3bbtm27aMDLurq6Mq5Jpuh4QkKC0W0MEArCQqY0bdrUwcHBaLEx+hGJca9R5Hu9evVQbbWvjAhAJVk2XcA9qA70OFiSYNFtK2RhOagVgkhOTlZeSfSd2Lls8kDRLCgoEIYiT7DgvL29TbdBFeOpgmYoWGXU0Wjl9OzZkx66ujt/4n1TU1PpIR47dkzdsqoP1Mrg2wLRWYxgmYNthaZD+ZdBodu2bRulfycJFDuxg3xlCxYc+hem2LmN/Zhi8xQsuE8//VR1NYeHjCdsq7VBM8QCvVeWEG/cKISlr0qg+tjY2AQFBbFEwDIEC2JEOVC7fGwrpCl9YFiJW7dunfK9K99+++2oqCixIJQIFtyCBQsk7d1MB4np7+9PDGj37t3CfoHZClaZZpKBisWP5WOLzuXm5ipfeomeo9GOmIHz8vJi7O+z4OzsTKndBs4CBAumL8W2Kp9R9ho1asybN0953aA4VFQlaxHq1au3Zs0aiv9EwXJycmKP4cGDB1EslO8AiW5FUlKSWCjoJAq1TEyw+vTpozzlFQpWmcZGbteuncJksdKs9EIxkBp/d3d32VYemklKI0dxy5YtU66VMNs9PDwePHjAHm5GRgbRKzMSLIorH9uqcePGW7ZsUV4xWBwMY6nb19nZ2fn6+hr1mVijoB1SY5iYmAhNkbeLMVSVbqX6+fnhNuHE1NjYWKKHLKMeRh1xfrkkwdI6NGmNGjWSoR14BBkRExMj+xUgOlLlA/b4Rx99dOjQISVJN3HiRHkHGkCq0LVEx0JGoMQNoIVnWTI6b2/yqd2UJTQ6J02wysG2gv8sWqC6g7ojO+k7c6NX1bp1a3ZjHuJusJAVosM4z1DoUlNTYd0wFlaYMF27djVqoupmURAnzQo/5MM8PHDggPLUJu5o5uLiIs83pDP6BIwdfHTJP/zwwxUrVqhSbBYuXNitWzex9T26TIc4+vj45OXlqRIoXHh4eKdOnVjOjoI0o9Hq37//1q1bZQcnXGPo6Ogoe5FQVlaWcNsv9HVYnq2E/1iyGSxbthSCZbrTTyFVsLSDg4P9/PxNFAQLK1euuHr16r1790pKSl6/fo3ShojVrVu3WbNmYrtTUEhPT8vPz3/y5ImVZqykX79+YgegsZOSknz+/HlEEob98+fPtQfJVa1aFfFEMWrSpAksu/nzFxj1Jy4uFr0MPA5VhTfEeyZMGH/t2rWysjKUe1dX11GjRg0ZQm4eJTFt2tQNGzbon84C3QwJCVF4IHti4sqLFy9ev369qKgIBVW7IQGaGbRDEHrkIDqAYWHhSmNPYt26lCtXrqDYIK9fvXqFXjzsKaQYDMC+fft6ePQ2RaAgNjbm8uXLt27dKi4uRmHQJimCRmGoU6cOVKBLly4TJgQpDwhZdurUKZQWlIT69euj2Q4IIC+NZCEzc+v27dt/++23N2/eoIoha6Atbdq0Nfogq2AtWZKwZMkSU6gVshaZimSdPHmy6fKVY4D+phpI/8LCm+Ucgfj4uGPHjmm3zUPtggkwe/acco4Dx+JgEix1bSsIKmyNmjVrNmjQoG3btujm+PsPV8VnDiMREXPWrVunO+P3448/Pnz464qNEofDAtNMHzSDyvd4gyXl4ODQuHHj0aOVHj7KUcLIkSNycnJ0p90hX8QGQTkcc0PCGBbH0jl8+KuFCxeeOXNGfyc/Nze3H38k7JbL4ZghpjoFm2NuREZGZGZmGpzPWqVKFbPdH5nDEcItrP9+kpLWbt68+fLly8Itknv37n306LEKiRWHIwMuWOZLYuLKXbt2wSaqXbv2gAEDEhIkn3s4Z87sr776iihVAN6eOnW6nA955HCUwAXLTElNXRcREaF/YraTk5Obm1uPHj0WLYqhPJiTs/f48eNnz569cuWKdv4XERsbm7i4OLETcDkc84QLlpnSsmUL4lnEVhqtcXV1rVWrlr29vXajvtLS0pKSEsgTzLHi4mKjnltbWwcFBaWnkxe1cjhmCx90N0eio6PE1MpKc5LdbQ3yPIda+fn5cY5AFwIAAAE4SURBVLXiWCJKtwHgmALZh0gbpXLlygEBAbt3SzuHkcMxE7hgmSPEfWmUY2trGxoaumPHTlN4zuGUA3wMy0xp0qTxrVu3VPSwWbNmc+fODQwcp6KfHE45wy0sMyU9Pf2TTz6hHE7HjqOj48SJE69evcbVimPpcAvL3Bk/ftz3339//fp17WYp7FSqVKlRo0YeHh5btmw1Udw4nHKGC5ZlkJ+f9/e///3cuXN37tx59OjRs2fPiLdVrly5Zs2arq6urVq16tevX1DQxHKOJ4djUrhgWSQHDuw/f/68ds+2srKyt956y9bWtkmTJtOmhVZ01DgcE8IFi8PhWAx80J3D4VgMXLA4HI7FwAWLw+FYDFywOByOxcAFi8PhWAxcsDgcjsXABYvD4VgMXLA4HI7FwAWLw+FYDP8D1SW9/wGfNw8AAAAASUVORK5CYII="
    },
    "signing_stu430": {
      "format": "image/png",
      "data": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUAAAADICAYAAACZBDirAAAAxnpUWHRSYXcgcHJvZmlsZSB0eXBlIGV4aWYAAHjabVDBDcMgDPwzRUfAPgNmHNKkUjfo+DVgqiTqSZzNGQ7jcHzer/DoYJIgqWiuOUeDVKncLNE40QZTlMEDsjK66uG5LrFJsIi51TwjLd0vrEjNsnQy0qcXtmuhivvrzcgfQu+ILdndqLoReBbIDdr8VsxVy/kL2xGv0LlCJ5Th/TO576XY9PZkIpgPEKIxkGcD6CsFNEvUmJDsYEQdCowZ5J3YQP7NaSF8ATPHWVWbCn+jAAABg2lDQ1BJQ0MgcHJvZmlsZQAAeJx9kT1Iw0AcxV9TpUUrHewg4pChOtmlijiWKhbBQmkrtOpgcukXNDEkKS6OgmvBwY/FqoOLs64OroIg+AHiLjgpukiJ/0sKLWI8OO7Hu3uPu3eA0Koz1exLAKpmGdlUUiwUV8TAK4IIYxBx+CRm6uncQh6e4+sePr7exXiW97k/x5BSMhngE4kTTDcs4nXimU1L57xPHGFVSSE+J5406ILEj1yXXX7jXHFY4JkRI5+dI44Qi5UelnuYVQ2VeJo4qqga5QsFlxXOW5zVeoN17slfGCppyzmu0xxDCotIIwMRMhqooQ4LMVo1UkxkaT/p4R91/BlyyeSqgZFjHhtQITl+8D/43a1Znoq7SaEk0P9i2x/jQGAXaDdt+/vYttsngP8ZuNK6/o0WMPtJerOrRY+A8DZwcd3V5D3gcgcYedIlQ3IkP02hXAbez+ibisDwLTCw6vbW2cfpA5CnrpZugINDYKJC2Wse7w729vbvmU5/P5TucrR1EBi2AAANdmlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4KPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNC40LjAtRXhpdjIiPgogPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iCiAgICB4bWxuczpzdEV2dD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlRXZlbnQjIgogICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgeG1sbnM6R0lNUD0iaHR0cDovL3d3dy5naW1wLm9yZy94bXAvIgogICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iCiAgIHhtcE1NOkRvY3VtZW50SUQ9ImdpbXA6ZG9jaWQ6Z2ltcDo0NjhkMjE1ZS0zZDU0LTQxN2MtYTk3Ny05YTc0YWQ0ZTRmN2QiCiAgIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6M2UzZDFiYjQtODdiMC00ZTk2LThlOGEtYWE1NTRkNDdmMTZlIgogICB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6YmM4Zjc2M2EtYjljYy00MTJmLWFiOWQtZTkzMjFhMjEyYzAxIgogICBkYzpGb3JtYXQ9ImltYWdlL3BuZyIKICAgR0lNUDpBUEk9IjIuMCIKICAgR0lNUDpQbGF0Zm9ybT0iV2luZG93cyIKICAgR0lNUDpUaW1lU3RhbXA9IjE3NTUyNTk0MDIwMzI4NzEiCiAgIEdJTVA6VmVyc2lvbj0iMi4xMC4zNiIKICAgdGlmZjpPcmllbnRhdGlvbj0iMSIKICAgeG1wOkNyZWF0b3JUb29sPSJHSU1QIDIuMTAiCiAgIHhtcDpNZXRhZGF0YURhdGU9IjIwMjU6MDg6MTVUMDk6MDM6MjEtMDM6MDAiCiAgIHhtcDpNb2RpZnlEYXRlPSIyMDI1OjA4OjE1VDA5OjAzOjIxLTAzOjAwIj4KICAgPHhtcE1NOkhpc3Rvcnk+CiAgICA8cmRmOlNlcT4KICAgICA8cmRmOmxpCiAgICAgIHN0RXZ0OmFjdGlvbj0ic2F2ZWQiCiAgICAgIHN0RXZ0OmNoYW5nZWQ9Ii8iCiAgICAgIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6MmE0YjgzMTAtZWU1Zi00Yzc5LWFlNDUtZGQ2ZDI0ZDg1MTY1IgogICAgICBzdEV2dDpzb2Z0d2FyZUFnZW50PSJHaW1wIDIuMTAgKFdpbmRvd3MpIgogICAgICBzdEV2dDp3aGVuPSIyMDI1LTA4LTE1VDA5OjAzOjIyIi8+CiAgICA8L3JkZjpTZXE+CiAgIDwveG1wTU06SGlzdG9yeT4KICA8L3JkZjpEZXNjcmlwdGlvbj4KIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAKPD94cGFja2V0IGVuZD0idyI/PlrUftEAAAAGYktHRAABAAEAAMXh+PgAAAAJcEhZcwAACxMAAAsTAQCanBgAAAAHdElNRQfpCA8MAxXaZvUxAAANx0lEQVR42u3dbWwUdR7A8d/MPtndlj5slyt9pAUp8tCA9tC0UuEaUmgPQbCRPpwP9QGvAU3A1npnjHImdy/0xDMxMRo53xy5K3LEVBJiGk8EiUrPcIhBxPMCtLGHAVsf4lU6v3sBXXe22+ey7JbvJ5nQzszutjOd7/53Z1oMVVUBgKuQySYAQAABgAACAAEEAAIIAAQQAAggABBAACCAAEAAAYAAAgABBAACCAAEEAAIIAAQQAAggABAAAGAAAIAAQQAAggABBAACCAAEEAAIIAAQAABgAACAAEEAAIIgAACAAEEAAIIAAQQAAggABBAACCAAEAAAYAAAgABBAACCAAEEAAIIAAQQAAggABAAAGAAAIAAQQAAggABBAACCAAEEAAIIAAQAABgAACAAEEAAIIAAQQAAggAAIIAAQQAAggABBAACCAAEAAAYAAAgABBAAC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"
    },
    "idle_stu430": {
      "format": "image/png",
      "data": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABE8AAAMACAYAAADVC0kgAAAACXBIWXMAAAsSAAALEgHS3X78AAAgAElEQVR4nOzd7XHcRtY2YOCp/S+9EUiOQNwIREdgOgJTEViOwFQEpiIwFYGpCERFsGQES0ZgMQK8Be+Z9YhLHs3gs4G5riqW7V1piOnBNNA3TnfXTdNUAAAAADzu/7QLAAAAwNOEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCe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AAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAD/vx07EAAAgIEg9P7UI9gRFEYAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAACfbQflTG/+wcqyUQAAAABJRU5ErkJggg=="
    },
    "signing_stu5XX": {
      "format": "image/png",
      "data": "data:image/png;base64,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eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIgogICB4bXBNTTpEb2N1bWVudElEPSJhZG9iZTpkb2NpZDpwaG90b3Nob3A6ODhhNTQ4NmQtZmRiNC0wMTRiLThhMjItZTFjMjljN2FlZmQxIgogICB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjMxZjg4NDFhLWUzMzQtNDI2Yi1iNWJhLWZjNjVmMzhkYWU0YyIKICAgeG1wTU06T3JpZ2luYWxEb2N1bWVudElEPSJ4bXAuZGlkOkE4MzE0NDhGNDIxNEUyMTFBQzk4ODAwOUE3REE0MjQ4IgogICBkYzpmb3JtYXQ9ImltYWdlL2pwZWciCiAgIEdJTVA6QVBJPSIyLjAiCiAgIEdJTVA6UGxhdGZvcm09IldpbmRvd3MiCiAgIEdJTVA6VGltZVN0YW1wPSIxNzE1ODYyMDk2Njg2NDQwIgogICBHSU1QOlZlcnNpb249IjIuMTAuMzYiCiAgIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiCiAgIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIKICAgdGlmZjpPcmllbnRhdGlvbj0iMSIKICAgeG1wOkNyZWF0ZURhdGU9IjIwMTItMTAtMTJUMTA6MTg6MDkrMDI6MDAiCiAgIHhtcDpDcmVhdG9yVG9vbD0iR0lNUCAyLjEwIgogICB4bXA6TWV0YWRhdGFEYXRlPSIyMDI0OjA1OjE2VDA5OjIxOjI5LTAzOjAwIgogICB4bXA6TW9kaWZ5RGF0ZT0iMjAyNDowNToxNlQwOToyMToyOS0wMzowMCI+CiAgIDx4bXBNTTpIaXN0b3J5PgogICAgPHJkZjpTZXE+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249ImNyZWF0ZWQiCiAgICAgIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6QTgzMTQ0OEY0MjE0RTIxMUFDOTg4MDA5QTdEQTQyNDgiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpIgogICAgICBzdEV2dDp3aGVuPSIyMDEyLTEwLTEyVDEwOjE4OjA5KzAyOjAwIi8+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249InNhdmVkIgogICAgICBzdEV2dDpjaGFuZ2VkPSIvIgogICAgICBzdEV2dDppbnN0YW5jZUlEPSJ4bXAuaWlkOkUxNzg0ODI2NDYxNEUyMTFBQzk4ODAwOUE3REE0MjQ4IgogICAgICBzdEV2dDpzb2Z0d2FyZUFnZW50PSJBZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKSIKICAgICAgc3RFdnQ6d2hlbj0iMjAxMi0xMC0xMlQxMDoyMzo0OSswMjowMCIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJzYXZlZCIKICAgICAgc3RFdnQ6Y2hhbmdlZD0iLyIKICAgICAgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDphMTAzYjU2MS03M2U2LWI3NDEtYmNmYi1hZWNmNWM5ZmVkYWQiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE5IChXaW5kb3dzKSIKICAgICAgc3RFdnQ6d2hlbj0iMjAxOC0xMC0yMlQxNTowODoxNSswMjowMCIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJjb252ZXJ0ZWQiCiAgICAgIHN0RXZ0OnBhcmFtZXRlcnM9ImZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9qcGVnIi8+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249ImRlcml2ZWQiCiAgICAgIHN0RXZ0OnBhcmFtZXRlcnM9ImNvbnZlcnRlZCBmcm9tIGFwcGxpY2F0aW9uL3ZuZC5hZG9iZS5waG90b3Nob3AgdG8gaW1hZ2UvanBlZyIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJzYXZlZCIKICAgICAgc3RFdnQ6Y2hhbmdlZD0iLyIKICAgICAgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDo1OTQ1MDZlZS1kMTAxLTNjNGItODE1Ni02NzQxNWI1ODdmNjEiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE5IChXaW5kb3dzKSIKICAgICAgc3RFdnQ6d2hlbj0iMjAxOC0xMC0yMlQxNTowODoxNSswMjowMCIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJzYXZlZCIKICAgICAgc3RFdnQ6Y2hhbmdlZD0iLyIKICAgICAgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDo2ZGZkNjQyOC0wOWQ1LTRkMDYtYTA3Yi0zNzgwZTJlMjk3MDEiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkdpbXAgMi4xMCAoV2luZG93cykiCiAgICAgIHN0RXZ0OndoZW49IjIwMjQtMDItMjZUMTQ6MDg6NDYiLz4KICAgICA8cmRmOmxpCiAgICAgIHN0RXZ0OmFjdGlvbj0ic2F2ZWQiCiAgICAgIHN0RXZ0OmNoYW5nZWQ9Ii8iCiAgICAgIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6ZTVkODA4NjQtMmE1Ni00YzY1LWIwMDItN2Y1Y2Q4MWUwNzg2IgogICAgICBzdEV2dDpzb2Z0d2FyZUFnZW50PSJHaW1wIDIuMTAgKFdpbmRvd3MpIgogICAgICBzdEV2dDp3aGVuPSIyMDI0LTA1LTE2VDA5OjIxOjM2Ii8+CiAgICA8L3JkZjpTZXE+CiAgIDwveG1wTU06SGlzdG9yeT4KICAgPHhtcE1NOkRlcml2ZWRGcm9tCiAgICBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkE4MzE0NDhGNDIxNEUyMTFBQzk4ODAwOUE3REE0MjQ4IgogICAgc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDphMTAzYjU2MS03M2U2LWI3NDEtYmNmYi1hZWNmNWM5ZmVkYWQiCiAgICBzdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6QTgzMTQ0OEY0MjE0RTIxMUFDOTg4MDA5QTdEQTQyNDgiLz4KICAgPHBob3Rvc2hvcDpEb2N1bWVudEFuY2VzdG9ycz4KICAgIDxyZGY6QmFnPgogICAgIDxyZGY6bGk+MEZDMTZFOUNBN0M1MzM3NkZDMzczRjg3MUJCRTFEMUQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPjE3OTEwMjU5ODUyNDM3REIyNkI2ODU2N0FDRjYzMUQ0PC9yZGY6bGk+CiAgICAgPHJkZjpsaT4zMjVGNEY4NjJCRTEzOUI3MDA4RTMxOTA3NjMxNzk5MjwvcmRmOmxpPgogICAgIDxyZGY6bGk+MzlFRjdDMjVGMjNDODM0Q0UyMDJDMEExRkYyNEM2RUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPjNFNzc4QUQxRDBBRkVGNDc0RjExNkJDM0U1OUJCRTRCPC9yZGY6bGk+CiAgICAgPHJkZjpsaT40NTcyQUVEMTFGNUYzMTNCQzY4OEExMjVGMUUyNkUyNDwvcmRmOmxpPgogICAgIDxyZGY6bGk+NTE1RTZFM0RDMjREQzE3MzAzNkJDQkRBNTM5QTU0Nzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPjY5QTVGMjk2MTk2ODVDODRBNzE0NDFDNzk0RkUyRjY0PC9yZGY6bGk+CiAgICAgPHJkZjpsaT44NEQ5OERFQkY5MjNBRTg4NjEzMkIyQzM3ODIxN0YzQTwvcmRmOmxpPgogICAgIDxyZGY6bGk+OEU4RDIzMTNFMTZFQUExNkMwMTNEMUIwRkYwNzI2Mzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPjkyRDA0RDRCRUFEMjZFNTE4RDM2QjY1NTdDQ0FBRTJFPC9yZGY6bGk+CiAgICAgPHJkZjpsaT5DMDNGOERENUVBRDY3REFCNThGRDc4MDRFMDRDNEJFMjwvcmRmOmxpPgogICAgIDxyZGY6bGk+RTc5MDMzODFERDQzQjYwNjAyNjQ4M0EzNjk0MEJCMDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MDcxM0Q0MzdFMjdEREUxMUE3MTdDRkVEMjM1RUJGMTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MDg2MUFCQkMzN0ZEREYxMTgxNTc5RTY2RDhDOUM0QUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MEMzRDkyQzRENDI1REUxMTkxNTI4REMxMEEyNDBGNUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MEQyMjM3RTlEM0I1REUxMTkyODBERTg1OUFENEExMzM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUJBQTg5QjdGOTUxREYxMTlGQjRBMUFBNzk5NDUyRTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUM2ODE4MkE0ODc1REUxMUE5OTJGRDJEQzZFOTgzMEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUU5QjQwMTI0MEJFREYxMUI2RDdBRDVDOEVENkE4Qjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUY1QUYzQjY3MjI5REYxMTlGRkFCMjZFMjQwQzcxQkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MjA4QzQ0NTA3RTEzREYxMTg4MkZEMzU1MDQwODUzODM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkNFMEFENDQ3QzI1RTExMUIyQTFGRUJEQjFFRkQwQTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkRCREQxQkZDRTFEREYxMTlBQkVDMTQ5MzMxRDMxNEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkRCRjc0NTAzQzAxREUxMTlFREJBMTQ3NzkwNDBFMUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkY4QjEwNDhEMjE0REUxMTlGN0NENzQ0QUZFNTM5RkU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzA3NERDNDBBN0U0REQxMTg1NkZDMzVFRUU3MDFGNTc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzJBRDkwMUMxNTQwREYxMUJBMjJFQjgzOTBFNDI3RkE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzY5RTcyN0ZCMDRGREUxMTk3NzdBMjQxRTExMzJCNDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzgyMjI3NDE5NjUwREUxMTgyOEVCNzlCN0ZGODdCNDY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzhBOTgyQTY2MzExREYxMTlBNkI4NzdFQzUyNDZDNzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6M0E0Njc3ODE1RTI5REYxMUEwQjA4N0RGODk3RjVDNTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6M0I4MkEwMEVDMTNCREYxMTgyODFGMUI3MDlDQjRGREU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6M0ZBQUIzMURDN0YzREUxMUJGQjNCQjYxQUUxQTE5OEI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NDU3RDAyOTU1MDU1REYxMThCNTlEOTU5RDlGQ0Q1MEI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NDg4RTdEMjE2NDE3REYxMUFCMzA5NkRCNTlCRTgyNzg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NEJENjRFM0Q1OTFBREYxMTlBNDQ4MTZFNDI2RDE0Q0M8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NEQ0NzUzMERCRkIxREUxMTgzOENCNzlCQjAyOUM1MzM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NTY1QzMwRDQzQTA4REYxMUE2MURCMjI3RURERjU5Rjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NUZFRUIwMTA5MjIwREYxMUJGMkE5NDQ5RDU5MjEzOEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NkMxQ0VFOTlGRjBDREUxMThCNjA4MDg2ODZEMUNEQTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NkM3MDdFQjU0QzRFREYxMTlCRjY5RjVFN0NDMzg1RDQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NkU2NERFN0RDRDFFREUxMTg1NUNCMjRFMDMxQjQwRDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NzUyNEU0REQ0QzlBREYxMUFDNENFOEJGQkIyNEQ0Njg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6N0Q4MkE0RDlGNTM4REYxMTg5QUZDRDI3Mjk0NjY5ODU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODNDMzI1QTNBMzIxREYxMTk1RjdENzc1REU1NUI4NkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODY4Rjg3M0Y4MTkyREUxMUFERTdBMEEzRTU1QjBDMUY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODc1MTQ2Qzc5M0VEREUxMTgzQ0NDMDc0NzhGOTQzMTk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODg2ODJFQ0Y1RkRGREUxMUIzNjZEOUVGNzRERTRCM0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODk2QzBGQ0JEQTMyREYxMUE0NzNCMjFDNDlEMTc1N0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6OEM4QjRGMzE3RTFBREYxMUJBQkNENzQ0NzJDRUUwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6OTFDNkI5REQ3RDFBREYxMUJBQkNENzQ0NzJDRUUwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6OUFFMjFCNkI0Rjg1REUxMTlGRTVEMzk4RjIxQTQ0MTM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6QTQ1MzcxNzU4QUY3REQxMUI4QkFCQjBDNDc5Nzc4NzE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6QTUyQjJCRTJENTA0REUxMTg1MzJBNzUzNjI4RTk1ODc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6Q0E0RTAzNEU3RTFBREYxMUJBQkNENzQ0NzJDRUUwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RDYyM0UyRkNDQjQ0REYxMUE2NTk5OTA0NDY3Nzk2NDI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RDY5NjkwMTAzQUIyREQxMUE4NEI4NThERUQzNTlBOTQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6REFDQjQyQUMwRDU3REYxMTlFNjE4M0E5MjFCNjBGNkQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RTFFRkE4ODlCOUIyREUxMTlBREFGRkJFRDY0MUQwMDc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RTcyNkFCNjdBMUQ3REUxMUExQUU4QTM4OEJGMTFGREI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RUI2OUIxODg4NjA2REUxMUIzODBDOURGRkY1RURCNkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RjQ0MTRBMDM4ODQyREYxMTlERTJCQUY4REZCNzM5Qzg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6Rjk3NDg2QzFFMjRGREYxMTgzQzc5OTY3MTBEMDk5REM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RkM2Mjg0Mzk1Q0RGREUxMUIzNjZEOUVGNzRERTRCM0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDFEM0JDMEEwMzk4REYxMThFMERGQkNDMzlGMUQ3MEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDI0RjczM0M0Q0Q5REYxMTgxODU5MTU2RERCNTI3Qjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDU4MDExNzQwNzIwNjgxMUE5NjFBMDIwOTRFNzgzQzQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDdENDQ4MEQwNDMxREYxMTk3MDVFNUEwQ0Q0RDJBRUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTFBNzcyMTJEMzQ4RTAxMUI2QkFCNTVENjRGNTk2MkQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTJFQ0RGQ0M2OTE4RTAxMTgzMTdBNTEyNkIxODRDOUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTMzNjIxQkFBNkE4RTExMTk1NEE5RTkxQ0Q4MEQ4RjE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTQ4MEVGRDY0ODI1NjgxMTg4QzY4ODYyNURENDg4NDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTU4OEFCQTY0QjdFREYxMThCQjNGRDNGRkZFNTBGQkM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTg0MDdFQTQ5Rjc0REYxMUI5QURGNTAxQjFGRUVDNUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MThBNkE1RkFCOTEzRTAxMTgwREFDRUIxRTRCMDgwRkM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MThGMTEwM0U1NEMzREYxMUFBRTQ5Q0Q4OEFBNjQ0QUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MUFCNzc3MjI3NjI5RTAxMTlBRDFCOTQ1QzE5NjRCQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MUQ2RTQzNzNBQzVGREYxMUE2OEVEMjUxRkYyM0VDMzQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MUUzMjY1NjVEQUEzRTAxMTg2NzU4NDVGODM2QUY0RUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjE2RUEyQzk3MUQxREYxMUE5QTlBQUY5MkE0MTM4Q0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjI4NzVEOUE3MzMzNjgxMThBNkRFMEI0M0Q0NTVGQjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjUwRjM3RkRCRTY1REYxMTk2QTJFNTM4NkVCN0VGQkY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Mjc0OURBQzE2OUUwREYxMUJBRTJBOUY0RkExQzczMEU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjhFRUE5Qjc5QUQ1REYxMTk2NDhGODUxMUI3NDE3RDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MkI0OURBQzE2OUUwREYxMUJBRTJBOUY0RkExQzczMEU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MkNDOTcxRDZEQ0UxREYxMTkzQjhBMTFBODBGNDYyMzY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MzE1RUM3QjI0Mjc3REYxMUEyOENEQjJFNkU4REVEOEY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MzVBMjM5OEU2RTkwMTFERjk3OERCODkyNjBFNjFEOEU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0E2Q0FGMjcyQjE5RTAxMTg0REQ4RkJEMTEwMzQwMDg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0E3Njc4M0NEMEE4REYxMUIyQTE5RDUwRkYyMUI4RDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0JDNkNFMTJDMzcwREYxMTg1MENCNzJEQjlEMkNCOTI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0QwMkU2MkFERjhDREYxMTgxRENDQjhFOEI3N0YzMUY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0YyODQwQkJEQUY0REYxMTlCOUZFRDY2QjY4NzVBNzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDI2MTE5MzNDNkU5REYxMTkzNjZEMjIyRjU5QjQ5MkM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDI2OTU2QTYzQzdFREYxMUE1QTRFOTA2NUZBQzcwNEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDQyMjY3MThFRUFEMTFFMUI5OTNBRjRGQTQ4N0Y2M0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDRCQTYxMEZGNzE1RTAxMTg1MEZBOTAxQjRDMUI2NzU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDgwQjdFNDZBRjc4REYxMUE4MjVDRjhERTVEOTFERjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDhCN0JEMEJEMUYxREYxMTkxMURBRTNGNzdBNzJDMTI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEEwQ0JFOEY5NDVDRTAxMTlCOTRFMzk4ODEzRTEzQUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEM4Qjk5QTdCNEQzRTAxMUE0ODdDODk2NjhDNzAzMzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEM5Mzc2QjgzRUJCREYxMTkzRDlDNjQxMUU2NTA5NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEVDM0UxRTk0MjI4REYxMUFEQTM5NzcwQTczNEJEMTA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEYxQjlCRTJFMjJBRTAxMTkwRkJDMDc1RTk5RjYwRjI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTE0RjY3QzVFM0EwREYxMTk4RjhBN0I5MzE2OTczNTk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTNFQjgyMUE2QjQyRTAxMUIwODlGQTc1Mzg1NDhCQzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTQwRDI5N0ZDQjBFRTExMUEzQTBERkREM0U3QUE3M0E8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTQzQTc5OEYxMzA3RTAxMTg0NkZFOEMwNEQzQzhERUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTRDM0Y5RjhCREFFREYxMUE1REM5NTlDODJBQkM5RTE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTU5RkNEM0I1MjdBREYxMTg5MTRERUIxMzUxNzYxRjE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUEzQjg4MkIxRjIwNjgxMUFCMDhERUIwNTVFRjQ1QjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUIzQjg4MkIxRjIwNjgxMUFCMDhERUIwNTVFRjQ1QjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUI2REQyQjc0NTg0REYxMUI3MjQ4QjdEREY3OTRBMUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUQyMDc3MjMyODIwNjgxMUFGRkRGNzA2RTc0MjYxMEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUZCQTY2N0U0MUJGREYxMTlDM0ZEQjJBQkM3QjkyMkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjAyMDc3MjMyODIwNjgxMUFGRkRGNzA2RTc0MjYxMEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjA2NDBBNUM1ODI2RTAxMTgyQ0FEMzhFQ0VEQ0UyNjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjE1MkM1QkQxMDIxNjgxMTk5NENGNzlEMDI0RkM1QUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjM0RkUxMDZGREFBREYxMTk2QkZBQjJBRUNGRTJGQTE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjM5QjFERDI5N0Q1REYxMTk2NDhGODUxMUI3NDE3RDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjNBRUY5MTA1MzA1RTAxMTg2N0Y4OUIwMjExRTRGN0E8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjQ3NEM4M0M2ODdDREYxMThFMUY5OUQ2OUIzNTI1Q0M8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Njg4RTlCMUY0OEJCREYxMTkzRDlDNjQxMUU2NTA5NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Njg5QjFERDI5N0Q1REYxMTk2NDhGODUxMUI3NDE3RDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Njk4QTc2QUIzRjRBRTAxMUEzQkM5NjI1ODZGMDk3Rjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjlDQ0U4NUI5RjZCRTAxMUFEMzhBNTYzRjk0MzU2NDI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkFEMkREMTQyNkNCREYxMTkyMDdGRjYzMUUzMTNDMUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkI5QUZGNjUyMERBREYxMUFEMkJDQkYxOUMwMkY5OEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkMxRDRDRkJEOEM4REYxMTg4NDlFMjE3NjQ3OTZBRTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkNBQTIyNTVDRjU3RTAxMThGNjFBQkFBMTI4MUU0RTA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkUyODJEQ0E3RjE3RTAxMUIwNzM5ODY2RTlBRDBDODE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkY0QUJDMzNGQjZGRTAxMUJFQjY4RkU1QkY3QzMyQUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NzM5RDdFOUZFQkFEREYxMUFBREVBREEzNTYyMjIwODM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NzdFOURCM0JEMkM4RTAxMTk1MjFCOTA1NjZCNTcwQTE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Nzg4MjAwQjMzMjYxREYxMUIzOEY5OTg4NzVDQzg2NTQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Nzg4QUY1OENEQzlGREYxMThDMDBDM0M5NjhBQkRDMDY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6N0JEMkE3MTc2QzM0RTAxMTgzQzE4OEMwQjBEQTRDQUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODI4MDg3M0JDQTIwNjgxMTkyQjBCQ0JCOUJENDA5Mjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODRDNzZFNUNBNjFFRTAxMTlCNjJDMUE3MkNEREJCMkQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODYxQ0IxMjkxMTZDREYxMUEwODFEQUM2NTU0OUZGRjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODcwMjI1RDIwRTk0REYxMTk1QTVGQzVDMzE2Q0M0MTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODhBMTIzMTE2NEQ3MTFERkE2OTc4NTIxRDYwREY0NjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODk1MEVCREJBMzAzRTExMTlBMTdFMEIxRDhFODdDMUY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODlBN0I0QjBEODM4REYxMUE0NDFFNjY3MTI0NjRBODA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OEI5MDg1OEZCNTczREYxMUJGQkJGMDA3NTlBM0Q0NTI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTBDNUQ1MjY2NDc5REYxMTg2NUNFRUYwOTg1MUZENzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTBERDlFRTBEOTJEREYxMUI1RDhGQzk2QzlBNTRBMTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTFGRjA1MUUwRkQzREYxMUIyRDFDNTFGNTlCNUZCMjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTdFM0UxRTE0OERERTExMUI1NTY4RjY4MDU0QzQzOTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUIwQkM5MEU3NkI0REYxMUEzNjVFRjUyNTc3NjIzODE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUM4MDZGQTZGRjIyRTAxMTg1RUM5NzNGMjM0NUZBRkY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUU1M0ZEODQyOEJCREYxMTkzRDlDNjQxMUU2NTA5NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUVGN0Q5MkZDMzkyREYxMUFFRDZBNTlCMEVGNzExNDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTJEQTMwRTVBOUNCREYxMUIyNjFBNTlDOEYxQjM3ODY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTQxNzAxREVGQ0IwREUxMUFGM0FBQjdGNTkyMTFBREY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTgzMTQ0OEY0MjE0RTIxMUFDOTg4MDA5QTdEQTQyNDg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTgzNzhBMTMzNkEzREYxMTlFRTc4RDM4RTMwQUFGNjM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QUFFNzY4RkY4RDZBREYxMTgyOTBDQkI5NEM1Q0Y0RjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QjExRDM2MEMyNUYxREYxMTk0NDVBNUZEODk1RDc4MUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QjE4NTREQjZBQjM3RTAxMThCM0Q5RDc1OTY1NkY5NDg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QjZGMjcxMUJCRUJCREYxMTk2RjVCNDREM0E5QkQ2RjY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzAzMDQwQkZERjkwREYxMUFFODJDQkE4ODBGMTM4Rjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzFBOURGMTRERTlDREYxMTg4MTdFQkU2RTg2MTRENDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzI2QzBENDk1MjY3REYxMUIyRTVDOENBMkEyMEI1MDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzY2QzBENDk1MjY3REYxMUIyRTVDOENBMkEyMEI1MDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzcxMTBFNUY1MDc2REYxMThFNjFBQ0QxNzlEMDYyNDQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzhDM0FEMEY5ODEwRTAxMTlFM0VFRDZEQTUyQkIwMjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0FCMjZCMzM0N0JGREYxMUIyMjdGMjJBQ0REM0Y2OUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0M0QUI1OTFBN0RDREYxMUJGNzlGQTYyQjUxREY2Qzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0NENkQwRTJEMzIwNjgxMUFGRkRGNzA2RTc0MjYxMEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0RFODhCQ0U0QjZGREYxMUIyMThCMDBEODQ3REMyOTc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RDkwQjBCQUZDMEI5REYxMThDQjBEMDNEMkM4N0JDRDQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6REFBMUQxOThBREI2REYxMUJDRkQ5M0U3NkEwREMyRjQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6REFDODUwNzg1NEQ1REYxMUEwOTRERjAxRTZFREUzMjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6REIxRTRDMUNFODdBREYxMThDQjdGRUE3Q0Q3NEQzNUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTAyQzE5MEU0MjZFREYxMUIyNERFOTA4QUNDQUMwOTU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTA2Rjc4NkRGQ0IxREYxMTk4REZCMjBGOTBEM0FBNkU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTFGQTBEOThBNDI1NjgxMThBNkRFMEI0M0Q0NTVGQjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTMwRTQ5MDJCQUNGREYxMUIxNEVFRDg4RDQ4QTEyQzI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTc0N0MwRjgwRjY1REYxMTlBOTRDNUQ4RDE4ODk1NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTc5NDA3OERERTY0REYxMThBNTNENEVGRTIwQzM1MTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTdERDUyNjQxQTE5RTAxMTk1RjFCQTQ3NEYyQzBCQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RThDMTU2MEU5MjE3RTAxMUFGRkJBNjU0MTlBRjEwQ0I8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTk2QzNBREYyMjQ0RTAxMUEyQzJEMEIwQjkyQzc3Mjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RUVDMTU2MEU5MjE3RTAxMUFGRkJBNjU0MTlBRjEwQ0I8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RUY4NDQxQzA2NUU3REYxMUI4QUJCQkY3RkZBNkIwQzQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RUZDOUQxRDQ3N0IwREYxMThCNDNDRjY3QkUzQzlGN0Q8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjAwMTZGMDU1OUQ4RTAxMTkyN0NDM0QwQjg4MUM3RTQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjA0RDM1QzY0MkI4REYxMThDRUE5RTUyRTFEMEZBQjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjJGRkRGMzRBRjY5RTAxMTlFOEJBRDFFNzNBMDdBQjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjVDOEJDMEMxNDRGRTAxMTkzNkVCOTA0QTYzOTBDMTU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjVDOTQ5RDRGQjY4REYxMUJCMjc5Rjk4RjA2NzM2MEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjY1Mzk4RUUwQjZBRTAxMUExNjFBN0ZFMDc4MDA2M0E8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Rjc3MkQyQ0U2NUE5REYxMUFERUI4MjREM0M2MjVGNTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjkxRTVFN0Q1OTMyREYxMUE5REY5QzY4Qjg2Mjc4MEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjlEMkJDMEEwMzk4REYxMThFMERGQkNDMzlGMUQ3MEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkFGQzE4NjdFNjY0RTAxMTgyOTRDN0NCNjkxRUI5NEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkJGMDAzMEJEMDk0REYxMUI5MjRGRkM5NjRGMkYwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkJGOTlFQjc1NjdEREYxMUE3NEVFNkNFMDM5OTQ0MjI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkNENzdBMkMxQTIwNjgxMTkyQjBCQ0JCOUJENDA5Mjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkVDNTJEMzk3NjYzREYxMUIyNjE5NEREMTM0MjdGOEI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkY1NzY5M0EwMThFREYxMUJFQkI4MzVBM0ExRDNDQUU8L3JkZjpsaT4KICAgIDwvcmRmOkJhZz4KICAgPC9waG90b3Nob3A6RG9jdW1lbnRBbmNlc3RvcnM+CiAgPC9yZGY6RGVzY3JpcHRpb24+CiA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz7k8bjoAAAABmJLR0QAAAAAAAD5Q7t/AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH6AUQDBUkrJYQAQAAIABJREFUeNrs3Xe0LNtB3/nfrqrO3Sff8N5TDigLUMAYGYEsooSEYETOyfYM4CF4WSyDjC0wBmaBl8cLa7xEMsgGBhhbWLI0IJQAjTSSkHgSMMqS9Z7euyef07m7au/5o/rEe0JXdao+5/tZ66qf7j23b3ftCvu3o3HOOQEAAADAFHgcAgAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAAAAAEEAAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAAAIAAAgAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAAAAAEEAAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAA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5oLY7ZEoAuMyFNTWaij5xrgnxypZ2psY5y3FeVeNtZQUEY88kIDnl9WbMxv7i8NYtPhUi393w/UOzLjJedam+nNdr+6UhuUrG+J6To8tSDT37VDH453tIiqOqnjmuXq8+s9GHK9UW5xOPVODV8OG/ADue7i205OP03LzfPjiy7DlfaZ0FzH7ZhcfJlEMPVJE/P6pJNw734OENnzxSRJw0zQnli9NPu/k4zSXU8DChxJwz3yPZUlHi1/afWUsWZyEzAnKWZ0BQTBGOG/9pdscRGlJWqqEJ3+TiEWPJlqSmYqjEfj9XJNNjPNYunKspfeTsXRJMkaNtMd1P+78lRt33+mJuUwqvZ+MZc8lI2titAhPi51i0SgY8IenkywHSFLH4wxIF5O/JYD8LQGMy1BwXaaCwQNt8HgE2O3RknqhkA5/QEdZeQS79oR+tGVPb6xpRGrvaBALAjBimB133e7BP1Y38mESnYPdJmB6thPZU504XB7B/3YF8fm+EKqqVUtnIKW7iAHpMjInODDmKuMQsc54LznZTkzKdGDv5yEUbAugvEI1q91JkrF2e+RwO6ZMcmDQALnFQw8lCZg724WsiQrytwSwZ28IJ6pVaJrxxd8jRcKVI2yYnOXAsKE281ojhtmwdoMxklt6MIJvyyIYOdzGfxZinF+AsdYjRcSzTyWhskrFh1sDKNwXQmWVClU1PldaqozM8QqmTnHEdUhq92QRCxckYt4tKj7+JIidu4M4XqWam8tdLgF902RkjLFj0rUOS0lg6jyCrp89lj5zzkneGaKL1Pq3e7b6mtNtRDyvJaILS7zxz3aCiO1ErPhnmkdERERERD8YJiBERERERMQEhIiIiIiImIAQERERERExASEiIiIiIiYgRERERERETECIiIiIiIgJCBERERERMQEhIiIiIiJiAkJERERERExAiIiIiIiIzibzFhBRe82cc5I3gYjYThDR+Scg69/uyTtDREREREQdTtB1XedtICIiIiKiHwL3gBARERERERMQIiIiIiJiAkJERERERMQEhIiIiIiImIAQERERERExASEiIiIiIiYgRERERETEBISIiIiIiIgJCBERERERMQEhIiIiIiJiAkJERERERExAiIiIiIiICQgREREREVEH+j8azaMqxdSnzAAAAA5lWElmTU0AKgAAAAgAAAAAAAAA0lOTAAAAAElFTkSuQmCC"
    },
    "idle_stu5XX": {
      "format": "image/png",
      "data": "data:image/png;base64,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kqG5c+O65JKkysvT7zvjxvn02WfxvJp1stmka68tktdC30kmpVmz0nvB0LGTTeeP86hbN4e8XkPbtiX16qthrV2b2zZYuyap6uqUWrZM7/q0PMYp5tu3p7R+fUwnnZT+9OegQR6deWZMc+bk1zK173zHp1atrL3smf1hhB88UACYAUGTc7nqptnvvLNEP/xBqU4+2a127Rzq0MGh0aN8+tl/FquoKLdLBPbvNxWPpx9yMq3l3xCplLRokbVBuMdj6DtX++V2588Si6lTPaqosLY2bPWamHbuZPojU6YpffKJtYGZ223o6qv9TdLXj2bKFI8qKqxtwFq7NqatW4/edwxDOuUUh265pUi/vqNMI0Z41aWLU61bO3TKKW7demup+ue4XG0qJUt7vOo7WHLOnIilohV2uzR5sl/lrfPnWo8a7dKgQdZm4aqqkpo3j0IVAAEEqEf79jb9/OcluvzyYnXpcuSBRZcuTl1xhTenn8PukKWqUU11UNtbb0UtnyHQrZtTN97oy/gAxmwaOdKpsWOtLfdIpaR33+WtZkO9/XZUwZC1ENeli1M33eTPi75z1ginpVnKg33nvfcixxx433CDTzffXKpTTnEfcWDv9Rr67neL5fXlthGsVPQy67kBffxxXLt3W9sH0bKlXT/8YXFevKzo2cuuqVOLLFfymzcvzDJNgAAC1O+66/zq2rX+N5pDhnhUUZG77tqls63et4qH2re/aZ5yu3altGBB2PLfGzjQo6uu8jbptR40yKHLLiuW3W5tgLNuXUyLF7GptKH27jU1d471IHfyyW5955qm3SMwcKBDV1xebOk3KkmVlTHNn3/0N+KTJns0bJi33rLDLVvadeGE3O2nKio21KJF+ve3YD1LUuNxadYs6/eJbl2d+sEP/HI04eLsbt1suunGYvm81q71vn1Jvf461a8AAghQD3+RoYoT0luK43AYuuwyf87OJzjzTGuDiz27m+412zPPRiwt15DqlpmMGuXTtdf5muR8kGHDnLruuhLLy3kSCVP/fCbEjyVLnnsuov37k5b7ztkjvLr+ep9sTXA+yJAhTl1/fYm8FgekyaSpZ+rpO/36pr8UcNQorzp2zM2PZ/iZTvl86f/b+/bW//t/772Y5RLjUt3ZID/5SVGTLL3r0cOuH/+4xNI+t4Neez2kSITN5wABBKhHy5Y22S30wJ49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BAAAQIAAAAACBAAAQIAAAAACBAAAQIAAAAACBAAAECAAAAACBAAAECAAAAACBAAAECAAAIAAAQAAECAAAIAAAQAAECAAAIAAAQAABAgAAIAAAQAABAgAAIAAAQAABAgAACBAAAAABAgAACBAAAAABAgAACBAAAAAAQIAACBAAAAAAQIAACBAAAAAAQIAACBAAAAAAQIAAAgQAAAAAQIAAAgQAAAAAQIAAAgQAABAgAAAAAgQAABAgAAAAAgQAABAgAAAAAIEAABAgAAAAAIEAABAgAAAAAIEAAAQIAAAAAIEAAAQIAAAAAIEAAAQIAAAgAABAAAQIAAAgAABAAAQIAAAgAABAAAQIAAAgAABAAAECAAAgAABAAAECAAAgAABAAAECAAAIEAAAAAECAAAIEAAAAAECAAAIEAAAAABAgAAIEAAAAABAgAAIEAAAAABAgAACBAAAAABAgAACBAAAAABAgAACBAAAECAAAAACBAAAECAAAAACBAAAECAAAAAAgQAAECAAAAAAgQAAECAAAAAAgQAAECAAAAAAgQAABAgAAAAAgQAABAgAAAAAgQAABAgAACAAAEAABAgAACAAAEAAHgn/w/L/0luQhua3QAAAABJRU5ErkJggg=="
    }
  }
}
")).json();
2387
- this._images = i.images, console.log("[SignatureLayer] Configurations loaded successfully");
2386
+ const D = await (await fetch("data:application/json;base64,{
  "version": "1.0",
  "description": "Reusable image assets for tablet screens (Base64 encoded)",
  "images": {
    "signing_stu300": {
      "format": "image/png",
      "data": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZAAAABkCAIAAAAnqfEgAAACcklEQVR4nO3d22rjQBBFUcfk/z/ZGUMPQb7ImaiqZZ1hLfIQAhF+2pRabfXH5fJ1AkhwfvcHAPhXggXEECwghmABMQQLiCFYQAzBAmIIFhBDsIAYggXE+Hz3BwDinc8fXZd6/WVBwQIatHwr+cfwuSUEYggWEEOwgBiCBbzHhqV6wQLeYNuDRcEC3mPDg0XBAva2ed+WYAG7GrXatm9LsIB+r2eozbtMBQuY4rFZ179cfyp74gUL6LdWpeI3eAQLmGU5ZBVnq78XKf4/wFPLPLXU6iRYwGyNL58RLGCiyiaGJ1druQrAo9GprlqdBAuYqrFWJ8ECgnhFMtCgcWX9hZ5njQA7cEsIxBAsIIZgATEEC4ghWEAM2xqAKkfVA0kcVQ9wQ7CAGIIFxBAsIIZFd6Df8p3Id0vpTs0BDmd06rtWa/363TXrHwvgqbta1ZslWMBcy3vAYrMEC5jLGhaQpOu7O54SAv0mvcrYhAXsqnJSoWABMQQL2E/xIGhrWMB+imtbJiwghmABMQQLiGENC2jgqHqAG24JgRiCBcQQLCCGYAExPCUEqpz8DCRx8jPADcECYggWEEOwgBiCBfT7efncMV/AQVwuX9ckrVVpeZD9r9jWAEwxknTXpuIrkk1YwERj1Bq/j3hVdmyZsIC5vptV31xqwgL2sBy1NhMsYKKx9D5mq3qz3BICszw+DSzeHpqwgCnW9i6MdXf7sIADeT1DmbCA/5xgATEEC4ghWEAM2xqABk5+BrixOmHt00vg+I4z1ljDAmK4JQRimLCAGIIFxBAsIIZgATEEC4ghWEAMwQJiCBYQQ7CAGIIFxBAsIMYfYtquyxpbfFMAAAAASUVORK5CYII="
    },
    "idle_stu300": {
      "format": "image/png",
      "data": "data:image/png;base64,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"
    },
    "signing_stu430": {
      "format": "image/png",
      "data": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUAAAADICAYAAACZBDirAAAAxnpUWHRSYXcgcHJvZmlsZSB0eXBlIGV4aWYAAHjabVDBDcMgDPwzRUfAPgNmHNKkUjfo+DVgqiTqSZzNGQ7jcHzer/DoYJIgqWiuOUeDVKncLNE40QZTlMEDsjK66uG5LrFJsIi51TwjLd0vrEjNsnQy0qcXtmuhivvrzcgfQu+ILdndqLoReBbIDdr8VsxVy/kL2xGv0LlCJ5Th/TO576XY9PZkIpgPEKIxkGcD6CsFNEvUmJDsYEQdCowZ5J3YQP7NaSF8ATPHWVWbCn+jAAABg2lDQ1BJQ0MgcHJvZmlsZQAAeJx9kT1Iw0AcxV9TpUUrHewg4pChOtmlijiWKhbBQmkrtOpgcukXNDEkKS6OgmvBwY/FqoOLs64OroIg+AHiLjgpukiJ/0sKLWI8OO7Hu3uPu3eA0Koz1exLAKpmGdlUUiwUV8TAK4IIYxBx+CRm6uncQh6e4+sePr7exXiW97k/x5BSMhngE4kTTDcs4nXimU1L57xPHGFVSSE+J5406ILEj1yXXX7jXHFY4JkRI5+dI44Qi5UelnuYVQ2VeJo4qqga5QsFlxXOW5zVeoN17slfGCppyzmu0xxDCotIIwMRMhqooQ4LMVo1UkxkaT/p4R91/BlyyeSqgZFjHhtQITl+8D/43a1Znoq7SaEk0P9i2x/jQGAXaDdt+/vYttsngP8ZuNK6/o0WMPtJerOrRY+A8DZwcd3V5D3gcgcYedIlQ3IkP02hXAbez+ibisDwLTCw6vbW2cfpA5CnrpZugINDYKJC2Wse7w729vbvmU5/P5TucrR1EBi2AAANdmlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4KPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNC40LjAtRXhpdjIiPgogPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iCiAgICB4bWxuczpzdEV2dD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlRXZlbnQjIgogICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgeG1sbnM6R0lNUD0iaHR0cDovL3d3dy5naW1wLm9yZy94bXAvIgogICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iCiAgIHhtcE1NOkRvY3VtZW50SUQ9ImdpbXA6ZG9jaWQ6Z2ltcDo0NjhkMjE1ZS0zZDU0LTQxN2MtYTk3Ny05YTc0YWQ0ZTRmN2QiCiAgIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6M2UzZDFiYjQtODdiMC00ZTk2LThlOGEtYWE1NTRkNDdmMTZlIgogICB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6YmM4Zjc2M2EtYjljYy00MTJmLWFiOWQtZTkzMjFhMjEyYzAxIgogICBkYzpGb3JtYXQ9ImltYWdlL3BuZyIKICAgR0lNUDpBUEk9IjIuMCIKICAgR0lNUDpQbGF0Zm9ybT0iV2luZG93cyIKICAgR0lNUDpUaW1lU3RhbXA9IjE3NTUyNTk0MDIwMzI4NzEiCiAgIEdJTVA6VmVyc2lvbj0iMi4xMC4zNiIKICAgdGlmZjpPcmllbnRhdGlvbj0iMSIKICAgeG1wOkNyZWF0b3JUb29sPSJHSU1QIDIuMTAiCiAgIHhtcDpNZXRhZGF0YURhdGU9IjIwMjU6MDg6MTVUMDk6MDM6MjEtMDM6MDAiCiAgIHhtcDpNb2RpZnlEYXRlPSIyMDI1OjA4OjE1VDA5OjAzOjIxLTAzOjAwIj4KICAgPHhtcE1NOkhpc3Rvcnk+CiAgICA8cmRmOlNlcT4KICAgICA8cmRmOmxpCiAgICAgIHN0RXZ0OmFjdGlvbj0ic2F2ZWQiCiAgICAgIHN0RXZ0OmNoYW5nZWQ9Ii8iCiAgICAgIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6MmE0YjgzMTAtZWU1Zi00Yzc5LWFlNDUtZGQ2ZDI0ZDg1MTY1IgogICAgICBzdEV2dDpzb2Z0d2FyZUFnZW50PSJHaW1wIDIuMTAgKFdpbmRvd3MpIgogICAgICBzdEV2dDp3aGVuPSIyMDI1LTA4LTE1VDA5OjAzOjIyIi8+CiAgICA8L3JkZjpTZXE+CiAgIDwveG1wTU06SGlzdG9yeT4KICA8L3JkZjpEZXNjcmlwdGlvbj4KIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAKPD94cGFja2V0IGVuZD0idyI/PlrUftEAAAAGYktHRAABAAEAAMXh+PgAAAAJcEhZcwAACxMAAAsTAQCanBgAAAAHdElNRQfpCA8MAxXaZvUxAAANx0lEQVR42u3dbWwUdR7A8d/MPtndlj5slyt9pAUp8tCA9tC0UuEaUmgPQbCRPpwP9QGvAU3A1npnjHImdy/0xDMxMRo53xy5K3LEVBJiGk8EiUrPcIhBxPMCtLGHAVsf4lU6v3sBXXe22+ey7JbvJ5nQzszutjOd7/53Z1oMVVUBgKuQySYAQAABgAACAAEEAAIIAAQQAAggABBAACCAAEAAAYAAAgABBAACCAAEEAAIIAAQQAAggABAAAGAAAIAAQQAAggABBAACCAAEEAAIIAAQAABgAACAAEEAAIIgAACAAEEAAIIAAQQAAggABBAACCAAEAAAYAAAgABBAACCAAEEAAIIAAQQAAggABAAAGAAAIAAQQAAggABBAACCAAEEAAIIAAQAABgAACAAEEAAIIAAQQAAggAAIIAAQQAAggABBAACCAAEAAAYAAAgABBAAC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"
    },
    "idle_stu430": {
      "format": "image/png",
      "data": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABE8AAAMACAYAAADVC0kgAAAACXBIWXMAAAsSAAALEgHS3X78AAAgAElEQVR4nOzd7XHcRtY2YOCp/S+9EUiOQNwIREdgOgJTEViOwFQEpiIwFYGpCERFsGQES0ZgMQK8Be+Z9YhLHs3gs4G5riqW7V1piOnBNNA3TnfXTdNUAAAAADzu/7QLAAAAwNOEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCe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AAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAAAkBCeAAAAACSEJwAAAAAJ4QkAAABAQngCAAD/vx07EAAAgIEg9P7UI9gRFEYAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAABBngAAAAAEeQIAAAAQ5AkAAABAkCcAAAAAQZ4AAAAABHkCAAAAEOQJAAAAQJAnAAAAAEGeAAAAAAR5AgAAABDkCQAAAECQJwAAAACfbQflTG/+wcqyUQAAAABJRU5ErkJggg=="
    },
    "signing_stu5XX": {
      "format": "image/png",
      "data": "data:image/png;base64,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eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIgogICB4bXBNTTpEb2N1bWVudElEPSJhZG9iZTpkb2NpZDpwaG90b3Nob3A6ODhhNTQ4NmQtZmRiNC0wMTRiLThhMjItZTFjMjljN2FlZmQxIgogICB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjMxZjg4NDFhLWUzMzQtNDI2Yi1iNWJhLWZjNjVmMzhkYWU0YyIKICAgeG1wTU06T3JpZ2luYWxEb2N1bWVudElEPSJ4bXAuZGlkOkE4MzE0NDhGNDIxNEUyMTFBQzk4ODAwOUE3REE0MjQ4IgogICBkYzpmb3JtYXQ9ImltYWdlL2pwZWciCiAgIEdJTVA6QVBJPSIyLjAiCiAgIEdJTVA6UGxhdGZvcm09IldpbmRvd3MiCiAgIEdJTVA6VGltZVN0YW1wPSIxNzE1ODYyMDk2Njg2NDQwIgogICBHSU1QOlZlcnNpb249IjIuMTAuMzYiCiAgIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiCiAgIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIKICAgdGlmZjpPcmllbnRhdGlvbj0iMSIKICAgeG1wOkNyZWF0ZURhdGU9IjIwMTItMTAtMTJUMTA6MTg6MDkrMDI6MDAiCiAgIHhtcDpDcmVhdG9yVG9vbD0iR0lNUCAyLjEwIgogICB4bXA6TWV0YWRhdGFEYXRlPSIyMDI0OjA1OjE2VDA5OjIxOjI5LTAzOjAwIgogICB4bXA6TW9kaWZ5RGF0ZT0iMjAyNDowNToxNlQwOToyMToyOS0wMzowMCI+CiAgIDx4bXBNTTpIaXN0b3J5PgogICAgPHJkZjpTZXE+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249ImNyZWF0ZWQiCiAgICAgIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6QTgzMTQ0OEY0MjE0RTIxMUFDOTg4MDA5QTdEQTQyNDgiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpIgogICAgICBzdEV2dDp3aGVuPSIyMDEyLTEwLTEyVDEwOjE4OjA5KzAyOjAwIi8+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249InNhdmVkIgogICAgICBzdEV2dDpjaGFuZ2VkPSIvIgogICAgICBzdEV2dDppbnN0YW5jZUlEPSJ4bXAuaWlkOkUxNzg0ODI2NDYxNEUyMTFBQzk4ODAwOUE3REE0MjQ4IgogICAgICBzdEV2dDpzb2Z0d2FyZUFnZW50PSJBZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKSIKICAgICAgc3RFdnQ6d2hlbj0iMjAxMi0xMC0xMlQxMDoyMzo0OSswMjowMCIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJzYXZlZCIKICAgICAgc3RFdnQ6Y2hhbmdlZD0iLyIKICAgICAgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDphMTAzYjU2MS03M2U2LWI3NDEtYmNmYi1hZWNmNWM5ZmVkYWQiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE5IChXaW5kb3dzKSIKICAgICAgc3RFdnQ6d2hlbj0iMjAxOC0xMC0yMlQxNTowODoxNSswMjowMCIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJjb252ZXJ0ZWQiCiAgICAgIHN0RXZ0OnBhcmFtZXRlcnM9ImZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9qcGVnIi8+CiAgICAgPHJkZjpsaQogICAgICBzdEV2dDphY3Rpb249ImRlcml2ZWQiCiAgICAgIHN0RXZ0OnBhcmFtZXRlcnM9ImNvbnZlcnRlZCBmcm9tIGFwcGxpY2F0aW9uL3ZuZC5hZG9iZS5waG90b3Nob3AgdG8gaW1hZ2UvanBlZyIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJzYXZlZCIKICAgICAgc3RFdnQ6Y2hhbmdlZD0iLyIKICAgICAgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDo1OTQ1MDZlZS1kMTAxLTNjNGItODE1Ni02NzQxNWI1ODdmNjEiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE5IChXaW5kb3dzKSIKICAgICAgc3RFdnQ6d2hlbj0iMjAxOC0xMC0yMlQxNTowODoxNSswMjowMCIvPgogICAgIDxyZGY6bGkKICAgICAgc3RFdnQ6YWN0aW9uPSJzYXZlZCIKICAgICAgc3RFdnQ6Y2hhbmdlZD0iLyIKICAgICAgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDo2ZGZkNjQyOC0wOWQ1LTRkMDYtYTA3Yi0zNzgwZTJlMjk3MDEiCiAgICAgIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkdpbXAgMi4xMCAoV2luZG93cykiCiAgICAgIHN0RXZ0OndoZW49IjIwMjQtMDItMjZUMTQ6MDg6NDYiLz4KICAgICA8cmRmOmxpCiAgICAgIHN0RXZ0OmFjdGlvbj0ic2F2ZWQiCiAgICAgIHN0RXZ0OmNoYW5nZWQ9Ii8iCiAgICAgIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6ZTVkODA4NjQtMmE1Ni00YzY1LWIwMDItN2Y1Y2Q4MWUwNzg2IgogICAgICBzdEV2dDpzb2Z0d2FyZUFnZW50PSJHaW1wIDIuMTAgKFdpbmRvd3MpIgogICAgICBzdEV2dDp3aGVuPSIyMDI0LTA1LTE2VDA5OjIxOjM2Ii8+CiAgICA8L3JkZjpTZXE+CiAgIDwveG1wTU06SGlzdG9yeT4KICAgPHhtcE1NOkRlcml2ZWRGcm9tCiAgICBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkE4MzE0NDhGNDIxNEUyMTFBQzk4ODAwOUE3REE0MjQ4IgogICAgc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDphMTAzYjU2MS03M2U2LWI3NDEtYmNmYi1hZWNmNWM5ZmVkYWQiCiAgICBzdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6QTgzMTQ0OEY0MjE0RTIxMUFDOTg4MDA5QTdEQTQyNDgiLz4KICAgPHBob3Rvc2hvcDpEb2N1bWVudEFuY2VzdG9ycz4KICAgIDxyZGY6QmFnPgogICAgIDxyZGY6bGk+MEZDMTZFOUNBN0M1MzM3NkZDMzczRjg3MUJCRTFEMUQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPjE3OTEwMjU5ODUyNDM3REIyNkI2ODU2N0FDRjYzMUQ0PC9yZGY6bGk+CiAgICAgPHJkZjpsaT4zMjVGNEY4NjJCRTEzOUI3MDA4RTMxOTA3NjMxNzk5MjwvcmRmOmxpPgogICAgIDxyZGY6bGk+MzlFRjdDMjVGMjNDODM0Q0UyMDJDMEExRkYyNEM2RUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPjNFNzc4QUQxRDBBRkVGNDc0RjExNkJDM0U1OUJCRTRCPC9yZGY6bGk+CiAgICAgPHJkZjpsaT40NTcyQUVEMTFGNUYzMTNCQzY4OEExMjVGMUUyNkUyNDwvcmRmOmxpPgogICAgIDxyZGY6bGk+NTE1RTZFM0RDMjREQzE3MzAzNkJDQkRBNTM5QTU0Nzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPjY5QTVGMjk2MTk2ODVDODRBNzE0NDFDNzk0RkUyRjY0PC9yZGY6bGk+CiAgICAgPHJkZjpsaT44NEQ5OERFQkY5MjNBRTg4NjEzMkIyQzM3ODIxN0YzQTwvcmRmOmxpPgogICAgIDxyZGY6bGk+OEU4RDIzMTNFMTZFQUExNkMwMTNEMUIwRkYwNzI2Mzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPjkyRDA0RDRCRUFEMjZFNTE4RDM2QjY1NTdDQ0FBRTJFPC9yZGY6bGk+CiAgICAgPHJkZjpsaT5DMDNGOERENUVBRDY3REFCNThGRDc4MDRFMDRDNEJFMjwvcmRmOmxpPgogICAgIDxyZGY6bGk+RTc5MDMzODFERDQzQjYwNjAyNjQ4M0EzNjk0MEJCMDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MDcxM0Q0MzdFMjdEREUxMUE3MTdDRkVEMjM1RUJGMTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MDg2MUFCQkMzN0ZEREYxMTgxNTc5RTY2RDhDOUM0QUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MEMzRDkyQzRENDI1REUxMTkxNTI4REMxMEEyNDBGNUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MEQyMjM3RTlEM0I1REUxMTkyODBERTg1OUFENEExMzM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUJBQTg5QjdGOTUxREYxMTlGQjRBMUFBNzk5NDUyRTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUM2ODE4MkE0ODc1REUxMUE5OTJGRDJEQzZFOTgzMEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUU5QjQwMTI0MEJFREYxMUI2RDdBRDVDOEVENkE4Qjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MUY1QUYzQjY3MjI5REYxMTlGRkFCMjZFMjQwQzcxQkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MjA4QzQ0NTA3RTEzREYxMTg4MkZEMzU1MDQwODUzODM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkNFMEFENDQ3QzI1RTExMUIyQTFGRUJEQjFFRkQwQTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkRCREQxQkZDRTFEREYxMTlBQkVDMTQ5MzMxRDMxNEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkRCRjc0NTAzQzAxREUxMTlFREJBMTQ3NzkwNDBFMUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MkY4QjEwNDhEMjE0REUxMTlGN0NENzQ0QUZFNTM5RkU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzA3NERDNDBBN0U0REQxMTg1NkZDMzVFRUU3MDFGNTc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzJBRDkwMUMxNTQwREYxMUJBMjJFQjgzOTBFNDI3RkE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzY5RTcyN0ZCMDRGREUxMTk3NzdBMjQxRTExMzJCNDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzgyMjI3NDE5NjUwREUxMTgyOEVCNzlCN0ZGODdCNDY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6MzhBOTgyQTY2MzExREYxMTlBNkI4NzdFQzUyNDZDNzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6M0E0Njc3ODE1RTI5REYxMUEwQjA4N0RGODk3RjVDNTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6M0I4MkEwMEVDMTNCREYxMTgyODFGMUI3MDlDQjRGREU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6M0ZBQUIzMURDN0YzREUxMUJGQjNCQjYxQUUxQTE5OEI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NDU3RDAyOTU1MDU1REYxMThCNTlEOTU5RDlGQ0Q1MEI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NDg4RTdEMjE2NDE3REYxMUFCMzA5NkRCNTlCRTgyNzg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NEJENjRFM0Q1OTFBREYxMTlBNDQ4MTZFNDI2RDE0Q0M8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NEQ0NzUzMERCRkIxREUxMTgzOENCNzlCQjAyOUM1MzM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NTY1QzMwRDQzQTA4REYxMUE2MURCMjI3RURERjU5Rjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NUZFRUIwMTA5MjIwREYxMUJGMkE5NDQ5RDU5MjEzOEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NkMxQ0VFOTlGRjBDREUxMThCNjA4MDg2ODZEMUNEQTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NkM3MDdFQjU0QzRFREYxMTlCRjY5RjVFN0NDMzg1RDQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NkU2NERFN0RDRDFFREUxMTg1NUNCMjRFMDMxQjQwRDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6NzUyNEU0REQ0QzlBREYxMUFDNENFOEJGQkIyNEQ0Njg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6N0Q4MkE0RDlGNTM4REYxMTg5QUZDRDI3Mjk0NjY5ODU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODNDMzI1QTNBMzIxREYxMTk1RjdENzc1REU1NUI4NkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODY4Rjg3M0Y4MTkyREUxMUFERTdBMEEzRTU1QjBDMUY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODc1MTQ2Qzc5M0VEREUxMTgzQ0NDMDc0NzhGOTQzMTk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODg2ODJFQ0Y1RkRGREUxMUIzNjZEOUVGNzRERTRCM0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6ODk2QzBGQ0JEQTMyREYxMUE0NzNCMjFDNDlEMTc1N0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6OEM4QjRGMzE3RTFBREYxMUJBQkNENzQ0NzJDRUUwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6OTFDNkI5REQ3RDFBREYxMUJBQkNENzQ0NzJDRUUwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6OUFFMjFCNkI0Rjg1REUxMTlGRTVEMzk4RjIxQTQ0MTM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6QTQ1MzcxNzU4QUY3REQxMUI4QkFCQjBDNDc5Nzc4NzE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6QTUyQjJCRTJENTA0REUxMTg1MzJBNzUzNjI4RTk1ODc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6Q0E0RTAzNEU3RTFBREYxMUJBQkNENzQ0NzJDRUUwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RDYyM0UyRkNDQjQ0REYxMUE2NTk5OTA0NDY3Nzk2NDI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RDY5NjkwMTAzQUIyREQxMUE4NEI4NThERUQzNTlBOTQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6REFDQjQyQUMwRDU3REYxMTlFNjE4M0E5MjFCNjBGNkQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RTFFRkE4ODlCOUIyREUxMTlBREFGRkJFRDY0MUQwMDc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RTcyNkFCNjdBMUQ3REUxMUExQUU4QTM4OEJGMTFGREI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RUI2OUIxODg4NjA2REUxMUIzODBDOURGRkY1RURCNkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RjQ0MTRBMDM4ODQyREYxMTlERTJCQUY4REZCNzM5Qzg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6Rjk3NDg2QzFFMjRGREYxMTgzQzc5OTY3MTBEMDk5REM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnV1aWQ6RkM2Mjg0Mzk1Q0RGREUxMUIzNjZEOUVGNzRERTRCM0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDFEM0JDMEEwMzk4REYxMThFMERGQkNDMzlGMUQ3MEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDI0RjczM0M0Q0Q5REYxMTgxODU5MTU2RERCNTI3Qjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDU4MDExNzQwNzIwNjgxMUE5NjFBMDIwOTRFNzgzQzQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MDdENDQ4MEQwNDMxREYxMTk3MDVFNUEwQ0Q0RDJBRUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTFBNzcyMTJEMzQ4RTAxMUI2QkFCNTVENjRGNTk2MkQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTJFQ0RGQ0M2OTE4RTAxMTgzMTdBNTEyNkIxODRDOUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTMzNjIxQkFBNkE4RTExMTk1NEE5RTkxQ0Q4MEQ4RjE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTQ4MEVGRDY0ODI1NjgxMTg4QzY4ODYyNURENDg4NDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTU4OEFCQTY0QjdFREYxMThCQjNGRDNGRkZFNTBGQkM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MTg0MDdFQTQ5Rjc0REYxMUI5QURGNTAxQjFGRUVDNUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MThBNkE1RkFCOTEzRTAxMTgwREFDRUIxRTRCMDgwRkM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MThGMTEwM0U1NEMzREYxMUFBRTQ5Q0Q4OEFBNjQ0QUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MUFCNzc3MjI3NjI5RTAxMTlBRDFCOTQ1QzE5NjRCQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MUQ2RTQzNzNBQzVGREYxMUE2OEVEMjUxRkYyM0VDMzQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MUUzMjY1NjVEQUEzRTAxMTg2NzU4NDVGODM2QUY0RUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjE2RUEyQzk3MUQxREYxMUE5QTlBQUY5MkE0MTM4Q0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjI4NzVEOUE3MzMzNjgxMThBNkRFMEI0M0Q0NTVGQjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjUwRjM3RkRCRTY1REYxMTk2QTJFNTM4NkVCN0VGQkY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Mjc0OURBQzE2OUUwREYxMUJBRTJBOUY0RkExQzczMEU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MjhFRUE5Qjc5QUQ1REYxMTk2NDhGODUxMUI3NDE3RDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MkI0OURBQzE2OUUwREYxMUJBRTJBOUY0RkExQzczMEU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MkNDOTcxRDZEQ0UxREYxMTkzQjhBMTFBODBGNDYyMzY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MzE1RUM3QjI0Mjc3REYxMUEyOENEQjJFNkU4REVEOEY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6MzVBMjM5OEU2RTkwMTFERjk3OERCODkyNjBFNjFEOEU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0E2Q0FGMjcyQjE5RTAxMTg0REQ4RkJEMTEwMzQwMDg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0E3Njc4M0NEMEE4REYxMUIyQTE5RDUwRkYyMUI4RDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0JDNkNFMTJDMzcwREYxMTg1MENCNzJEQjlEMkNCOTI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0QwMkU2MkFERjhDREYxMTgxRENDQjhFOEI3N0YzMUY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6M0YyODQwQkJEQUY0REYxMTlCOUZFRDY2QjY4NzVBNzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDI2MTE5MzNDNkU5REYxMTkzNjZEMjIyRjU5QjQ5MkM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDI2OTU2QTYzQzdFREYxMUE1QTRFOTA2NUZBQzcwNEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDQyMjY3MThFRUFEMTFFMUI5OTNBRjRGQTQ4N0Y2M0U8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDRCQTYxMEZGNzE1RTAxMTg1MEZBOTAxQjRDMUI2NzU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDgwQjdFNDZBRjc4REYxMUE4MjVDRjhERTVEOTFERjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NDhCN0JEMEJEMUYxREYxMTkxMURBRTNGNzdBNzJDMTI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEEwQ0JFOEY5NDVDRTAxMTlCOTRFMzk4ODEzRTEzQUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEM4Qjk5QTdCNEQzRTAxMUE0ODdDODk2NjhDNzAzMzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEM5Mzc2QjgzRUJCREYxMTkzRDlDNjQxMUU2NTA5NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEVDM0UxRTk0MjI4REYxMUFEQTM5NzcwQTczNEJEMTA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NEYxQjlCRTJFMjJBRTAxMTkwRkJDMDc1RTk5RjYwRjI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTE0RjY3QzVFM0EwREYxMTk4RjhBN0I5MzE2OTczNTk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTNFQjgyMUE2QjQyRTAxMUIwODlGQTc1Mzg1NDhCQzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTQwRDI5N0ZDQjBFRTExMUEzQTBERkREM0U3QUE3M0E8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTQzQTc5OEYxMzA3RTAxMTg0NkZFOEMwNEQzQzhERUM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTRDM0Y5RjhCREFFREYxMUE1REM5NTlDODJBQkM5RTE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NTU5RkNEM0I1MjdBREYxMTg5MTRERUIxMzUxNzYxRjE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUEzQjg4MkIxRjIwNjgxMUFCMDhERUIwNTVFRjQ1QjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUIzQjg4MkIxRjIwNjgxMUFCMDhERUIwNTVFRjQ1QjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUI2REQyQjc0NTg0REYxMUI3MjQ4QjdEREY3OTRBMUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUQyMDc3MjMyODIwNjgxMUFGRkRGNzA2RTc0MjYxMEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NUZCQTY2N0U0MUJGREYxMTlDM0ZEQjJBQkM3QjkyMkI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjAyMDc3MjMyODIwNjgxMUFGRkRGNzA2RTc0MjYxMEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjA2NDBBNUM1ODI2RTAxMTgyQ0FEMzhFQ0VEQ0UyNjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjE1MkM1QkQxMDIxNjgxMTk5NENGNzlEMDI0RkM1QUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjM0RkUxMDZGREFBREYxMTk2QkZBQjJBRUNGRTJGQTE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjM5QjFERDI5N0Q1REYxMTk2NDhGODUxMUI3NDE3RDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjNBRUY5MTA1MzA1RTAxMTg2N0Y4OUIwMjExRTRGN0E8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjQ3NEM4M0M2ODdDREYxMThFMUY5OUQ2OUIzNTI1Q0M8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Njg4RTlCMUY0OEJCREYxMTkzRDlDNjQxMUU2NTA5NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Njg5QjFERDI5N0Q1REYxMTk2NDhGODUxMUI3NDE3RDM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Njk4QTc2QUIzRjRBRTAxMUEzQkM5NjI1ODZGMDk3Rjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NjlDQ0U4NUI5RjZCRTAxMUFEMzhBNTYzRjk0MzU2NDI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkFEMkREMTQyNkNCREYxMTkyMDdGRjYzMUUzMTNDMUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkI5QUZGNjUyMERBREYxMUFEMkJDQkYxOUMwMkY5OEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkMxRDRDRkJEOEM4REYxMTg4NDlFMjE3NjQ3OTZBRTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkNBQTIyNTVDRjU3RTAxMThGNjFBQkFBMTI4MUU0RTA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkUyODJEQ0E3RjE3RTAxMUIwNzM5ODY2RTlBRDBDODE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NkY0QUJDMzNGQjZGRTAxMUJFQjY4RkU1QkY3QzMyQUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NzM5RDdFOUZFQkFEREYxMUFBREVBREEzNTYyMjIwODM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6NzdFOURCM0JEMkM4RTAxMTk1MjFCOTA1NjZCNTcwQTE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Nzg4MjAwQjMzMjYxREYxMUIzOEY5OTg4NzVDQzg2NTQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Nzg4QUY1OENEQzlGREYxMThDMDBDM0M5NjhBQkRDMDY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6N0JEMkE3MTc2QzM0RTAxMTgzQzE4OEMwQjBEQTRDQUE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODI4MDg3M0JDQTIwNjgxMTkyQjBCQ0JCOUJENDA5Mjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODRDNzZFNUNBNjFFRTAxMTlCNjJDMUE3MkNEREJCMkQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODYxQ0IxMjkxMTZDREYxMUEwODFEQUM2NTU0OUZGRjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODcwMjI1RDIwRTk0REYxMTk1QTVGQzVDMzE2Q0M0MTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODhBMTIzMTE2NEQ3MTFERkE2OTc4NTIxRDYwREY0NjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODk1MEVCREJBMzAzRTExMTlBMTdFMEIxRDhFODdDMUY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6ODlBN0I0QjBEODM4REYxMUE0NDFFNjY3MTI0NjRBODA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OEI5MDg1OEZCNTczREYxMUJGQkJGMDA3NTlBM0Q0NTI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTBDNUQ1MjY2NDc5REYxMTg2NUNFRUYwOTg1MUZENzk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTBERDlFRTBEOTJEREYxMUI1RDhGQzk2QzlBNTRBMTY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTFGRjA1MUUwRkQzREYxMUIyRDFDNTFGNTlCNUZCMjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OTdFM0UxRTE0OERERTExMUI1NTY4RjY4MDU0QzQzOTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUIwQkM5MEU3NkI0REYxMUEzNjVFRjUyNTc3NjIzODE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUM4MDZGQTZGRjIyRTAxMTg1RUM5NzNGMjM0NUZBRkY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUU1M0ZEODQyOEJCREYxMTkzRDlDNjQxMUU2NTA5NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6OUVGN0Q5MkZDMzkyREYxMUFFRDZBNTlCMEVGNzExNDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTJEQTMwRTVBOUNCREYxMUIyNjFBNTlDOEYxQjM3ODY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTQxNzAxREVGQ0IwREUxMUFGM0FBQjdGNTkyMTFBREY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTgzMTQ0OEY0MjE0RTIxMUFDOTg4MDA5QTdEQTQyNDg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QTgzNzhBMTMzNkEzREYxMTlFRTc4RDM4RTMwQUFGNjM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QUFFNzY4RkY4RDZBREYxMTgyOTBDQkI5NEM1Q0Y0RjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QjExRDM2MEMyNUYxREYxMTk0NDVBNUZEODk1RDc4MUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QjE4NTREQjZBQjM3RTAxMThCM0Q5RDc1OTY1NkY5NDg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QjZGMjcxMUJCRUJCREYxMTk2RjVCNDREM0E5QkQ2RjY8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzAzMDQwQkZERjkwREYxMUFFODJDQkE4ODBGMTM4Rjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzFBOURGMTRERTlDREYxMTg4MTdFQkU2RTg2MTRENDk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzI2QzBENDk1MjY3REYxMUIyRTVDOENBMkEyMEI1MDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzY2QzBENDk1MjY3REYxMUIyRTVDOENBMkEyMEI1MDE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzcxMTBFNUY1MDc2REYxMThFNjFBQ0QxNzlEMDYyNDQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6QzhDM0FEMEY5ODEwRTAxMTlFM0VFRDZEQTUyQkIwMjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0FCMjZCMzM0N0JGREYxMUIyMjdGMjJBQ0REM0Y2OUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0M0QUI1OTFBN0RDREYxMUJGNzlGQTYyQjUxREY2Qzc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0NENkQwRTJEMzIwNjgxMUFGRkRGNzA2RTc0MjYxMEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Q0RFODhCQ0U0QjZGREYxMUIyMThCMDBEODQ3REMyOTc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RDkwQjBCQUZDMEI5REYxMThDQjBEMDNEMkM4N0JDRDQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6REFBMUQxOThBREI2REYxMUJDRkQ5M0U3NkEwREMyRjQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6REFDODUwNzg1NEQ1REYxMUEwOTRERjAxRTZFREUzMjA8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6REIxRTRDMUNFODdBREYxMThDQjdGRUE3Q0Q3NEQzNUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTAyQzE5MEU0MjZFREYxMUIyNERFOTA4QUNDQUMwOTU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTA2Rjc4NkRGQ0IxREYxMTk4REZCMjBGOTBEM0FBNkU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTFGQTBEOThBNDI1NjgxMThBNkRFMEI0M0Q0NTVGQjk8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTMwRTQ5MDJCQUNGREYxMUIxNEVFRDg4RDQ4QTEyQzI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTc0N0MwRjgwRjY1REYxMTlBOTRDNUQ4RDE4ODk1NUI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTc5NDA3OERERTY0REYxMThBNTNENEVGRTIwQzM1MTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTdERDUyNjQxQTE5RTAxMTk1RjFCQTQ3NEYyQzBCQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RThDMTU2MEU5MjE3RTAxMUFGRkJBNjU0MTlBRjEwQ0I8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RTk2QzNBREYyMjQ0RTAxMUEyQzJEMEIwQjkyQzc3Mjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RUVDMTU2MEU5MjE3RTAxMUFGRkJBNjU0MTlBRjEwQ0I8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RUY4NDQxQzA2NUU3REYxMUI4QUJCQkY3RkZBNkIwQzQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RUZDOUQxRDQ3N0IwREYxMThCNDNDRjY3QkUzQzlGN0Q8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjAwMTZGMDU1OUQ4RTAxMTkyN0NDM0QwQjg4MUM3RTQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjA0RDM1QzY0MkI4REYxMThDRUE5RTUyRTFEMEZBQjg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjJGRkRGMzRBRjY5RTAxMTlFOEJBRDFFNzNBMDdBQjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjVDOEJDMEMxNDRGRTAxMTkzNkVCOTA0QTYzOTBDMTU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjVDOTQ5RDRGQjY4REYxMUJCMjc5Rjk4RjA2NzM2MEE8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjY1Mzk4RUUwQjZBRTAxMUExNjFBN0ZFMDc4MDA2M0E8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6Rjc3MkQyQ0U2NUE5REYxMUFERUI4MjREM0M2MjVGNTg8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjkxRTVFN0Q1OTMyREYxMUE5REY5QzY4Qjg2Mjc4MEQ8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RjlEMkJDMEEwMzk4REYxMThFMERGQkNDMzlGMUQ3MEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkFGQzE4NjdFNjY0RTAxMTgyOTRDN0NCNjkxRUI5NEM8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkJGMDAzMEJEMDk0REYxMUI5MjRGRkM5NjRGMkYwQUU8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkJGOTlFQjc1NjdEREYxMUE3NEVFNkNFMDM5OTQ0MjI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkNENzdBMkMxQTIwNjgxMTkyQjBCQ0JCOUJENDA5Mjc8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkVDNTJEMzk3NjYzREYxMUIyNjE5NEREMTM0MjdGOEI8L3JkZjpsaT4KICAgICA8cmRmOmxpPnhtcC5kaWQ6RkY1NzY5M0EwMThFREYxMUJFQkI4MzVBM0ExRDNDQUU8L3JkZjpsaT4KICAgIDwvcmRmOkJhZz4KICAgPC9waG90b3Nob3A6RG9jdW1lbnRBbmNlc3RvcnM+CiAgPC9yZGY6RGVzY3JpcHRpb24+CiA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz7k8bjoAAAABmJLR0QAAAAAAAD5Q7t/AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH6AUQDBUkrJYQAQAAIABJREFUeNrs3Xe0LNtB3/nfrqrO3Sff8N5TDigLUMAYGYEsooSEYETOyfYM4CF4WSyDjC0wBmaBl8cLa7xEMsgGBhhbWLI0IJQAjTSSkHgSMMqS9Z7euyef07m7au/5o/rEe0JXdao+5/tZ66qf7j23b3ftCvu3o3HOOQEAAADAFHgcAgAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAAAAAEEAAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAAAIAAAgAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAAAAAEEAAAAAAEEAAAAAAEEAAAAAAggAAAAAAggAAAAAAAAQQAAAAAAQQAAAAAAQQAAAAACCAAAAAACCAAAAAAQAABAAAAQAABAAAAQAABAAAAAAIIAAAAAAIIAAAAABBAAAAAABBAAAAAABBAAAAAAIAAAgAAAIAAAgAA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5oLY7ZEoAuMyFNTWaij5xrgnxypZ2psY5y3FeVeNtZQUEY88kIDnl9WbMxv7i8NYtPhUi393w/UOzLjJedam+nNdr+6UhuUrG+J6To8tSDT37VDH453tIiqOqnjmuXq8+s9GHK9UW5xOPVODV8OG/ADue7i205OP03LzfPjiy7DlfaZ0FzH7ZhcfJlEMPVJE/P6pJNw734OENnzxSRJw0zQnli9NPu/k4zSXU8DChxJwz3yPZUlHi1/afWUsWZyEzAnKWZ0BQTBGOG/9pdscRGlJWqqEJ3+TiEWPJlqSmYqjEfj9XJNNjPNYunKspfeTsXRJMkaNtMd1P+78lRt33+mJuUwqvZ+MZc8lI2titAhPi51i0SgY8IenkywHSFLH4wxIF5O/JYD8LQGMy1BwXaaCwQNt8HgE2O3RknqhkA5/QEdZeQS79oR+tGVPb6xpRGrvaBALAjBimB133e7BP1Y38mESnYPdJmB6thPZU504XB7B/3YF8fm+EKqqVUtnIKW7iAHpMjInODDmKuMQsc54LznZTkzKdGDv5yEUbAugvEI1q91JkrF2e+RwO6ZMcmDQALnFQw8lCZg724WsiQrytwSwZ28IJ6pVaJrxxd8jRcKVI2yYnOXAsKE281ojhtmwdoMxklt6MIJvyyIYOdzGfxZinF+AsdYjRcSzTyWhskrFh1sDKNwXQmWVClU1PldaqozM8QqmTnHEdUhq92QRCxckYt4tKj7+JIidu4M4XqWam8tdLgF902RkjLFj0rUOS0lg6jyCrp89lj5zzkneGaKL1Pq3e7b6mtNtRDyvJaILS7zxz3aCiO1ErPhnmkdERERERD8YJiBERERERMQEhIiIiIiImIAQERERERExASEiIiIiIiYgRERERERETECIiIiIiIgJCBERERERMQEhIiIiIiJiAkJERERERExAiIiIiIiIzibzFhBRe82cc5I3gYjYThDR+Scg69/uyTtDREREREQdTtB1XedtICIiIiKiHwL3gBARERERERMQIiIiIiJiAkJERERERMQEhIiIiIiImIAQERERERExASEiIiIiIiYgRERERETEBISIiIiIiIgJCBERERERMQEhIiIiIiJiAkJERERERExAiIiIiIiICQgREREREVEH+j8azaMqxdSnzAAAAA5lWElmTU0AKgAAAAgAAAAAAAAA0lOTAAAAAElFTkSuQmCC"
    },
    "idle_stu5XX": {
      "format": "image/png",
      "data": "data:image/png;base64,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kqG5c+O65JKkysvT7zvjxvn02WfxvJp1stmka68tktdC30kmpVmz0nvB0LGTTeeP86hbN4e8XkPbtiX16qthrV2b2zZYuyap6uqUWrZM7/q0PMYp5tu3p7R+fUwnnZT+9OegQR6deWZMc+bk1zK173zHp1atrL3smf1hhB88UACYAUGTc7nqptnvvLNEP/xBqU4+2a127Rzq0MGh0aN8+tl/FquoKLdLBPbvNxWPpx9yMq3l3xCplLRokbVBuMdj6DtX++V2588Si6lTPaqosLY2bPWamHbuZPojU6YpffKJtYGZ223o6qv9TdLXj2bKFI8qKqxtwFq7NqatW4/edwxDOuUUh265pUi/vqNMI0Z41aWLU61bO3TKKW7demup+ue4XG0qJUt7vOo7WHLOnIilohV2uzR5sl/lrfPnWo8a7dKgQdZm4aqqkpo3j0IVAAEEqEf79jb9/OcluvzyYnXpcuSBRZcuTl1xhTenn8PukKWqUU11UNtbb0UtnyHQrZtTN97oy/gAxmwaOdKpsWOtLfdIpaR33+WtZkO9/XZUwZC1ENeli1M33eTPi75z1ginpVnKg33nvfcixxx433CDTzffXKpTTnEfcWDv9Rr67neL5fXlthGsVPQy67kBffxxXLt3W9sH0bKlXT/8YXFevKzo2cuuqVOLLFfymzcvzDJNgAAC1O+66/zq2rX+N5pDhnhUUZG77tqls63et4qH2re/aZ5yu3altGBB2PLfGzjQo6uu8jbptR40yKHLLiuW3W5tgLNuXUyLF7GptKH27jU1d471IHfyyW5955qm3SMwcKBDV1xebOk3KkmVlTHNn3/0N+KTJns0bJi33rLDLVvadeGE3O2nKio21KJF+ve3YD1LUuNxadYs6/eJbl2d+sEP/HI04eLsbt1suunGYvm81q71vn1Jvf461a8AAghQD3+RoYoT0luK43AYuuwyf87OJzjzTGuDiz27m+412zPPRiwt15DqlpmMGuXTtdf5muR8kGHDnLruuhLLy3kSCVP/fCbEjyVLnnsuov37k5b7ztkjvLr+ep9sTXA+yJAhTl1/fYm8FgekyaSpZ+rpO/36pr8UcNQorzp2zM2PZ/iZTvl86f/b+/bW//t/772Y5RLjUt3ZID/5SVGTLL3r0cOuH/+4xNI+t4Neez2kSITN5wABBKhHy5Y22S30wJ49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BAAAQIAAAAACBAAAQIAAAAACBAAAQIAAAAACBAAAECAAAAACBAAAECAAAAACBAAAECAAAIAAAQAAECAAAIAAAQAAECAAAIAAAQAABAgAAIAAAQAABAgAAIAAAQAABAgAACBAAAAABAgAACBAAAAABAgAACBAAAAAAQIAACBAAAAAAQIAACBAAAAAAQIAACBAAAAAAQIAAAgQAAAAAQIAAAgQAAAAAQIAAAgQAABAgAAAAAgQAABAgAAAAAgQAABAgAAAAAIEAABAgAAAAAIEAABAgAAAAAIEAAAQIAAAAAIEAAAQIAAAAAIEAAAQIAAAgAABAAAQIAAAgAABAAAQIAAAgAABAAAQIAAAgAABAAAECAAAgAABAAAECAAAgAABAAAECAAAIEAAAAAECAAAIEAAAAAECAAAIEAAAAABAgAAIEAAAAABAgAAIEAAAAABAgAACBAAAAABAgAACBAAAAABAgAACBAAAECAAAAACBAAAECAAAAACBAAAECAAAAAAgQAAECAAAAAAgQAAECAAAAAAgQAAECAAAAAAgQAABAgAAAAAgQAABAgAAAAAgQAABAgAACAAAEAABAgAACAAAEAAHgn/w/L/0luQhua3QAAAABJRU5ErkJggg=="
    }
  }
}
")).json();
2387
+ this._images = D.images, console.log("[SignatureLayer] Configurations loaded successfully");
2388
2388
  } catch (A) {
2389
2389
  throw console.error("[SignatureLayer] Failed to load configurations:", A), new Error("Failed to load device configurations");
2390
2390
  }
@@ -2398,9 +2398,9 @@ class KI {
2398
2398
  const C = A.name || "";
2399
2399
  if (!this._deviceConfigs)
2400
2400
  return console.error("[SignatureLayer] Device configs not loaded"), this._getDefaultConfig();
2401
- for (const [B, i] of Object.entries(this._deviceConfigs))
2402
- if (i.match && C.includes(i.match))
2403
- return console.log(`[SignatureLayer] Matched device config: ${i.name}`), this._resolveImageReferences(i);
2401
+ for (const [B, D] of Object.entries(this._deviceConfigs))
2402
+ if (D.match && C.includes(D.match))
2403
+ return console.log(`[SignatureLayer] Matched device config: ${D.name}`), this._resolveImageReferences(D);
2404
2404
  return console.warn("[SignatureLayer] No specific config found, using DefaultDriver"), this._resolveImageReferences(this._deviceConfigs.DefaultDriver);
2405
2405
  }
2406
2406
  /**
@@ -2456,7 +2456,7 @@ class KI {
2456
2456
  C.y,
2457
2457
  C.width,
2458
2458
  C.height,
2459
- (B, i) => this._handleDrawingHotspot(B, i)
2459
+ (B, D) => this._handleDrawingHotspot(B, D)
2460
2460
  );
2461
2461
  } else
2462
2462
  throw new Error("[SignatureLayer] Canvas-style tablet requires drawingArea hotspot configuration");
@@ -2468,8 +2468,8 @@ class KI {
2468
2468
  C.y,
2469
2469
  C.width,
2470
2470
  C.height,
2471
- async (B, i) => {
2472
- i === "click" && (await this.stopSigning(), this._fireOKCallbacks());
2471
+ async (B, D) => {
2472
+ D === "click" && (await this.stopSigning(), this._fireOKCallbacks());
2473
2473
  }
2474
2474
  );
2475
2475
  }
@@ -2481,8 +2481,8 @@ class KI {
2481
2481
  C.y,
2482
2482
  C.width,
2483
2483
  C.height,
2484
- async (B, i) => {
2485
- i === "click" && (await this.clearSignature(), this._fireClearCallbacks());
2484
+ async (B, D) => {
2485
+ D === "click" && (await this.clearSignature(), this._fireClearCallbacks());
2486
2486
  }
2487
2487
  );
2488
2488
  }
@@ -2494,8 +2494,8 @@ class KI {
2494
2494
  C.y,
2495
2495
  C.width,
2496
2496
  C.height,
2497
- async (B, i) => {
2498
- i === "click" && (await this.stopSigning(), this._fireCancelCallbacks());
2497
+ async (B, D) => {
2498
+ D === "click" && (await this.stopSigning(), this._fireCancelCallbacks());
2499
2499
  }
2500
2500
  );
2501
2501
  }
@@ -2598,37 +2598,39 @@ typeof CommandArgsBuilder < "u" && (window.CommandArgsBuilder = CommandArgsBuild
2598
2598
  typeof HotspotManager < "u" && (window.HotspotManager = HotspotManager);
2599
2599
  typeof AspectRatioCorrector < "u" && (window.AspectRatioCorrector = AspectRatioCorrector);
2600
2600
  typeof PageInputController < "u" && (window.PageInputController = PageInputController);
2601
- var Sg = Object.defineProperty, Fg = Object.getOwnPropertyDescriptor, a = (D, A, C, B) => {
2602
- for (var i = B > 1 ? void 0 : B ? Fg(A, C) : A, U = D.length - 1, N; U >= 0; U--)
2603
- (N = D[U]) && (i = (B ? N(A, C, i) : N(i)) || i);
2604
- return B && i && Sg(A, C, i), i;
2601
+ var Sg = Object.defineProperty, Fg = Object.getOwnPropertyDescriptor, G = (i, A, C, B) => {
2602
+ for (var D = B > 1 ? void 0 : B ? Fg(A, C) : A, U = i.length - 1, w; U >= 0; U--)
2603
+ (w = i[U]) && (D = (B ? w(A, C, D) : w(D)) || D);
2604
+ return B && D && Sg(A, C, D), D;
2605
2605
  };
2606
- let G = class extends Qg {
2606
+ let M = class extends Qg {
2607
2607
  constructor() {
2608
- super(), this.licenseKey = "", this.canvasAdditionalText = null, this.topBarVisible = !0, this.bottomBarVisible = !0, this.okButtonVisible = !0, this.clearButtonVisible = !0, this.cancelButtonVisible = !0, this.canvasLineVisible = !0, this.deviceStateTextVisible = !0, this.customDeviceStateText = null, this.minThickness = 1, this.maxThickness = 5, this.penColor = "#000000", this.customCssVariables = {}, this._deviceStateText = "Not connected", this._isConnected = !1, this._hasStartedDrawing = !1, this._isDisconnectingIntentionally = !1, this.licenseServerUrl = "https://test.signosoft.com/api/v1/driver/leases", this.sigLayer = null, this.canvasPainter = null, this.mouseInputHandler = null, this.offscreenDrawingCanvas = null;
2608
+ super(), this.licenseKey = "", this.canvasAdditionalText = null, this.topBarVisible = !0, this.bottomBarVisible = !0, this.okButtonVisible = !0, this.clearButtonVisible = !0, this.cancelButtonVisible = !0, this.canvasLineVisible = !0, this.deviceStateTextVisible = !0, this.customDeviceStateText = null, this.minThickness = 1, this.maxThickness = 5, this.penColor = "#000000", this.customCssVariables = {}, this._deviceStateText = "Not connected", this._isConnected = !1, this._hasStartedDrawing = !1, this._isDisconnectingIntentionally = !1, this._isConnecting = !1, this._isLoadingConnection = !1, this._loadingMessage = "", this.licenseServerUrl = "https://test.signosoft.com/api/v1/driver/leases", this.sigLayer = null, this.canvasPainter = null, this.mouseInputHandler = null, this.offscreenDrawingCanvas = null;
2609
2609
  }
2610
2610
  /**
2611
2611
  * Invoked once after the component's first render.
2612
- * Initializes CanvasPainter and MouseInputHandler, then starts driver initialization.
2612
+ * Initializes CanvasPainter and MouseInputHandler.
2613
+ * Attempts to auto-connect to a physical tablet first. If that fails, it then automatically
2614
+ * attempts to connect in mouse fallback mode, all without user interaction.
2613
2615
  */
2614
- firstUpdated() {
2616
+ async firstUpdated() {
2615
2617
  this.canvasRef ? (this.canvasPainter = new Dg(this.canvasRef, {
2616
2618
  minThickness: this.minThickness,
2617
2619
  maxThickness: this.maxThickness,
2618
2620
  color: this.penColor
2619
2621
  }), this.mouseInputHandler = new og(
2620
2622
  this.canvasRef,
2621
- (D) => {
2622
- this.canvasPainter && this.canvasPainter.drawSegment(D), D.inContact && !this._hasStartedDrawing && (this._hasStartedDrawing = !0), this.dispatch("sign-pen", D);
2623
+ (i) => {
2624
+ this.canvasPainter && this.canvasPainter.drawSegment(i), i.inContact && !this._hasStartedDrawing && (this._hasStartedDrawing = !0), this.dispatch("sign-pen", i);
2623
2625
  }
2624
- )) : console.error("signosoft-signpad: Canvas reference not found!"), this._deviceStateText = "Not connected", this._isConnected = !1, this._hasStartedDrawing = !1;
2626
+ )) : console.error("signosoft-signpad: Canvas reference not found!"), this._setDisconnectedState(), this.licenseKey && (this._loadingMessage = "Connecting to your device...", this._isLoadingConnection = !0, await this.connectTablet(!0, !1));
2625
2627
  }
2626
2628
  /**
2627
2629
  * Invoked before the component's render method is called.
2628
2630
  * Updates CanvasPainter's drawing options if related properties have changed.
2629
2631
  */
2630
- willUpdate(D) {
2631
- this.canvasPainter && (D.has("minThickness") || D.has("maxThickness") || D.has("penColor")) && this.canvasPainter.updateDrawingOptions({
2632
+ willUpdate(i) {
2633
+ this.canvasPainter && (i.has("minThickness") || i.has("maxThickness") || i.has("penColor")) && this.canvasPainter.updateDrawingOptions({
2632
2634
  minThickness: this.minThickness,
2633
2635
  maxThickness: this.maxThickness,
2634
2636
  color: this.penColor
@@ -2638,8 +2640,8 @@ let G = class extends Qg {
2638
2640
  * Invoked after the component's render method is called and its DOM has been updated.
2639
2641
  * Applies custom CSS variables from the `customCssVariables` property to the host element.
2640
2642
  */
2641
- updated(D) {
2642
- if (super.updated(D), D.has("customCssVariables"))
2643
+ updated(i) {
2644
+ if (super.updated(i), i.has("customCssVariables"))
2643
2645
  for (const A in this.customCssVariables)
2644
2646
  Object.prototype.hasOwnProperty.call(this.customCssVariables, A) && this.style.setProperty(A, this.customCssVariables[A]);
2645
2647
  }
@@ -2651,8 +2653,8 @@ let G = class extends Qg {
2651
2653
  if (!this.sigLayer)
2652
2654
  try {
2653
2655
  this.sigLayer = new window.SignatureLayer(), this.setupCallbacks();
2654
- } catch (D) {
2655
- throw console.error("Signosoft Signpad: Error instantiating driver", D), this.dispatch("sign-error", D), this._deviceStateText = "Initialization Error", this._isConnected = !1, this._hasStartedDrawing = !1, D;
2656
+ } catch (i) {
2657
+ throw console.error("Signosoft Signpad: Error instantiating driver", i), this.dispatch("sign-error", i), this._setDisconnectedState(), i;
2656
2658
  }
2657
2659
  }
2658
2660
  /**
@@ -2661,10 +2663,15 @@ let G = class extends Qg {
2661
2663
  * trigger the corresponding public methods of this component.
2662
2664
  */
2663
2665
  setupCallbacks() {
2664
- this.sigLayer && (this.sigLayer.onOK(() => this.ok()), this.sigLayer.onClear(() => this.clear()), this.sigLayer.onCancel(() => this.cancel()), this.sigLayer.onPen((D) => {
2665
- this.canvasPainter && this.canvasPainter.drawSegment(D), D.inContact && !this._hasStartedDrawing && (this._hasStartedDrawing = !0), this.dispatch("sign-pen", D);
2666
+ this.sigLayer && (this.sigLayer.onOK(() => {
2667
+ console.log(
2668
+ "signosoft-signpad: sigLayer.onOK callback fired at:",
2669
+ performance.now()
2670
+ ), this.ok();
2671
+ }), this.sigLayer.onClear(() => this.clear()), this.sigLayer.onCancel(() => this.cancel()), this.sigLayer.onPen((i) => {
2672
+ this.canvasPainter && this.canvasPainter.drawSegment(i), i.inContact && !this._hasStartedDrawing && (this._hasStartedDrawing = !0), this.dispatch("sign-pen", i);
2666
2673
  }), this.sigLayer.onUnexpectedDisconnect(() => {
2667
- this._isDisconnectingIntentionally || (this.dispatch("sign-disconnect"), this._deviceStateText = "Disconnected", this._isConnected = !1, this._hasStartedDrawing = !1);
2674
+ this._isDisconnectingIntentionally || (this.dispatch("sign-disconnect"), this._setDisconnectedState());
2668
2675
  }));
2669
2676
  }
2670
2677
  /**
@@ -2672,9 +2679,9 @@ let G = class extends Qg {
2672
2679
  * @param name - The name of the custom event to dispatch.
2673
2680
  * @param [detail] - Optional data to include with the event, accessible via `event.detail`.
2674
2681
  */
2675
- dispatch(D, A) {
2682
+ dispatch(i, A) {
2676
2683
  this.dispatchEvent(
2677
- new CustomEvent(D, {
2684
+ new CustomEvent(i, {
2678
2685
  detail: A,
2679
2686
  bubbles: !0,
2680
2687
  composed: !0
@@ -2682,27 +2689,25 @@ let G = class extends Qg {
2682
2689
  );
2683
2690
  }
2684
2691
  /**
2685
- * Connects to the signature tablet.
2686
- * This involves obtaining a license, initializing the signature layer,
2687
- * connecting to the device, and starting the signing process.
2688
- * This method strategically passes an offscreen canvas or the actual visible canvas to SignatureLayer
2689
- * based on the detected device, to prevent unwanted internal drawing by SignatureLayer.
2692
+ * Connects to the signature tablet or enables mouse fallback.
2690
2693
  * This method can be invoked externally (e.g., from a "Connect Signpad" button).
2691
- * @param autoConnect - If true, attempts to automatically select the first available device.
2692
- * @returns True if successfully connected and signing started, false otherwise.
2694
+ * @param autoConnect - If true, attempts to automatically select the first available device without a prompt.
2695
+ * @param allowFallback - If true, and no physical tablet is found, the component will connect in mouse fallback mode.
2696
+ * @returns True if successfully connected (to physical device or allowed fallback), false otherwise.
2693
2697
  */
2694
- async connectTablet(D = !1) {
2698
+ async connectTablet(i = !1, A = !1) {
2699
+ this._isConnecting = !0, this._loadingState(!0, "Connecting to your device...");
2695
2700
  try {
2696
2701
  if (await this.prepareSignatureLayer(), !this.sigLayer || !this.canvasPainter)
2697
2702
  return console.error(
2698
- "sigLayer or CanvasPainter is not initialized after prepareSignatureLayer."
2703
+ "signosoft-signpad: Signature layer or CanvasPainter not initialized during connection."
2699
2704
  ), this.dispatch(
2700
2705
  "sign-error",
2701
2706
  new Error(
2702
2707
  "Signature layer or CanvasPainter not initialized during connection."
2703
2708
  )
2704
- ), !1;
2705
- const A = await fetch(this.licenseServerUrl, {
2709
+ ), this._setDisconnectedState(), !1;
2710
+ const C = await fetch(this.licenseServerUrl, {
2706
2711
  method: "POST",
2707
2712
  headers: { "Content-Type": "application/json" },
2708
2713
  body: JSON.stringify({
@@ -2711,26 +2716,20 @@ let G = class extends Qg {
2711
2716
  port: 4204
2712
2717
  })
2713
2718
  });
2714
- if (!A.ok) {
2715
- const i = await A.text();
2719
+ if (!C.ok) {
2720
+ const h = await C.text();
2716
2721
  throw new Error(
2717
- `License server did not respond: ${A.statusText} - ${i}`
2722
+ `License server did not respond: ${C.statusText} - ${h}`
2718
2723
  );
2719
2724
  }
2720
- const C = await A.json();
2721
- await this.sigLayer.initialize(C);
2722
- const B = await this.sigLayer.connect(D);
2723
- if (B) {
2724
- this.canvasPainter.clear(), this.mouseInputHandler?.resetSession(), this._hasStartedDrawing = !1;
2725
- const i = this.sigLayer.getDeviceInfo();
2726
- i?.name === "Pointer Input (Fallback Mode)" ? this._deviceStateText = "Mouse Event" : this._deviceStateText = i ? i.name : "Connected (Unknown Device)", this._isConnected = !0;
2727
- let U;
2728
- i && i.name.includes("Pointer Input (Fallback Mode)") ? (U = this.canvasRef, this.mouseInputHandler?.addListeners()) : (this.offscreenDrawingCanvas || (this.offscreenDrawingCanvas = document.createElement("canvas"), this.offscreenDrawingCanvas.width = 10, this.offscreenDrawingCanvas.height = 10), U = this.offscreenDrawingCanvas, this.mouseInputHandler?.removeListeners()), await this.sigLayer.startSigning(U);
2729
- } else
2730
- this._deviceStateText = "Connection Failed", this._isConnected = !1, this._hasStartedDrawing = !1;
2731
- return B;
2732
- } catch (A) {
2733
- return console.error("ERROR IN CONNECT_TABLET:", A), this.dispatch("sign-error", A), this._deviceStateText = `Connection Error: ${A instanceof Error ? A.message : String(A)}`, this._isConnected = !1, this._hasStartedDrawing = !1, !1;
2725
+ const B = await C.json();
2726
+ await this.sigLayer.initialize(B);
2727
+ const D = await this.sigLayer.connect(i), U = this.sigLayer.getDeviceInfo(), w = U?.name === "Pointer Input (Fallback Mode)";
2728
+ return D && !w ? (this._resetDrawingState(), this._deviceStateText = U ? U.name : "Connected (Unknown Device)", this._isConnected = !0, this._isConnecting = !1, this.offscreenDrawingCanvas || (this.offscreenDrawingCanvas = document.createElement("canvas"), this.offscreenDrawingCanvas.width = 10, this.offscreenDrawingCanvas.height = 10), await this.sigLayer.startSigning(this.offscreenDrawingCanvas), this.mouseInputHandler?.removeListeners(), !0) : w && A ? (this._resetDrawingState(), this._deviceStateText = "Mouse Event", this._isConnected = !0, this._isConnecting = !1, await this.sigLayer.startSigning(this.canvasRef), this.mouseInputHandler?.addListeners(), !0) : (this._setDisconnectedState(), !1);
2729
+ } catch (C) {
2730
+ return console.error("signosoft-signpad: Error in connectTablet method:", C), this.dispatch("sign-error", C), this._setDisconnectedState(), !1;
2731
+ } finally {
2732
+ this._loadingState(!1, "");
2734
2733
  }
2735
2734
  }
2736
2735
  /**
@@ -2739,17 +2738,20 @@ let G = class extends Qg {
2739
2738
  * @returns A promise that resolves when the tablet is disconnected.
2740
2739
  */
2741
2740
  async disconnectTablet() {
2742
- if (!this.sigLayer) {
2743
- console.warn("Signature layer is not initialized, cannot disconnect."), this._deviceStateText = "Disconnected", this._isConnected = !1, this._hasStartedDrawing = !1, this.mouseInputHandler?.removeListeners(), this.mouseInputHandler?.resetSession(), this.canvasPainter?.clear(), this.dispatch("sign-disconnect");
2744
- return;
2745
- }
2746
- try {
2747
- this._isDisconnectingIntentionally = !0, await this.sigLayer.disconnect(), this.mouseInputHandler?.removeListeners(), this.mouseInputHandler?.resetSession(), this.canvasPainter?.clear(), this._deviceStateText = "Disconnected", this._isConnected = !1, this._hasStartedDrawing = !1, this.dispatch("sign-disconnect");
2748
- } catch (D) {
2749
- console.error("ERROR IN DISCONNECT_TABLET:", D), this.dispatch("sign-error", D), this._deviceStateText = `Disconnect Error: ${D instanceof Error ? D.message : String(D)}`, this._isConnected = !1, this._hasStartedDrawing = !1;
2750
- } finally {
2751
- this._isDisconnectingIntentionally = !1, this.sigLayer = null;
2752
- }
2741
+ if (this._loadingState(!0, "Disconnecting device..."), this.sigLayer)
2742
+ try {
2743
+ this._isDisconnectingIntentionally = !0, await this.sigLayer.disconnect();
2744
+ } catch (i) {
2745
+ console.error(
2746
+ "ERROR IN DISCONNECT_TABLET during sigLayer.disconnect:",
2747
+ i
2748
+ ), this.dispatch("sign-error", i);
2749
+ } finally {
2750
+ this._isDisconnectingIntentionally = !1, this._setDisconnectedState(), this.dispatch("sign-disconnect");
2751
+ }
2752
+ else
2753
+ this._setDisconnectedState(), this.dispatch("sign-disconnect");
2754
+ this._loadingState(!1, "");
2753
2755
  }
2754
2756
  /**
2755
2757
  * Clears the current signature from both the tablet's screen and the component's canvas.
@@ -2758,7 +2760,14 @@ let G = class extends Qg {
2758
2760
  * This method can be invoked externally or internally (e.g., from a "Clear" button).
2759
2761
  */
2760
2762
  async clear() {
2761
- await this.sigLayer?.clearSignature(), this.canvasPainter?.clear(), this.mouseInputHandler?.resetSession(), this._hasStartedDrawing = !1, this.ClearButton && await this.ClearButton(), this.dispatch("sign-clear");
2763
+ this._loadingState(!0, "Clearing signature...");
2764
+ try {
2765
+ await this.sigLayer?.clearSignature(), this._resetDrawingState(), this.ClearButton && await this.ClearButton(), this.dispatch("sign-clear");
2766
+ } catch (i) {
2767
+ console.error("ERROR IN CLEAR:", i), this.dispatch("sign-error", i);
2768
+ } finally {
2769
+ this._loadingState(!1, "");
2770
+ }
2762
2771
  }
2763
2772
  /**
2764
2773
  * Handles the 'OK' action, typically stopping the signing process and preparing the signature for submission.
@@ -2767,7 +2776,15 @@ let G = class extends Qg {
2767
2776
  * This method can be invoked externally or internally (e.g., from an "OK" button).
2768
2777
  */
2769
2778
  async ok() {
2770
- await this.sigLayer?.stopSigning(), this.mouseInputHandler?.removeListeners(), this.mouseInputHandler?.resetSession(), this._deviceStateText = "Disconnected", this._isConnected = !1, this._hasStartedDrawing = !1, this.OkButton && await this.OkButton(), this.dispatch("sign-ok"), this.sigLayer = null;
2779
+ this._loadingState(!0, "Processing signature...");
2780
+ let i = null;
2781
+ try {
2782
+ this.sigLayer && (await this.sigLayer.stopSigning(), await this.sigLayer.clearSignature()), i = this.getSignatureImageBase64("image/png"), await this.disconnectTablet(), this.OkButton && await this.OkButton(), this.dispatch("sign-ok", { imageData: i });
2783
+ } catch (A) {
2784
+ console.error("ERROR IN OK:", A), this.dispatch("sign-error", A), this._setDisconnectedState();
2785
+ } finally {
2786
+ this._loadingState(!1, "");
2787
+ }
2771
2788
  }
2772
2789
  /**
2773
2790
  * Handles the 'Cancel' action, which typically clears any drawn signature and stops the signing process.
@@ -2776,13 +2793,60 @@ let G = class extends Qg {
2776
2793
  * This method can be invoked externally or internally (e.g., from a "Cancel" button).
2777
2794
  */
2778
2795
  async cancel() {
2779
- await this.sigLayer?.clearSignature(), this.canvasPainter?.clear(), this.mouseInputHandler?.removeListeners(), this.mouseInputHandler?.resetSession(), this._deviceStateText = "Disconnected", this._isConnected = !1, this._hasStartedDrawing = !1, this.CancelButton && await this.CancelButton(), this.dispatch("sign-cancel"), this.sigLayer = null;
2796
+ this._loadingState(!0, "Cancelling signature...");
2797
+ try {
2798
+ this.sigLayer && (await this.sigLayer.stopSigning(), await this.sigLayer.clearSignature()), await this.disconnectTablet(), this.CancelButton && await this.CancelButton(), this.dispatch("sign-cancel");
2799
+ } catch (i) {
2800
+ console.error("ERROR IN CANCEL:", i), this.dispatch("sign-error", i), this._setDisconnectedState();
2801
+ } finally {
2802
+ this._loadingState(!1, "");
2803
+ }
2804
+ }
2805
+ /**
2806
+ * Helper method to set loading state and message.
2807
+ * @param isLoading - Whether the component is in a loading state.
2808
+ * @param message - The loading message to display.
2809
+ */
2810
+ _loadingState(i, A) {
2811
+ this._isLoadingConnection = i, this._loadingMessage = A;
2812
+ }
2813
+ /**
2814
+ * Helper method to reset the component to a disconnected, idle state.
2815
+ * Clears all connection, drawing, and loading-related states, and performs UI cleanup.
2816
+ */
2817
+ _setDisconnectedState() {
2818
+ this._deviceStateText = "Not connected", this._isConnected = !1, this._hasStartedDrawing = !1, this._isConnecting = !1, this._isDisconnectingIntentionally = !1, this._isLoadingConnection = !1, this._loadingMessage = "", this.mouseInputHandler?.removeListeners(), this.mouseInputHandler?.resetSession(), this.canvasPainter?.clear(), this.sigLayer = null;
2819
+ }
2820
+ /**
2821
+ * Helper method to clear the current drawing and reset drawing-related flags,
2822
+ * without affecting the connection status.
2823
+ */
2824
+ _resetDrawingState() {
2825
+ this.canvasPainter?.clear(), this.mouseInputHandler?.resetSession(), this._hasStartedDrawing = !1;
2826
+ }
2827
+ /**
2828
+ * Retrieves the current signature drawn on the canvas as a Base64 encoded image string.
2829
+ * @param format The image format, e.g., 'image/png' (default), 'image/jpeg', 'image/webp'.
2830
+ * @param quality For 'image/jpeg' or 'image/webp', a number between 0 and 1 indicating image quality.
2831
+ * @returns A Base64 string of the signature image, or null if the canvas is not available or empty.
2832
+ */
2833
+ getSignatureImageBase64(i = "image/png", A) {
2834
+ if (!this.canvasRef || !this._hasStartedDrawing)
2835
+ return console.warn("No signature drawn or canvas not available."), null;
2836
+ try {
2837
+ return i === "image/jpeg" || i === "image/webp" ? this.canvasRef.toDataURL(i, A) : this.canvasRef.toDataURL(i);
2838
+ } catch (C) {
2839
+ return console.error("Error generating signature image Base64:", C), this.dispatch(
2840
+ "sign-error",
2841
+ new Error("Failed to get signature image Base64.")
2842
+ ), null;
2843
+ }
2780
2844
  }
2781
2845
  /**
2782
2846
  * Renders the component's HTML template.
2783
2847
  */
2784
2848
  render() {
2785
- const D = this.customDeviceStateText !== null && this.customDeviceStateText.trim() !== "" ? this.customDeviceStateText : this._deviceStateText, A = this.canvasAdditionalText !== null && this.canvasAdditionalText.trim() !== "" ? this.canvasAdditionalText : this._isConnected ? `Sign with ${this._deviceStateText}` : "Connect your device to start signing", C = this._isConnected ? "connected" : "", B = !this._isConnected || !this._hasStartedDrawing;
2849
+ const i = this.customDeviceStateText !== null && this.customDeviceStateText.trim() !== "" ? this.customDeviceStateText : this._deviceStateText, A = this.canvasAdditionalText !== null && this.canvasAdditionalText.trim() !== "" ? this.canvasAdditionalText : this._isConnected ? "Sign with your device" : "Connect your device to start signing", C = this._isConnected ? "connected" : "", B = !this._isConnected || !this._hasStartedDrawing || this._isLoadingConnection;
2786
2850
  return t`
2787
2851
  <div class="signpad-canvas-container">
2788
2852
  ${this.topBarVisible ? t`
@@ -2803,13 +2867,33 @@ let G = class extends Qg {
2803
2867
  <button
2804
2868
  class="btn btn-link disconnect-button"
2805
2869
  @click=${this.disconnectTablet}
2870
+ ?disabled=${this._isLoadingConnection}
2806
2871
  >
2807
2872
  Disconnect
2808
2873
  </button>
2809
2874
  ` : t`
2810
2875
  <button
2811
2876
  class="btn btn-link connect-button"
2812
- @click=${() => this.connectTablet(!0)}
2877
+ ?disabled=${this._isConnecting || this._isLoadingConnection}
2878
+ @click=${async () => {
2879
+ this._isConnecting = !0, this._loadingState(
2880
+ !0,
2881
+ "Connecting to your device..."
2882
+ );
2883
+ try {
2884
+ await this.connectTablet(!0, !1) || (this._isConnecting = !1, this._loadingState(
2885
+ !0,
2886
+ "Waiting for device selection..."
2887
+ ), await this.connectTablet(!1, !0));
2888
+ } catch (D) {
2889
+ console.error(
2890
+ "signosoft-signpad: Error during 'Connect' button action:",
2891
+ D
2892
+ ), this.dispatch("sign-error", D), this._setDisconnectedState();
2893
+ } finally {
2894
+ this._isConnecting = !1, this._loadingState(!1, "");
2895
+ }
2896
+ }}
2813
2897
  >
2814
2898
  Connect
2815
2899
  </button>
@@ -2818,14 +2902,14 @@ let G = class extends Qg {
2818
2902
  </div>
2819
2903
  ` : ""}
2820
2904
 
2821
- <div class="signpad-canvas-wrapper">
2905
+ <div class="signpad-canvas-wrapper" style="position: relative;">
2822
2906
  <canvas class="signpad-canvas"></canvas>
2823
2907
  ${this.canvasLineVisible ? t`<div class="signpad-canvas-line-container">
2824
2908
  <div class="signpad-canvas-line-left">
2825
2909
  ${this.deviceStateTextVisible ? t`<p
2826
2910
  class="signpad-canvas-line-state ${C}"
2827
2911
  >
2828
- ${D}
2912
+ ${i}
2829
2913
  </p>` : t``}
2830
2914
  </div>
2831
2915
  <div class="signpad-canvas-line-right">
@@ -2834,6 +2918,12 @@ let G = class extends Qg {
2834
2918
  </p>
2835
2919
  </div>
2836
2920
  </div>` : t``}
2921
+ ${this._isLoadingConnection ? t`
2922
+ <div class="signpad-loading-overlay">
2923
+ <div class="spinner"></div>
2924
+ <p>${this._loadingMessage}</p>
2925
+ </div>
2926
+ ` : ""}
2837
2927
  </div>
2838
2928
 
2839
2929
  ${this.bottomBarVisible ? t`
@@ -2871,76 +2961,85 @@ let G = class extends Qg {
2871
2961
  `;
2872
2962
  }
2873
2963
  };
2874
- G.styles = [Bg(Ug)];
2875
- a([
2964
+ M.styles = [Bg(Ug)];
2965
+ G([
2876
2966
  l({ type: String })
2877
- ], G.prototype, "licenseKey", 2);
2878
- a([
2967
+ ], M.prototype, "licenseKey", 2);
2968
+ G([
2879
2969
  l({ type: String })
2880
- ], G.prototype, "canvasAdditionalText", 2);
2881
- a([
2970
+ ], M.prototype, "canvasAdditionalText", 2);
2971
+ G([
2882
2972
  l({ type: Boolean })
2883
- ], G.prototype, "topBarVisible", 2);
2884
- a([
2973
+ ], M.prototype, "topBarVisible", 2);
2974
+ G([
2885
2975
  l({ type: Boolean })
2886
- ], G.prototype, "bottomBarVisible", 2);
2887
- a([
2976
+ ], M.prototype, "bottomBarVisible", 2);
2977
+ G([
2888
2978
  l({ type: Boolean })
2889
- ], G.prototype, "okButtonVisible", 2);
2890
- a([
2979
+ ], M.prototype, "okButtonVisible", 2);
2980
+ G([
2891
2981
  l({ type: Boolean })
2892
- ], G.prototype, "clearButtonVisible", 2);
2893
- a([
2982
+ ], M.prototype, "clearButtonVisible", 2);
2983
+ G([
2894
2984
  l({ type: Boolean })
2895
- ], G.prototype, "cancelButtonVisible", 2);
2896
- a([
2985
+ ], M.prototype, "cancelButtonVisible", 2);
2986
+ G([
2897
2987
  l({ type: Boolean })
2898
- ], G.prototype, "canvasLineVisible", 2);
2899
- a([
2988
+ ], M.prototype, "canvasLineVisible", 2);
2989
+ G([
2900
2990
  l({ type: Boolean })
2901
- ], G.prototype, "deviceStateTextVisible", 2);
2902
- a([
2991
+ ], M.prototype, "deviceStateTextVisible", 2);
2992
+ G([
2903
2993
  l({ type: String })
2904
- ], G.prototype, "customDeviceStateText", 2);
2905
- a([
2994
+ ], M.prototype, "customDeviceStateText", 2);
2995
+ G([
2906
2996
  l({ type: Number })
2907
- ], G.prototype, "minThickness", 2);
2908
- a([
2997
+ ], M.prototype, "minThickness", 2);
2998
+ G([
2909
2999
  l({ type: Number })
2910
- ], G.prototype, "maxThickness", 2);
2911
- a([
3000
+ ], M.prototype, "maxThickness", 2);
3001
+ G([
2912
3002
  l({ type: String })
2913
- ], G.prototype, "penColor", 2);
2914
- a([
3003
+ ], M.prototype, "penColor", 2);
3004
+ G([
2915
3005
  l({ type: Function })
2916
- ], G.prototype, "OkButton", 2);
2917
- a([
3006
+ ], M.prototype, "OkButton", 2);
3007
+ G([
2918
3008
  l({ type: Function })
2919
- ], G.prototype, "ClearButton", 2);
2920
- a([
3009
+ ], M.prototype, "ClearButton", 2);
3010
+ G([
2921
3011
  l({ type: Function })
2922
- ], G.prototype, "CancelButton", 2);
2923
- a([
3012
+ ], M.prototype, "CancelButton", 2);
3013
+ G([
2924
3014
  l({ type: Object })
2925
- ], G.prototype, "customCssVariables", 2);
2926
- a([
3015
+ ], M.prototype, "customCssVariables", 2);
3016
+ G([
2927
3017
  Eg("canvas")
2928
- ], G.prototype, "canvasRef", 2);
2929
- a([
2930
- cA()
2931
- ], G.prototype, "_deviceStateText", 2);
2932
- a([
2933
- cA()
2934
- ], G.prototype, "_isConnected", 2);
2935
- a([
2936
- cA()
2937
- ], G.prototype, "_hasStartedDrawing", 2);
2938
- a([
2939
- cA()
2940
- ], G.prototype, "_isDisconnectingIntentionally", 2);
2941
- G = a([
3018
+ ], M.prototype, "canvasRef", 2);
3019
+ G([
3020
+ v()
3021
+ ], M.prototype, "_deviceStateText", 2);
3022
+ G([
3023
+ v()
3024
+ ], M.prototype, "_isConnected", 2);
3025
+ G([
3026
+ v()
3027
+ ], M.prototype, "_hasStartedDrawing", 2);
3028
+ G([
3029
+ v()
3030
+ ], M.prototype, "_isDisconnectingIntentionally", 2);
3031
+ G([
3032
+ v()
3033
+ ], M.prototype, "_isConnecting", 2);
3034
+ G([
3035
+ v()
3036
+ ], M.prototype, "_isLoadingConnection", 2);
3037
+ G([
3038
+ v()
3039
+ ], M.prototype, "_loadingMessage", 2);
3040
+ M = G([
2942
3041
  ig("signosoft-signpad")
2943
- ], G);
3042
+ ], M);
2944
3043
  export {
2945
- G as SignosoftSignpad
3044
+ M as SignosoftSignpad
2946
3045
  };