diff --git "a/src/backend/gradio_pdf/templates/component/Index-f4230f0b.js" "b/src/backend/gradio_pdf/templates/component/Index-f4230f0b.js"
new file mode 100644--- /dev/null
+++ "b/src/backend/gradio_pdf/templates/component/Index-f4230f0b.js"
@@ -0,0 +1,19923 @@
+var ni = Object.defineProperty;
+var ii = (t, e, i) => e in t ? ni(t, e, { enumerable: !0, configurable: !0, writable: !0, value: i }) : t[e] = i;
+var nt = (t, e, i) => (ii(t, typeof e != "symbol" ? e + "" : e, i), i), $t = (t, e, i) => {
+  if (!e.has(t))
+    throw TypeError("Cannot " + i);
+};
+var a = (t, e, i) => ($t(t, e, "read from private field"), i ? i.call(t) : e.get(t)), W = (t, e, i) => {
+  if (e.has(t))
+    throw TypeError("Cannot add the same private member more than once");
+  e instanceof WeakSet ? e.add(t) : e.set(t, i);
+}, oe = (t, e, i, n) => ($t(t, e, "write to private field"), n ? n.call(t, i) : e.set(t, i), i);
+var _t = (t, e, i, n) => ({
+  set _(s) {
+    oe(t, e, s, i);
+  },
+  get _() {
+    return a(t, e, n);
+  }
+}), K = (t, e, i) => ($t(t, e, "access private method"), i);
+const {
+  SvelteComponent: SvelteComponent$e,
+  append: append$d,
+  attr: attr$d,
+  detach: detach$e,
+  init: init$e,
+  insert: insert$e,
+  noop: noop$7,
+  safe_not_equal: safe_not_equal$f,
+  set_style: set_style$6,
+  svg_element: svg_element$5
+} = window.__gradio__svelte__internal;
+function create_fragment$e(t) {
+  let e, i, n, s;
+  return {
+    c() {
+      e = svg_element$5("svg"), i = svg_element$5("g"), n = svg_element$5("path"), s = svg_element$5("path"), attr$d(n, "d", "M18,6L6.087,17.913"), set_style$6(n, "fill", "none"), set_style$6(n, "fill-rule", "nonzero"), set_style$6(n, "stroke-width", "2px"), attr$d(i, "transform", "matrix(1.14096,-0.140958,-0.140958,1.14096,-0.0559523,0.0559523)"), attr$d(s, "d", "M4.364,4.364L19.636,19.636"), set_style$6(s, "fill", "none"), set_style$6(s, "fill-rule", "nonzero"), set_style$6(s, "stroke-width", "2px"), attr$d(e, "width", "100%"), attr$d(e, "height", "100%"), attr$d(e, "viewBox", "0 0 24 24"), attr$d(e, "version", "1.1"), attr$d(e, "xmlns", "http://www.w3.org/2000/svg"), attr$d(e, "xmlns:xlink", "http://www.w3.org/1999/xlink"), attr$d(e, "xml:space", "preserve"), attr$d(e, "stroke", "currentColor"), set_style$6(e, "fill-rule", "evenodd"), set_style$6(e, "clip-rule", "evenodd"), set_style$6(e, "stroke-linecap", "round"), set_style$6(e, "stroke-linejoin", "round");
+    },
+    m(l, h) {
+      insert$e(l, e, h), append$d(e, i), append$d(i, n), append$d(e, s);
+    },
+    p: noop$7,
+    i: noop$7,
+    o: noop$7,
+    d(l) {
+      l && detach$e(e);
+    }
+  };
+}
+class Clear extends SvelteComponent$e {
+  constructor(e) {
+    super(), init$e(this, e, null, create_fragment$e, safe_not_equal$f, {});
+  }
+}
+const DropdownArrow_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$d,
+  append: append$c,
+  attr: attr$c,
+  detach: detach$d,
+  init: init$d,
+  insert: insert$d,
+  noop: noop$6,
+  safe_not_equal: safe_not_equal$e,
+  svg_element: svg_element$4
+} = window.__gradio__svelte__internal;
+function create_fragment$d(t) {
+  let e, i;
+  return {
+    c() {
+      e = svg_element$4("svg"), i = svg_element$4("path"), attr$c(i, "d", "M17 3a2.828 2.828 0 1 1 4 4L7.5 20.5 2 22l1.5-5.5L17 3z"), attr$c(e, "xmlns", "http://www.w3.org/2000/svg"), attr$c(e, "width", "100%"), attr$c(e, "height", "100%"), attr$c(e, "viewBox", "0 0 24 24"), attr$c(e, "fill", "none"), attr$c(e, "stroke", "currentColor"), attr$c(e, "stroke-width", "1.5"), attr$c(e, "stroke-linecap", "round"), attr$c(e, "stroke-linejoin", "round"), attr$c(e, "class", "feather feather-edit-2");
+    },
+    m(n, s) {
+      insert$d(n, e, s), append$c(e, i);
+    },
+    p: noop$6,
+    i: noop$6,
+    o: noop$6,
+    d(n) {
+      n && detach$d(e);
+    }
+  };
+}
+class Edit extends SvelteComponent$d {
+  constructor(e) {
+    super(), init$d(this, e, null, create_fragment$d, safe_not_equal$e, {});
+  }
+}
+const {
+  SvelteComponent: SvelteComponent$c,
+  append: append$b,
+  attr: attr$b,
+  detach: detach$c,
+  init: init$c,
+  insert: insert$c,
+  noop: noop$5,
+  safe_not_equal: safe_not_equal$d,
+  svg_element: svg_element$3
+} = window.__gradio__svelte__internal;
+function create_fragment$c(t) {
+  let e, i, n;
+  return {
+    c() {
+      e = svg_element$3("svg"), i = svg_element$3("path"), n = svg_element$3("polyline"), attr$b(i, "d", "M13 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9z"), attr$b(n, "points", "13 2 13 9 20 9"), attr$b(e, "xmlns", "http://www.w3.org/2000/svg"), attr$b(e, "width", "100%"), attr$b(e, "height", "100%"), attr$b(e, "viewBox", "0 0 24 24"), attr$b(e, "fill", "none"), attr$b(e, "stroke", "currentColor"), attr$b(e, "stroke-width", "1.5"), attr$b(e, "stroke-linecap", "round"), attr$b(e, "stroke-linejoin", "round"), attr$b(e, "class", "feather feather-file");
+    },
+    m(s, l) {
+      insert$c(s, e, l), append$b(e, i), append$b(e, n);
+    },
+    p: noop$5,
+    i: noop$5,
+    o: noop$5,
+    d(s) {
+      s && detach$c(e);
+    }
+  };
+}
+let File$1 = class extends SvelteComponent$c {
+  constructor(e) {
+    super(), init$c(this, e, null, create_fragment$c, safe_not_equal$d, {});
+  }
+};
+const {
+  SvelteComponent: SvelteComponent$b,
+  append: append$a,
+  attr: attr$a,
+  detach: detach$b,
+  init: init$b,
+  insert: insert$b,
+  noop: noop$4,
+  safe_not_equal: safe_not_equal$c,
+  svg_element: svg_element$2
+} = window.__gradio__svelte__internal;
+function create_fragment$b(t) {
+  let e, i, n;
+  return {
+    c() {
+      e = svg_element$2("svg"), i = svg_element$2("polyline"), n = svg_element$2("path"), attr$a(i, "points", "1 4 1 10 7 10"), attr$a(n, "d", "M3.51 15a9 9 0 1 0 2.13-9.36L1 10"), attr$a(e, "xmlns", "http://www.w3.org/2000/svg"), attr$a(e, "width", "100%"), attr$a(e, "height", "100%"), attr$a(e, "viewBox", "0 0 24 24"), attr$a(e, "fill", "none"), attr$a(e, "stroke", "currentColor"), attr$a(e, "stroke-width", "2"), attr$a(e, "stroke-linecap", "round"), attr$a(e, "stroke-linejoin", "round"), attr$a(e, "class", "feather feather-rotate-ccw");
+    },
+    m(s, l) {
+      insert$b(s, e, l), append$a(e, i), append$a(e, n);
+    },
+    p: noop$4,
+    i: noop$4,
+    o: noop$4,
+    d(s) {
+      s && detach$b(e);
+    }
+  };
+}
+class Undo extends SvelteComponent$b {
+  constructor(e) {
+    super(), init$b(this, e, null, create_fragment$b, safe_not_equal$c, {});
+  }
+}
+const {
+  SvelteComponent: SvelteComponent$a,
+  append: append$9,
+  attr: attr$9,
+  detach: detach$a,
+  init: init$a,
+  insert: insert$a,
+  noop: noop$3,
+  safe_not_equal: safe_not_equal$b,
+  svg_element: svg_element$1
+} = window.__gradio__svelte__internal;
+function create_fragment$a(t) {
+  let e, i, n, s;
+  return {
+    c() {
+      e = svg_element$1("svg"), i = svg_element$1("path"), n = svg_element$1("polyline"), s = svg_element$1("line"), attr$9(i, "d", "M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"), attr$9(n, "points", "17 8 12 3 7 8"), attr$9(s, "x1", "12"), attr$9(s, "y1", "3"), attr$9(s, "x2", "12"), attr$9(s, "y2", "15"), attr$9(e, "xmlns", "http://www.w3.org/2000/svg"), attr$9(e, "width", "90%"), attr$9(e, "height", "90%"), attr$9(e, "viewBox", "0 0 24 24"), attr$9(e, "fill", "none"), attr$9(e, "stroke", "currentColor"), attr$9(e, "stroke-width", "2"), attr$9(e, "stroke-linecap", "round"), attr$9(e, "stroke-linejoin", "round"), attr$9(e, "class", "feather feather-upload");
+    },
+    m(l, h) {
+      insert$a(l, e, h), append$9(e, i), append$9(e, n), append$9(e, s);
+    },
+    p: noop$3,
+    i: noop$3,
+    o: noop$3,
+    d(l) {
+      l && detach$a(e);
+    }
+  };
+}
+let Upload$1 = class extends SvelteComponent$a {
+  constructor(e) {
+    super(), init$a(this, e, null, create_fragment$a, safe_not_equal$b, {});
+  }
+};
+const PdfUploadText_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$9,
+  append: append$8,
+  attr: attr$8,
+  create_component: create_component$5,
+  destroy_component: destroy_component$5,
+  detach: detach$9,
+  element: element$9,
+  init: init$9,
+  insert: insert$9,
+  mount_component: mount_component$5,
+  safe_not_equal: safe_not_equal$a,
+  text: text$4,
+  toggle_class: toggle_class$8,
+  transition_in: transition_in$8,
+  transition_out: transition_out$8
+} = window.__gradio__svelte__internal;
+function create_fragment$9(t) {
+  let e, i, n, s, l, h, _;
+  return n = new Upload$1({}), {
+    c() {
+      e = element$9("div"), i = element$9("span"), create_component$5(n.$$.fragment), s = text$4(`
+    Drop PDF
+    `), l = element$9("span"), l.textContent = "- or -", h = text$4(`
+    Click to Upload`), attr$8(i, "class", "icon-wrap svelte-kzcjhc"), toggle_class$8(
+        i,
+        "hovered",
+        /*hovered*/
+        t[0]
+      ), attr$8(l, "class", "or svelte-kzcjhc"), attr$8(e, "class", "wrap svelte-kzcjhc");
+    },
+    m(c, o) {
+      insert$9(c, e, o), append$8(e, i), mount_component$5(n, i, null), append$8(e, s), append$8(e, l), append$8(e, h), _ = !0;
+    },
+    p(c, [o]) {
+      (!_ || o & /*hovered*/
+      1) && toggle_class$8(
+        i,
+        "hovered",
+        /*hovered*/
+        c[0]
+      );
+    },
+    i(c) {
+      _ || (transition_in$8(n.$$.fragment, c), _ = !0);
+    },
+    o(c) {
+      transition_out$8(n.$$.fragment, c), _ = !1;
+    },
+    d(c) {
+      c && detach$9(e), destroy_component$5(n);
+    }
+  };
+}
+function instance$9(t, e, i) {
+  let { hovered: n = !1 } = e;
+  return t.$$set = (s) => {
+    "hovered" in s && i(0, n = s.hovered);
+  }, [n];
+}
+class PdfUploadText extends SvelteComponent$9 {
+  constructor(e) {
+    super(), init$9(this, e, instance$9, create_fragment$9, safe_not_equal$a, { hovered: 0 });
+  }
+}
+const Block_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$8,
+  assign: assign$1,
+  create_slot: create_slot$3,
+  detach: detach$8,
+  element: element$8,
+  get_all_dirty_from_scope: get_all_dirty_from_scope$3,
+  get_slot_changes: get_slot_changes$3,
+  get_spread_update: get_spread_update$1,
+  init: init$8,
+  insert: insert$8,
+  safe_not_equal: safe_not_equal$9,
+  set_dynamic_element_data,
+  set_style: set_style$5,
+  toggle_class: toggle_class$7,
+  transition_in: transition_in$7,
+  transition_out: transition_out$7,
+  update_slot_base: update_slot_base$3
+} = window.__gradio__svelte__internal;
+function create_dynamic_element(t) {
+  let e, i, n;
+  const s = (
+    /*#slots*/
+    t[17].default
+  ), l = create_slot$3(
+    s,
+    t,
+    /*$$scope*/
+    t[16],
+    null
+  );
+  let h = [
+    { "data-testid": (
+      /*test_id*/
+      t[7]
+    ) },
+    { id: (
+      /*elem_id*/
+      t[2]
+    ) },
+    {
+      class: i = "block " + /*elem_classes*/
+      t[3].join(" ") + " svelte-1t38q2d"
+    }
+  ], _ = {};
+  for (let c = 0; c < h.length; c += 1)
+    _ = assign$1(_, h[c]);
+  return {
+    c() {
+      e = element$8(
+        /*tag*/
+        t[14]
+      ), l && l.c(), set_dynamic_element_data(
+        /*tag*/
+        t[14]
+      )(e, _), toggle_class$7(
+        e,
+        "hidden",
+        /*visible*/
+        t[10] === !1
+      ), toggle_class$7(
+        e,
+        "padded",
+        /*padding*/
+        t[6]
+      ), toggle_class$7(
+        e,
+        "border_focus",
+        /*border_mode*/
+        t[5] === "focus"
+      ), toggle_class$7(e, "hide-container", !/*explicit_call*/
+      t[8] && !/*container*/
+      t[9]), set_style$5(e, "height", typeof /*height*/
+      t[0] == "number" ? (
+        /*height*/
+        t[0] + "px"
+      ) : void 0), set_style$5(e, "width", typeof /*width*/
+      t[1] == "number" ? `calc(min(${/*width*/
+      t[1]}px, 100%))` : void 0), set_style$5(
+        e,
+        "border-style",
+        /*variant*/
+        t[4]
+      ), set_style$5(
+        e,
+        "overflow",
+        /*allow_overflow*/
+        t[11] ? "visible" : "hidden"
+      ), set_style$5(
+        e,
+        "flex-grow",
+        /*scale*/
+        t[12]
+      ), set_style$5(e, "min-width", `calc(min(${/*min_width*/
+      t[13]}px, 100%))`), set_style$5(e, "border-width", "var(--block-border-width)");
+    },
+    m(c, o) {
+      insert$8(c, e, o), l && l.m(e, null), n = !0;
+    },
+    p(c, o) {
+      l && l.p && (!n || o & /*$$scope*/
+      65536) && update_slot_base$3(
+        l,
+        s,
+        c,
+        /*$$scope*/
+        c[16],
+        n ? get_slot_changes$3(
+          s,
+          /*$$scope*/
+          c[16],
+          o,
+          null
+        ) : get_all_dirty_from_scope$3(
+          /*$$scope*/
+          c[16]
+        ),
+        null
+      ), set_dynamic_element_data(
+        /*tag*/
+        c[14]
+      )(e, _ = get_spread_update$1(h, [
+        (!n || o & /*test_id*/
+        128) && { "data-testid": (
+          /*test_id*/
+          c[7]
+        ) },
+        (!n || o & /*elem_id*/
+        4) && { id: (
+          /*elem_id*/
+          c[2]
+        ) },
+        (!n || o & /*elem_classes*/
+        8 && i !== (i = "block " + /*elem_classes*/
+        c[3].join(" ") + " svelte-1t38q2d")) && { class: i }
+      ])), toggle_class$7(
+        e,
+        "hidden",
+        /*visible*/
+        c[10] === !1
+      ), toggle_class$7(
+        e,
+        "padded",
+        /*padding*/
+        c[6]
+      ), toggle_class$7(
+        e,
+        "border_focus",
+        /*border_mode*/
+        c[5] === "focus"
+      ), toggle_class$7(e, "hide-container", !/*explicit_call*/
+      c[8] && !/*container*/
+      c[9]), o & /*height*/
+      1 && set_style$5(e, "height", typeof /*height*/
+      c[0] == "number" ? (
+        /*height*/
+        c[0] + "px"
+      ) : void 0), o & /*width*/
+      2 && set_style$5(e, "width", typeof /*width*/
+      c[1] == "number" ? `calc(min(${/*width*/
+      c[1]}px, 100%))` : void 0), o & /*variant*/
+      16 && set_style$5(
+        e,
+        "border-style",
+        /*variant*/
+        c[4]
+      ), o & /*allow_overflow*/
+      2048 && set_style$5(
+        e,
+        "overflow",
+        /*allow_overflow*/
+        c[11] ? "visible" : "hidden"
+      ), o & /*scale*/
+      4096 && set_style$5(
+        e,
+        "flex-grow",
+        /*scale*/
+        c[12]
+      ), o & /*min_width*/
+      8192 && set_style$5(e, "min-width", `calc(min(${/*min_width*/
+      c[13]}px, 100%))`);
+    },
+    i(c) {
+      n || (transition_in$7(l, c), n = !0);
+    },
+    o(c) {
+      transition_out$7(l, c), n = !1;
+    },
+    d(c) {
+      c && detach$8(e), l && l.d(c);
+    }
+  };
+}
+function create_fragment$8(t) {
+  let e, i = (
+    /*tag*/
+    t[14] && create_dynamic_element(t)
+  );
+  return {
+    c() {
+      i && i.c();
+    },
+    m(n, s) {
+      i && i.m(n, s), e = !0;
+    },
+    p(n, [s]) {
+      /*tag*/
+      n[14] && i.p(n, s);
+    },
+    i(n) {
+      e || (transition_in$7(i, n), e = !0);
+    },
+    o(n) {
+      transition_out$7(i, n), e = !1;
+    },
+    d(n) {
+      i && i.d(n);
+    }
+  };
+}
+function instance$8(t, e, i) {
+  let { $$slots: n = {}, $$scope: s } = e, { height: l = void 0 } = e, { width: h = void 0 } = e, { elem_id: _ = "" } = e, { elem_classes: c = [] } = e, { variant: o = "solid" } = e, { border_mode: r = "base" } = e, { padding: T = !0 } = e, { type: S = "normal" } = e, { test_id: w = void 0 } = e, { explicit_call: C = !1 } = e, { container: P = !0 } = e, { visible: b = !0 } = e, { allow_overflow: k = !0 } = e, { scale: F = null } = e, { min_width: x = 0 } = e, y = S === "fieldset" ? "fieldset" : "div";
+  return t.$$set = (p) => {
+    "height" in p && i(0, l = p.height), "width" in p && i(1, h = p.width), "elem_id" in p && i(2, _ = p.elem_id), "elem_classes" in p && i(3, c = p.elem_classes), "variant" in p && i(4, o = p.variant), "border_mode" in p && i(5, r = p.border_mode), "padding" in p && i(6, T = p.padding), "type" in p && i(15, S = p.type), "test_id" in p && i(7, w = p.test_id), "explicit_call" in p && i(8, C = p.explicit_call), "container" in p && i(9, P = p.container), "visible" in p && i(10, b = p.visible), "allow_overflow" in p && i(11, k = p.allow_overflow), "scale" in p && i(12, F = p.scale), "min_width" in p && i(13, x = p.min_width), "$$scope" in p && i(16, s = p.$$scope);
+  }, [
+    l,
+    h,
+    _,
+    c,
+    o,
+    r,
+    T,
+    w,
+    C,
+    P,
+    b,
+    k,
+    F,
+    x,
+    y,
+    S,
+    s,
+    n
+  ];
+}
+class Block extends SvelteComponent$8 {
+  constructor(e) {
+    super(), init$8(this, e, instance$8, create_fragment$8, safe_not_equal$9, {
+      height: 0,
+      width: 1,
+      elem_id: 2,
+      elem_classes: 3,
+      variant: 4,
+      border_mode: 5,
+      padding: 6,
+      type: 15,
+      test_id: 7,
+      explicit_call: 8,
+      container: 9,
+      visible: 10,
+      allow_overflow: 11,
+      scale: 12,
+      min_width: 13
+    });
+  }
+}
+const Info_svelte_svelte_type_style_lang = "", BlockTitle_svelte_svelte_type_style_lang = "", BlockLabel_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$7,
+  append: append$7,
+  attr: attr$7,
+  create_component: create_component$4,
+  destroy_component: destroy_component$4,
+  detach: detach$7,
+  element: element$7,
+  init: init$7,
+  insert: insert$7,
+  mount_component: mount_component$4,
+  safe_not_equal: safe_not_equal$8,
+  set_data: set_data$3,
+  space: space$6,
+  text: text$3,
+  toggle_class: toggle_class$6,
+  transition_in: transition_in$6,
+  transition_out: transition_out$6
+} = window.__gradio__svelte__internal;
+function create_fragment$7(t) {
+  let e, i, n, s, l, h;
+  return n = new /*Icon*/
+  t[1]({}), {
+    c() {
+      e = element$7("label"), i = element$7("span"), create_component$4(n.$$.fragment), s = space$6(), l = text$3(
+        /*label*/
+        t[0]
+      ), attr$7(i, "class", "svelte-9gxdi0"), attr$7(e, "for", ""), attr$7(e, "data-testid", "block-label"), attr$7(e, "class", "svelte-9gxdi0"), toggle_class$6(e, "hide", !/*show_label*/
+      t[2]), toggle_class$6(e, "sr-only", !/*show_label*/
+      t[2]), toggle_class$6(
+        e,
+        "float",
+        /*float*/
+        t[4]
+      ), toggle_class$6(
+        e,
+        "hide-label",
+        /*disable*/
+        t[3]
+      );
+    },
+    m(_, c) {
+      insert$7(_, e, c), append$7(e, i), mount_component$4(n, i, null), append$7(e, s), append$7(e, l), h = !0;
+    },
+    p(_, [c]) {
+      (!h || c & /*label*/
+      1) && set_data$3(
+        l,
+        /*label*/
+        _[0]
+      ), (!h || c & /*show_label*/
+      4) && toggle_class$6(e, "hide", !/*show_label*/
+      _[2]), (!h || c & /*show_label*/
+      4) && toggle_class$6(e, "sr-only", !/*show_label*/
+      _[2]), (!h || c & /*float*/
+      16) && toggle_class$6(
+        e,
+        "float",
+        /*float*/
+        _[4]
+      ), (!h || c & /*disable*/
+      8) && toggle_class$6(
+        e,
+        "hide-label",
+        /*disable*/
+        _[3]
+      );
+    },
+    i(_) {
+      h || (transition_in$6(n.$$.fragment, _), h = !0);
+    },
+    o(_) {
+      transition_out$6(n.$$.fragment, _), h = !1;
+    },
+    d(_) {
+      _ && detach$7(e), destroy_component$4(n);
+    }
+  };
+}
+function instance$7(t, e, i) {
+  let { label: n = null } = e, { Icon: s } = e, { show_label: l = !0 } = e, { disable: h = !1 } = e, { float: _ = !0 } = e;
+  return t.$$set = (c) => {
+    "label" in c && i(0, n = c.label), "Icon" in c && i(1, s = c.Icon), "show_label" in c && i(2, l = c.show_label), "disable" in c && i(3, h = c.disable), "float" in c && i(4, _ = c.float);
+  }, [n, s, l, h, _];
+}
+class BlockLabel extends SvelteComponent$7 {
+  constructor(e) {
+    super(), init$7(this, e, instance$7, create_fragment$7, safe_not_equal$8, {
+      label: 0,
+      Icon: 1,
+      show_label: 2,
+      disable: 3,
+      float: 4
+    });
+  }
+}
+const IconButton_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$6,
+  append: append$6,
+  attr: attr$6,
+  bubble: bubble$2,
+  create_component: create_component$3,
+  destroy_component: destroy_component$3,
+  detach: detach$6,
+  element: element$6,
+  init: init$6,
+  insert: insert$6,
+  listen: listen$2,
+  mount_component: mount_component$3,
+  safe_not_equal: safe_not_equal$7,
+  set_data: set_data$2,
+  space: space$5,
+  text: text$2,
+  toggle_class: toggle_class$5,
+  transition_in: transition_in$5,
+  transition_out: transition_out$5
+} = window.__gradio__svelte__internal;
+function create_if_block$4(t) {
+  let e, i;
+  return {
+    c() {
+      e = element$6("span"), i = text$2(
+        /*label*/
+        t[1]
+      ), attr$6(e, "class", "svelte-xtz2g8");
+    },
+    m(n, s) {
+      insert$6(n, e, s), append$6(e, i);
+    },
+    p(n, s) {
+      s & /*label*/
+      2 && set_data$2(
+        i,
+        /*label*/
+        n[1]
+      );
+    },
+    d(n) {
+      n && detach$6(e);
+    }
+  };
+}
+function create_fragment$6(t) {
+  let e, i, n, s, l, h, _, c = (
+    /*show_label*/
+    t[2] && create_if_block$4(t)
+  );
+  return s = new /*Icon*/
+  t[0]({}), {
+    c() {
+      e = element$6("button"), c && c.c(), i = space$5(), n = element$6("div"), create_component$3(s.$$.fragment), attr$6(n, "class", "svelte-xtz2g8"), toggle_class$5(
+        n,
+        "small",
+        /*size*/
+        t[4] === "small"
+      ), toggle_class$5(
+        n,
+        "large",
+        /*size*/
+        t[4] === "large"
+      ), attr$6(
+        e,
+        "aria-label",
+        /*label*/
+        t[1]
+      ), attr$6(
+        e,
+        "title",
+        /*label*/
+        t[1]
+      ), attr$6(e, "class", "svelte-xtz2g8"), toggle_class$5(
+        e,
+        "pending",
+        /*pending*/
+        t[3]
+      ), toggle_class$5(
+        e,
+        "padded",
+        /*padded*/
+        t[5]
+      );
+    },
+    m(o, r) {
+      insert$6(o, e, r), c && c.m(e, null), append$6(e, i), append$6(e, n), mount_component$3(s, n, null), l = !0, h || (_ = listen$2(
+        e,
+        "click",
+        /*click_handler*/
+        t[6]
+      ), h = !0);
+    },
+    p(o, [r]) {
+      /*show_label*/
+      o[2] ? c ? c.p(o, r) : (c = create_if_block$4(o), c.c(), c.m(e, i)) : c && (c.d(1), c = null), (!l || r & /*size*/
+      16) && toggle_class$5(
+        n,
+        "small",
+        /*size*/
+        o[4] === "small"
+      ), (!l || r & /*size*/
+      16) && toggle_class$5(
+        n,
+        "large",
+        /*size*/
+        o[4] === "large"
+      ), (!l || r & /*label*/
+      2) && attr$6(
+        e,
+        "aria-label",
+        /*label*/
+        o[1]
+      ), (!l || r & /*label*/
+      2) && attr$6(
+        e,
+        "title",
+        /*label*/
+        o[1]
+      ), (!l || r & /*pending*/
+      8) && toggle_class$5(
+        e,
+        "pending",
+        /*pending*/
+        o[3]
+      ), (!l || r & /*padded*/
+      32) && toggle_class$5(
+        e,
+        "padded",
+        /*padded*/
+        o[5]
+      );
+    },
+    i(o) {
+      l || (transition_in$5(s.$$.fragment, o), l = !0);
+    },
+    o(o) {
+      transition_out$5(s.$$.fragment, o), l = !1;
+    },
+    d(o) {
+      o && detach$6(e), c && c.d(), destroy_component$3(s), h = !1, _();
+    }
+  };
+}
+function instance$6(t, e, i) {
+  let { Icon: n } = e, { label: s = "" } = e, { show_label: l = !1 } = e, { pending: h = !1 } = e, { size: _ = "small" } = e, { padded: c = !0 } = e;
+  function o(r) {
+    bubble$2.call(this, t, r);
+  }
+  return t.$$set = (r) => {
+    "Icon" in r && i(0, n = r.Icon), "label" in r && i(1, s = r.label), "show_label" in r && i(2, l = r.show_label), "pending" in r && i(3, h = r.pending), "size" in r && i(4, _ = r.size), "padded" in r && i(5, c = r.padded);
+  }, [n, s, l, h, _, c, o];
+}
+class IconButton extends SvelteComponent$6 {
+  constructor(e) {
+    super(), init$6(this, e, instance$6, create_fragment$6, safe_not_equal$7, {
+      Icon: 0,
+      label: 1,
+      show_label: 2,
+      pending: 3,
+      size: 4,
+      padded: 5
+    });
+  }
+}
+const Empty_svelte_svelte_type_style_lang = "", color_values = [
+  { color: "red", primary: 600, secondary: 100 },
+  { color: "green", primary: 600, secondary: 100 },
+  { color: "blue", primary: 600, secondary: 100 },
+  { color: "yellow", primary: 500, secondary: 100 },
+  { color: "purple", primary: 600, secondary: 100 },
+  { color: "teal", primary: 600, secondary: 100 },
+  { color: "orange", primary: 600, secondary: 100 },
+  { color: "cyan", primary: 600, secondary: 100 },
+  { color: "lime", primary: 500, secondary: 100 },
+  { color: "pink", primary: 600, secondary: 100 }
+], tw_colors = {
+  inherit: "inherit",
+  current: "currentColor",
+  transparent: "transparent",
+  black: "#000",
+  white: "#fff",
+  slate: {
+    50: "#f8fafc",
+    100: "#f1f5f9",
+    200: "#e2e8f0",
+    300: "#cbd5e1",
+    400: "#94a3b8",
+    500: "#64748b",
+    600: "#475569",
+    700: "#334155",
+    800: "#1e293b",
+    900: "#0f172a",
+    950: "#020617"
+  },
+  gray: {
+    50: "#f9fafb",
+    100: "#f3f4f6",
+    200: "#e5e7eb",
+    300: "#d1d5db",
+    400: "#9ca3af",
+    500: "#6b7280",
+    600: "#4b5563",
+    700: "#374151",
+    800: "#1f2937",
+    900: "#111827",
+    950: "#030712"
+  },
+  zinc: {
+    50: "#fafafa",
+    100: "#f4f4f5",
+    200: "#e4e4e7",
+    300: "#d4d4d8",
+    400: "#a1a1aa",
+    500: "#71717a",
+    600: "#52525b",
+    700: "#3f3f46",
+    800: "#27272a",
+    900: "#18181b",
+    950: "#09090b"
+  },
+  neutral: {
+    50: "#fafafa",
+    100: "#f5f5f5",
+    200: "#e5e5e5",
+    300: "#d4d4d4",
+    400: "#a3a3a3",
+    500: "#737373",
+    600: "#525252",
+    700: "#404040",
+    800: "#262626",
+    900: "#171717",
+    950: "#0a0a0a"
+  },
+  stone: {
+    50: "#fafaf9",
+    100: "#f5f5f4",
+    200: "#e7e5e4",
+    300: "#d6d3d1",
+    400: "#a8a29e",
+    500: "#78716c",
+    600: "#57534e",
+    700: "#44403c",
+    800: "#292524",
+    900: "#1c1917",
+    950: "#0c0a09"
+  },
+  red: {
+    50: "#fef2f2",
+    100: "#fee2e2",
+    200: "#fecaca",
+    300: "#fca5a5",
+    400: "#f87171",
+    500: "#ef4444",
+    600: "#dc2626",
+    700: "#b91c1c",
+    800: "#991b1b",
+    900: "#7f1d1d",
+    950: "#450a0a"
+  },
+  orange: {
+    50: "#fff7ed",
+    100: "#ffedd5",
+    200: "#fed7aa",
+    300: "#fdba74",
+    400: "#fb923c",
+    500: "#f97316",
+    600: "#ea580c",
+    700: "#c2410c",
+    800: "#9a3412",
+    900: "#7c2d12",
+    950: "#431407"
+  },
+  amber: {
+    50: "#fffbeb",
+    100: "#fef3c7",
+    200: "#fde68a",
+    300: "#fcd34d",
+    400: "#fbbf24",
+    500: "#f59e0b",
+    600: "#d97706",
+    700: "#b45309",
+    800: "#92400e",
+    900: "#78350f",
+    950: "#451a03"
+  },
+  yellow: {
+    50: "#fefce8",
+    100: "#fef9c3",
+    200: "#fef08a",
+    300: "#fde047",
+    400: "#facc15",
+    500: "#eab308",
+    600: "#ca8a04",
+    700: "#a16207",
+    800: "#854d0e",
+    900: "#713f12",
+    950: "#422006"
+  },
+  lime: {
+    50: "#f7fee7",
+    100: "#ecfccb",
+    200: "#d9f99d",
+    300: "#bef264",
+    400: "#a3e635",
+    500: "#84cc16",
+    600: "#65a30d",
+    700: "#4d7c0f",
+    800: "#3f6212",
+    900: "#365314",
+    950: "#1a2e05"
+  },
+  green: {
+    50: "#f0fdf4",
+    100: "#dcfce7",
+    200: "#bbf7d0",
+    300: "#86efac",
+    400: "#4ade80",
+    500: "#22c55e",
+    600: "#16a34a",
+    700: "#15803d",
+    800: "#166534",
+    900: "#14532d",
+    950: "#052e16"
+  },
+  emerald: {
+    50: "#ecfdf5",
+    100: "#d1fae5",
+    200: "#a7f3d0",
+    300: "#6ee7b7",
+    400: "#34d399",
+    500: "#10b981",
+    600: "#059669",
+    700: "#047857",
+    800: "#065f46",
+    900: "#064e3b",
+    950: "#022c22"
+  },
+  teal: {
+    50: "#f0fdfa",
+    100: "#ccfbf1",
+    200: "#99f6e4",
+    300: "#5eead4",
+    400: "#2dd4bf",
+    500: "#14b8a6",
+    600: "#0d9488",
+    700: "#0f766e",
+    800: "#115e59",
+    900: "#134e4a",
+    950: "#042f2e"
+  },
+  cyan: {
+    50: "#ecfeff",
+    100: "#cffafe",
+    200: "#a5f3fc",
+    300: "#67e8f9",
+    400: "#22d3ee",
+    500: "#06b6d4",
+    600: "#0891b2",
+    700: "#0e7490",
+    800: "#155e75",
+    900: "#164e63",
+    950: "#083344"
+  },
+  sky: {
+    50: "#f0f9ff",
+    100: "#e0f2fe",
+    200: "#bae6fd",
+    300: "#7dd3fc",
+    400: "#38bdf8",
+    500: "#0ea5e9",
+    600: "#0284c7",
+    700: "#0369a1",
+    800: "#075985",
+    900: "#0c4a6e",
+    950: "#082f49"
+  },
+  blue: {
+    50: "#eff6ff",
+    100: "#dbeafe",
+    200: "#bfdbfe",
+    300: "#93c5fd",
+    400: "#60a5fa",
+    500: "#3b82f6",
+    600: "#2563eb",
+    700: "#1d4ed8",
+    800: "#1e40af",
+    900: "#1e3a8a",
+    950: "#172554"
+  },
+  indigo: {
+    50: "#eef2ff",
+    100: "#e0e7ff",
+    200: "#c7d2fe",
+    300: "#a5b4fc",
+    400: "#818cf8",
+    500: "#6366f1",
+    600: "#4f46e5",
+    700: "#4338ca",
+    800: "#3730a3",
+    900: "#312e81",
+    950: "#1e1b4b"
+  },
+  violet: {
+    50: "#f5f3ff",
+    100: "#ede9fe",
+    200: "#ddd6fe",
+    300: "#c4b5fd",
+    400: "#a78bfa",
+    500: "#8b5cf6",
+    600: "#7c3aed",
+    700: "#6d28d9",
+    800: "#5b21b6",
+    900: "#4c1d95",
+    950: "#2e1065"
+  },
+  purple: {
+    50: "#faf5ff",
+    100: "#f3e8ff",
+    200: "#e9d5ff",
+    300: "#d8b4fe",
+    400: "#c084fc",
+    500: "#a855f7",
+    600: "#9333ea",
+    700: "#7e22ce",
+    800: "#6b21a8",
+    900: "#581c87",
+    950: "#3b0764"
+  },
+  fuchsia: {
+    50: "#fdf4ff",
+    100: "#fae8ff",
+    200: "#f5d0fe",
+    300: "#f0abfc",
+    400: "#e879f9",
+    500: "#d946ef",
+    600: "#c026d3",
+    700: "#a21caf",
+    800: "#86198f",
+    900: "#701a75",
+    950: "#4a044e"
+  },
+  pink: {
+    50: "#fdf2f8",
+    100: "#fce7f3",
+    200: "#fbcfe8",
+    300: "#f9a8d4",
+    400: "#f472b6",
+    500: "#ec4899",
+    600: "#db2777",
+    700: "#be185d",
+    800: "#9d174d",
+    900: "#831843",
+    950: "#500724"
+  },
+  rose: {
+    50: "#fff1f2",
+    100: "#ffe4e6",
+    200: "#fecdd3",
+    300: "#fda4af",
+    400: "#fb7185",
+    500: "#f43f5e",
+    600: "#e11d48",
+    700: "#be123c",
+    800: "#9f1239",
+    900: "#881337",
+    950: "#4c0519"
+  }
+};
+color_values.reduce(
+  (t, { color: e, primary: i, secondary: n }) => ({
+    ...t,
+    [e]: {
+      primary: tw_colors[e][i],
+      secondary: tw_colors[e][n]
+    }
+  }),
+  {}
+);
+const UploadText_svelte_svelte_type_style_lang = "", Toolbar_svelte_svelte_type_style_lang = "";
+new Intl.Collator(0, { numeric: 1 }).compare;
+function is_url$1(t) {
+  try {
+    const e = new URL(t);
+    return e.protocol === "http:" || e.protocol === "https:";
+  } catch {
+    return !1;
+  }
+}
+function get_fetchable_url_or_file$1(t, e, i) {
+  return t == null ? i ? `/proxy=${i}file=` : `${e}/file=` : is_url$1(t) ? t : i ? `/proxy=${i}file=${t}` : `${e}/file=${t}`;
+}
+const Button_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$5,
+  append: append$5,
+  attr: attr$5,
+  bubble: bubble$1,
+  check_outros: check_outros$3,
+  create_slot: create_slot$2,
+  detach: detach$5,
+  element: element$5,
+  empty: empty$2,
+  get_all_dirty_from_scope: get_all_dirty_from_scope$2,
+  get_slot_changes: get_slot_changes$2,
+  group_outros: group_outros$3,
+  init: init$5,
+  insert: insert$5,
+  listen: listen$1,
+  safe_not_equal: safe_not_equal$6,
+  set_style: set_style$4,
+  space: space$4,
+  src_url_equal,
+  toggle_class: toggle_class$4,
+  transition_in: transition_in$4,
+  transition_out: transition_out$4,
+  update_slot_base: update_slot_base$2
+} = window.__gradio__svelte__internal;
+function create_else_block$2(t) {
+  let e, i, n, s, l, h, _ = (
+    /*icon*/
+    t[7] && create_if_block_2$1(t)
+  );
+  const c = (
+    /*#slots*/
+    t[15].default
+  ), o = create_slot$2(
+    c,
+    t,
+    /*$$scope*/
+    t[14],
+    null
+  );
+  return {
+    c() {
+      e = element$5("button"), _ && _.c(), i = space$4(), o && o.c(), attr$5(e, "class", n = /*size*/
+      t[4] + " " + /*variant*/
+      t[3] + " " + /*elem_classes*/
+      t[1].join(" ") + " svelte-8huxfn"), attr$5(
+        e,
+        "id",
+        /*elem_id*/
+        t[0]
+      ), e.disabled = /*disabled*/
+      t[8], toggle_class$4(e, "hidden", !/*visible*/
+      t[2]), set_style$4(
+        e,
+        "flex-grow",
+        /*scale*/
+        t[9]
+      ), set_style$4(
+        e,
+        "width",
+        /*scale*/
+        t[9] === 0 ? "fit-content" : null
+      ), set_style$4(e, "min-width", typeof /*min_width*/
+      t[10] == "number" ? `calc(min(${/*min_width*/
+      t[10]}px, 100%))` : null);
+    },
+    m(r, T) {
+      insert$5(r, e, T), _ && _.m(e, null), append$5(e, i), o && o.m(e, null), s = !0, l || (h = listen$1(
+        e,
+        "click",
+        /*click_handler*/
+        t[16]
+      ), l = !0);
+    },
+    p(r, T) {
+      /*icon*/
+      r[7] ? _ ? _.p(r, T) : (_ = create_if_block_2$1(r), _.c(), _.m(e, i)) : _ && (_.d(1), _ = null), o && o.p && (!s || T & /*$$scope*/
+      16384) && update_slot_base$2(
+        o,
+        c,
+        r,
+        /*$$scope*/
+        r[14],
+        s ? get_slot_changes$2(
+          c,
+          /*$$scope*/
+          r[14],
+          T,
+          null
+        ) : get_all_dirty_from_scope$2(
+          /*$$scope*/
+          r[14]
+        ),
+        null
+      ), (!s || T & /*size, variant, elem_classes*/
+      26 && n !== (n = /*size*/
+      r[4] + " " + /*variant*/
+      r[3] + " " + /*elem_classes*/
+      r[1].join(" ") + " svelte-8huxfn")) && attr$5(e, "class", n), (!s || T & /*elem_id*/
+      1) && attr$5(
+        e,
+        "id",
+        /*elem_id*/
+        r[0]
+      ), (!s || T & /*disabled*/
+      256) && (e.disabled = /*disabled*/
+      r[8]), (!s || T & /*size, variant, elem_classes, visible*/
+      30) && toggle_class$4(e, "hidden", !/*visible*/
+      r[2]), T & /*scale*/
+      512 && set_style$4(
+        e,
+        "flex-grow",
+        /*scale*/
+        r[9]
+      ), T & /*scale*/
+      512 && set_style$4(
+        e,
+        "width",
+        /*scale*/
+        r[9] === 0 ? "fit-content" : null
+      ), T & /*min_width*/
+      1024 && set_style$4(e, "min-width", typeof /*min_width*/
+      r[10] == "number" ? `calc(min(${/*min_width*/
+      r[10]}px, 100%))` : null);
+    },
+    i(r) {
+      s || (transition_in$4(o, r), s = !0);
+    },
+    o(r) {
+      transition_out$4(o, r), s = !1;
+    },
+    d(r) {
+      r && detach$5(e), _ && _.d(), o && o.d(r), l = !1, h();
+    }
+  };
+}
+function create_if_block$3(t) {
+  let e, i, n, s, l = (
+    /*icon*/
+    t[7] && create_if_block_1$3(t)
+  );
+  const h = (
+    /*#slots*/
+    t[15].default
+  ), _ = create_slot$2(
+    h,
+    t,
+    /*$$scope*/
+    t[14],
+    null
+  );
+  return {
+    c() {
+      e = element$5("a"), l && l.c(), i = space$4(), _ && _.c(), attr$5(
+        e,
+        "href",
+        /*link*/
+        t[6]
+      ), attr$5(e, "rel", "noopener noreferrer"), attr$5(
+        e,
+        "aria-disabled",
+        /*disabled*/
+        t[8]
+      ), attr$5(e, "class", n = /*size*/
+      t[4] + " " + /*variant*/
+      t[3] + " " + /*elem_classes*/
+      t[1].join(" ") + " svelte-8huxfn"), attr$5(
+        e,
+        "id",
+        /*elem_id*/
+        t[0]
+      ), toggle_class$4(e, "hidden", !/*visible*/
+      t[2]), toggle_class$4(
+        e,
+        "disabled",
+        /*disabled*/
+        t[8]
+      ), set_style$4(
+        e,
+        "flex-grow",
+        /*scale*/
+        t[9]
+      ), set_style$4(
+        e,
+        "pointer-events",
+        /*disabled*/
+        t[8] ? "none" : null
+      ), set_style$4(
+        e,
+        "width",
+        /*scale*/
+        t[9] === 0 ? "fit-content" : null
+      ), set_style$4(e, "min-width", typeof /*min_width*/
+      t[10] == "number" ? `calc(min(${/*min_width*/
+      t[10]}px, 100%))` : null);
+    },
+    m(c, o) {
+      insert$5(c, e, o), l && l.m(e, null), append$5(e, i), _ && _.m(e, null), s = !0;
+    },
+    p(c, o) {
+      /*icon*/
+      c[7] ? l ? l.p(c, o) : (l = create_if_block_1$3(c), l.c(), l.m(e, i)) : l && (l.d(1), l = null), _ && _.p && (!s || o & /*$$scope*/
+      16384) && update_slot_base$2(
+        _,
+        h,
+        c,
+        /*$$scope*/
+        c[14],
+        s ? get_slot_changes$2(
+          h,
+          /*$$scope*/
+          c[14],
+          o,
+          null
+        ) : get_all_dirty_from_scope$2(
+          /*$$scope*/
+          c[14]
+        ),
+        null
+      ), (!s || o & /*link*/
+      64) && attr$5(
+        e,
+        "href",
+        /*link*/
+        c[6]
+      ), (!s || o & /*disabled*/
+      256) && attr$5(
+        e,
+        "aria-disabled",
+        /*disabled*/
+        c[8]
+      ), (!s || o & /*size, variant, elem_classes*/
+      26 && n !== (n = /*size*/
+      c[4] + " " + /*variant*/
+      c[3] + " " + /*elem_classes*/
+      c[1].join(" ") + " svelte-8huxfn")) && attr$5(e, "class", n), (!s || o & /*elem_id*/
+      1) && attr$5(
+        e,
+        "id",
+        /*elem_id*/
+        c[0]
+      ), (!s || o & /*size, variant, elem_classes, visible*/
+      30) && toggle_class$4(e, "hidden", !/*visible*/
+      c[2]), (!s || o & /*size, variant, elem_classes, disabled*/
+      282) && toggle_class$4(
+        e,
+        "disabled",
+        /*disabled*/
+        c[8]
+      ), o & /*scale*/
+      512 && set_style$4(
+        e,
+        "flex-grow",
+        /*scale*/
+        c[9]
+      ), o & /*disabled*/
+      256 && set_style$4(
+        e,
+        "pointer-events",
+        /*disabled*/
+        c[8] ? "none" : null
+      ), o & /*scale*/
+      512 && set_style$4(
+        e,
+        "width",
+        /*scale*/
+        c[9] === 0 ? "fit-content" : null
+      ), o & /*min_width*/
+      1024 && set_style$4(e, "min-width", typeof /*min_width*/
+      c[10] == "number" ? `calc(min(${/*min_width*/
+      c[10]}px, 100%))` : null);
+    },
+    i(c) {
+      s || (transition_in$4(_, c), s = !0);
+    },
+    o(c) {
+      transition_out$4(_, c), s = !1;
+    },
+    d(c) {
+      c && detach$5(e), l && l.d(), _ && _.d(c);
+    }
+  };
+}
+function create_if_block_2$1(t) {
+  let e, i, n;
+  return {
+    c() {
+      e = element$5("img"), attr$5(e, "class", "button-icon svelte-8huxfn"), src_url_equal(e.src, i = /*icon_path*/
+      t[11]) || attr$5(e, "src", i), attr$5(e, "alt", n = `${/*value*/
+      t[5]} icon`);
+    },
+    m(s, l) {
+      insert$5(s, e, l);
+    },
+    p(s, l) {
+      l & /*icon_path*/
+      2048 && !src_url_equal(e.src, i = /*icon_path*/
+      s[11]) && attr$5(e, "src", i), l & /*value*/
+      32 && n !== (n = `${/*value*/
+      s[5]} icon`) && attr$5(e, "alt", n);
+    },
+    d(s) {
+      s && detach$5(e);
+    }
+  };
+}
+function create_if_block_1$3(t) {
+  let e, i, n;
+  return {
+    c() {
+      e = element$5("img"), attr$5(e, "class", "button-icon svelte-8huxfn"), src_url_equal(e.src, i = /*icon_path*/
+      t[11]) || attr$5(e, "src", i), attr$5(e, "alt", n = `${/*value*/
+      t[5]} icon`);
+    },
+    m(s, l) {
+      insert$5(s, e, l);
+    },
+    p(s, l) {
+      l & /*icon_path*/
+      2048 && !src_url_equal(e.src, i = /*icon_path*/
+      s[11]) && attr$5(e, "src", i), l & /*value*/
+      32 && n !== (n = `${/*value*/
+      s[5]} icon`) && attr$5(e, "alt", n);
+    },
+    d(s) {
+      s && detach$5(e);
+    }
+  };
+}
+function create_fragment$5(t) {
+  let e, i, n, s;
+  const l = [create_if_block$3, create_else_block$2], h = [];
+  function _(c, o) {
+    return (
+      /*link*/
+      c[6] && /*link*/
+      c[6].length > 0 ? 0 : 1
+    );
+  }
+  return e = _(t), i = h[e] = l[e](t), {
+    c() {
+      i.c(), n = empty$2();
+    },
+    m(c, o) {
+      h[e].m(c, o), insert$5(c, n, o), s = !0;
+    },
+    p(c, [o]) {
+      let r = e;
+      e = _(c), e === r ? h[e].p(c, o) : (group_outros$3(), transition_out$4(h[r], 1, 1, () => {
+        h[r] = null;
+      }), check_outros$3(), i = h[e], i ? i.p(c, o) : (i = h[e] = l[e](c), i.c()), transition_in$4(i, 1), i.m(n.parentNode, n));
+    },
+    i(c) {
+      s || (transition_in$4(i), s = !0);
+    },
+    o(c) {
+      transition_out$4(i), s = !1;
+    },
+    d(c) {
+      c && detach$5(n), h[e].d(c);
+    }
+  };
+}
+function instance$5(t, e, i) {
+  let n, { $$slots: s = {}, $$scope: l } = e, { elem_id: h = "" } = e, { elem_classes: _ = [] } = e, { visible: c = !0 } = e, { variant: o = "secondary" } = e, { size: r = "lg" } = e, { value: T = null } = e, { link: S = null } = e, { icon: w = null } = e, { disabled: C = !1 } = e, { scale: P = null } = e, { min_width: b = void 0 } = e, { root: k = "" } = e, { proxy_url: F = null } = e;
+  function x(y) {
+    bubble$1.call(this, t, y);
+  }
+  return t.$$set = (y) => {
+    "elem_id" in y && i(0, h = y.elem_id), "elem_classes" in y && i(1, _ = y.elem_classes), "visible" in y && i(2, c = y.visible), "variant" in y && i(3, o = y.variant), "size" in y && i(4, r = y.size), "value" in y && i(5, T = y.value), "link" in y && i(6, S = y.link), "icon" in y && i(7, w = y.icon), "disabled" in y && i(8, C = y.disabled), "scale" in y && i(9, P = y.scale), "min_width" in y && i(10, b = y.min_width), "root" in y && i(12, k = y.root), "proxy_url" in y && i(13, F = y.proxy_url), "$$scope" in y && i(14, l = y.$$scope);
+  }, t.$$.update = () => {
+    t.$$.dirty & /*icon, root, proxy_url*/
+    12416 && i(11, n = get_fetchable_url_or_file$1(w, k, F));
+  }, [
+    h,
+    _,
+    c,
+    o,
+    r,
+    T,
+    S,
+    w,
+    C,
+    P,
+    b,
+    n,
+    k,
+    F,
+    l,
+    s,
+    x
+  ];
+}
+class Button extends SvelteComponent$5 {
+  constructor(e) {
+    super(), init$5(this, e, instance$5, create_fragment$5, safe_not_equal$6, {
+      elem_id: 0,
+      elem_classes: 1,
+      visible: 2,
+      variant: 3,
+      size: 4,
+      value: 5,
+      link: 6,
+      icon: 7,
+      disabled: 8,
+      scale: 9,
+      min_width: 10,
+      root: 12,
+      proxy_url: 13
+    });
+  }
+}
+function pretty_si(t) {
+  let e = ["", "k", "M", "G", "T", "P", "E", "Z"], i = 0;
+  for (; t > 1e3 && i < e.length - 1; )
+    t /= 1e3, i++;
+  let n = e[i];
+  return (Number.isInteger(t) ? t : t.toFixed(1)) + n;
+}
+function noop$2() {
+}
+function run(t) {
+  return t();
+}
+function run_all$1(t) {
+  t.forEach(run);
+}
+function is_function(t) {
+  return typeof t == "function";
+}
+function safe_not_equal$5(t, e) {
+  return t != t ? e == e : t !== e || t && typeof t == "object" || typeof t == "function";
+}
+function subscribe(t, ...e) {
+  if (t == null) {
+    for (const n of e)
+      n(void 0);
+    return noop$2;
+  }
+  const i = t.subscribe(...e);
+  return i.unsubscribe ? () => i.unsubscribe() : i;
+}
+const is_client = typeof window < "u";
+let now = is_client ? () => window.performance.now() : () => Date.now(), raf = is_client ? (t) => requestAnimationFrame(t) : noop$2;
+const tasks = /* @__PURE__ */ new Set();
+function run_tasks(t) {
+  tasks.forEach((e) => {
+    e.c(t) || (tasks.delete(e), e.f());
+  }), tasks.size !== 0 && raf(run_tasks);
+}
+function loop(t) {
+  let e;
+  return tasks.size === 0 && raf(run_tasks), {
+    promise: new Promise((i) => {
+      tasks.add(e = { c: t, f: i });
+    }),
+    abort() {
+      tasks.delete(e);
+    }
+  };
+}
+const subscriber_queue = [];
+function readable(t, e) {
+  return {
+    subscribe: writable(t, e).subscribe
+  };
+}
+function writable(t, e = noop$2) {
+  let i;
+  const n = /* @__PURE__ */ new Set();
+  function s(_) {
+    if (safe_not_equal$5(t, _) && (t = _, i)) {
+      const c = !subscriber_queue.length;
+      for (const o of n)
+        o[1](), subscriber_queue.push(o, t);
+      if (c) {
+        for (let o = 0; o < subscriber_queue.length; o += 2)
+          subscriber_queue[o][0](subscriber_queue[o + 1]);
+        subscriber_queue.length = 0;
+      }
+    }
+  }
+  function l(_) {
+    s(_(t));
+  }
+  function h(_, c = noop$2) {
+    const o = [_, c];
+    return n.add(o), n.size === 1 && (i = e(s, l) || noop$2), _(t), () => {
+      n.delete(o), n.size === 0 && i && (i(), i = null);
+    };
+  }
+  return { set: s, update: l, subscribe: h };
+}
+function derived(t, e, i) {
+  const n = !Array.isArray(t), s = n ? [t] : t;
+  if (!s.every(Boolean))
+    throw new Error("derived() expects stores as input, got a falsy value");
+  const l = e.length < 2;
+  return readable(i, (h, _) => {
+    let c = !1;
+    const o = [];
+    let r = 0, T = noop$2;
+    const S = () => {
+      if (r)
+        return;
+      T();
+      const C = e(n ? o[0] : o, h, _);
+      l ? h(C) : T = is_function(C) ? C : noop$2;
+    }, w = s.map(
+      (C, P) => subscribe(
+        C,
+        (b) => {
+          o[P] = b, r &= ~(1 << P), c && S();
+        },
+        () => {
+          r |= 1 << P;
+        }
+      )
+    );
+    return c = !0, S(), function() {
+      run_all$1(w), T(), c = !1;
+    };
+  });
+}
+function is_date(t) {
+  return Object.prototype.toString.call(t) === "[object Date]";
+}
+function tick_spring(t, e, i, n) {
+  if (typeof i == "number" || is_date(i)) {
+    const s = n - i, l = (i - e) / (t.dt || 1 / 60), h = t.opts.stiffness * s, _ = t.opts.damping * l, c = (h - _) * t.inv_mass, o = (l + c) * t.dt;
+    return Math.abs(o) < t.opts.precision && Math.abs(s) < t.opts.precision ? n : (t.settled = !1, is_date(i) ? new Date(i.getTime() + o) : i + o);
+  } else {
+    if (Array.isArray(i))
+      return i.map(
+        (s, l) => tick_spring(t, e[l], i[l], n[l])
+      );
+    if (typeof i == "object") {
+      const s = {};
+      for (const l in i)
+        s[l] = tick_spring(t, e[l], i[l], n[l]);
+      return s;
+    } else
+      throw new Error(`Cannot spring ${typeof i} values`);
+  }
+}
+function spring(t, e = {}) {
+  const i = writable(t), { stiffness: n = 0.15, damping: s = 0.8, precision: l = 0.01 } = e;
+  let h, _, c, o = t, r = t, T = 1, S = 0, w = !1;
+  function C(b, k = {}) {
+    r = b;
+    const F = c = {};
+    return t == null || k.hard || P.stiffness >= 1 && P.damping >= 1 ? (w = !0, h = now(), o = b, i.set(t = r), Promise.resolve()) : (k.soft && (S = 1 / ((k.soft === !0 ? 0.5 : +k.soft) * 60), T = 0), _ || (h = now(), w = !1, _ = loop((x) => {
+      if (w)
+        return w = !1, _ = null, !1;
+      T = Math.min(T + S, 1);
+      const y = {
+        inv_mass: T,
+        opts: P,
+        settled: !0,
+        dt: (x - h) * 60 / 1e3
+      }, p = tick_spring(y, o, t, r);
+      return h = x, o = t, i.set(t = p), y.settled && (_ = null), !y.settled;
+    })), new Promise((x) => {
+      _.promise.then(() => {
+        F === c && x();
+      });
+    }));
+  }
+  const P = {
+    set: C,
+    update: (b, k) => C(b(r, t), k),
+    subscribe: i.subscribe,
+    stiffness: n,
+    damping: s,
+    precision: l
+  };
+  return P;
+}
+const Loader_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$4,
+  append: append$4,
+  attr: attr$4,
+  component_subscribe,
+  detach: detach$4,
+  element: element$4,
+  init: init$4,
+  insert: insert$4,
+  noop: noop$1,
+  safe_not_equal: safe_not_equal$4,
+  set_style: set_style$3,
+  svg_element,
+  toggle_class: toggle_class$3
+} = window.__gradio__svelte__internal, { onMount } = window.__gradio__svelte__internal;
+function create_fragment$4(t) {
+  let e, i, n, s, l, h, _, c, o, r, T, S;
+  return {
+    c() {
+      e = element$4("div"), i = svg_element("svg"), n = svg_element("g"), s = svg_element("path"), l = svg_element("path"), h = svg_element("path"), _ = svg_element("path"), c = svg_element("g"), o = svg_element("path"), r = svg_element("path"), T = svg_element("path"), S = svg_element("path"), attr$4(s, "d", "M255.926 0.754768L509.702 139.936V221.027L255.926 81.8465V0.754768Z"), attr$4(s, "fill", "#FF7C00"), attr$4(s, "fill-opacity", "0.4"), attr$4(s, "class", "svelte-43sxxs"), attr$4(l, "d", "M509.69 139.936L254.981 279.641V361.255L509.69 221.55V139.936Z"), attr$4(l, "fill", "#FF7C00"), attr$4(l, "class", "svelte-43sxxs"), attr$4(h, "d", "M0.250138 139.937L254.981 279.641V361.255L0.250138 221.55V139.937Z"), attr$4(h, "fill", "#FF7C00"), attr$4(h, "fill-opacity", "0.4"), attr$4(h, "class", "svelte-43sxxs"), attr$4(_, "d", "M255.923 0.232622L0.236328 139.936V221.55L255.923 81.8469V0.232622Z"), attr$4(_, "fill", "#FF7C00"), attr$4(_, "class", "svelte-43sxxs"), set_style$3(n, "transform", "translate(" + /*$top*/
+      t[1][0] + "px, " + /*$top*/
+      t[1][1] + "px)"), attr$4(o, "d", "M255.926 141.5L509.702 280.681V361.773L255.926 222.592V141.5Z"), attr$4(o, "fill", "#FF7C00"), attr$4(o, "fill-opacity", "0.4"), attr$4(o, "class", "svelte-43sxxs"), attr$4(r, "d", "M509.69 280.679L254.981 420.384V501.998L509.69 362.293V280.679Z"), attr$4(r, "fill", "#FF7C00"), attr$4(r, "class", "svelte-43sxxs"), attr$4(T, "d", "M0.250138 280.681L254.981 420.386V502L0.250138 362.295V280.681Z"), attr$4(T, "fill", "#FF7C00"), attr$4(T, "fill-opacity", "0.4"), attr$4(T, "class", "svelte-43sxxs"), attr$4(S, "d", "M255.923 140.977L0.236328 280.68V362.294L255.923 222.591V140.977Z"), attr$4(S, "fill", "#FF7C00"), attr$4(S, "class", "svelte-43sxxs"), set_style$3(c, "transform", "translate(" + /*$bottom*/
+      t[2][0] + "px, " + /*$bottom*/
+      t[2][1] + "px)"), attr$4(i, "viewBox", "-1200 -1200 3000 3000"), attr$4(i, "fill", "none"), attr$4(i, "xmlns", "http://www.w3.org/2000/svg"), attr$4(i, "class", "svelte-43sxxs"), attr$4(e, "class", "svelte-43sxxs"), toggle_class$3(
+        e,
+        "margin",
+        /*margin*/
+        t[0]
+      );
+    },
+    m(w, C) {
+      insert$4(w, e, C), append$4(e, i), append$4(i, n), append$4(n, s), append$4(n, l), append$4(n, h), append$4(n, _), append$4(i, c), append$4(c, o), append$4(c, r), append$4(c, T), append$4(c, S);
+    },
+    p(w, [C]) {
+      C & /*$top*/
+      2 && set_style$3(n, "transform", "translate(" + /*$top*/
+      w[1][0] + "px, " + /*$top*/
+      w[1][1] + "px)"), C & /*$bottom*/
+      4 && set_style$3(c, "transform", "translate(" + /*$bottom*/
+      w[2][0] + "px, " + /*$bottom*/
+      w[2][1] + "px)"), C & /*margin*/
+      1 && toggle_class$3(
+        e,
+        "margin",
+        /*margin*/
+        w[0]
+      );
+    },
+    i: noop$1,
+    o: noop$1,
+    d(w) {
+      w && detach$4(e);
+    }
+  };
+}
+function instance$4(t, e, i) {
+  let n, s, { margin: l = !0 } = e;
+  const h = spring([0, 0]);
+  component_subscribe(t, h, (S) => i(1, n = S));
+  const _ = spring([0, 0]);
+  component_subscribe(t, _, (S) => i(2, s = S));
+  let c;
+  async function o() {
+    await Promise.all([h.set([125, 140]), _.set([-125, -140])]), await Promise.all([h.set([-125, 140]), _.set([125, -140])]), await Promise.all([h.set([-125, 0]), _.set([125, -0])]), await Promise.all([h.set([125, 0]), _.set([-125, 0])]);
+  }
+  async function r() {
+    await o(), c || r();
+  }
+  async function T() {
+    await Promise.all([h.set([125, 0]), _.set([-125, 0])]), r();
+  }
+  return onMount(() => (T(), () => c = !0)), t.$$set = (S) => {
+    "margin" in S && i(0, l = S.margin);
+  }, [l, n, s, h, _];
+}
+class Loader extends SvelteComponent$4 {
+  constructor(e) {
+    super(), init$4(this, e, instance$4, create_fragment$4, safe_not_equal$4, { margin: 0 });
+  }
+}
+const index_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$3,
+  append: append$3,
+  attr: attr$3,
+  binding_callbacks: binding_callbacks$2,
+  check_outros: check_outros$2,
+  create_component: create_component$2,
+  create_slot: create_slot$1,
+  destroy_component: destroy_component$2,
+  destroy_each,
+  detach: detach$3,
+  element: element$3,
+  empty: empty$1,
+  ensure_array_like,
+  get_all_dirty_from_scope: get_all_dirty_from_scope$1,
+  get_slot_changes: get_slot_changes$1,
+  group_outros: group_outros$2,
+  init: init$3,
+  insert: insert$3,
+  mount_component: mount_component$2,
+  noop,
+  safe_not_equal: safe_not_equal$3,
+  set_data: set_data$1,
+  set_style: set_style$2,
+  space: space$3,
+  text: text$1,
+  toggle_class: toggle_class$2,
+  transition_in: transition_in$3,
+  transition_out: transition_out$3,
+  update_slot_base: update_slot_base$1
+} = window.__gradio__svelte__internal, { tick: tick$2 } = window.__gradio__svelte__internal, { onDestroy } = window.__gradio__svelte__internal, get_error_slot_changes = (t) => ({}), get_error_slot_context = (t) => ({});
+function get_each_context(t, e, i) {
+  const n = t.slice();
+  return n[38] = e[i], n[40] = i, n;
+}
+function get_each_context_1(t, e, i) {
+  const n = t.slice();
+  return n[38] = e[i], n;
+}
+function create_if_block_17(t) {
+  let e, i = (
+    /*i18n*/
+    t[1]("common.error") + ""
+  ), n, s, l;
+  const h = (
+    /*#slots*/
+    t[29].error
+  ), _ = create_slot$1(
+    h,
+    t,
+    /*$$scope*/
+    t[28],
+    get_error_slot_context
+  );
+  return {
+    c() {
+      e = element$3("span"), n = text$1(i), s = space$3(), _ && _.c(), attr$3(e, "class", "error svelte-14miwb5");
+    },
+    m(c, o) {
+      insert$3(c, e, o), append$3(e, n), insert$3(c, s, o), _ && _.m(c, o), l = !0;
+    },
+    p(c, o) {
+      (!l || o[0] & /*i18n*/
+      2) && i !== (i = /*i18n*/
+      c[1]("common.error") + "") && set_data$1(n, i), _ && _.p && (!l || o[0] & /*$$scope*/
+      268435456) && update_slot_base$1(
+        _,
+        h,
+        c,
+        /*$$scope*/
+        c[28],
+        l ? get_slot_changes$1(
+          h,
+          /*$$scope*/
+          c[28],
+          o,
+          get_error_slot_changes
+        ) : get_all_dirty_from_scope$1(
+          /*$$scope*/
+          c[28]
+        ),
+        get_error_slot_context
+      );
+    },
+    i(c) {
+      l || (transition_in$3(_, c), l = !0);
+    },
+    o(c) {
+      transition_out$3(_, c), l = !1;
+    },
+    d(c) {
+      c && (detach$3(e), detach$3(s)), _ && _.d(c);
+    }
+  };
+}
+function create_if_block$2(t) {
+  let e, i, n, s, l, h, _, c, o, r = (
+    /*variant*/
+    t[8] === "default" && /*show_eta_bar*/
+    t[18] && /*show_progress*/
+    t[6] === "full" && create_if_block_16(t)
+  );
+  function T(x, y) {
+    if (
+      /*progress*/
+      x[7]
+    )
+      return create_if_block_11;
+    if (
+      /*queue_position*/
+      x[2] !== null && /*queue_size*/
+      x[3] !== void 0 && /*queue_position*/
+      x[2] >= 0
+    )
+      return create_if_block_14;
+    if (
+      /*queue_position*/
+      x[2] === 0
+    )
+      return create_if_block_15;
+  }
+  let S = T(t), w = S && S(t), C = (
+    /*timer*/
+    t[5] && create_if_block_10(t)
+  );
+  const P = [create_if_block_2, create_if_block_9], b = [];
+  function k(x, y) {
+    return (
+      /*last_progress_level*/
+      x[15] != null ? 0 : (
+        /*show_progress*/
+        x[6] === "full" ? 1 : -1
+      )
+    );
+  }
+  ~(l = k(t)) && (h = b[l] = P[l](t));
+  let F = !/*timer*/
+  t[5] && create_if_block_1$2(t);
+  return {
+    c() {
+      r && r.c(), e = space$3(), i = element$3("div"), w && w.c(), n = space$3(), C && C.c(), s = space$3(), h && h.c(), _ = space$3(), F && F.c(), c = empty$1(), attr$3(i, "class", "progress-text svelte-14miwb5"), toggle_class$2(
+        i,
+        "meta-text-center",
+        /*variant*/
+        t[8] === "center"
+      ), toggle_class$2(
+        i,
+        "meta-text",
+        /*variant*/
+        t[8] === "default"
+      );
+    },
+    m(x, y) {
+      r && r.m(x, y), insert$3(x, e, y), insert$3(x, i, y), w && w.m(i, null), append$3(i, n), C && C.m(i, null), insert$3(x, s, y), ~l && b[l].m(x, y), insert$3(x, _, y), F && F.m(x, y), insert$3(x, c, y), o = !0;
+    },
+    p(x, y) {
+      /*variant*/
+      x[8] === "default" && /*show_eta_bar*/
+      x[18] && /*show_progress*/
+      x[6] === "full" ? r ? r.p(x, y) : (r = create_if_block_16(x), r.c(), r.m(e.parentNode, e)) : r && (r.d(1), r = null), S === (S = T(x)) && w ? w.p(x, y) : (w && w.d(1), w = S && S(x), w && (w.c(), w.m(i, n))), /*timer*/
+      x[5] ? C ? C.p(x, y) : (C = create_if_block_10(x), C.c(), C.m(i, null)) : C && (C.d(1), C = null), (!o || y[0] & /*variant*/
+      256) && toggle_class$2(
+        i,
+        "meta-text-center",
+        /*variant*/
+        x[8] === "center"
+      ), (!o || y[0] & /*variant*/
+      256) && toggle_class$2(
+        i,
+        "meta-text",
+        /*variant*/
+        x[8] === "default"
+      );
+      let p = l;
+      l = k(x), l === p ? ~l && b[l].p(x, y) : (h && (group_outros$2(), transition_out$3(b[p], 1, 1, () => {
+        b[p] = null;
+      }), check_outros$2()), ~l ? (h = b[l], h ? h.p(x, y) : (h = b[l] = P[l](x), h.c()), transition_in$3(h, 1), h.m(_.parentNode, _)) : h = null), /*timer*/
+      x[5] ? F && (F.d(1), F = null) : F ? F.p(x, y) : (F = create_if_block_1$2(x), F.c(), F.m(c.parentNode, c));
+    },
+    i(x) {
+      o || (transition_in$3(h), o = !0);
+    },
+    o(x) {
+      transition_out$3(h), o = !1;
+    },
+    d(x) {
+      x && (detach$3(e), detach$3(i), detach$3(s), detach$3(_), detach$3(c)), r && r.d(x), w && w.d(), C && C.d(), ~l && b[l].d(x), F && F.d(x);
+    }
+  };
+}
+function create_if_block_16(t) {
+  let e, i = `translateX(${/*eta_level*/
+  (t[17] || 0) * 100 - 100}%)`;
+  return {
+    c() {
+      e = element$3("div"), attr$3(e, "class", "eta-bar svelte-14miwb5"), set_style$2(e, "transform", i);
+    },
+    m(n, s) {
+      insert$3(n, e, s);
+    },
+    p(n, s) {
+      s[0] & /*eta_level*/
+      131072 && i !== (i = `translateX(${/*eta_level*/
+      (n[17] || 0) * 100 - 100}%)`) && set_style$2(e, "transform", i);
+    },
+    d(n) {
+      n && detach$3(e);
+    }
+  };
+}
+function create_if_block_15(t) {
+  let e;
+  return {
+    c() {
+      e = text$1("processing |");
+    },
+    m(i, n) {
+      insert$3(i, e, n);
+    },
+    p: noop,
+    d(i) {
+      i && detach$3(e);
+    }
+  };
+}
+function create_if_block_14(t) {
+  let e, i = (
+    /*queue_position*/
+    t[2] + 1 + ""
+  ), n, s, l, h;
+  return {
+    c() {
+      e = text$1("queue: "), n = text$1(i), s = text$1("/"), l = text$1(
+        /*queue_size*/
+        t[3]
+      ), h = text$1(" |");
+    },
+    m(_, c) {
+      insert$3(_, e, c), insert$3(_, n, c), insert$3(_, s, c), insert$3(_, l, c), insert$3(_, h, c);
+    },
+    p(_, c) {
+      c[0] & /*queue_position*/
+      4 && i !== (i = /*queue_position*/
+      _[2] + 1 + "") && set_data$1(n, i), c[0] & /*queue_size*/
+      8 && set_data$1(
+        l,
+        /*queue_size*/
+        _[3]
+      );
+    },
+    d(_) {
+      _ && (detach$3(e), detach$3(n), detach$3(s), detach$3(l), detach$3(h));
+    }
+  };
+}
+function create_if_block_11(t) {
+  let e, i = ensure_array_like(
+    /*progress*/
+    t[7]
+  ), n = [];
+  for (let s = 0; s < i.length; s += 1)
+    n[s] = create_each_block_1(get_each_context_1(t, i, s));
+  return {
+    c() {
+      for (let s = 0; s < n.length; s += 1)
+        n[s].c();
+      e = empty$1();
+    },
+    m(s, l) {
+      for (let h = 0; h < n.length; h += 1)
+        n[h] && n[h].m(s, l);
+      insert$3(s, e, l);
+    },
+    p(s, l) {
+      if (l[0] & /*progress*/
+      128) {
+        i = ensure_array_like(
+          /*progress*/
+          s[7]
+        );
+        let h;
+        for (h = 0; h < i.length; h += 1) {
+          const _ = get_each_context_1(s, i, h);
+          n[h] ? n[h].p(_, l) : (n[h] = create_each_block_1(_), n[h].c(), n[h].m(e.parentNode, e));
+        }
+        for (; h < n.length; h += 1)
+          n[h].d(1);
+        n.length = i.length;
+      }
+    },
+    d(s) {
+      s && detach$3(e), destroy_each(n, s);
+    }
+  };
+}
+function create_if_block_12(t) {
+  let e, i = (
+    /*p*/
+    t[38].unit + ""
+  ), n, s, l = " ", h;
+  function _(r, T) {
+    return (
+      /*p*/
+      r[38].length != null ? create_if_block_13 : create_else_block$1
+    );
+  }
+  let c = _(t), o = c(t);
+  return {
+    c() {
+      o.c(), e = space$3(), n = text$1(i), s = text$1(" | "), h = text$1(l);
+    },
+    m(r, T) {
+      o.m(r, T), insert$3(r, e, T), insert$3(r, n, T), insert$3(r, s, T), insert$3(r, h, T);
+    },
+    p(r, T) {
+      c === (c = _(r)) && o ? o.p(r, T) : (o.d(1), o = c(r), o && (o.c(), o.m(e.parentNode, e))), T[0] & /*progress*/
+      128 && i !== (i = /*p*/
+      r[38].unit + "") && set_data$1(n, i);
+    },
+    d(r) {
+      r && (detach$3(e), detach$3(n), detach$3(s), detach$3(h)), o.d(r);
+    }
+  };
+}
+function create_else_block$1(t) {
+  let e = pretty_si(
+    /*p*/
+    t[38].index || 0
+  ) + "", i;
+  return {
+    c() {
+      i = text$1(e);
+    },
+    m(n, s) {
+      insert$3(n, i, s);
+    },
+    p(n, s) {
+      s[0] & /*progress*/
+      128 && e !== (e = pretty_si(
+        /*p*/
+        n[38].index || 0
+      ) + "") && set_data$1(i, e);
+    },
+    d(n) {
+      n && detach$3(i);
+    }
+  };
+}
+function create_if_block_13(t) {
+  let e = pretty_si(
+    /*p*/
+    t[38].index || 0
+  ) + "", i, n, s = pretty_si(
+    /*p*/
+    t[38].length
+  ) + "", l;
+  return {
+    c() {
+      i = text$1(e), n = text$1("/"), l = text$1(s);
+    },
+    m(h, _) {
+      insert$3(h, i, _), insert$3(h, n, _), insert$3(h, l, _);
+    },
+    p(h, _) {
+      _[0] & /*progress*/
+      128 && e !== (e = pretty_si(
+        /*p*/
+        h[38].index || 0
+      ) + "") && set_data$1(i, e), _[0] & /*progress*/
+      128 && s !== (s = pretty_si(
+        /*p*/
+        h[38].length
+      ) + "") && set_data$1(l, s);
+    },
+    d(h) {
+      h && (detach$3(i), detach$3(n), detach$3(l));
+    }
+  };
+}
+function create_each_block_1(t) {
+  let e, i = (
+    /*p*/
+    t[38].index != null && create_if_block_12(t)
+  );
+  return {
+    c() {
+      i && i.c(), e = empty$1();
+    },
+    m(n, s) {
+      i && i.m(n, s), insert$3(n, e, s);
+    },
+    p(n, s) {
+      /*p*/
+      n[38].index != null ? i ? i.p(n, s) : (i = create_if_block_12(n), i.c(), i.m(e.parentNode, e)) : i && (i.d(1), i = null);
+    },
+    d(n) {
+      n && detach$3(e), i && i.d(n);
+    }
+  };
+}
+function create_if_block_10(t) {
+  let e, i = (
+    /*eta*/
+    t[0] ? `/${/*formatted_eta*/
+    t[19]}` : ""
+  ), n, s;
+  return {
+    c() {
+      e = text$1(
+        /*formatted_timer*/
+        t[20]
+      ), n = text$1(i), s = text$1("s");
+    },
+    m(l, h) {
+      insert$3(l, e, h), insert$3(l, n, h), insert$3(l, s, h);
+    },
+    p(l, h) {
+      h[0] & /*formatted_timer*/
+      1048576 && set_data$1(
+        e,
+        /*formatted_timer*/
+        l[20]
+      ), h[0] & /*eta, formatted_eta*/
+      524289 && i !== (i = /*eta*/
+      l[0] ? `/${/*formatted_eta*/
+      l[19]}` : "") && set_data$1(n, i);
+    },
+    d(l) {
+      l && (detach$3(e), detach$3(n), detach$3(s));
+    }
+  };
+}
+function create_if_block_9(t) {
+  let e, i;
+  return e = new Loader({
+    props: { margin: (
+      /*variant*/
+      t[8] === "default"
+    ) }
+  }), {
+    c() {
+      create_component$2(e.$$.fragment);
+    },
+    m(n, s) {
+      mount_component$2(e, n, s), i = !0;
+    },
+    p(n, s) {
+      const l = {};
+      s[0] & /*variant*/
+      256 && (l.margin = /*variant*/
+      n[8] === "default"), e.$set(l);
+    },
+    i(n) {
+      i || (transition_in$3(e.$$.fragment, n), i = !0);
+    },
+    o(n) {
+      transition_out$3(e.$$.fragment, n), i = !1;
+    },
+    d(n) {
+      destroy_component$2(e, n);
+    }
+  };
+}
+function create_if_block_2(t) {
+  let e, i, n, s, l, h = `${/*last_progress_level*/
+  t[15] * 100}%`, _ = (
+    /*progress*/
+    t[7] != null && create_if_block_3(t)
+  );
+  return {
+    c() {
+      e = element$3("div"), i = element$3("div"), _ && _.c(), n = space$3(), s = element$3("div"), l = element$3("div"), attr$3(i, "class", "progress-level-inner svelte-14miwb5"), attr$3(l, "class", "progress-bar svelte-14miwb5"), set_style$2(l, "width", h), attr$3(s, "class", "progress-bar-wrap svelte-14miwb5"), attr$3(e, "class", "progress-level svelte-14miwb5");
+    },
+    m(c, o) {
+      insert$3(c, e, o), append$3(e, i), _ && _.m(i, null), append$3(e, n), append$3(e, s), append$3(s, l), t[30](l);
+    },
+    p(c, o) {
+      /*progress*/
+      c[7] != null ? _ ? _.p(c, o) : (_ = create_if_block_3(c), _.c(), _.m(i, null)) : _ && (_.d(1), _ = null), o[0] & /*last_progress_level*/
+      32768 && h !== (h = `${/*last_progress_level*/
+      c[15] * 100}%`) && set_style$2(l, "width", h);
+    },
+    i: noop,
+    o: noop,
+    d(c) {
+      c && detach$3(e), _ && _.d(), t[30](null);
+    }
+  };
+}
+function create_if_block_3(t) {
+  let e, i = ensure_array_like(
+    /*progress*/
+    t[7]
+  ), n = [];
+  for (let s = 0; s < i.length; s += 1)
+    n[s] = create_each_block(get_each_context(t, i, s));
+  return {
+    c() {
+      for (let s = 0; s < n.length; s += 1)
+        n[s].c();
+      e = empty$1();
+    },
+    m(s, l) {
+      for (let h = 0; h < n.length; h += 1)
+        n[h] && n[h].m(s, l);
+      insert$3(s, e, l);
+    },
+    p(s, l) {
+      if (l[0] & /*progress_level, progress*/
+      16512) {
+        i = ensure_array_like(
+          /*progress*/
+          s[7]
+        );
+        let h;
+        for (h = 0; h < i.length; h += 1) {
+          const _ = get_each_context(s, i, h);
+          n[h] ? n[h].p(_, l) : (n[h] = create_each_block(_), n[h].c(), n[h].m(e.parentNode, e));
+        }
+        for (; h < n.length; h += 1)
+          n[h].d(1);
+        n.length = i.length;
+      }
+    },
+    d(s) {
+      s && detach$3(e), destroy_each(n, s);
+    }
+  };
+}
+function create_if_block_4(t) {
+  let e, i, n, s, l = (
+    /*i*/
+    t[40] !== 0 && create_if_block_8()
+  ), h = (
+    /*p*/
+    t[38].desc != null && create_if_block_7(t)
+  ), _ = (
+    /*p*/
+    t[38].desc != null && /*progress_level*/
+    t[14] && /*progress_level*/
+    t[14][
+      /*i*/
+      t[40]
+    ] != null && create_if_block_6()
+  ), c = (
+    /*progress_level*/
+    t[14] != null && create_if_block_5(t)
+  );
+  return {
+    c() {
+      l && l.c(), e = space$3(), h && h.c(), i = space$3(), _ && _.c(), n = space$3(), c && c.c(), s = empty$1();
+    },
+    m(o, r) {
+      l && l.m(o, r), insert$3(o, e, r), h && h.m(o, r), insert$3(o, i, r), _ && _.m(o, r), insert$3(o, n, r), c && c.m(o, r), insert$3(o, s, r);
+    },
+    p(o, r) {
+      /*p*/
+      o[38].desc != null ? h ? h.p(o, r) : (h = create_if_block_7(o), h.c(), h.m(i.parentNode, i)) : h && (h.d(1), h = null), /*p*/
+      o[38].desc != null && /*progress_level*/
+      o[14] && /*progress_level*/
+      o[14][
+        /*i*/
+        o[40]
+      ] != null ? _ || (_ = create_if_block_6(), _.c(), _.m(n.parentNode, n)) : _ && (_.d(1), _ = null), /*progress_level*/
+      o[14] != null ? c ? c.p(o, r) : (c = create_if_block_5(o), c.c(), c.m(s.parentNode, s)) : c && (c.d(1), c = null);
+    },
+    d(o) {
+      o && (detach$3(e), detach$3(i), detach$3(n), detach$3(s)), l && l.d(o), h && h.d(o), _ && _.d(o), c && c.d(o);
+    }
+  };
+}
+function create_if_block_8(t) {
+  let e;
+  return {
+    c() {
+      e = text$1(" /");
+    },
+    m(i, n) {
+      insert$3(i, e, n);
+    },
+    d(i) {
+      i && detach$3(e);
+    }
+  };
+}
+function create_if_block_7(t) {
+  let e = (
+    /*p*/
+    t[38].desc + ""
+  ), i;
+  return {
+    c() {
+      i = text$1(e);
+    },
+    m(n, s) {
+      insert$3(n, i, s);
+    },
+    p(n, s) {
+      s[0] & /*progress*/
+      128 && e !== (e = /*p*/
+      n[38].desc + "") && set_data$1(i, e);
+    },
+    d(n) {
+      n && detach$3(i);
+    }
+  };
+}
+function create_if_block_6(t) {
+  let e;
+  return {
+    c() {
+      e = text$1("-");
+    },
+    m(i, n) {
+      insert$3(i, e, n);
+    },
+    d(i) {
+      i && detach$3(e);
+    }
+  };
+}
+function create_if_block_5(t) {
+  let e = (100 * /*progress_level*/
+  (t[14][
+    /*i*/
+    t[40]
+  ] || 0)).toFixed(1) + "", i, n;
+  return {
+    c() {
+      i = text$1(e), n = text$1("%");
+    },
+    m(s, l) {
+      insert$3(s, i, l), insert$3(s, n, l);
+    },
+    p(s, l) {
+      l[0] & /*progress_level*/
+      16384 && e !== (e = (100 * /*progress_level*/
+      (s[14][
+        /*i*/
+        s[40]
+      ] || 0)).toFixed(1) + "") && set_data$1(i, e);
+    },
+    d(s) {
+      s && (detach$3(i), detach$3(n));
+    }
+  };
+}
+function create_each_block(t) {
+  let e, i = (
+    /*p*/
+    (t[38].desc != null || /*progress_level*/
+    t[14] && /*progress_level*/
+    t[14][
+      /*i*/
+      t[40]
+    ] != null) && create_if_block_4(t)
+  );
+  return {
+    c() {
+      i && i.c(), e = empty$1();
+    },
+    m(n, s) {
+      i && i.m(n, s), insert$3(n, e, s);
+    },
+    p(n, s) {
+      /*p*/
+      n[38].desc != null || /*progress_level*/
+      n[14] && /*progress_level*/
+      n[14][
+        /*i*/
+        n[40]
+      ] != null ? i ? i.p(n, s) : (i = create_if_block_4(n), i.c(), i.m(e.parentNode, e)) : i && (i.d(1), i = null);
+    },
+    d(n) {
+      n && detach$3(e), i && i.d(n);
+    }
+  };
+}
+function create_if_block_1$2(t) {
+  let e, i;
+  return {
+    c() {
+      e = element$3("p"), i = text$1(
+        /*loading_text*/
+        t[9]
+      ), attr$3(e, "class", "loading svelte-14miwb5");
+    },
+    m(n, s) {
+      insert$3(n, e, s), append$3(e, i);
+    },
+    p(n, s) {
+      s[0] & /*loading_text*/
+      512 && set_data$1(
+        i,
+        /*loading_text*/
+        n[9]
+      );
+    },
+    d(n) {
+      n && detach$3(e);
+    }
+  };
+}
+function create_fragment$3(t) {
+  let e, i, n, s, l;
+  const h = [create_if_block$2, create_if_block_17], _ = [];
+  function c(o, r) {
+    return (
+      /*status*/
+      o[4] === "pending" ? 0 : (
+        /*status*/
+        o[4] === "error" ? 1 : -1
+      )
+    );
+  }
+  return ~(i = c(t)) && (n = _[i] = h[i](t)), {
+    c() {
+      e = element$3("div"), n && n.c(), attr$3(e, "class", s = "wrap " + /*variant*/
+      t[8] + " " + /*show_progress*/
+      t[6] + " svelte-14miwb5"), toggle_class$2(e, "hide", !/*status*/
+      t[4] || /*status*/
+      t[4] === "complete" || /*show_progress*/
+      t[6] === "hidden"), toggle_class$2(
+        e,
+        "translucent",
+        /*variant*/
+        t[8] === "center" && /*status*/
+        (t[4] === "pending" || /*status*/
+        t[4] === "error") || /*translucent*/
+        t[11] || /*show_progress*/
+        t[6] === "minimal"
+      ), toggle_class$2(
+        e,
+        "generating",
+        /*status*/
+        t[4] === "generating"
+      ), toggle_class$2(
+        e,
+        "border",
+        /*border*/
+        t[12]
+      ), set_style$2(
+        e,
+        "position",
+        /*absolute*/
+        t[10] ? "absolute" : "static"
+      ), set_style$2(
+        e,
+        "padding",
+        /*absolute*/
+        t[10] ? "0" : "var(--size-8) 0"
+      );
+    },
+    m(o, r) {
+      insert$3(o, e, r), ~i && _[i].m(e, null), t[31](e), l = !0;
+    },
+    p(o, r) {
+      let T = i;
+      i = c(o), i === T ? ~i && _[i].p(o, r) : (n && (group_outros$2(), transition_out$3(_[T], 1, 1, () => {
+        _[T] = null;
+      }), check_outros$2()), ~i ? (n = _[i], n ? n.p(o, r) : (n = _[i] = h[i](o), n.c()), transition_in$3(n, 1), n.m(e, null)) : n = null), (!l || r[0] & /*variant, show_progress*/
+      320 && s !== (s = "wrap " + /*variant*/
+      o[8] + " " + /*show_progress*/
+      o[6] + " svelte-14miwb5")) && attr$3(e, "class", s), (!l || r[0] & /*variant, show_progress, status, show_progress*/
+      336) && toggle_class$2(e, "hide", !/*status*/
+      o[4] || /*status*/
+      o[4] === "complete" || /*show_progress*/
+      o[6] === "hidden"), (!l || r[0] & /*variant, show_progress, variant, status, translucent, show_progress*/
+      2384) && toggle_class$2(
+        e,
+        "translucent",
+        /*variant*/
+        o[8] === "center" && /*status*/
+        (o[4] === "pending" || /*status*/
+        o[4] === "error") || /*translucent*/
+        o[11] || /*show_progress*/
+        o[6] === "minimal"
+      ), (!l || r[0] & /*variant, show_progress, status*/
+      336) && toggle_class$2(
+        e,
+        "generating",
+        /*status*/
+        o[4] === "generating"
+      ), (!l || r[0] & /*variant, show_progress, border*/
+      4416) && toggle_class$2(
+        e,
+        "border",
+        /*border*/
+        o[12]
+      ), r[0] & /*absolute*/
+      1024 && set_style$2(
+        e,
+        "position",
+        /*absolute*/
+        o[10] ? "absolute" : "static"
+      ), r[0] & /*absolute*/
+      1024 && set_style$2(
+        e,
+        "padding",
+        /*absolute*/
+        o[10] ? "0" : "var(--size-8) 0"
+      );
+    },
+    i(o) {
+      l || (transition_in$3(n), l = !0);
+    },
+    o(o) {
+      transition_out$3(n), l = !1;
+    },
+    d(o) {
+      o && detach$3(e), ~i && _[i].d(), t[31](null);
+    }
+  };
+}
+let items = [], called = !1;
+async function scroll_into_view(t, e = !0) {
+  if (!(window.__gradio_mode__ === "website" || window.__gradio_mode__ !== "app" && e !== !0)) {
+    if (items.push(t), !called)
+      called = !0;
+    else
+      return;
+    await tick$2(), requestAnimationFrame(() => {
+      let i = [0, 0];
+      for (let n = 0; n < items.length; n++) {
+        const l = items[n].getBoundingClientRect();
+        (n === 0 || l.top + window.scrollY <= i[0]) && (i[0] = l.top + window.scrollY, i[1] = n);
+      }
+      window.scrollTo({ top: i[0] - 20, behavior: "smooth" }), called = !1, items = [];
+    });
+  }
+}
+function instance$3(t, e, i) {
+  let n, { $$slots: s = {}, $$scope: l } = e, { i18n: h } = e, { eta: _ = null } = e, { queue: c = !1 } = e, { queue_position: o } = e, { queue_size: r } = e, { status: T } = e, { scroll_to_output: S = !1 } = e, { timer: w = !0 } = e, { show_progress: C = "full" } = e, { message: P = null } = e, { progress: b = null } = e, { variant: k = "default" } = e, { loading_text: F = "Loading..." } = e, { absolute: x = !0 } = e, { translucent: y = !1 } = e, { border: p = !1 } = e, { autoscroll: E } = e, $, M = !1, m = 0, N = 0, D = null, X = 0, G = null, I, B = null, ee = !0;
+  const Y = () => {
+    i(25, m = performance.now()), i(26, N = 0), M = !0, q();
+  };
+  function q() {
+    requestAnimationFrame(() => {
+      i(26, N = (performance.now() - m) / 1e3), M && q();
+    });
+  }
+  function le() {
+    i(26, N = 0), M && (M = !1);
+  }
+  onDestroy(() => {
+    M && le();
+  });
+  let pe = null;
+  function we(R) {
+    binding_callbacks$2[R ? "unshift" : "push"](() => {
+      B = R, i(16, B), i(7, b), i(14, G), i(15, I);
+    });
+  }
+  function be(R) {
+    binding_callbacks$2[R ? "unshift" : "push"](() => {
+      $ = R, i(13, $);
+    });
+  }
+  return t.$$set = (R) => {
+    "i18n" in R && i(1, h = R.i18n), "eta" in R && i(0, _ = R.eta), "queue" in R && i(21, c = R.queue), "queue_position" in R && i(2, o = R.queue_position), "queue_size" in R && i(3, r = R.queue_size), "status" in R && i(4, T = R.status), "scroll_to_output" in R && i(22, S = R.scroll_to_output), "timer" in R && i(5, w = R.timer), "show_progress" in R && i(6, C = R.show_progress), "message" in R && i(23, P = R.message), "progress" in R && i(7, b = R.progress), "variant" in R && i(8, k = R.variant), "loading_text" in R && i(9, F = R.loading_text), "absolute" in R && i(10, x = R.absolute), "translucent" in R && i(11, y = R.translucent), "border" in R && i(12, p = R.border), "autoscroll" in R && i(24, E = R.autoscroll), "$$scope" in R && i(28, l = R.$$scope);
+  }, t.$$.update = () => {
+    t.$$.dirty[0] & /*eta, old_eta, queue, timer_start*/
+    169869313 && (_ === null ? i(0, _ = D) : c && i(0, _ = (performance.now() - m) / 1e3 + _), _ != null && (i(19, pe = _.toFixed(1)), i(27, D = _))), t.$$.dirty[0] & /*eta, timer_diff*/
+    67108865 && i(17, X = _ === null || _ <= 0 || !N ? null : Math.min(N / _, 1)), t.$$.dirty[0] & /*progress*/
+    128 && b != null && i(18, ee = !1), t.$$.dirty[0] & /*progress, progress_level, progress_bar, last_progress_level*/
+    114816 && (b != null ? i(14, G = b.map((R) => {
+      if (R.index != null && R.length != null)
+        return R.index / R.length;
+      if (R.progress != null)
+        return R.progress;
+    })) : i(14, G = null), G ? (i(15, I = G[G.length - 1]), B && (I === 0 ? i(16, B.style.transition = "0", B) : i(16, B.style.transition = "150ms", B))) : i(15, I = void 0)), t.$$.dirty[0] & /*status*/
+    16 && (T === "pending" ? Y() : le()), t.$$.dirty[0] & /*el, scroll_to_output, status, autoscroll*/
+    20979728 && $ && S && (T === "pending" || T === "complete") && scroll_into_view($, E), t.$$.dirty[0] & /*status, message*/
+    8388624, t.$$.dirty[0] & /*timer_diff*/
+    67108864 && i(20, n = N.toFixed(1));
+  }, [
+    _,
+    h,
+    o,
+    r,
+    T,
+    w,
+    C,
+    b,
+    k,
+    F,
+    x,
+    y,
+    p,
+    $,
+    G,
+    I,
+    B,
+    X,
+    ee,
+    pe,
+    n,
+    c,
+    S,
+    P,
+    E,
+    m,
+    N,
+    D,
+    l,
+    s,
+    we,
+    be
+  ];
+}
+class Static extends SvelteComponent$3 {
+  constructor(e) {
+    super(), init$3(
+      this,
+      e,
+      instance$3,
+      create_fragment$3,
+      safe_not_equal$3,
+      {
+        i18n: 1,
+        eta: 0,
+        queue: 21,
+        queue_position: 2,
+        queue_size: 3,
+        status: 4,
+        scroll_to_output: 22,
+        timer: 5,
+        show_progress: 6,
+        message: 23,
+        progress: 7,
+        variant: 8,
+        loading_text: 9,
+        absolute: 10,
+        translucent: 11,
+        border: 12,
+        autoscroll: 24
+      },
+      null,
+      [-1, -1]
+    );
+  }
+}
+const ToastContent_svelte_svelte_type_style_lang = "", Toast_svelte_svelte_type_style_lang = "";
+var fn = new Intl.Collator(0, { numeric: 1 }).compare;
+function semiver(t, e, i) {
+  return t = t.split("."), e = e.split("."), fn(t[0], e[0]) || fn(t[1], e[1]) || (e[2] = e.slice(2).join("."), i = /[.-]/.test(t[2] = t.slice(2).join(".")), i == /[.-]/.test(e[2]) ? fn(t[2], e[2]) : i ? -1 : 1);
+}
+function resolve_root(t, e, i) {
+  return e.startsWith("http://") || e.startsWith("https://") ? i ? t : e : t + e;
+}
+function determine_protocol(t) {
+  if (t.startsWith("http")) {
+    const { protocol: e, host: i } = new URL(t);
+    return i.endsWith("hf.space") ? {
+      ws_protocol: "wss",
+      host: i,
+      http_protocol: e
+    } : {
+      ws_protocol: e === "https:" ? "wss" : "ws",
+      http_protocol: e,
+      host: i
+    };
+  } else if (t.startsWith("file:"))
+    return {
+      ws_protocol: "ws",
+      http_protocol: "http:",
+      host: "lite.local"
+      // Special fake hostname only used for this case. This matches the hostname allowed in `is_self_host()` in `js/wasm/network/host.ts`.
+    };
+  return {
+    ws_protocol: "wss",
+    http_protocol: "https:",
+    host: t
+  };
+}
+const RE_SPACE_NAME = /^[^\/]*\/[^\/]*$/, RE_SPACE_DOMAIN = /.*hf\.space\/{0,1}$/;
+async function process_endpoint(t, e) {
+  const i = {};
+  e && (i.Authorization = `Bearer ${e}`);
+  const n = t.trim();
+  if (RE_SPACE_NAME.test(n))
+    try {
+      const s = await fetch(
+        `https://huggingface.co/api/spaces/${n}/host`,
+        { headers: i }
+      );
+      if (s.status !== 200)
+        throw new Error("Space metadata could not be loaded.");
+      const l = (await s.json()).host;
+      return {
+        space_id: t,
+        ...determine_protocol(l)
+      };
+    } catch (s) {
+      throw new Error("Space metadata could not be loaded." + s.message);
+    }
+  if (RE_SPACE_DOMAIN.test(n)) {
+    const { ws_protocol: s, http_protocol: l, host: h } = determine_protocol(n);
+    return {
+      space_id: h.replace(".hf.space", ""),
+      ws_protocol: s,
+      http_protocol: l,
+      host: h
+    };
+  }
+  return {
+    space_id: !1,
+    ...determine_protocol(n)
+  };
+}
+function map_names_to_ids(t) {
+  let e = {};
+  return t.forEach(({ api_name: i }, n) => {
+    i && (e[i] = n);
+  }), e;
+}
+const RE_DISABLED_DISCUSSION = /^(?=[^]*\b[dD]iscussions{0,1}\b)(?=[^]*\b[dD]isabled\b)[^]*$/;
+async function discussions_enabled(t) {
+  try {
+    const i = (await fetch(
+      `https://huggingface.co/api/spaces/${t}/discussions`,
+      {
+        method: "HEAD"
+      }
+    )).headers.get("x-error-message");
+    return !(i && RE_DISABLED_DISCUSSION.test(i));
+  } catch {
+    return !1;
+  }
+}
+function normalise_file(t, e, i) {
+  if (t == null)
+    return null;
+  if (Array.isArray(t)) {
+    const n = [];
+    for (const s of t)
+      s == null ? n.push(null) : n.push(normalise_file(s, e, i));
+    return n;
+  }
+  return t.is_stream ? i == null ? new FileData({
+    ...t,
+    url: e + "/stream/" + t.path
+  }) : new FileData({
+    ...t,
+    url: "/proxy=" + i + "stream/" + t.path
+  }) : new FileData({
+    ...t,
+    url: get_fetchable_url_or_file(t.path, e, i)
+  });
+}
+function is_url(t) {
+  try {
+    const e = new URL(t);
+    return e.protocol === "http:" || e.protocol === "https:";
+  } catch {
+    return !1;
+  }
+}
+function get_fetchable_url_or_file(t, e, i) {
+  return t == null ? i ? `/proxy=${i}file=` : `${e}/file=` : is_url(t) ? t : i ? `/proxy=${i}file=${t}` : `${e}/file=${t}`;
+}
+async function upload(t, e, i = upload_files) {
+  let n = (Array.isArray(t) ? t : [t]).map(
+    (s) => s.blob
+  );
+  return await Promise.all(
+    await i(e, n).then(
+      async (s) => {
+        if (s.error)
+          throw new Error(s.error);
+        return s.files ? s.files.map((l, h) => {
+          const _ = new FileData({ ...t[h], path: l });
+          return normalise_file(_, e, null);
+        }) : [];
+      }
+    )
+  );
+}
+async function prepare_files(t, e) {
+  return t.map(
+    (i, n) => new FileData({
+      path: i.name,
+      orig_name: i.name,
+      blob: i,
+      size: i.size,
+      mime_type: i.type,
+      is_stream: e
+    })
+  );
+}
+class FileData {
+  constructor({
+    path: e,
+    url: i,
+    orig_name: n,
+    size: s,
+    blob: l,
+    is_stream: h,
+    mime_type: _,
+    alt_text: c
+  }) {
+    this.path = e, this.url = i, this.orig_name = n, this.size = s, this.blob = i ? void 0 : l, this.is_stream = h, this.mime_type = _, this.alt_text = c;
+  }
+}
+const QUEUE_FULL_MSG = "This application is too busy. Keep trying!", BROKEN_CONNECTION_MSG = "Connection errored out.";
+let NodeBlob;
+function api_factory(t, e) {
+  return { post_data: i, upload_files: n, client: s, handle_blob: l };
+  async function i(h, _, c) {
+    const o = { "Content-Type": "application/json" };
+    c && (o.Authorization = `Bearer ${c}`);
+    try {
+      var r = await t(h, {
+        method: "POST",
+        body: JSON.stringify(_),
+        headers: o
+      });
+    } catch {
+      return [{ error: BROKEN_CONNECTION_MSG }, 500];
+    }
+    return [await r.json(), r.status];
+  }
+  async function n(h, _, c) {
+    const o = {};
+    c && (o.Authorization = `Bearer ${c}`);
+    const r = 1e3, T = [];
+    for (let w = 0; w < _.length; w += r) {
+      const C = _.slice(w, w + r), P = new FormData();
+      C.forEach((k) => {
+        P.append("files", k);
+      });
+      try {
+        var S = await t(`${h}/upload`, {
+          method: "POST",
+          body: P,
+          headers: o
+        });
+      } catch {
+        return { error: BROKEN_CONNECTION_MSG };
+      }
+      const b = await S.json();
+      T.push(...b);
+    }
+    return { files: T };
+  }
+  async function s(h, _ = { normalise_files: !0 }) {
+    return new Promise(async (c) => {
+      const { status_callback: o, hf_token: r, normalise_files: T } = _, S = {
+        predict: N,
+        submit: D,
+        view_api: G,
+        component_server: X
+      }, w = T ?? !0;
+      if ((typeof window > "u" || !("WebSocket" in window)) && !global.Websocket) {
+        const I = await import("./wrapper-98f94c21-523a3923.js");
+        NodeBlob = (await Promise.resolve().then(() => __viteBrowserExternal)).Blob, global.WebSocket = I.WebSocket;
+      }
+      const { ws_protocol: C, http_protocol: P, host: b, space_id: k } = await process_endpoint(h, r), F = Math.random().toString(36).substring(2), x = {};
+      let y, p = {}, E = !1;
+      r && k && (E = await get_jwt(k, r));
+      async function $(I) {
+        if (y = I, p = map_names_to_ids((I == null ? void 0 : I.dependencies) || []), y.auth_required)
+          return {
+            config: y,
+            ...S
+          };
+        try {
+          M = await G(y);
+        } catch (B) {
+          console.error(`Could not get api details: ${B.message}`);
+        }
+        return {
+          config: y,
+          ...S
+        };
+      }
+      let M;
+      async function m(I) {
+        if (o && o(I), I.status === "running")
+          try {
+            y = await resolve_config(
+              t,
+              `${P}//${b}`,
+              r
+            );
+            const B = await $(y);
+            c(B);
+          } catch (B) {
+            console.error(B), o && o({
+              status: "error",
+              message: "Could not load this space.",
+              load_status: "error",
+              detail: "NOT_FOUND"
+            });
+          }
+      }
+      try {
+        y = await resolve_config(
+          t,
+          `${P}//${b}`,
+          r
+        );
+        const I = await $(y);
+        c(I);
+      } catch (I) {
+        console.error(I), k ? check_space_status(
+          k,
+          RE_SPACE_NAME.test(k) ? "space_name" : "subdomain",
+          m
+        ) : o && o({
+          status: "error",
+          message: "Could not load this space.",
+          load_status: "error",
+          detail: "NOT_FOUND"
+        });
+      }
+      function N(I, B, ee) {
+        let Y = !1, q = !1, le;
+        if (typeof I == "number")
+          le = y.dependencies[I];
+        else {
+          const pe = I.replace(/^\//, "");
+          le = y.dependencies[p[pe]];
+        }
+        if (le.types.continuous)
+          throw new Error(
+            "Cannot call predict on this function as it may run forever. Use submit instead"
+          );
+        return new Promise((pe, we) => {
+          const be = D(I, B, ee);
+          let R;
+          be.on("data", (d) => {
+            q && (be.destroy(), pe(d)), Y = !0, R = d;
+          }).on("status", (d) => {
+            d.stage === "error" && we(d), d.stage === "complete" && (q = !0, Y && (be.destroy(), pe(R)));
+          });
+        });
+      }
+      function D(I, B, ee) {
+        let Y, q;
+        if (typeof I == "number")
+          Y = I, q = M.unnamed_endpoints[Y];
+        else {
+          const Q = I.replace(/^\//, "");
+          Y = p[Q], q = M.named_endpoints[I.trim()];
+        }
+        if (typeof Y != "number")
+          throw new Error(
+            "There is no endpoint matching that name of fn_index matching that number."
+          );
+        let le, pe, we = y.protocol ?? "sse";
+        const be = typeof I == "number" ? "/predict" : I;
+        let R, d = null, g = !1;
+        const f = {};
+        let v = "";
+        typeof window < "u" && (v = new URLSearchParams(window.location.search).toString()), l(
+          `${P}//${resolve_root(b, y.path, !0)}`,
+          B,
+          q,
+          r
+        ).then((Q) => {
+          if (R = { data: Q || [], event_data: ee, fn_index: Y }, skip_queue(Y, y))
+            A({
+              type: "status",
+              endpoint: be,
+              stage: "pending",
+              queue: !1,
+              fn_index: Y,
+              time: /* @__PURE__ */ new Date()
+            }), i(
+              `${P}//${resolve_root(b, y.path, !0)}/run${be.startsWith("/") ? be : `/${be}`}${v ? "?" + v : ""}`,
+              {
+                ...R,
+                session_hash: F
+              },
+              r
+            ).then(([ue, me]) => {
+              const fe = w ? transform_output(
+                ue.data,
+                q,
+                y.root,
+                y.root_url
+              ) : ue.data;
+              me == 200 ? (A({
+                type: "data",
+                endpoint: be,
+                fn_index: Y,
+                data: fe,
+                time: /* @__PURE__ */ new Date()
+              }), A({
+                type: "status",
+                endpoint: be,
+                fn_index: Y,
+                stage: "complete",
+                eta: ue.average_duration,
+                queue: !1,
+                time: /* @__PURE__ */ new Date()
+              })) : A({
+                type: "status",
+                stage: "error",
+                endpoint: be,
+                fn_index: Y,
+                message: ue.error,
+                queue: !1,
+                time: /* @__PURE__ */ new Date()
+              });
+            }).catch((ue) => {
+              A({
+                type: "status",
+                stage: "error",
+                message: ue.message,
+                endpoint: be,
+                fn_index: Y,
+                queue: !1,
+                time: /* @__PURE__ */ new Date()
+              });
+            });
+          else if (we == "ws") {
+            A({
+              type: "status",
+              stage: "pending",
+              queue: !0,
+              endpoint: be,
+              fn_index: Y,
+              time: /* @__PURE__ */ new Date()
+            });
+            let ue = new URL(`${C}://${resolve_root(
+              b,
+              y.path,
+              !0
+            )}
+							/queue/join${v ? "?" + v : ""}`);
+            E && ue.searchParams.set("__sign", E), le = e(ue), le.onclose = (me) => {
+              me.wasClean || A({
+                type: "status",
+                stage: "error",
+                broken: !0,
+                message: BROKEN_CONNECTION_MSG,
+                queue: !0,
+                endpoint: be,
+                fn_index: Y,
+                time: /* @__PURE__ */ new Date()
+              });
+            }, le.onmessage = function(me) {
+              const fe = JSON.parse(me.data), { type: Pe, status: Fe, data: Ee } = handle_message(
+                fe,
+                x[Y]
+              );
+              if (Pe === "update" && Fe && !g)
+                A({
+                  type: "status",
+                  endpoint: be,
+                  fn_index: Y,
+                  time: /* @__PURE__ */ new Date(),
+                  ...Fe
+                }), Fe.stage === "error" && le.close();
+              else if (Pe === "hash") {
+                le.send(JSON.stringify({ fn_index: Y, session_hash: F }));
+                return;
+              } else
+                Pe === "data" ? le.send(JSON.stringify({ ...R, session_hash: F })) : Pe === "complete" ? g = Fe : Pe === "log" ? A({
+                  type: "log",
+                  log: Ee.log,
+                  level: Ee.level,
+                  endpoint: be,
+                  fn_index: Y
+                }) : Pe === "generating" && A({
+                  type: "status",
+                  time: /* @__PURE__ */ new Date(),
+                  ...Fe,
+                  stage: Fe == null ? void 0 : Fe.stage,
+                  queue: !0,
+                  endpoint: be,
+                  fn_index: Y
+                });
+              Ee && (A({
+                type: "data",
+                time: /* @__PURE__ */ new Date(),
+                data: w ? transform_output(
+                  Ee.data,
+                  q,
+                  y.root,
+                  y.root_url
+                ) : Ee.data,
+                endpoint: be,
+                fn_index: Y
+              }), g && (A({
+                type: "status",
+                time: /* @__PURE__ */ new Date(),
+                ...g,
+                stage: Fe == null ? void 0 : Fe.stage,
+                queue: !0,
+                endpoint: be,
+                fn_index: Y
+              }), le.close()));
+            }, semiver(y.version || "2.0.0", "3.6") < 0 && addEventListener(
+              "open",
+              () => le.send(JSON.stringify({ hash: F }))
+            );
+          } else {
+            A({
+              type: "status",
+              stage: "pending",
+              queue: !0,
+              endpoint: be,
+              fn_index: Y,
+              time: /* @__PURE__ */ new Date()
+            });
+            var ce = new URLSearchParams({
+              fn_index: Y.toString(),
+              session_hash: F
+            }).toString();
+            let ue = new URL(
+              `${P}//${resolve_root(
+                b,
+                y.path,
+                !0
+              )}/queue/join?${ce}`
+            );
+            pe = new EventSource(ue), pe.onmessage = async function(me) {
+              const fe = JSON.parse(me.data), { type: Pe, status: Fe, data: Ee } = handle_message(
+                fe,
+                x[Y]
+              );
+              if (Pe === "update" && Fe && !g)
+                A({
+                  type: "status",
+                  endpoint: be,
+                  fn_index: Y,
+                  time: /* @__PURE__ */ new Date(),
+                  ...Fe
+                }), Fe.stage === "error" && pe.close();
+              else if (Pe === "data") {
+                d = fe.event_id;
+                let [De, _e] = await i(
+                  `${P}//${resolve_root(
+                    b,
+                    y.path,
+                    !0
+                  )}/queue/data`,
+                  {
+                    ...R,
+                    session_hash: F,
+                    event_id: d
+                  },
+                  r
+                );
+                _e !== 200 && (A({
+                  type: "status",
+                  stage: "error",
+                  message: BROKEN_CONNECTION_MSG,
+                  queue: !0,
+                  endpoint: be,
+                  fn_index: Y,
+                  time: /* @__PURE__ */ new Date()
+                }), pe.close());
+              } else
+                Pe === "complete" ? g = Fe : Pe === "log" ? A({
+                  type: "log",
+                  log: Ee.log,
+                  level: Ee.level,
+                  endpoint: be,
+                  fn_index: Y
+                }) : Pe === "generating" && A({
+                  type: "status",
+                  time: /* @__PURE__ */ new Date(),
+                  ...Fe,
+                  stage: Fe == null ? void 0 : Fe.stage,
+                  queue: !0,
+                  endpoint: be,
+                  fn_index: Y
+                });
+              Ee && (A({
+                type: "data",
+                time: /* @__PURE__ */ new Date(),
+                data: w ? transform_output(
+                  Ee.data,
+                  q,
+                  y.root,
+                  y.root_url
+                ) : Ee.data,
+                endpoint: be,
+                fn_index: Y
+              }), g && (A({
+                type: "status",
+                time: /* @__PURE__ */ new Date(),
+                ...g,
+                stage: Fe == null ? void 0 : Fe.stage,
+                queue: !0,
+                endpoint: be,
+                fn_index: Y
+              }), pe.close()));
+            };
+          }
+        });
+        function A(Q) {
+          const ue = f[Q.type] || [];
+          ue == null || ue.forEach((me) => me(Q));
+        }
+        function O(Q, ce) {
+          const ue = f, me = ue[Q] || [];
+          return ue[Q] = me, me == null || me.push(ce), { on: O, off: H, cancel: z, destroy: ae };
+        }
+        function H(Q, ce) {
+          const ue = f;
+          let me = ue[Q] || [];
+          return me = me == null ? void 0 : me.filter((fe) => fe !== ce), ue[Q] = me, { on: O, off: H, cancel: z, destroy: ae };
+        }
+        async function z() {
+          const Q = {
+            stage: "complete",
+            queue: !1,
+            time: /* @__PURE__ */ new Date()
+          };
+          g = Q, A({
+            ...Q,
+            type: "status",
+            endpoint: be,
+            fn_index: Y
+          });
+          let ce = {};
+          we === "ws" ? (le && le.readyState === 0 ? le.addEventListener("open", () => {
+            le.close();
+          }) : le.close(), ce = { fn_index: Y, session_hash: F }) : (pe.close(), ce = { event_id: d });
+          try {
+            await t(
+              `${P}//${resolve_root(
+                b,
+                y.path,
+                !0
+              )}/reset`,
+              {
+                headers: { "Content-Type": "application/json" },
+                method: "POST",
+                body: JSON.stringify(ce)
+              }
+            );
+          } catch {
+            console.warn(
+              "The `/reset` endpoint could not be called. Subsequent endpoint results may be unreliable."
+            );
+          }
+        }
+        function ae() {
+          for (const Q in f)
+            f[Q].forEach((ce) => {
+              H(Q, ce);
+            });
+        }
+        return {
+          on: O,
+          off: H,
+          cancel: z,
+          destroy: ae
+        };
+      }
+      async function X(I, B, ee) {
+        var Y;
+        const q = { "Content-Type": "application/json" };
+        r && (q.Authorization = `Bearer ${r}`);
+        let le, pe = y.components.find(
+          (R) => R.id === I
+        );
+        (Y = pe == null ? void 0 : pe.props) != null && Y.root_url ? le = pe.props.root_url : le = `${P}//${resolve_root(
+          b,
+          y.path,
+          !0
+        )}/`;
+        const we = await t(
+          `${le}component_server/`,
+          {
+            method: "POST",
+            body: JSON.stringify({
+              data: ee,
+              component_id: I,
+              fn_name: B,
+              session_hash: F
+            }),
+            headers: q
+          }
+        );
+        if (!we.ok)
+          throw new Error(
+            "Could not connect to component server: " + we.statusText
+          );
+        return await we.json();
+      }
+      async function G(I) {
+        if (M)
+          return M;
+        const B = { "Content-Type": "application/json" };
+        r && (B.Authorization = `Bearer ${r}`);
+        let ee;
+        if (semiver(I.version || "2.0.0", "3.30") < 0 ? ee = await t(
+          "https://gradio-space-api-fetcher-v2.hf.space/api",
+          {
+            method: "POST",
+            body: JSON.stringify({
+              serialize: !1,
+              config: JSON.stringify(I)
+            }),
+            headers: B
+          }
+        ) : ee = await t(`${I.root}/info`, {
+          headers: B
+        }), !ee.ok)
+          throw new Error(BROKEN_CONNECTION_MSG);
+        let Y = await ee.json();
+        return "api" in Y && (Y = Y.api), Y.named_endpoints["/predict"] && !Y.unnamed_endpoints[0] && (Y.unnamed_endpoints[0] = Y.named_endpoints["/predict"]), transform_api_info(Y, I, p);
+      }
+    });
+  }
+  async function l(h, _, c, o) {
+    const r = await walk_and_store_blobs(
+      _,
+      void 0,
+      [],
+      !0,
+      c
+    );
+    return Promise.all(
+      r.map(async ({ path: T, blob: S, type: w }) => {
+        if (S) {
+          const C = (await n(h, [S], o)).files[0];
+          return { path: T, file_url: C, type: w, name: S == null ? void 0 : S.name };
+        }
+        return { path: T, type: w };
+      })
+    ).then((T) => (T.forEach(({ path: S, file_url: w, type: C, name: P }) => {
+      if (C === "Gallery")
+        update_object(_, w, S);
+      else if (w) {
+        const b = new FileData({ path: w, orig_name: P });
+        update_object(_, b, S);
+      }
+    }), _));
+  }
+}
+const { post_data, upload_files, client, handle_blob } = api_factory(
+  fetch,
+  (...t) => new WebSocket(...t)
+);
+function transform_output(t, e, i, n) {
+  return t.map((s, l) => {
+    var h, _, c, o;
+    return ((_ = (h = e == null ? void 0 : e.returns) == null ? void 0 : h[l]) == null ? void 0 : _.component) === "File" ? normalise_file(s, i, n) : ((o = (c = e == null ? void 0 : e.returns) == null ? void 0 : c[l]) == null ? void 0 : o.component) === "Gallery" ? s.map((r) => Array.isArray(r) ? [normalise_file(r[0], i, n), r[1]] : [normalise_file(r, i, n), null]) : typeof s == "object" && s.path ? normalise_file(s, i, n) : s;
+  });
+}
+function get_type(t, e, i, n) {
+  switch (t.type) {
+    case "string":
+      return "string";
+    case "boolean":
+      return "boolean";
+    case "number":
+      return "number";
+  }
+  if (i === "JSONSerializable" || i === "StringSerializable")
+    return "any";
+  if (i === "ListStringSerializable")
+    return "string[]";
+  if (e === "Image")
+    return n === "parameter" ? "Blob | File | Buffer" : "string";
+  if (i === "FileSerializable")
+    return (t == null ? void 0 : t.type) === "array" ? n === "parameter" ? "(Blob | File | Buffer)[]" : "{ name: string; data: string; size?: number; is_file?: boolean; orig_name?: string}[]" : n === "parameter" ? "Blob | File | Buffer" : "{ name: string; data: string; size?: number; is_file?: boolean; orig_name?: string}";
+  if (i === "GallerySerializable")
+    return n === "parameter" ? "[(Blob | File | Buffer), (string | null)][]" : "[{ name: string; data: string; size?: number; is_file?: boolean; orig_name?: string}, (string | null))][]";
+}
+function get_description(t, e) {
+  return e === "GallerySerializable" ? "array of [file, label] tuples" : e === "ListStringSerializable" ? "array of strings" : e === "FileSerializable" ? "array of files or single file" : t.description;
+}
+function transform_api_info(t, e, i) {
+  const n = {
+    named_endpoints: {},
+    unnamed_endpoints: {}
+  };
+  for (const s in t) {
+    const l = t[s];
+    for (const h in l) {
+      const _ = e.dependencies[h] ? h : i[h.replace("/", "")], c = l[h];
+      n[s][h] = {}, n[s][h].parameters = {}, n[s][h].returns = {}, n[s][h].type = e.dependencies[_].types, n[s][h].parameters = c.parameters.map(
+        ({ label: o, component: r, type: T, serializer: S }) => ({
+          label: o,
+          component: r,
+          type: get_type(T, r, S, "parameter"),
+          description: get_description(T, S)
+        })
+      ), n[s][h].returns = c.returns.map(
+        ({ label: o, component: r, type: T, serializer: S }) => ({
+          label: o,
+          component: r,
+          type: get_type(T, r, S, "return"),
+          description: get_description(T, S)
+        })
+      );
+    }
+  }
+  return n;
+}
+async function get_jwt(t, e) {
+  try {
+    return (await (await fetch(`https://huggingface.co/api/spaces/${t}/jwt`, {
+      headers: {
+        Authorization: `Bearer ${e}`
+      }
+    })).json()).token || !1;
+  } catch (i) {
+    return console.error(i), !1;
+  }
+}
+function update_object(t, e, i) {
+  for (; i.length > 1; )
+    t = t[i.shift()];
+  t[i.shift()] = e;
+}
+async function walk_and_store_blobs(t, e = void 0, i = [], n = !1, s = void 0) {
+  if (Array.isArray(t)) {
+    let l = [];
+    return await Promise.all(
+      t.map(async (h, _) => {
+        var c;
+        let o = i.slice();
+        o.push(_);
+        const r = await walk_and_store_blobs(
+          t[_],
+          n ? ((c = s == null ? void 0 : s.parameters[_]) == null ? void 0 : c.component) || void 0 : e,
+          o,
+          !1,
+          s
+        );
+        l = l.concat(r);
+      })
+    ), l;
+  } else {
+    if (globalThis.Buffer && t instanceof globalThis.Buffer)
+      return [
+        {
+          path: i,
+          blob: e === "Image" ? !1 : new NodeBlob([t]),
+          type: e
+        }
+      ];
+    if (typeof t == "object") {
+      let l = [];
+      for (let h in t)
+        if (t.hasOwnProperty(h)) {
+          let _ = i.slice();
+          _.push(h), l = l.concat(
+            await walk_and_store_blobs(
+              t[h],
+              void 0,
+              _,
+              !1,
+              s
+            )
+          );
+        }
+      return l;
+    }
+  }
+  return [];
+}
+function skip_queue(t, e) {
+  var i, n, s, l;
+  return !(((n = (i = e == null ? void 0 : e.dependencies) == null ? void 0 : i[t]) == null ? void 0 : n.queue) === null ? e.enable_queue : (l = (s = e == null ? void 0 : e.dependencies) == null ? void 0 : s[t]) != null && l.queue) || !1;
+}
+async function resolve_config(t, e, i) {
+  const n = {};
+  if (i && (n.Authorization = `Bearer ${i}`), typeof window < "u" && window.gradio_config && location.origin !== "http://localhost:9876" && !window.gradio_config.dev_mode) {
+    const s = window.gradio_config.root, l = window.gradio_config;
+    return l.root = resolve_root(e, l.root, !1), { ...l, path: s };
+  } else if (e) {
+    let s = await t(`${e}/config`, {
+      headers: n
+    });
+    if (s.status === 200) {
+      const l = await s.json();
+      return l.path = l.path ?? "", l.root = e, l;
+    }
+    throw new Error("Could not get config.");
+  }
+  throw new Error("No config or app endpoint found");
+}
+async function check_space_status(t, e, i) {
+  let n = e === "subdomain" ? `https://huggingface.co/api/spaces/by-subdomain/${t}` : `https://huggingface.co/api/spaces/${t}`, s, l;
+  try {
+    if (s = await fetch(n), l = s.status, l !== 200)
+      throw new Error();
+    s = await s.json();
+  } catch {
+    i({
+      status: "error",
+      load_status: "error",
+      message: "Could not get space status",
+      detail: "NOT_FOUND"
+    });
+    return;
+  }
+  if (!s || l !== 200)
+    return;
+  const {
+    runtime: { stage: h },
+    id: _
+  } = s;
+  switch (h) {
+    case "STOPPED":
+    case "SLEEPING":
+      i({
+        status: "sleeping",
+        load_status: "pending",
+        message: "Space is asleep. Waking it up...",
+        detail: h
+      }), setTimeout(() => {
+        check_space_status(t, e, i);
+      }, 1e3);
+      break;
+    case "PAUSED":
+      i({
+        status: "paused",
+        load_status: "error",
+        message: "This space has been paused by the author. If you would like to try this demo, consider duplicating the space.",
+        detail: h,
+        discussions_enabled: await discussions_enabled(_)
+      });
+      break;
+    case "RUNNING":
+    case "RUNNING_BUILDING":
+      i({
+        status: "running",
+        load_status: "complete",
+        message: "",
+        detail: h
+      });
+      break;
+    case "BUILDING":
+      i({
+        status: "building",
+        load_status: "pending",
+        message: "Space is building...",
+        detail: h
+      }), setTimeout(() => {
+        check_space_status(t, e, i);
+      }, 1e3);
+      break;
+    default:
+      i({
+        status: "space_error",
+        load_status: "error",
+        message: "This space is experiencing an issue.",
+        detail: h,
+        discussions_enabled: await discussions_enabled(_)
+      });
+      break;
+  }
+}
+function handle_message(t, e) {
+  switch (t.msg) {
+    case "send_data":
+      return { type: "data" };
+    case "send_hash":
+      return { type: "hash" };
+    case "queue_full":
+      return {
+        type: "update",
+        status: {
+          queue: !0,
+          message: QUEUE_FULL_MSG,
+          stage: "error",
+          code: t.code,
+          success: t.success
+        }
+      };
+    case "estimation":
+      return {
+        type: "update",
+        status: {
+          queue: !0,
+          stage: e || "pending",
+          code: t.code,
+          size: t.queue_size,
+          position: t.rank,
+          eta: t.rank_eta,
+          success: t.success
+        }
+      };
+    case "progress":
+      return {
+        type: "update",
+        status: {
+          queue: !0,
+          stage: "pending",
+          code: t.code,
+          progress_data: t.progress_data,
+          success: t.success
+        }
+      };
+    case "log":
+      return { type: "log", data: t };
+    case "process_generating":
+      return {
+        type: "generating",
+        status: {
+          queue: !0,
+          message: t.success ? null : t.output.error,
+          stage: t.success ? "generating" : "error",
+          code: t.code,
+          progress_data: t.progress_data,
+          eta: t.average_duration
+        },
+        data: t.success ? t.output : null
+      };
+    case "process_completed":
+      return "error" in t.output ? {
+        type: "update",
+        status: {
+          queue: !0,
+          message: t.output.error,
+          stage: "error",
+          code: t.code,
+          success: t.success
+        }
+      } : {
+        type: "complete",
+        status: {
+          queue: !0,
+          message: t.success ? void 0 : t.output.error,
+          stage: t.success ? "complete" : "error",
+          code: t.code,
+          progress_data: t.progress_data,
+          eta: t.output.average_duration
+        },
+        data: t.success ? t.output : null
+      };
+    case "process_starts":
+      return {
+        type: "update",
+        status: {
+          queue: !0,
+          stage: "pending",
+          code: t.code,
+          size: t.rank,
+          position: 0,
+          success: t.success
+        }
+      };
+  }
+  return { type: "none", status: { stage: "error", queue: !0 } };
+}
+function getDefaultExportFromCjs(t) {
+  return t && t.__esModule && Object.prototype.hasOwnProperty.call(t, "default") ? t.default : t;
+}
+function getAugmentedNamespace(t) {
+  if (t.__esModule)
+    return t;
+  var e = t.default;
+  if (typeof e == "function") {
+    var i = function n() {
+      return this instanceof n ? Reflect.construct(e, arguments, this.constructor) : e.apply(this, arguments);
+    };
+    i.prototype = e.prototype;
+  } else
+    i = {};
+  return Object.defineProperty(i, "__esModule", { value: !0 }), Object.keys(t).forEach(function(n) {
+    var s = Object.getOwnPropertyDescriptor(t, n);
+    Object.defineProperty(i, n, s.get ? s : {
+      enumerable: !0,
+      get: function() {
+        return t[n];
+      }
+    });
+  }), i;
+}
+var isMergeableObject = function(e) {
+  return isNonNullObject(e) && !isSpecial(e);
+};
+function isNonNullObject(t) {
+  return !!t && typeof t == "object";
+}
+function isSpecial(t) {
+  var e = Object.prototype.toString.call(t);
+  return e === "[object RegExp]" || e === "[object Date]" || isReactElement(t);
+}
+var canUseSymbol = typeof Symbol == "function" && Symbol.for, REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for("react.element") : 60103;
+function isReactElement(t) {
+  return t.$$typeof === REACT_ELEMENT_TYPE;
+}
+function emptyTarget(t) {
+  return Array.isArray(t) ? [] : {};
+}
+function cloneUnlessOtherwiseSpecified(t, e) {
+  return e.clone !== !1 && e.isMergeableObject(t) ? deepmerge(emptyTarget(t), t, e) : t;
+}
+function defaultArrayMerge(t, e, i) {
+  return t.concat(e).map(function(n) {
+    return cloneUnlessOtherwiseSpecified(n, i);
+  });
+}
+function getMergeFunction(t, e) {
+  if (!e.customMerge)
+    return deepmerge;
+  var i = e.customMerge(t);
+  return typeof i == "function" ? i : deepmerge;
+}
+function getEnumerableOwnPropertySymbols(t) {
+  return Object.getOwnPropertySymbols ? Object.getOwnPropertySymbols(t).filter(function(e) {
+    return Object.propertyIsEnumerable.call(t, e);
+  }) : [];
+}
+function getKeys(t) {
+  return Object.keys(t).concat(getEnumerableOwnPropertySymbols(t));
+}
+function propertyIsOnObject(t, e) {
+  try {
+    return e in t;
+  } catch {
+    return !1;
+  }
+}
+function propertyIsUnsafe(t, e) {
+  return propertyIsOnObject(t, e) && !(Object.hasOwnProperty.call(t, e) && Object.propertyIsEnumerable.call(t, e));
+}
+function mergeObject(t, e, i) {
+  var n = {};
+  return i.isMergeableObject(t) && getKeys(t).forEach(function(s) {
+    n[s] = cloneUnlessOtherwiseSpecified(t[s], i);
+  }), getKeys(e).forEach(function(s) {
+    propertyIsUnsafe(t, s) || (propertyIsOnObject(t, s) && i.isMergeableObject(e[s]) ? n[s] = getMergeFunction(s, i)(t[s], e[s], i) : n[s] = cloneUnlessOtherwiseSpecified(e[s], i));
+  }), n;
+}
+function deepmerge(t, e, i) {
+  i = i || {}, i.arrayMerge = i.arrayMerge || defaultArrayMerge, i.isMergeableObject = i.isMergeableObject || isMergeableObject, i.cloneUnlessOtherwiseSpecified = cloneUnlessOtherwiseSpecified;
+  var n = Array.isArray(e), s = Array.isArray(t), l = n === s;
+  return l ? n ? i.arrayMerge(t, e, i) : mergeObject(t, e, i) : cloneUnlessOtherwiseSpecified(e, i);
+}
+deepmerge.all = function(e, i) {
+  if (!Array.isArray(e))
+    throw new Error("first argument should be an array");
+  return e.reduce(function(n, s) {
+    return deepmerge(n, s, i);
+  }, {});
+};
+var deepmerge_1 = deepmerge, cjs = deepmerge_1;
+const deepmerge$1 = /* @__PURE__ */ getDefaultExportFromCjs(cjs);
+var extendStatics = function(t, e) {
+  return extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(i, n) {
+    i.__proto__ = n;
+  } || function(i, n) {
+    for (var s in n)
+      Object.prototype.hasOwnProperty.call(n, s) && (i[s] = n[s]);
+  }, extendStatics(t, e);
+};
+function __extends(t, e) {
+  if (typeof e != "function" && e !== null)
+    throw new TypeError("Class extends value " + String(e) + " is not a constructor or null");
+  extendStatics(t, e);
+  function i() {
+    this.constructor = t;
+  }
+  t.prototype = e === null ? Object.create(e) : (i.prototype = e.prototype, new i());
+}
+var __assign = function() {
+  return __assign = Object.assign || function(e) {
+    for (var i, n = 1, s = arguments.length; n < s; n++) {
+      i = arguments[n];
+      for (var l in i)
+        Object.prototype.hasOwnProperty.call(i, l) && (e[l] = i[l]);
+    }
+    return e;
+  }, __assign.apply(this, arguments);
+};
+function __spreadArray(t, e, i) {
+  if (i || arguments.length === 2)
+    for (var n = 0, s = e.length, l; n < s; n++)
+      (l || !(n in e)) && (l || (l = Array.prototype.slice.call(e, 0, n)), l[n] = e[n]);
+  return t.concat(l || Array.prototype.slice.call(e));
+}
+typeof SuppressedError == "function" && SuppressedError;
+var ErrorKind;
+(function(t) {
+  t[t.EXPECT_ARGUMENT_CLOSING_BRACE = 1] = "EXPECT_ARGUMENT_CLOSING_BRACE", t[t.EMPTY_ARGUMENT = 2] = "EMPTY_ARGUMENT", t[t.MALFORMED_ARGUMENT = 3] = "MALFORMED_ARGUMENT", t[t.EXPECT_ARGUMENT_TYPE = 4] = "EXPECT_ARGUMENT_TYPE", t[t.INVALID_ARGUMENT_TYPE = 5] = "INVALID_ARGUMENT_TYPE", t[t.EXPECT_ARGUMENT_STYLE = 6] = "EXPECT_ARGUMENT_STYLE", t[t.INVALID_NUMBER_SKELETON = 7] = "INVALID_NUMBER_SKELETON", t[t.INVALID_DATE_TIME_SKELETON = 8] = "INVALID_DATE_TIME_SKELETON", t[t.EXPECT_NUMBER_SKELETON = 9] = "EXPECT_NUMBER_SKELETON", t[t.EXPECT_DATE_TIME_SKELETON = 10] = "EXPECT_DATE_TIME_SKELETON", t[t.UNCLOSED_QUOTE_IN_ARGUMENT_STYLE = 11] = "UNCLOSED_QUOTE_IN_ARGUMENT_STYLE", t[t.EXPECT_SELECT_ARGUMENT_OPTIONS = 12] = "EXPECT_SELECT_ARGUMENT_OPTIONS", t[t.EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE = 13] = "EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE", t[t.INVALID_PLURAL_ARGUMENT_OFFSET_VALUE = 14] = "INVALID_PLURAL_ARGUMENT_OFFSET_VALUE", t[t.EXPECT_SELECT_ARGUMENT_SELECTOR = 15] = "EXPECT_SELECT_ARGUMENT_SELECTOR", t[t.EXPECT_PLURAL_ARGUMENT_SELECTOR = 16] = "EXPECT_PLURAL_ARGUMENT_SELECTOR", t[t.EXPECT_SELECT_ARGUMENT_SELECTOR_FRAGMENT = 17] = "EXPECT_SELECT_ARGUMENT_SELECTOR_FRAGMENT", t[t.EXPECT_PLURAL_ARGUMENT_SELECTOR_FRAGMENT = 18] = "EXPECT_PLURAL_ARGUMENT_SELECTOR_FRAGMENT", t[t.INVALID_PLURAL_ARGUMENT_SELECTOR = 19] = "INVALID_PLURAL_ARGUMENT_SELECTOR", t[t.DUPLICATE_PLURAL_ARGUMENT_SELECTOR = 20] = "DUPLICATE_PLURAL_ARGUMENT_SELECTOR", t[t.DUPLICATE_SELECT_ARGUMENT_SELECTOR = 21] = "DUPLICATE_SELECT_ARGUMENT_SELECTOR", t[t.MISSING_OTHER_CLAUSE = 22] = "MISSING_OTHER_CLAUSE", t[t.INVALID_TAG = 23] = "INVALID_TAG", t[t.INVALID_TAG_NAME = 25] = "INVALID_TAG_NAME", t[t.UNMATCHED_CLOSING_TAG = 26] = "UNMATCHED_CLOSING_TAG", t[t.UNCLOSED_TAG = 27] = "UNCLOSED_TAG";
+})(ErrorKind || (ErrorKind = {}));
+var TYPE;
+(function(t) {
+  t[t.literal = 0] = "literal", t[t.argument = 1] = "argument", t[t.number = 2] = "number", t[t.date = 3] = "date", t[t.time = 4] = "time", t[t.select = 5] = "select", t[t.plural = 6] = "plural", t[t.pound = 7] = "pound", t[t.tag = 8] = "tag";
+})(TYPE || (TYPE = {}));
+var SKELETON_TYPE;
+(function(t) {
+  t[t.number = 0] = "number", t[t.dateTime = 1] = "dateTime";
+})(SKELETON_TYPE || (SKELETON_TYPE = {}));
+function isLiteralElement(t) {
+  return t.type === TYPE.literal;
+}
+function isArgumentElement(t) {
+  return t.type === TYPE.argument;
+}
+function isNumberElement(t) {
+  return t.type === TYPE.number;
+}
+function isDateElement(t) {
+  return t.type === TYPE.date;
+}
+function isTimeElement(t) {
+  return t.type === TYPE.time;
+}
+function isSelectElement(t) {
+  return t.type === TYPE.select;
+}
+function isPluralElement(t) {
+  return t.type === TYPE.plural;
+}
+function isPoundElement(t) {
+  return t.type === TYPE.pound;
+}
+function isTagElement(t) {
+  return t.type === TYPE.tag;
+}
+function isNumberSkeleton(t) {
+  return !!(t && typeof t == "object" && t.type === SKELETON_TYPE.number);
+}
+function isDateTimeSkeleton(t) {
+  return !!(t && typeof t == "object" && t.type === SKELETON_TYPE.dateTime);
+}
+var SPACE_SEPARATOR_REGEX = /[ \xA0\u1680\u2000-\u200A\u202F\u205F\u3000]/, DATE_TIME_REGEX = /(?:[Eec]{1,6}|G{1,5}|[Qq]{1,5}|(?:[yYur]+|U{1,5})|[ML]{1,5}|d{1,2}|D{1,3}|F{1}|[abB]{1,5}|[hkHK]{1,2}|w{1,2}|W{1}|m{1,2}|s{1,2}|[zZOvVxX]{1,4})(?=([^']*'[^']*')*[^']*$)/g;
+function parseDateTimeSkeleton(t) {
+  var e = {};
+  return t.replace(DATE_TIME_REGEX, function(i) {
+    var n = i.length;
+    switch (i[0]) {
+      case "G":
+        e.era = n === 4 ? "long" : n === 5 ? "narrow" : "short";
+        break;
+      case "y":
+        e.year = n === 2 ? "2-digit" : "numeric";
+        break;
+      case "Y":
+      case "u":
+      case "U":
+      case "r":
+        throw new RangeError("`Y/u/U/r` (year) patterns are not supported, use `y` instead");
+      case "q":
+      case "Q":
+        throw new RangeError("`q/Q` (quarter) patterns are not supported");
+      case "M":
+      case "L":
+        e.month = ["numeric", "2-digit", "short", "long", "narrow"][n - 1];
+        break;
+      case "w":
+      case "W":
+        throw new RangeError("`w/W` (week) patterns are not supported");
+      case "d":
+        e.day = ["numeric", "2-digit"][n - 1];
+        break;
+      case "D":
+      case "F":
+      case "g":
+        throw new RangeError("`D/F/g` (day) patterns are not supported, use `d` instead");
+      case "E":
+        e.weekday = n === 4 ? "short" : n === 5 ? "narrow" : "short";
+        break;
+      case "e":
+        if (n < 4)
+          throw new RangeError("`e..eee` (weekday) patterns are not supported");
+        e.weekday = ["short", "long", "narrow", "short"][n - 4];
+        break;
+      case "c":
+        if (n < 4)
+          throw new RangeError("`c..ccc` (weekday) patterns are not supported");
+        e.weekday = ["short", "long", "narrow", "short"][n - 4];
+        break;
+      case "a":
+        e.hour12 = !0;
+        break;
+      case "b":
+      case "B":
+        throw new RangeError("`b/B` (period) patterns are not supported, use `a` instead");
+      case "h":
+        e.hourCycle = "h12", e.hour = ["numeric", "2-digit"][n - 1];
+        break;
+      case "H":
+        e.hourCycle = "h23", e.hour = ["numeric", "2-digit"][n - 1];
+        break;
+      case "K":
+        e.hourCycle = "h11", e.hour = ["numeric", "2-digit"][n - 1];
+        break;
+      case "k":
+        e.hourCycle = "h24", e.hour = ["numeric", "2-digit"][n - 1];
+        break;
+      case "j":
+      case "J":
+      case "C":
+        throw new RangeError("`j/J/C` (hour) patterns are not supported, use `h/H/K/k` instead");
+      case "m":
+        e.minute = ["numeric", "2-digit"][n - 1];
+        break;
+      case "s":
+        e.second = ["numeric", "2-digit"][n - 1];
+        break;
+      case "S":
+      case "A":
+        throw new RangeError("`S/A` (second) patterns are not supported, use `s` instead");
+      case "z":
+        e.timeZoneName = n < 4 ? "short" : "long";
+        break;
+      case "Z":
+      case "O":
+      case "v":
+      case "V":
+      case "X":
+      case "x":
+        throw new RangeError("`Z/O/v/V/X/x` (timeZone) patterns are not supported, use `z` instead");
+    }
+    return "";
+  }), e;
+}
+var WHITE_SPACE_REGEX = /[\t-\r \x85\u200E\u200F\u2028\u2029]/i;
+function parseNumberSkeletonFromString(t) {
+  if (t.length === 0)
+    throw new Error("Number skeleton cannot be empty");
+  for (var e = t.split(WHITE_SPACE_REGEX).filter(function(S) {
+    return S.length > 0;
+  }), i = [], n = 0, s = e; n < s.length; n++) {
+    var l = s[n], h = l.split("/");
+    if (h.length === 0)
+      throw new Error("Invalid number skeleton");
+    for (var _ = h[0], c = h.slice(1), o = 0, r = c; o < r.length; o++) {
+      var T = r[o];
+      if (T.length === 0)
+        throw new Error("Invalid number skeleton");
+    }
+    i.push({ stem: _, options: c });
+  }
+  return i;
+}
+function icuUnitToEcma(t) {
+  return t.replace(/^(.*?)-/, "");
+}
+var FRACTION_PRECISION_REGEX = /^\.(?:(0+)(\*)?|(#+)|(0+)(#+))$/g, SIGNIFICANT_PRECISION_REGEX = /^(@+)?(\+|#+)?[rs]?$/g, INTEGER_WIDTH_REGEX = /(\*)(0+)|(#+)(0+)|(0+)/g, CONCISE_INTEGER_WIDTH_REGEX = /^(0+)$/;
+function parseSignificantPrecision(t) {
+  var e = {};
+  return t[t.length - 1] === "r" ? e.roundingPriority = "morePrecision" : t[t.length - 1] === "s" && (e.roundingPriority = "lessPrecision"), t.replace(SIGNIFICANT_PRECISION_REGEX, function(i, n, s) {
+    return typeof s != "string" ? (e.minimumSignificantDigits = n.length, e.maximumSignificantDigits = n.length) : s === "+" ? e.minimumSignificantDigits = n.length : n[0] === "#" ? e.maximumSignificantDigits = n.length : (e.minimumSignificantDigits = n.length, e.maximumSignificantDigits = n.length + (typeof s == "string" ? s.length : 0)), "";
+  }), e;
+}
+function parseSign(t) {
+  switch (t) {
+    case "sign-auto":
+      return {
+        signDisplay: "auto"
+      };
+    case "sign-accounting":
+    case "()":
+      return {
+        currencySign: "accounting"
+      };
+    case "sign-always":
+    case "+!":
+      return {
+        signDisplay: "always"
+      };
+    case "sign-accounting-always":
+    case "()!":
+      return {
+        signDisplay: "always",
+        currencySign: "accounting"
+      };
+    case "sign-except-zero":
+    case "+?":
+      return {
+        signDisplay: "exceptZero"
+      };
+    case "sign-accounting-except-zero":
+    case "()?":
+      return {
+        signDisplay: "exceptZero",
+        currencySign: "accounting"
+      };
+    case "sign-never":
+    case "+_":
+      return {
+        signDisplay: "never"
+      };
+  }
+}
+function parseConciseScientificAndEngineeringStem(t) {
+  var e;
+  if (t[0] === "E" && t[1] === "E" ? (e = {
+    notation: "engineering"
+  }, t = t.slice(2)) : t[0] === "E" && (e = {
+    notation: "scientific"
+  }, t = t.slice(1)), e) {
+    var i = t.slice(0, 2);
+    if (i === "+!" ? (e.signDisplay = "always", t = t.slice(2)) : i === "+?" && (e.signDisplay = "exceptZero", t = t.slice(2)), !CONCISE_INTEGER_WIDTH_REGEX.test(t))
+      throw new Error("Malformed concise eng/scientific notation");
+    e.minimumIntegerDigits = t.length;
+  }
+  return e;
+}
+function parseNotationOptions(t) {
+  var e = {}, i = parseSign(t);
+  return i || e;
+}
+function parseNumberSkeleton(t) {
+  for (var e = {}, i = 0, n = t; i < n.length; i++) {
+    var s = n[i];
+    switch (s.stem) {
+      case "percent":
+      case "%":
+        e.style = "percent";
+        continue;
+      case "%x100":
+        e.style = "percent", e.scale = 100;
+        continue;
+      case "currency":
+        e.style = "currency", e.currency = s.options[0];
+        continue;
+      case "group-off":
+      case ",_":
+        e.useGrouping = !1;
+        continue;
+      case "precision-integer":
+      case ".":
+        e.maximumFractionDigits = 0;
+        continue;
+      case "measure-unit":
+      case "unit":
+        e.style = "unit", e.unit = icuUnitToEcma(s.options[0]);
+        continue;
+      case "compact-short":
+      case "K":
+        e.notation = "compact", e.compactDisplay = "short";
+        continue;
+      case "compact-long":
+      case "KK":
+        e.notation = "compact", e.compactDisplay = "long";
+        continue;
+      case "scientific":
+        e = __assign(__assign(__assign({}, e), { notation: "scientific" }), s.options.reduce(function(c, o) {
+          return __assign(__assign({}, c), parseNotationOptions(o));
+        }, {}));
+        continue;
+      case "engineering":
+        e = __assign(__assign(__assign({}, e), { notation: "engineering" }), s.options.reduce(function(c, o) {
+          return __assign(__assign({}, c), parseNotationOptions(o));
+        }, {}));
+        continue;
+      case "notation-simple":
+        e.notation = "standard";
+        continue;
+      case "unit-width-narrow":
+        e.currencyDisplay = "narrowSymbol", e.unitDisplay = "narrow";
+        continue;
+      case "unit-width-short":
+        e.currencyDisplay = "code", e.unitDisplay = "short";
+        continue;
+      case "unit-width-full-name":
+        e.currencyDisplay = "name", e.unitDisplay = "long";
+        continue;
+      case "unit-width-iso-code":
+        e.currencyDisplay = "symbol";
+        continue;
+      case "scale":
+        e.scale = parseFloat(s.options[0]);
+        continue;
+      case "integer-width":
+        if (s.options.length > 1)
+          throw new RangeError("integer-width stems only accept a single optional option");
+        s.options[0].replace(INTEGER_WIDTH_REGEX, function(c, o, r, T, S, w) {
+          if (o)
+            e.minimumIntegerDigits = r.length;
+          else {
+            if (T && S)
+              throw new Error("We currently do not support maximum integer digits");
+            if (w)
+              throw new Error("We currently do not support exact integer digits");
+          }
+          return "";
+        });
+        continue;
+    }
+    if (CONCISE_INTEGER_WIDTH_REGEX.test(s.stem)) {
+      e.minimumIntegerDigits = s.stem.length;
+      continue;
+    }
+    if (FRACTION_PRECISION_REGEX.test(s.stem)) {
+      if (s.options.length > 1)
+        throw new RangeError("Fraction-precision stems only accept a single optional option");
+      s.stem.replace(FRACTION_PRECISION_REGEX, function(c, o, r, T, S, w) {
+        return r === "*" ? e.minimumFractionDigits = o.length : T && T[0] === "#" ? e.maximumFractionDigits = T.length : S && w ? (e.minimumFractionDigits = S.length, e.maximumFractionDigits = S.length + w.length) : (e.minimumFractionDigits = o.length, e.maximumFractionDigits = o.length), "";
+      });
+      var l = s.options[0];
+      l === "w" ? e = __assign(__assign({}, e), { trailingZeroDisplay: "stripIfInteger" }) : l && (e = __assign(__assign({}, e), parseSignificantPrecision(l)));
+      continue;
+    }
+    if (SIGNIFICANT_PRECISION_REGEX.test(s.stem)) {
+      e = __assign(__assign({}, e), parseSignificantPrecision(s.stem));
+      continue;
+    }
+    var h = parseSign(s.stem);
+    h && (e = __assign(__assign({}, e), h));
+    var _ = parseConciseScientificAndEngineeringStem(s.stem);
+    _ && (e = __assign(__assign({}, e), _));
+  }
+  return e;
+}
+var timeData = {
+  AX: [
+    "H"
+  ],
+  BQ: [
+    "H"
+  ],
+  CP: [
+    "H"
+  ],
+  CZ: [
+    "H"
+  ],
+  DK: [
+    "H"
+  ],
+  FI: [
+    "H"
+  ],
+  ID: [
+    "H"
+  ],
+  IS: [
+    "H"
+  ],
+  ML: [
+    "H"
+  ],
+  NE: [
+    "H"
+  ],
+  RU: [
+    "H"
+  ],
+  SE: [
+    "H"
+  ],
+  SJ: [
+    "H"
+  ],
+  SK: [
+    "H"
+  ],
+  AS: [
+    "h",
+    "H"
+  ],
+  BT: [
+    "h",
+    "H"
+  ],
+  DJ: [
+    "h",
+    "H"
+  ],
+  ER: [
+    "h",
+    "H"
+  ],
+  GH: [
+    "h",
+    "H"
+  ],
+  IN: [
+    "h",
+    "H"
+  ],
+  LS: [
+    "h",
+    "H"
+  ],
+  PG: [
+    "h",
+    "H"
+  ],
+  PW: [
+    "h",
+    "H"
+  ],
+  SO: [
+    "h",
+    "H"
+  ],
+  TO: [
+    "h",
+    "H"
+  ],
+  VU: [
+    "h",
+    "H"
+  ],
+  WS: [
+    "h",
+    "H"
+  ],
+  "001": [
+    "H",
+    "h"
+  ],
+  AL: [
+    "h",
+    "H",
+    "hB"
+  ],
+  TD: [
+    "h",
+    "H",
+    "hB"
+  ],
+  "ca-ES": [
+    "H",
+    "h",
+    "hB"
+  ],
+  CF: [
+    "H",
+    "h",
+    "hB"
+  ],
+  CM: [
+    "H",
+    "h",
+    "hB"
+  ],
+  "fr-CA": [
+    "H",
+    "h",
+    "hB"
+  ],
+  "gl-ES": [
+    "H",
+    "h",
+    "hB"
+  ],
+  "it-CH": [
+    "H",
+    "h",
+    "hB"
+  ],
+  "it-IT": [
+    "H",
+    "h",
+    "hB"
+  ],
+  LU: [
+    "H",
+    "h",
+    "hB"
+  ],
+  NP: [
+    "H",
+    "h",
+    "hB"
+  ],
+  PF: [
+    "H",
+    "h",
+    "hB"
+  ],
+  SC: [
+    "H",
+    "h",
+    "hB"
+  ],
+  SM: [
+    "H",
+    "h",
+    "hB"
+  ],
+  SN: [
+    "H",
+    "h",
+    "hB"
+  ],
+  TF: [
+    "H",
+    "h",
+    "hB"
+  ],
+  VA: [
+    "H",
+    "h",
+    "hB"
+  ],
+  CY: [
+    "h",
+    "H",
+    "hb",
+    "hB"
+  ],
+  GR: [
+    "h",
+    "H",
+    "hb",
+    "hB"
+  ],
+  CO: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  DO: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  KP: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  KR: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  NA: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  PA: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  PR: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  VE: [
+    "h",
+    "H",
+    "hB",
+    "hb"
+  ],
+  AC: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  AI: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  BW: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  BZ: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  CC: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  CK: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  CX: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  DG: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  FK: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  GB: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  GG: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  GI: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  IE: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  IM: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  IO: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  JE: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  LT: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  MK: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  MN: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  MS: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  NF: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  NG: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  NR: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  NU: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  PN: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  SH: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  SX: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  TA: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  ZA: [
+    "H",
+    "h",
+    "hb",
+    "hB"
+  ],
+  "af-ZA": [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  AR: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  CL: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  CR: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  CU: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  EA: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  "es-BO": [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  "es-BR": [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  "es-EC": [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  "es-ES": [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  "es-GQ": [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  "es-PE": [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  GT: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  HN: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  IC: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  KG: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  KM: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  LK: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  MA: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  MX: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  NI: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  PY: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  SV: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  UY: [
+    "H",
+    "h",
+    "hB",
+    "hb"
+  ],
+  JP: [
+    "H",
+    "h",
+    "K"
+  ],
+  AD: [
+    "H",
+    "hB"
+  ],
+  AM: [
+    "H",
+    "hB"
+  ],
+  AO: [
+    "H",
+    "hB"
+  ],
+  AT: [
+    "H",
+    "hB"
+  ],
+  AW: [
+    "H",
+    "hB"
+  ],
+  BE: [
+    "H",
+    "hB"
+  ],
+  BF: [
+    "H",
+    "hB"
+  ],
+  BJ: [
+    "H",
+    "hB"
+  ],
+  BL: [
+    "H",
+    "hB"
+  ],
+  BR: [
+    "H",
+    "hB"
+  ],
+  CG: [
+    "H",
+    "hB"
+  ],
+  CI: [
+    "H",
+    "hB"
+  ],
+  CV: [
+    "H",
+    "hB"
+  ],
+  DE: [
+    "H",
+    "hB"
+  ],
+  EE: [
+    "H",
+    "hB"
+  ],
+  FR: [
+    "H",
+    "hB"
+  ],
+  GA: [
+    "H",
+    "hB"
+  ],
+  GF: [
+    "H",
+    "hB"
+  ],
+  GN: [
+    "H",
+    "hB"
+  ],
+  GP: [
+    "H",
+    "hB"
+  ],
+  GW: [
+    "H",
+    "hB"
+  ],
+  HR: [
+    "H",
+    "hB"
+  ],
+  IL: [
+    "H",
+    "hB"
+  ],
+  IT: [
+    "H",
+    "hB"
+  ],
+  KZ: [
+    "H",
+    "hB"
+  ],
+  MC: [
+    "H",
+    "hB"
+  ],
+  MD: [
+    "H",
+    "hB"
+  ],
+  MF: [
+    "H",
+    "hB"
+  ],
+  MQ: [
+    "H",
+    "hB"
+  ],
+  MZ: [
+    "H",
+    "hB"
+  ],
+  NC: [
+    "H",
+    "hB"
+  ],
+  NL: [
+    "H",
+    "hB"
+  ],
+  PM: [
+    "H",
+    "hB"
+  ],
+  PT: [
+    "H",
+    "hB"
+  ],
+  RE: [
+    "H",
+    "hB"
+  ],
+  RO: [
+    "H",
+    "hB"
+  ],
+  SI: [
+    "H",
+    "hB"
+  ],
+  SR: [
+    "H",
+    "hB"
+  ],
+  ST: [
+    "H",
+    "hB"
+  ],
+  TG: [
+    "H",
+    "hB"
+  ],
+  TR: [
+    "H",
+    "hB"
+  ],
+  WF: [
+    "H",
+    "hB"
+  ],
+  YT: [
+    "H",
+    "hB"
+  ],
+  BD: [
+    "h",
+    "hB",
+    "H"
+  ],
+  PK: [
+    "h",
+    "hB",
+    "H"
+  ],
+  AZ: [
+    "H",
+    "hB",
+    "h"
+  ],
+  BA: [
+    "H",
+    "hB",
+    "h"
+  ],
+  BG: [
+    "H",
+    "hB",
+    "h"
+  ],
+  CH: [
+    "H",
+    "hB",
+    "h"
+  ],
+  GE: [
+    "H",
+    "hB",
+    "h"
+  ],
+  LI: [
+    "H",
+    "hB",
+    "h"
+  ],
+  ME: [
+    "H",
+    "hB",
+    "h"
+  ],
+  RS: [
+    "H",
+    "hB",
+    "h"
+  ],
+  UA: [
+    "H",
+    "hB",
+    "h"
+  ],
+  UZ: [
+    "H",
+    "hB",
+    "h"
+  ],
+  XK: [
+    "H",
+    "hB",
+    "h"
+  ],
+  AG: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  AU: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  BB: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  BM: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  BS: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  CA: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  DM: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  "en-001": [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  FJ: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  FM: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  GD: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  GM: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  GU: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  GY: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  JM: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  KI: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  KN: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  KY: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  LC: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  LR: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  MH: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  MP: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  MW: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  NZ: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  SB: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  SG: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  SL: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  SS: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  SZ: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  TC: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  TT: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  UM: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  US: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  VC: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  VG: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  VI: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  ZM: [
+    "h",
+    "hb",
+    "H",
+    "hB"
+  ],
+  BO: [
+    "H",
+    "hB",
+    "h",
+    "hb"
+  ],
+  EC: [
+    "H",
+    "hB",
+    "h",
+    "hb"
+  ],
+  ES: [
+    "H",
+    "hB",
+    "h",
+    "hb"
+  ],
+  GQ: [
+    "H",
+    "hB",
+    "h",
+    "hb"
+  ],
+  PE: [
+    "H",
+    "hB",
+    "h",
+    "hb"
+  ],
+  AE: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  "ar-001": [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  BH: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  DZ: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  EG: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  EH: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  HK: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  IQ: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  JO: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  KW: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  LB: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  LY: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  MO: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  MR: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  OM: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  PH: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  PS: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  QA: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  SA: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  SD: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  SY: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  TN: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  YE: [
+    "h",
+    "hB",
+    "hb",
+    "H"
+  ],
+  AF: [
+    "H",
+    "hb",
+    "hB",
+    "h"
+  ],
+  LA: [
+    "H",
+    "hb",
+    "hB",
+    "h"
+  ],
+  CN: [
+    "H",
+    "hB",
+    "hb",
+    "h"
+  ],
+  LV: [
+    "H",
+    "hB",
+    "hb",
+    "h"
+  ],
+  TL: [
+    "H",
+    "hB",
+    "hb",
+    "h"
+  ],
+  "zu-ZA": [
+    "H",
+    "hB",
+    "hb",
+    "h"
+  ],
+  CD: [
+    "hB",
+    "H"
+  ],
+  IR: [
+    "hB",
+    "H"
+  ],
+  "hi-IN": [
+    "hB",
+    "h",
+    "H"
+  ],
+  "kn-IN": [
+    "hB",
+    "h",
+    "H"
+  ],
+  "ml-IN": [
+    "hB",
+    "h",
+    "H"
+  ],
+  "te-IN": [
+    "hB",
+    "h",
+    "H"
+  ],
+  KH: [
+    "hB",
+    "h",
+    "H",
+    "hb"
+  ],
+  "ta-IN": [
+    "hB",
+    "h",
+    "hb",
+    "H"
+  ],
+  BN: [
+    "hb",
+    "hB",
+    "h",
+    "H"
+  ],
+  MY: [
+    "hb",
+    "hB",
+    "h",
+    "H"
+  ],
+  ET: [
+    "hB",
+    "hb",
+    "h",
+    "H"
+  ],
+  "gu-IN": [
+    "hB",
+    "hb",
+    "h",
+    "H"
+  ],
+  "mr-IN": [
+    "hB",
+    "hb",
+    "h",
+    "H"
+  ],
+  "pa-IN": [
+    "hB",
+    "hb",
+    "h",
+    "H"
+  ],
+  TW: [
+    "hB",
+    "hb",
+    "h",
+    "H"
+  ],
+  KE: [
+    "hB",
+    "hb",
+    "H",
+    "h"
+  ],
+  MM: [
+    "hB",
+    "hb",
+    "H",
+    "h"
+  ],
+  TZ: [
+    "hB",
+    "hb",
+    "H",
+    "h"
+  ],
+  UG: [
+    "hB",
+    "hb",
+    "H",
+    "h"
+  ]
+};
+function getBestPattern(t, e) {
+  for (var i = "", n = 0; n < t.length; n++) {
+    var s = t.charAt(n);
+    if (s === "j") {
+      for (var l = 0; n + 1 < t.length && t.charAt(n + 1) === s; )
+        l++, n++;
+      var h = 1 + (l & 1), _ = l < 2 ? 1 : 3 + (l >> 1), c = "a", o = getDefaultHourSymbolFromLocale(e);
+      for ((o == "H" || o == "k") && (_ = 0); _-- > 0; )
+        i += c;
+      for (; h-- > 0; )
+        i = o + i;
+    } else
+      s === "J" ? i += "H" : i += s;
+  }
+  return i;
+}
+function getDefaultHourSymbolFromLocale(t) {
+  var e = t.hourCycle;
+  if (e === void 0 && // @ts-ignore hourCycle(s) is not identified yet
+  t.hourCycles && // @ts-ignore
+  t.hourCycles.length && (e = t.hourCycles[0]), e)
+    switch (e) {
+      case "h24":
+        return "k";
+      case "h23":
+        return "H";
+      case "h12":
+        return "h";
+      case "h11":
+        return "K";
+      default:
+        throw new Error("Invalid hourCycle");
+    }
+  var i = t.language, n;
+  i !== "root" && (n = t.maximize().region);
+  var s = timeData[n || ""] || timeData[i || ""] || timeData["".concat(i, "-001")] || timeData["001"];
+  return s[0];
+}
+var _a, SPACE_SEPARATOR_START_REGEX = new RegExp("^".concat(SPACE_SEPARATOR_REGEX.source, "*")), SPACE_SEPARATOR_END_REGEX = new RegExp("".concat(SPACE_SEPARATOR_REGEX.source, "*$"));
+function createLocation(t, e) {
+  return { start: t, end: e };
+}
+var hasNativeStartsWith = !!String.prototype.startsWith, hasNativeFromCodePoint = !!String.fromCodePoint, hasNativeFromEntries = !!Object.fromEntries, hasNativeCodePointAt = !!String.prototype.codePointAt, hasTrimStart = !!String.prototype.trimStart, hasTrimEnd = !!String.prototype.trimEnd, hasNativeIsSafeInteger = !!Number.isSafeInteger, isSafeInteger = hasNativeIsSafeInteger ? Number.isSafeInteger : function(t) {
+  return typeof t == "number" && isFinite(t) && Math.floor(t) === t && Math.abs(t) <= 9007199254740991;
+}, REGEX_SUPPORTS_U_AND_Y = !0;
+try {
+  var re = RE("([^\\p{White_Space}\\p{Pattern_Syntax}]*)", "yu");
+  REGEX_SUPPORTS_U_AND_Y = ((_a = re.exec("a")) === null || _a === void 0 ? void 0 : _a[0]) === "a";
+} catch {
+  REGEX_SUPPORTS_U_AND_Y = !1;
+}
+var startsWith = hasNativeStartsWith ? (
+  // Native
+  function(e, i, n) {
+    return e.startsWith(i, n);
+  }
+) : (
+  // For IE11
+  function(e, i, n) {
+    return e.slice(n, n + i.length) === i;
+  }
+), fromCodePoint = hasNativeFromCodePoint ? String.fromCodePoint : (
+  // IE11
+  function() {
+    for (var e = [], i = 0; i < arguments.length; i++)
+      e[i] = arguments[i];
+    for (var n = "", s = e.length, l = 0, h; s > l; ) {
+      if (h = e[l++], h > 1114111)
+        throw RangeError(h + " is not a valid code point");
+      n += h < 65536 ? String.fromCharCode(h) : String.fromCharCode(((h -= 65536) >> 10) + 55296, h % 1024 + 56320);
+    }
+    return n;
+  }
+), fromEntries = (
+  // native
+  hasNativeFromEntries ? Object.fromEntries : (
+    // Ponyfill
+    function(e) {
+      for (var i = {}, n = 0, s = e; n < s.length; n++) {
+        var l = s[n], h = l[0], _ = l[1];
+        i[h] = _;
+      }
+      return i;
+    }
+  )
+), codePointAt = hasNativeCodePointAt ? (
+  // Native
+  function(e, i) {
+    return e.codePointAt(i);
+  }
+) : (
+  // IE 11
+  function(e, i) {
+    var n = e.length;
+    if (!(i < 0 || i >= n)) {
+      var s = e.charCodeAt(i), l;
+      return s < 55296 || s > 56319 || i + 1 === n || (l = e.charCodeAt(i + 1)) < 56320 || l > 57343 ? s : (s - 55296 << 10) + (l - 56320) + 65536;
+    }
+  }
+), trimStart = hasTrimStart ? (
+  // Native
+  function(e) {
+    return e.trimStart();
+  }
+) : (
+  // Ponyfill
+  function(e) {
+    return e.replace(SPACE_SEPARATOR_START_REGEX, "");
+  }
+), trimEnd = hasTrimEnd ? (
+  // Native
+  function(e) {
+    return e.trimEnd();
+  }
+) : (
+  // Ponyfill
+  function(e) {
+    return e.replace(SPACE_SEPARATOR_END_REGEX, "");
+  }
+);
+function RE(t, e) {
+  return new RegExp(t, e);
+}
+var matchIdentifierAtIndex;
+if (REGEX_SUPPORTS_U_AND_Y) {
+  var IDENTIFIER_PREFIX_RE_1 = RE("([^\\p{White_Space}\\p{Pattern_Syntax}]*)", "yu");
+  matchIdentifierAtIndex = function(e, i) {
+    var n;
+    IDENTIFIER_PREFIX_RE_1.lastIndex = i;
+    var s = IDENTIFIER_PREFIX_RE_1.exec(e);
+    return (n = s[1]) !== null && n !== void 0 ? n : "";
+  };
+} else
+  matchIdentifierAtIndex = function(e, i) {
+    for (var n = []; ; ) {
+      var s = codePointAt(e, i);
+      if (s === void 0 || _isWhiteSpace(s) || _isPatternSyntax(s))
+        break;
+      n.push(s), i += s >= 65536 ? 2 : 1;
+    }
+    return fromCodePoint.apply(void 0, n);
+  };
+var Parser = (
+  /** @class */
+  function() {
+    function t(e, i) {
+      i === void 0 && (i = {}), this.message = e, this.position = { offset: 0, line: 1, column: 1 }, this.ignoreTag = !!i.ignoreTag, this.locale = i.locale, this.requiresOtherClause = !!i.requiresOtherClause, this.shouldParseSkeletons = !!i.shouldParseSkeletons;
+    }
+    return t.prototype.parse = function() {
+      if (this.offset() !== 0)
+        throw Error("parser can only be used once");
+      return this.parseMessage(0, "", !1);
+    }, t.prototype.parseMessage = function(e, i, n) {
+      for (var s = []; !this.isEOF(); ) {
+        var l = this.char();
+        if (l === 123) {
+          var h = this.parseArgument(e, n);
+          if (h.err)
+            return h;
+          s.push(h.val);
+        } else {
+          if (l === 125 && e > 0)
+            break;
+          if (l === 35 && (i === "plural" || i === "selectordinal")) {
+            var _ = this.clonePosition();
+            this.bump(), s.push({
+              type: TYPE.pound,
+              location: createLocation(_, this.clonePosition())
+            });
+          } else if (l === 60 && !this.ignoreTag && this.peek() === 47) {
+            if (n)
+              break;
+            return this.error(ErrorKind.UNMATCHED_CLOSING_TAG, createLocation(this.clonePosition(), this.clonePosition()));
+          } else if (l === 60 && !this.ignoreTag && _isAlpha(this.peek() || 0)) {
+            var h = this.parseTag(e, i);
+            if (h.err)
+              return h;
+            s.push(h.val);
+          } else {
+            var h = this.parseLiteral(e, i);
+            if (h.err)
+              return h;
+            s.push(h.val);
+          }
+        }
+      }
+      return { val: s, err: null };
+    }, t.prototype.parseTag = function(e, i) {
+      var n = this.clonePosition();
+      this.bump();
+      var s = this.parseTagName();
+      if (this.bumpSpace(), this.bumpIf("/>"))
+        return {
+          val: {
+            type: TYPE.literal,
+            value: "<".concat(s, "/>"),
+            location: createLocation(n, this.clonePosition())
+          },
+          err: null
+        };
+      if (this.bumpIf(">")) {
+        var l = this.parseMessage(e + 1, i, !0);
+        if (l.err)
+          return l;
+        var h = l.val, _ = this.clonePosition();
+        if (this.bumpIf("</")) {
+          if (this.isEOF() || !_isAlpha(this.char()))
+            return this.error(ErrorKind.INVALID_TAG, createLocation(_, this.clonePosition()));
+          var c = this.clonePosition(), o = this.parseTagName();
+          return s !== o ? this.error(ErrorKind.UNMATCHED_CLOSING_TAG, createLocation(c, this.clonePosition())) : (this.bumpSpace(), this.bumpIf(">") ? {
+            val: {
+              type: TYPE.tag,
+              value: s,
+              children: h,
+              location: createLocation(n, this.clonePosition())
+            },
+            err: null
+          } : this.error(ErrorKind.INVALID_TAG, createLocation(_, this.clonePosition())));
+        } else
+          return this.error(ErrorKind.UNCLOSED_TAG, createLocation(n, this.clonePosition()));
+      } else
+        return this.error(ErrorKind.INVALID_TAG, createLocation(n, this.clonePosition()));
+    }, t.prototype.parseTagName = function() {
+      var e = this.offset();
+      for (this.bump(); !this.isEOF() && _isPotentialElementNameChar(this.char()); )
+        this.bump();
+      return this.message.slice(e, this.offset());
+    }, t.prototype.parseLiteral = function(e, i) {
+      for (var n = this.clonePosition(), s = ""; ; ) {
+        var l = this.tryParseQuote(i);
+        if (l) {
+          s += l;
+          continue;
+        }
+        var h = this.tryParseUnquoted(e, i);
+        if (h) {
+          s += h;
+          continue;
+        }
+        var _ = this.tryParseLeftAngleBracket();
+        if (_) {
+          s += _;
+          continue;
+        }
+        break;
+      }
+      var c = createLocation(n, this.clonePosition());
+      return {
+        val: { type: TYPE.literal, value: s, location: c },
+        err: null
+      };
+    }, t.prototype.tryParseLeftAngleBracket = function() {
+      return !this.isEOF() && this.char() === 60 && (this.ignoreTag || // If at the opening tag or closing tag position, bail.
+      !_isAlphaOrSlash(this.peek() || 0)) ? (this.bump(), "<") : null;
+    }, t.prototype.tryParseQuote = function(e) {
+      if (this.isEOF() || this.char() !== 39)
+        return null;
+      switch (this.peek()) {
+        case 39:
+          return this.bump(), this.bump(), "'";
+        case 123:
+        case 60:
+        case 62:
+        case 125:
+          break;
+        case 35:
+          if (e === "plural" || e === "selectordinal")
+            break;
+          return null;
+        default:
+          return null;
+      }
+      this.bump();
+      var i = [this.char()];
+      for (this.bump(); !this.isEOF(); ) {
+        var n = this.char();
+        if (n === 39)
+          if (this.peek() === 39)
+            i.push(39), this.bump();
+          else {
+            this.bump();
+            break;
+          }
+        else
+          i.push(n);
+        this.bump();
+      }
+      return fromCodePoint.apply(void 0, i);
+    }, t.prototype.tryParseUnquoted = function(e, i) {
+      if (this.isEOF())
+        return null;
+      var n = this.char();
+      return n === 60 || n === 123 || n === 35 && (i === "plural" || i === "selectordinal") || n === 125 && e > 0 ? null : (this.bump(), fromCodePoint(n));
+    }, t.prototype.parseArgument = function(e, i) {
+      var n = this.clonePosition();
+      if (this.bump(), this.bumpSpace(), this.isEOF())
+        return this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(n, this.clonePosition()));
+      if (this.char() === 125)
+        return this.bump(), this.error(ErrorKind.EMPTY_ARGUMENT, createLocation(n, this.clonePosition()));
+      var s = this.parseIdentifierIfPossible().value;
+      if (!s)
+        return this.error(ErrorKind.MALFORMED_ARGUMENT, createLocation(n, this.clonePosition()));
+      if (this.bumpSpace(), this.isEOF())
+        return this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(n, this.clonePosition()));
+      switch (this.char()) {
+        case 125:
+          return this.bump(), {
+            val: {
+              type: TYPE.argument,
+              // value does not include the opening and closing braces.
+              value: s,
+              location: createLocation(n, this.clonePosition())
+            },
+            err: null
+          };
+        case 44:
+          return this.bump(), this.bumpSpace(), this.isEOF() ? this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(n, this.clonePosition())) : this.parseArgumentOptions(e, i, s, n);
+        default:
+          return this.error(ErrorKind.MALFORMED_ARGUMENT, createLocation(n, this.clonePosition()));
+      }
+    }, t.prototype.parseIdentifierIfPossible = function() {
+      var e = this.clonePosition(), i = this.offset(), n = matchIdentifierAtIndex(this.message, i), s = i + n.length;
+      this.bumpTo(s);
+      var l = this.clonePosition(), h = createLocation(e, l);
+      return { value: n, location: h };
+    }, t.prototype.parseArgumentOptions = function(e, i, n, s) {
+      var l, h = this.clonePosition(), _ = this.parseIdentifierIfPossible().value, c = this.clonePosition();
+      switch (_) {
+        case "":
+          return this.error(ErrorKind.EXPECT_ARGUMENT_TYPE, createLocation(h, c));
+        case "number":
+        case "date":
+        case "time": {
+          this.bumpSpace();
+          var o = null;
+          if (this.bumpIf(",")) {
+            this.bumpSpace();
+            var r = this.clonePosition(), T = this.parseSimpleArgStyleIfPossible();
+            if (T.err)
+              return T;
+            var S = trimEnd(T.val);
+            if (S.length === 0)
+              return this.error(ErrorKind.EXPECT_ARGUMENT_STYLE, createLocation(this.clonePosition(), this.clonePosition()));
+            var w = createLocation(r, this.clonePosition());
+            o = { style: S, styleLocation: w };
+          }
+          var C = this.tryParseArgumentClose(s);
+          if (C.err)
+            return C;
+          var P = createLocation(s, this.clonePosition());
+          if (o && startsWith(o == null ? void 0 : o.style, "::", 0)) {
+            var b = trimStart(o.style.slice(2));
+            if (_ === "number") {
+              var T = this.parseNumberSkeletonFromString(b, o.styleLocation);
+              return T.err ? T : {
+                val: { type: TYPE.number, value: n, location: P, style: T.val },
+                err: null
+              };
+            } else {
+              if (b.length === 0)
+                return this.error(ErrorKind.EXPECT_DATE_TIME_SKELETON, P);
+              var k = b;
+              this.locale && (k = getBestPattern(b, this.locale));
+              var S = {
+                type: SKELETON_TYPE.dateTime,
+                pattern: k,
+                location: o.styleLocation,
+                parsedOptions: this.shouldParseSkeletons ? parseDateTimeSkeleton(k) : {}
+              }, F = _ === "date" ? TYPE.date : TYPE.time;
+              return {
+                val: { type: F, value: n, location: P, style: S },
+                err: null
+              };
+            }
+          }
+          return {
+            val: {
+              type: _ === "number" ? TYPE.number : _ === "date" ? TYPE.date : TYPE.time,
+              value: n,
+              location: P,
+              style: (l = o == null ? void 0 : o.style) !== null && l !== void 0 ? l : null
+            },
+            err: null
+          };
+        }
+        case "plural":
+        case "selectordinal":
+        case "select": {
+          var x = this.clonePosition();
+          if (this.bumpSpace(), !this.bumpIf(","))
+            return this.error(ErrorKind.EXPECT_SELECT_ARGUMENT_OPTIONS, createLocation(x, __assign({}, x)));
+          this.bumpSpace();
+          var y = this.parseIdentifierIfPossible(), p = 0;
+          if (_ !== "select" && y.value === "offset") {
+            if (!this.bumpIf(":"))
+              return this.error(ErrorKind.EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE, createLocation(this.clonePosition(), this.clonePosition()));
+            this.bumpSpace();
+            var T = this.tryParseDecimalInteger(ErrorKind.EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE, ErrorKind.INVALID_PLURAL_ARGUMENT_OFFSET_VALUE);
+            if (T.err)
+              return T;
+            this.bumpSpace(), y = this.parseIdentifierIfPossible(), p = T.val;
+          }
+          var E = this.tryParsePluralOrSelectOptions(e, _, i, y);
+          if (E.err)
+            return E;
+          var C = this.tryParseArgumentClose(s);
+          if (C.err)
+            return C;
+          var $ = createLocation(s, this.clonePosition());
+          return _ === "select" ? {
+            val: {
+              type: TYPE.select,
+              value: n,
+              options: fromEntries(E.val),
+              location: $
+            },
+            err: null
+          } : {
+            val: {
+              type: TYPE.plural,
+              value: n,
+              options: fromEntries(E.val),
+              offset: p,
+              pluralType: _ === "plural" ? "cardinal" : "ordinal",
+              location: $
+            },
+            err: null
+          };
+        }
+        default:
+          return this.error(ErrorKind.INVALID_ARGUMENT_TYPE, createLocation(h, c));
+      }
+    }, t.prototype.tryParseArgumentClose = function(e) {
+      return this.isEOF() || this.char() !== 125 ? this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(e, this.clonePosition())) : (this.bump(), { val: !0, err: null });
+    }, t.prototype.parseSimpleArgStyleIfPossible = function() {
+      for (var e = 0, i = this.clonePosition(); !this.isEOF(); ) {
+        var n = this.char();
+        switch (n) {
+          case 39: {
+            this.bump();
+            var s = this.clonePosition();
+            if (!this.bumpUntil("'"))
+              return this.error(ErrorKind.UNCLOSED_QUOTE_IN_ARGUMENT_STYLE, createLocation(s, this.clonePosition()));
+            this.bump();
+            break;
+          }
+          case 123: {
+            e += 1, this.bump();
+            break;
+          }
+          case 125: {
+            if (e > 0)
+              e -= 1;
+            else
+              return {
+                val: this.message.slice(i.offset, this.offset()),
+                err: null
+              };
+            break;
+          }
+          default:
+            this.bump();
+            break;
+        }
+      }
+      return {
+        val: this.message.slice(i.offset, this.offset()),
+        err: null
+      };
+    }, t.prototype.parseNumberSkeletonFromString = function(e, i) {
+      var n = [];
+      try {
+        n = parseNumberSkeletonFromString(e);
+      } catch {
+        return this.error(ErrorKind.INVALID_NUMBER_SKELETON, i);
+      }
+      return {
+        val: {
+          type: SKELETON_TYPE.number,
+          tokens: n,
+          location: i,
+          parsedOptions: this.shouldParseSkeletons ? parseNumberSkeleton(n) : {}
+        },
+        err: null
+      };
+    }, t.prototype.tryParsePluralOrSelectOptions = function(e, i, n, s) {
+      for (var l, h = !1, _ = [], c = /* @__PURE__ */ new Set(), o = s.value, r = s.location; ; ) {
+        if (o.length === 0) {
+          var T = this.clonePosition();
+          if (i !== "select" && this.bumpIf("=")) {
+            var S = this.tryParseDecimalInteger(ErrorKind.EXPECT_PLURAL_ARGUMENT_SELECTOR, ErrorKind.INVALID_PLURAL_ARGUMENT_SELECTOR);
+            if (S.err)
+              return S;
+            r = createLocation(T, this.clonePosition()), o = this.message.slice(T.offset, this.offset());
+          } else
+            break;
+        }
+        if (c.has(o))
+          return this.error(i === "select" ? ErrorKind.DUPLICATE_SELECT_ARGUMENT_SELECTOR : ErrorKind.DUPLICATE_PLURAL_ARGUMENT_SELECTOR, r);
+        o === "other" && (h = !0), this.bumpSpace();
+        var w = this.clonePosition();
+        if (!this.bumpIf("{"))
+          return this.error(i === "select" ? ErrorKind.EXPECT_SELECT_ARGUMENT_SELECTOR_FRAGMENT : ErrorKind.EXPECT_PLURAL_ARGUMENT_SELECTOR_FRAGMENT, createLocation(this.clonePosition(), this.clonePosition()));
+        var C = this.parseMessage(e + 1, i, n);
+        if (C.err)
+          return C;
+        var P = this.tryParseArgumentClose(w);
+        if (P.err)
+          return P;
+        _.push([
+          o,
+          {
+            value: C.val,
+            location: createLocation(w, this.clonePosition())
+          }
+        ]), c.add(o), this.bumpSpace(), l = this.parseIdentifierIfPossible(), o = l.value, r = l.location;
+      }
+      return _.length === 0 ? this.error(i === "select" ? ErrorKind.EXPECT_SELECT_ARGUMENT_SELECTOR : ErrorKind.EXPECT_PLURAL_ARGUMENT_SELECTOR, createLocation(this.clonePosition(), this.clonePosition())) : this.requiresOtherClause && !h ? this.error(ErrorKind.MISSING_OTHER_CLAUSE, createLocation(this.clonePosition(), this.clonePosition())) : { val: _, err: null };
+    }, t.prototype.tryParseDecimalInteger = function(e, i) {
+      var n = 1, s = this.clonePosition();
+      this.bumpIf("+") || this.bumpIf("-") && (n = -1);
+      for (var l = !1, h = 0; !this.isEOF(); ) {
+        var _ = this.char();
+        if (_ >= 48 && _ <= 57)
+          l = !0, h = h * 10 + (_ - 48), this.bump();
+        else
+          break;
+      }
+      var c = createLocation(s, this.clonePosition());
+      return l ? (h *= n, isSafeInteger(h) ? { val: h, err: null } : this.error(i, c)) : this.error(e, c);
+    }, t.prototype.offset = function() {
+      return this.position.offset;
+    }, t.prototype.isEOF = function() {
+      return this.offset() === this.message.length;
+    }, t.prototype.clonePosition = function() {
+      return {
+        offset: this.position.offset,
+        line: this.position.line,
+        column: this.position.column
+      };
+    }, t.prototype.char = function() {
+      var e = this.position.offset;
+      if (e >= this.message.length)
+        throw Error("out of bound");
+      var i = codePointAt(this.message, e);
+      if (i === void 0)
+        throw Error("Offset ".concat(e, " is at invalid UTF-16 code unit boundary"));
+      return i;
+    }, t.prototype.error = function(e, i) {
+      return {
+        val: null,
+        err: {
+          kind: e,
+          message: this.message,
+          location: i
+        }
+      };
+    }, t.prototype.bump = function() {
+      if (!this.isEOF()) {
+        var e = this.char();
+        e === 10 ? (this.position.line += 1, this.position.column = 1, this.position.offset += 1) : (this.position.column += 1, this.position.offset += e < 65536 ? 1 : 2);
+      }
+    }, t.prototype.bumpIf = function(e) {
+      if (startsWith(this.message, e, this.offset())) {
+        for (var i = 0; i < e.length; i++)
+          this.bump();
+        return !0;
+      }
+      return !1;
+    }, t.prototype.bumpUntil = function(e) {
+      var i = this.offset(), n = this.message.indexOf(e, i);
+      return n >= 0 ? (this.bumpTo(n), !0) : (this.bumpTo(this.message.length), !1);
+    }, t.prototype.bumpTo = function(e) {
+      if (this.offset() > e)
+        throw Error("targetOffset ".concat(e, " must be greater than or equal to the current offset ").concat(this.offset()));
+      for (e = Math.min(e, this.message.length); ; ) {
+        var i = this.offset();
+        if (i === e)
+          break;
+        if (i > e)
+          throw Error("targetOffset ".concat(e, " is at invalid UTF-16 code unit boundary"));
+        if (this.bump(), this.isEOF())
+          break;
+      }
+    }, t.prototype.bumpSpace = function() {
+      for (; !this.isEOF() && _isWhiteSpace(this.char()); )
+        this.bump();
+    }, t.prototype.peek = function() {
+      if (this.isEOF())
+        return null;
+      var e = this.char(), i = this.offset(), n = this.message.charCodeAt(i + (e >= 65536 ? 2 : 1));
+      return n ?? null;
+    }, t;
+  }()
+);
+function _isAlpha(t) {
+  return t >= 97 && t <= 122 || t >= 65 && t <= 90;
+}
+function _isAlphaOrSlash(t) {
+  return _isAlpha(t) || t === 47;
+}
+function _isPotentialElementNameChar(t) {
+  return t === 45 || t === 46 || t >= 48 && t <= 57 || t === 95 || t >= 97 && t <= 122 || t >= 65 && t <= 90 || t == 183 || t >= 192 && t <= 214 || t >= 216 && t <= 246 || t >= 248 && t <= 893 || t >= 895 && t <= 8191 || t >= 8204 && t <= 8205 || t >= 8255 && t <= 8256 || t >= 8304 && t <= 8591 || t >= 11264 && t <= 12271 || t >= 12289 && t <= 55295 || t >= 63744 && t <= 64975 || t >= 65008 && t <= 65533 || t >= 65536 && t <= 983039;
+}
+function _isWhiteSpace(t) {
+  return t >= 9 && t <= 13 || t === 32 || t === 133 || t >= 8206 && t <= 8207 || t === 8232 || t === 8233;
+}
+function _isPatternSyntax(t) {
+  return t >= 33 && t <= 35 || t === 36 || t >= 37 && t <= 39 || t === 40 || t === 41 || t === 42 || t === 43 || t === 44 || t === 45 || t >= 46 && t <= 47 || t >= 58 && t <= 59 || t >= 60 && t <= 62 || t >= 63 && t <= 64 || t === 91 || t === 92 || t === 93 || t === 94 || t === 96 || t === 123 || t === 124 || t === 125 || t === 126 || t === 161 || t >= 162 && t <= 165 || t === 166 || t === 167 || t === 169 || t === 171 || t === 172 || t === 174 || t === 176 || t === 177 || t === 182 || t === 187 || t === 191 || t === 215 || t === 247 || t >= 8208 && t <= 8213 || t >= 8214 && t <= 8215 || t === 8216 || t === 8217 || t === 8218 || t >= 8219 && t <= 8220 || t === 8221 || t === 8222 || t === 8223 || t >= 8224 && t <= 8231 || t >= 8240 && t <= 8248 || t === 8249 || t === 8250 || t >= 8251 && t <= 8254 || t >= 8257 && t <= 8259 || t === 8260 || t === 8261 || t === 8262 || t >= 8263 && t <= 8273 || t === 8274 || t === 8275 || t >= 8277 && t <= 8286 || t >= 8592 && t <= 8596 || t >= 8597 && t <= 8601 || t >= 8602 && t <= 8603 || t >= 8604 && t <= 8607 || t === 8608 || t >= 8609 && t <= 8610 || t === 8611 || t >= 8612 && t <= 8613 || t === 8614 || t >= 8615 && t <= 8621 || t === 8622 || t >= 8623 && t <= 8653 || t >= 8654 && t <= 8655 || t >= 8656 && t <= 8657 || t === 8658 || t === 8659 || t === 8660 || t >= 8661 && t <= 8691 || t >= 8692 && t <= 8959 || t >= 8960 && t <= 8967 || t === 8968 || t === 8969 || t === 8970 || t === 8971 || t >= 8972 && t <= 8991 || t >= 8992 && t <= 8993 || t >= 8994 && t <= 9e3 || t === 9001 || t === 9002 || t >= 9003 && t <= 9083 || t === 9084 || t >= 9085 && t <= 9114 || t >= 9115 && t <= 9139 || t >= 9140 && t <= 9179 || t >= 9180 && t <= 9185 || t >= 9186 && t <= 9254 || t >= 9255 && t <= 9279 || t >= 9280 && t <= 9290 || t >= 9291 && t <= 9311 || t >= 9472 && t <= 9654 || t === 9655 || t >= 9656 && t <= 9664 || t === 9665 || t >= 9666 && t <= 9719 || t >= 9720 && t <= 9727 || t >= 9728 && t <= 9838 || t === 9839 || t >= 9840 && t <= 10087 || t === 10088 || t === 10089 || t === 10090 || t === 10091 || t === 10092 || t === 10093 || t === 10094 || t === 10095 || t === 10096 || t === 10097 || t === 10098 || t === 10099 || t === 10100 || t === 10101 || t >= 10132 && t <= 10175 || t >= 10176 && t <= 10180 || t === 10181 || t === 10182 || t >= 10183 && t <= 10213 || t === 10214 || t === 10215 || t === 10216 || t === 10217 || t === 10218 || t === 10219 || t === 10220 || t === 10221 || t === 10222 || t === 10223 || t >= 10224 && t <= 10239 || t >= 10240 && t <= 10495 || t >= 10496 && t <= 10626 || t === 10627 || t === 10628 || t === 10629 || t === 10630 || t === 10631 || t === 10632 || t === 10633 || t === 10634 || t === 10635 || t === 10636 || t === 10637 || t === 10638 || t === 10639 || t === 10640 || t === 10641 || t === 10642 || t === 10643 || t === 10644 || t === 10645 || t === 10646 || t === 10647 || t === 10648 || t >= 10649 && t <= 10711 || t === 10712 || t === 10713 || t === 10714 || t === 10715 || t >= 10716 && t <= 10747 || t === 10748 || t === 10749 || t >= 10750 && t <= 11007 || t >= 11008 && t <= 11055 || t >= 11056 && t <= 11076 || t >= 11077 && t <= 11078 || t >= 11079 && t <= 11084 || t >= 11085 && t <= 11123 || t >= 11124 && t <= 11125 || t >= 11126 && t <= 11157 || t === 11158 || t >= 11159 && t <= 11263 || t >= 11776 && t <= 11777 || t === 11778 || t === 11779 || t === 11780 || t === 11781 || t >= 11782 && t <= 11784 || t === 11785 || t === 11786 || t === 11787 || t === 11788 || t === 11789 || t >= 11790 && t <= 11798 || t === 11799 || t >= 11800 && t <= 11801 || t === 11802 || t === 11803 || t === 11804 || t === 11805 || t >= 11806 && t <= 11807 || t === 11808 || t === 11809 || t === 11810 || t === 11811 || t === 11812 || t === 11813 || t === 11814 || t === 11815 || t === 11816 || t === 11817 || t >= 11818 && t <= 11822 || t === 11823 || t >= 11824 && t <= 11833 || t >= 11834 && t <= 11835 || t >= 11836 && t <= 11839 || t === 11840 || t === 11841 || t === 11842 || t >= 11843 && t <= 11855 || t >= 11856 && t <= 11857 || t === 11858 || t >= 11859 && t <= 11903 || t >= 12289 && t <= 12291 || t === 12296 || t === 12297 || t === 12298 || t === 12299 || t === 12300 || t === 12301 || t === 12302 || t === 12303 || t === 12304 || t === 12305 || t >= 12306 && t <= 12307 || t === 12308 || t === 12309 || t === 12310 || t === 12311 || t === 12312 || t === 12313 || t === 12314 || t === 12315 || t === 12316 || t === 12317 || t >= 12318 && t <= 12319 || t === 12320 || t === 12336 || t === 64830 || t === 64831 || t >= 65093 && t <= 65094;
+}
+function pruneLocation(t) {
+  t.forEach(function(e) {
+    if (delete e.location, isSelectElement(e) || isPluralElement(e))
+      for (var i in e.options)
+        delete e.options[i].location, pruneLocation(e.options[i].value);
+    else
+      isNumberElement(e) && isNumberSkeleton(e.style) || (isDateElement(e) || isTimeElement(e)) && isDateTimeSkeleton(e.style) ? delete e.style.location : isTagElement(e) && pruneLocation(e.children);
+  });
+}
+function parse(t, e) {
+  e === void 0 && (e = {}), e = __assign({ shouldParseSkeletons: !0, requiresOtherClause: !0 }, e);
+  var i = new Parser(t, e).parse();
+  if (i.err) {
+    var n = SyntaxError(ErrorKind[i.err.kind]);
+    throw n.location = i.err.location, n.originalMessage = i.err.message, n;
+  }
+  return e != null && e.captureLocation || pruneLocation(i.val), i.val;
+}
+function memoize(t, e) {
+  var i = e && e.cache ? e.cache : cacheDefault, n = e && e.serializer ? e.serializer : serializerDefault, s = e && e.strategy ? e.strategy : strategyDefault;
+  return s(t, {
+    cache: i,
+    serializer: n
+  });
+}
+function isPrimitive(t) {
+  return t == null || typeof t == "number" || typeof t == "boolean";
+}
+function monadic(t, e, i, n) {
+  var s = isPrimitive(n) ? n : i(n), l = e.get(s);
+  return typeof l > "u" && (l = t.call(this, n), e.set(s, l)), l;
+}
+function variadic(t, e, i) {
+  var n = Array.prototype.slice.call(arguments, 3), s = i(n), l = e.get(s);
+  return typeof l > "u" && (l = t.apply(this, n), e.set(s, l)), l;
+}
+function assemble(t, e, i, n, s) {
+  return i.bind(e, t, n, s);
+}
+function strategyDefault(t, e) {
+  var i = t.length === 1 ? monadic : variadic;
+  return assemble(t, this, i, e.cache.create(), e.serializer);
+}
+function strategyVariadic(t, e) {
+  return assemble(t, this, variadic, e.cache.create(), e.serializer);
+}
+function strategyMonadic(t, e) {
+  return assemble(t, this, monadic, e.cache.create(), e.serializer);
+}
+var serializerDefault = function() {
+  return JSON.stringify(arguments);
+};
+function ObjectWithoutPrototypeCache() {
+  this.cache = /* @__PURE__ */ Object.create(null);
+}
+ObjectWithoutPrototypeCache.prototype.get = function(t) {
+  return this.cache[t];
+};
+ObjectWithoutPrototypeCache.prototype.set = function(t, e) {
+  this.cache[t] = e;
+};
+var cacheDefault = {
+  create: function() {
+    return new ObjectWithoutPrototypeCache();
+  }
+}, strategies = {
+  variadic: strategyVariadic,
+  monadic: strategyMonadic
+}, ErrorCode;
+(function(t) {
+  t.MISSING_VALUE = "MISSING_VALUE", t.INVALID_VALUE = "INVALID_VALUE", t.MISSING_INTL_API = "MISSING_INTL_API";
+})(ErrorCode || (ErrorCode = {}));
+var FormatError = (
+  /** @class */
+  function(t) {
+    __extends(e, t);
+    function e(i, n, s) {
+      var l = t.call(this, i) || this;
+      return l.code = n, l.originalMessage = s, l;
+    }
+    return e.prototype.toString = function() {
+      return "[formatjs Error: ".concat(this.code, "] ").concat(this.message);
+    }, e;
+  }(Error)
+), InvalidValueError = (
+  /** @class */
+  function(t) {
+    __extends(e, t);
+    function e(i, n, s, l) {
+      return t.call(this, 'Invalid values for "'.concat(i, '": "').concat(n, '". Options are "').concat(Object.keys(s).join('", "'), '"'), ErrorCode.INVALID_VALUE, l) || this;
+    }
+    return e;
+  }(FormatError)
+), InvalidValueTypeError = (
+  /** @class */
+  function(t) {
+    __extends(e, t);
+    function e(i, n, s) {
+      return t.call(this, 'Value for "'.concat(i, '" must be of type ').concat(n), ErrorCode.INVALID_VALUE, s) || this;
+    }
+    return e;
+  }(FormatError)
+), MissingValueError = (
+  /** @class */
+  function(t) {
+    __extends(e, t);
+    function e(i, n) {
+      return t.call(this, 'The intl string context variable "'.concat(i, '" was not provided to the string "').concat(n, '"'), ErrorCode.MISSING_VALUE, n) || this;
+    }
+    return e;
+  }(FormatError)
+), PART_TYPE;
+(function(t) {
+  t[t.literal = 0] = "literal", t[t.object = 1] = "object";
+})(PART_TYPE || (PART_TYPE = {}));
+function mergeLiteral(t) {
+  return t.length < 2 ? t : t.reduce(function(e, i) {
+    var n = e[e.length - 1];
+    return !n || n.type !== PART_TYPE.literal || i.type !== PART_TYPE.literal ? e.push(i) : n.value += i.value, e;
+  }, []);
+}
+function isFormatXMLElementFn(t) {
+  return typeof t == "function";
+}
+function formatToParts(t, e, i, n, s, l, h) {
+  if (t.length === 1 && isLiteralElement(t[0]))
+    return [
+      {
+        type: PART_TYPE.literal,
+        value: t[0].value
+      }
+    ];
+  for (var _ = [], c = 0, o = t; c < o.length; c++) {
+    var r = o[c];
+    if (isLiteralElement(r)) {
+      _.push({
+        type: PART_TYPE.literal,
+        value: r.value
+      });
+      continue;
+    }
+    if (isPoundElement(r)) {
+      typeof l == "number" && _.push({
+        type: PART_TYPE.literal,
+        value: i.getNumberFormat(e).format(l)
+      });
+      continue;
+    }
+    var T = r.value;
+    if (!(s && T in s))
+      throw new MissingValueError(T, h);
+    var S = s[T];
+    if (isArgumentElement(r)) {
+      (!S || typeof S == "string" || typeof S == "number") && (S = typeof S == "string" || typeof S == "number" ? String(S) : ""), _.push({
+        type: typeof S == "string" ? PART_TYPE.literal : PART_TYPE.object,
+        value: S
+      });
+      continue;
+    }
+    if (isDateElement(r)) {
+      var w = typeof r.style == "string" ? n.date[r.style] : isDateTimeSkeleton(r.style) ? r.style.parsedOptions : void 0;
+      _.push({
+        type: PART_TYPE.literal,
+        value: i.getDateTimeFormat(e, w).format(S)
+      });
+      continue;
+    }
+    if (isTimeElement(r)) {
+      var w = typeof r.style == "string" ? n.time[r.style] : isDateTimeSkeleton(r.style) ? r.style.parsedOptions : n.time.medium;
+      _.push({
+        type: PART_TYPE.literal,
+        value: i.getDateTimeFormat(e, w).format(S)
+      });
+      continue;
+    }
+    if (isNumberElement(r)) {
+      var w = typeof r.style == "string" ? n.number[r.style] : isNumberSkeleton(r.style) ? r.style.parsedOptions : void 0;
+      w && w.scale && (S = S * (w.scale || 1)), _.push({
+        type: PART_TYPE.literal,
+        value: i.getNumberFormat(e, w).format(S)
+      });
+      continue;
+    }
+    if (isTagElement(r)) {
+      var C = r.children, P = r.value, b = s[P];
+      if (!isFormatXMLElementFn(b))
+        throw new InvalidValueTypeError(P, "function", h);
+      var k = formatToParts(C, e, i, n, s, l), F = b(k.map(function(p) {
+        return p.value;
+      }));
+      Array.isArray(F) || (F = [F]), _.push.apply(_, F.map(function(p) {
+        return {
+          type: typeof p == "string" ? PART_TYPE.literal : PART_TYPE.object,
+          value: p
+        };
+      }));
+    }
+    if (isSelectElement(r)) {
+      var x = r.options[S] || r.options.other;
+      if (!x)
+        throw new InvalidValueError(r.value, S, Object.keys(r.options), h);
+      _.push.apply(_, formatToParts(x.value, e, i, n, s));
+      continue;
+    }
+    if (isPluralElement(r)) {
+      var x = r.options["=".concat(S)];
+      if (!x) {
+        if (!Intl.PluralRules)
+          throw new FormatError(`Intl.PluralRules is not available in this environment.
+Try polyfilling it using "@formatjs/intl-pluralrules"
+`, ErrorCode.MISSING_INTL_API, h);
+        var y = i.getPluralRules(e, { type: r.pluralType }).select(S - (r.offset || 0));
+        x = r.options[y] || r.options.other;
+      }
+      if (!x)
+        throw new InvalidValueError(r.value, S, Object.keys(r.options), h);
+      _.push.apply(_, formatToParts(x.value, e, i, n, s, S - (r.offset || 0)));
+      continue;
+    }
+  }
+  return mergeLiteral(_);
+}
+function mergeConfig(t, e) {
+  return e ? __assign(__assign(__assign({}, t || {}), e || {}), Object.keys(t).reduce(function(i, n) {
+    return i[n] = __assign(__assign({}, t[n]), e[n] || {}), i;
+  }, {})) : t;
+}
+function mergeConfigs(t, e) {
+  return e ? Object.keys(t).reduce(function(i, n) {
+    return i[n] = mergeConfig(t[n], e[n]), i;
+  }, __assign({}, t)) : t;
+}
+function createFastMemoizeCache(t) {
+  return {
+    create: function() {
+      return {
+        get: function(e) {
+          return t[e];
+        },
+        set: function(e, i) {
+          t[e] = i;
+        }
+      };
+    }
+  };
+}
+function createDefaultFormatters(t) {
+  return t === void 0 && (t = {
+    number: {},
+    dateTime: {},
+    pluralRules: {}
+  }), {
+    getNumberFormat: memoize(function() {
+      for (var e, i = [], n = 0; n < arguments.length; n++)
+        i[n] = arguments[n];
+      return new ((e = Intl.NumberFormat).bind.apply(e, __spreadArray([void 0], i, !1)))();
+    }, {
+      cache: createFastMemoizeCache(t.number),
+      strategy: strategies.variadic
+    }),
+    getDateTimeFormat: memoize(function() {
+      for (var e, i = [], n = 0; n < arguments.length; n++)
+        i[n] = arguments[n];
+      return new ((e = Intl.DateTimeFormat).bind.apply(e, __spreadArray([void 0], i, !1)))();
+    }, {
+      cache: createFastMemoizeCache(t.dateTime),
+      strategy: strategies.variadic
+    }),
+    getPluralRules: memoize(function() {
+      for (var e, i = [], n = 0; n < arguments.length; n++)
+        i[n] = arguments[n];
+      return new ((e = Intl.PluralRules).bind.apply(e, __spreadArray([void 0], i, !1)))();
+    }, {
+      cache: createFastMemoizeCache(t.pluralRules),
+      strategy: strategies.variadic
+    })
+  };
+}
+var IntlMessageFormat = (
+  /** @class */
+  function() {
+    function t(e, i, n, s) {
+      var l = this;
+      if (i === void 0 && (i = t.defaultLocale), this.formatterCache = {
+        number: {},
+        dateTime: {},
+        pluralRules: {}
+      }, this.format = function(h) {
+        var _ = l.formatToParts(h);
+        if (_.length === 1)
+          return _[0].value;
+        var c = _.reduce(function(o, r) {
+          return !o.length || r.type !== PART_TYPE.literal || typeof o[o.length - 1] != "string" ? o.push(r.value) : o[o.length - 1] += r.value, o;
+        }, []);
+        return c.length <= 1 ? c[0] || "" : c;
+      }, this.formatToParts = function(h) {
+        return formatToParts(l.ast, l.locales, l.formatters, l.formats, h, void 0, l.message);
+      }, this.resolvedOptions = function() {
+        return {
+          locale: l.resolvedLocale.toString()
+        };
+      }, this.getAst = function() {
+        return l.ast;
+      }, this.locales = i, this.resolvedLocale = t.resolveLocale(i), typeof e == "string") {
+        if (this.message = e, !t.__parse)
+          throw new TypeError("IntlMessageFormat.__parse must be set to process `message` of type `string`");
+        this.ast = t.__parse(e, {
+          ignoreTag: s == null ? void 0 : s.ignoreTag,
+          locale: this.resolvedLocale
+        });
+      } else
+        this.ast = e;
+      if (!Array.isArray(this.ast))
+        throw new TypeError("A message must be provided as a String or AST.");
+      this.formats = mergeConfigs(t.formats, n), this.formatters = s && s.formatters || createDefaultFormatters(this.formatterCache);
+    }
+    return Object.defineProperty(t, "defaultLocale", {
+      get: function() {
+        return t.memoizedDefaultLocale || (t.memoizedDefaultLocale = new Intl.NumberFormat().resolvedOptions().locale), t.memoizedDefaultLocale;
+      },
+      enumerable: !1,
+      configurable: !0
+    }), t.memoizedDefaultLocale = null, t.resolveLocale = function(e) {
+      var i = Intl.NumberFormat.supportedLocalesOf(e);
+      return i.length > 0 ? new Intl.Locale(i[0]) : new Intl.Locale(typeof e == "string" ? e : e[0]);
+    }, t.__parse = parse, t.formats = {
+      number: {
+        integer: {
+          maximumFractionDigits: 0
+        },
+        currency: {
+          style: "currency"
+        },
+        percent: {
+          style: "percent"
+        }
+      },
+      date: {
+        short: {
+          month: "numeric",
+          day: "numeric",
+          year: "2-digit"
+        },
+        medium: {
+          month: "short",
+          day: "numeric",
+          year: "numeric"
+        },
+        long: {
+          month: "long",
+          day: "numeric",
+          year: "numeric"
+        },
+        full: {
+          weekday: "long",
+          month: "long",
+          day: "numeric",
+          year: "numeric"
+        }
+      },
+      time: {
+        short: {
+          hour: "numeric",
+          minute: "numeric"
+        },
+        medium: {
+          hour: "numeric",
+          minute: "numeric",
+          second: "numeric"
+        },
+        long: {
+          hour: "numeric",
+          minute: "numeric",
+          second: "numeric",
+          timeZoneName: "short"
+        },
+        full: {
+          hour: "numeric",
+          minute: "numeric",
+          second: "numeric",
+          timeZoneName: "short"
+        }
+      }
+    }, t;
+  }()
+);
+function delve(t, e) {
+  if (e == null)
+    return;
+  if (e in t)
+    return t[e];
+  const i = e.split(".");
+  let n = t;
+  for (let s = 0; s < i.length; s++)
+    if (typeof n == "object") {
+      if (s > 0) {
+        const l = i.slice(s, i.length).join(".");
+        if (l in n) {
+          n = n[l];
+          break;
+        }
+      }
+      n = n[i[s]];
+    } else
+      n = void 0;
+  return n;
+}
+const lookupCache = {}, addToCache = (t, e, i) => i && (e in lookupCache || (lookupCache[e] = {}), t in lookupCache[e] || (lookupCache[e][t] = i), i), lookup = (t, e) => {
+  if (e == null)
+    return;
+  if (e in lookupCache && t in lookupCache[e])
+    return lookupCache[e][t];
+  const i = getPossibleLocales(e);
+  for (let n = 0; n < i.length; n++) {
+    const s = i[n], l = getMessageFromDictionary(s, t);
+    if (l)
+      return addToCache(t, e, l);
+  }
+};
+let dictionary;
+const $dictionary = writable({});
+function getLocaleDictionary(t) {
+  return dictionary[t] || null;
+}
+function hasLocaleDictionary(t) {
+  return t in dictionary;
+}
+function getMessageFromDictionary(t, e) {
+  if (!hasLocaleDictionary(t))
+    return null;
+  const i = getLocaleDictionary(t);
+  return delve(i, e);
+}
+function getClosestAvailableLocale(t) {
+  if (t == null)
+    return;
+  const e = getPossibleLocales(t);
+  for (let i = 0; i < e.length; i++) {
+    const n = e[i];
+    if (hasLocaleDictionary(n))
+      return n;
+  }
+}
+function addMessages(t, ...e) {
+  delete lookupCache[t], $dictionary.update((i) => (i[t] = deepmerge$1.all([i[t] || {}, ...e]), i));
+}
+derived(
+  [$dictionary],
+  ([t]) => Object.keys(t)
+);
+$dictionary.subscribe((t) => dictionary = t);
+const queue = {};
+function removeLoaderFromQueue(t, e) {
+  queue[t].delete(e), queue[t].size === 0 && delete queue[t];
+}
+function getLocaleQueue(t) {
+  return queue[t];
+}
+function getLocalesQueues(t) {
+  return getPossibleLocales(t).map((e) => {
+    const i = getLocaleQueue(e);
+    return [e, i ? [...i] : []];
+  }).filter(([, e]) => e.length > 0);
+}
+function hasLocaleQueue(t) {
+  return t == null ? !1 : getPossibleLocales(t).some(
+    (e) => {
+      var i;
+      return (i = getLocaleQueue(e)) == null ? void 0 : i.size;
+    }
+  );
+}
+function loadLocaleQueue(t, e) {
+  return Promise.all(
+    e.map((n) => (removeLoaderFromQueue(t, n), n().then((s) => s.default || s)))
+  ).then((n) => addMessages(t, ...n));
+}
+const activeFlushes = {};
+function flush(t) {
+  if (!hasLocaleQueue(t))
+    return t in activeFlushes ? activeFlushes[t] : Promise.resolve();
+  const e = getLocalesQueues(t);
+  return activeFlushes[t] = Promise.all(
+    e.map(
+      ([i, n]) => loadLocaleQueue(i, n)
+    )
+  ).then(() => {
+    if (hasLocaleQueue(t))
+      return flush(t);
+    delete activeFlushes[t];
+  }), activeFlushes[t];
+}
+const defaultFormats = {
+  number: {
+    scientific: { notation: "scientific" },
+    engineering: { notation: "engineering" },
+    compactLong: { notation: "compact", compactDisplay: "long" },
+    compactShort: { notation: "compact", compactDisplay: "short" }
+  },
+  date: {
+    short: { month: "numeric", day: "numeric", year: "2-digit" },
+    medium: { month: "short", day: "numeric", year: "numeric" },
+    long: { month: "long", day: "numeric", year: "numeric" },
+    full: { weekday: "long", month: "long", day: "numeric", year: "numeric" }
+  },
+  time: {
+    short: { hour: "numeric", minute: "numeric" },
+    medium: { hour: "numeric", minute: "numeric", second: "numeric" },
+    long: {
+      hour: "numeric",
+      minute: "numeric",
+      second: "numeric",
+      timeZoneName: "short"
+    },
+    full: {
+      hour: "numeric",
+      minute: "numeric",
+      second: "numeric",
+      timeZoneName: "short"
+    }
+  }
+}, defaultOptions = {
+  fallbackLocale: null,
+  loadingDelay: 200,
+  formats: defaultFormats,
+  warnOnMissingMessages: !0,
+  handleMissingMessage: void 0,
+  ignoreTag: !0
+}, options = defaultOptions;
+function getOptions() {
+  return options;
+}
+const $isLoading = writable(!1);
+var __defProp$1 = Object.defineProperty, __defProps = Object.defineProperties, __getOwnPropDescs = Object.getOwnPropertyDescriptors, __getOwnPropSymbols$1 = Object.getOwnPropertySymbols, __hasOwnProp$1 = Object.prototype.hasOwnProperty, __propIsEnum$1 = Object.prototype.propertyIsEnumerable, __defNormalProp$1 = (t, e, i) => e in t ? __defProp$1(t, e, { enumerable: !0, configurable: !0, writable: !0, value: i }) : t[e] = i, __spreadValues$1 = (t, e) => {
+  for (var i in e || (e = {}))
+    __hasOwnProp$1.call(e, i) && __defNormalProp$1(t, i, e[i]);
+  if (__getOwnPropSymbols$1)
+    for (var i of __getOwnPropSymbols$1(e))
+      __propIsEnum$1.call(e, i) && __defNormalProp$1(t, i, e[i]);
+  return t;
+}, __spreadProps = (t, e) => __defProps(t, __getOwnPropDescs(e));
+let current;
+const internalLocale = writable(null);
+function getSubLocales(t) {
+  return t.split("-").map((e, i, n) => n.slice(0, i + 1).join("-")).reverse();
+}
+function getPossibleLocales(t, e = getOptions().fallbackLocale) {
+  const i = getSubLocales(t);
+  return e ? [.../* @__PURE__ */ new Set([...i, ...getSubLocales(e)])] : i;
+}
+function getCurrentLocale() {
+  return current ?? void 0;
+}
+internalLocale.subscribe((t) => {
+  current = t ?? void 0, typeof window < "u" && t != null && document.documentElement.setAttribute("lang", t);
+});
+const set = (t) => {
+  if (t && getClosestAvailableLocale(t) && hasLocaleQueue(t)) {
+    const { loadingDelay: e } = getOptions();
+    let i;
+    return typeof window < "u" && getCurrentLocale() != null && e ? i = window.setTimeout(
+      () => $isLoading.set(!0),
+      e
+    ) : $isLoading.set(!0), flush(t).then(() => {
+      internalLocale.set(t);
+    }).finally(() => {
+      clearTimeout(i), $isLoading.set(!1);
+    });
+  }
+  return internalLocale.set(t);
+}, $locale = __spreadProps(__spreadValues$1({}, internalLocale), {
+  set
+}), monadicMemoize = (t) => {
+  const e = /* @__PURE__ */ Object.create(null);
+  return (n) => {
+    const s = JSON.stringify(n);
+    return s in e ? e[s] : e[s] = t(n);
+  };
+};
+var __defProp = Object.defineProperty, __getOwnPropSymbols = Object.getOwnPropertySymbols, __hasOwnProp = Object.prototype.hasOwnProperty, __propIsEnum = Object.prototype.propertyIsEnumerable, __defNormalProp = (t, e, i) => e in t ? __defProp(t, e, { enumerable: !0, configurable: !0, writable: !0, value: i }) : t[e] = i, __spreadValues = (t, e) => {
+  for (var i in e || (e = {}))
+    __hasOwnProp.call(e, i) && __defNormalProp(t, i, e[i]);
+  if (__getOwnPropSymbols)
+    for (var i of __getOwnPropSymbols(e))
+      __propIsEnum.call(e, i) && __defNormalProp(t, i, e[i]);
+  return t;
+}, __objRest = (t, e) => {
+  var i = {};
+  for (var n in t)
+    __hasOwnProp.call(t, n) && e.indexOf(n) < 0 && (i[n] = t[n]);
+  if (t != null && __getOwnPropSymbols)
+    for (var n of __getOwnPropSymbols(t))
+      e.indexOf(n) < 0 && __propIsEnum.call(t, n) && (i[n] = t[n]);
+  return i;
+};
+const getIntlFormatterOptions = (t, e) => {
+  const { formats: i } = getOptions();
+  if (t in i && e in i[t])
+    return i[t][e];
+  throw new Error(`[svelte-i18n] Unknown "${e}" ${t} format.`);
+}, createNumberFormatter = monadicMemoize(
+  (t) => {
+    var e = t, { locale: i, format: n } = e, s = __objRest(e, ["locale", "format"]);
+    if (i == null)
+      throw new Error('[svelte-i18n] A "locale" must be set to format numbers');
+    return n && (s = getIntlFormatterOptions("number", n)), new Intl.NumberFormat(i, s);
+  }
+), createDateFormatter = monadicMemoize(
+  (t) => {
+    var e = t, { locale: i, format: n } = e, s = __objRest(e, ["locale", "format"]);
+    if (i == null)
+      throw new Error('[svelte-i18n] A "locale" must be set to format dates');
+    return n ? s = getIntlFormatterOptions("date", n) : Object.keys(s).length === 0 && (s = getIntlFormatterOptions("date", "short")), new Intl.DateTimeFormat(i, s);
+  }
+), createTimeFormatter = monadicMemoize(
+  (t) => {
+    var e = t, { locale: i, format: n } = e, s = __objRest(e, ["locale", "format"]);
+    if (i == null)
+      throw new Error(
+        '[svelte-i18n] A "locale" must be set to format time values'
+      );
+    return n ? s = getIntlFormatterOptions("time", n) : Object.keys(s).length === 0 && (s = getIntlFormatterOptions("time", "short")), new Intl.DateTimeFormat(i, s);
+  }
+), getNumberFormatter = (t = {}) => {
+  var e = t, {
+    locale: i = getCurrentLocale()
+  } = e, n = __objRest(e, [
+    "locale"
+  ]);
+  return createNumberFormatter(__spreadValues({ locale: i }, n));
+}, getDateFormatter = (t = {}) => {
+  var e = t, {
+    locale: i = getCurrentLocale()
+  } = e, n = __objRest(e, [
+    "locale"
+  ]);
+  return createDateFormatter(__spreadValues({ locale: i }, n));
+}, getTimeFormatter = (t = {}) => {
+  var e = t, {
+    locale: i = getCurrentLocale()
+  } = e, n = __objRest(e, [
+    "locale"
+  ]);
+  return createTimeFormatter(__spreadValues({ locale: i }, n));
+}, getMessageFormatter = monadicMemoize(
+  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
+  (t, e = getCurrentLocale()) => new IntlMessageFormat(t, e, getOptions().formats, {
+    ignoreTag: getOptions().ignoreTag
+  })
+), formatMessage = (t, e = {}) => {
+  var i, n, s, l;
+  let h = e;
+  typeof t == "object" && (h = t, t = h.id);
+  const {
+    values: _,
+    locale: c = getCurrentLocale(),
+    default: o
+  } = h;
+  if (c == null)
+    throw new Error(
+      "[svelte-i18n] Cannot format a message without first setting the initial locale."
+    );
+  let r = lookup(t, c);
+  if (!r)
+    r = (l = (s = (n = (i = getOptions()).handleMissingMessage) == null ? void 0 : n.call(i, { locale: c, id: t, defaultValue: o })) != null ? s : o) != null ? l : t;
+  else if (typeof r != "string")
+    return console.warn(
+      `[svelte-i18n] Message with id "${t}" must be of type "string", found: "${typeof r}". Gettin its value through the "$format" method is deprecated; use the "json" method instead.`
+    ), r;
+  if (!_)
+    return r;
+  let T = r;
+  try {
+    T = getMessageFormatter(r, c).format(_);
+  } catch (S) {
+    S instanceof Error && console.warn(
+      `[svelte-i18n] Message "${t}" has syntax error:`,
+      S.message
+    );
+  }
+  return T;
+}, formatTime = (t, e) => getTimeFormatter(e).format(t), formatDate = (t, e) => getDateFormatter(e).format(t), formatNumber = (t, e) => getNumberFormatter(e).format(t), getJSON = (t, e = getCurrentLocale()) => lookup(t, e);
+derived([$locale, $dictionary], () => formatMessage);
+derived([$locale], () => formatTime);
+derived([$locale], () => formatDate);
+derived([$locale], () => formatNumber);
+derived([$locale, $dictionary], () => getJSON);
+const Upload_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$2,
+  append: append$2,
+  attr: attr$2,
+  binding_callbacks: binding_callbacks$1,
+  bubble,
+  create_slot,
+  detach: detach$2,
+  element: element$2,
+  get_all_dirty_from_scope,
+  get_slot_changes,
+  init: init$2,
+  insert: insert$2,
+  listen,
+  prevent_default,
+  run_all,
+  safe_not_equal: safe_not_equal$2,
+  space: space$2,
+  stop_propagation,
+  toggle_class: toggle_class$1,
+  transition_in: transition_in$2,
+  transition_out: transition_out$2,
+  update_slot_base
+} = window.__gradio__svelte__internal, { createEventDispatcher: createEventDispatcher$1, tick: tick$1, getContext } = window.__gradio__svelte__internal;
+function create_fragment$2(t) {
+  let e, i, n, s, l, h, _, c, o;
+  const r = (
+    /*#slots*/
+    t[16].default
+  ), T = create_slot(
+    r,
+    t,
+    /*$$scope*/
+    t[15],
+    null
+  );
+  return {
+    c() {
+      e = element$2("button"), T && T.c(), i = space$2(), n = element$2("input"), attr$2(n, "type", "file"), attr$2(
+        n,
+        "accept",
+        /*filetype*/
+        t[0]
+      ), n.multiple = s = /*file_count*/
+      t[4] === "multiple" || void 0, attr$2(n, "webkitdirectory", l = /*file_count*/
+      t[4] === "directory" || void 0), attr$2(n, "mozdirectory", h = /*file_count*/
+      t[4] === "directory" || void 0), attr$2(n, "class", "svelte-18dlsnh"), attr$2(e, "class", "svelte-18dlsnh"), toggle_class$1(
+        e,
+        "hidden",
+        /*hidden*/
+        t[5]
+      ), toggle_class$1(
+        e,
+        "center",
+        /*center*/
+        t[2]
+      ), toggle_class$1(
+        e,
+        "boundedheight",
+        /*boundedheight*/
+        t[1]
+      ), toggle_class$1(
+        e,
+        "flex",
+        /*flex*/
+        t[3]
+      );
+    },
+    m(S, w) {
+      insert$2(S, e, w), T && T.m(e, null), append$2(e, i), append$2(e, n), t[24](n), _ = !0, c || (o = [
+        listen(
+          n,
+          "change",
+          /*load_files_from_upload*/
+          t[9]
+        ),
+        listen(e, "drag", stop_propagation(prevent_default(
+          /*drag_handler*/
+          t[17]
+        ))),
+        listen(e, "dragstart", stop_propagation(prevent_default(
+          /*dragstart_handler*/
+          t[18]
+        ))),
+        listen(e, "dragend", stop_propagation(prevent_default(
+          /*dragend_handler*/
+          t[19]
+        ))),
+        listen(e, "dragover", stop_propagation(prevent_default(
+          /*dragover_handler*/
+          t[20]
+        ))),
+        listen(e, "dragenter", stop_propagation(prevent_default(
+          /*dragenter_handler*/
+          t[21]
+        ))),
+        listen(e, "dragleave", stop_propagation(prevent_default(
+          /*dragleave_handler*/
+          t[22]
+        ))),
+        listen(e, "drop", stop_propagation(prevent_default(
+          /*drop_handler*/
+          t[23]
+        ))),
+        listen(
+          e,
+          "click",
+          /*open_file_upload*/
+          t[6]
+        ),
+        listen(
+          e,
+          "drop",
+          /*loadFilesFromDrop*/
+          t[10]
+        ),
+        listen(
+          e,
+          "dragenter",
+          /*updateDragging*/
+          t[8]
+        ),
+        listen(
+          e,
+          "dragleave",
+          /*updateDragging*/
+          t[8]
+        )
+      ], c = !0);
+    },
+    p(S, [w]) {
+      T && T.p && (!_ || w & /*$$scope*/
+      32768) && update_slot_base(
+        T,
+        r,
+        S,
+        /*$$scope*/
+        S[15],
+        _ ? get_slot_changes(
+          r,
+          /*$$scope*/
+          S[15],
+          w,
+          null
+        ) : get_all_dirty_from_scope(
+          /*$$scope*/
+          S[15]
+        ),
+        null
+      ), (!_ || w & /*filetype*/
+      1) && attr$2(
+        n,
+        "accept",
+        /*filetype*/
+        S[0]
+      ), (!_ || w & /*file_count*/
+      16 && s !== (s = /*file_count*/
+      S[4] === "multiple" || void 0)) && (n.multiple = s), (!_ || w & /*file_count*/
+      16 && l !== (l = /*file_count*/
+      S[4] === "directory" || void 0)) && attr$2(n, "webkitdirectory", l), (!_ || w & /*file_count*/
+      16 && h !== (h = /*file_count*/
+      S[4] === "directory" || void 0)) && attr$2(n, "mozdirectory", h), (!_ || w & /*hidden*/
+      32) && toggle_class$1(
+        e,
+        "hidden",
+        /*hidden*/
+        S[5]
+      ), (!_ || w & /*center*/
+      4) && toggle_class$1(
+        e,
+        "center",
+        /*center*/
+        S[2]
+      ), (!_ || w & /*boundedheight*/
+      2) && toggle_class$1(
+        e,
+        "boundedheight",
+        /*boundedheight*/
+        S[1]
+      ), (!_ || w & /*flex*/
+      8) && toggle_class$1(
+        e,
+        "flex",
+        /*flex*/
+        S[3]
+      );
+    },
+    i(S) {
+      _ || (transition_in$2(T, S), _ = !0);
+    },
+    o(S) {
+      transition_out$2(T, S), _ = !1;
+    },
+    d(S) {
+      S && detach$2(e), T && T.d(S), t[24](null), c = !1, run_all(o);
+    }
+  };
+}
+function _optionalChain(t) {
+  let e, i = t[0], n = 1;
+  for (; n < t.length; ) {
+    const s = t[n], l = t[n + 1];
+    if (n += 2, (s === "optionalAccess" || s === "optionalCall") && i == null)
+      return;
+    s === "access" || s === "optionalAccess" ? (e = i, i = l(i)) : (s === "call" || s === "optionalCall") && (i = l((...h) => i.call(e, ...h)), e = void 0);
+  }
+  return i;
+}
+function is_valid_mimetype(t, e) {
+  return !t || t === "*" ? !0 : t.endsWith("/*") ? e.startsWith(t.slice(0, -1)) : t === e;
+}
+function instance$2(t, e, i) {
+  let { $$slots: n = {}, $$scope: s } = e, { filetype: l = null } = e, { dragging: h = !1 } = e, { boundedheight: _ = !0 } = e, { center: c = !0 } = e, { flex: o = !0 } = e, { file_count: r = "single" } = e, { disable_click: T = !1 } = e, { root: S } = e, { hidden: w = !1 } = e;
+  const C = getContext("upload_files");
+  let P;
+  const b = createEventDispatcher$1();
+  function k() {
+    i(11, h = !h);
+  }
+  function F() {
+    T || (i(7, P.value = "", P), P.click());
+  }
+  async function x(B) {
+    await tick$1();
+    const ee = await upload(B, S, C);
+    return b("load", r === "single" ? _optionalChain([ee, "optionalAccess", (Y) => Y[0]]) : ee), ee || [];
+  }
+  async function y(B) {
+    if (!B.length)
+      return;
+    let ee = B.map((q) => new File([q], q.name)), Y = await prepare_files(ee);
+    return await x(Y);
+  }
+  async function p(B) {
+    const ee = B.target;
+    ee.files && await y(Array.from(ee.files));
+  }
+  async function E(B) {
+    if (i(11, h = !1), !_optionalChain([B, "access", (Y) => Y.dataTransfer, "optionalAccess", (Y) => Y.files]))
+      return;
+    const ee = Array.from(B.dataTransfer.files).filter((Y) => _optionalChain([
+      l,
+      "optionalAccess",
+      (q) => q.split,
+      "call",
+      (q) => q(","),
+      "access",
+      (q) => q.some,
+      "call",
+      (q) => q((le) => is_valid_mimetype(le, Y.type))
+    ]) ? !0 : (b("error", `Invalid file type only ${l} allowed.`), !1));
+    await y(ee);
+  }
+  function $(B) {
+    bubble.call(this, t, B);
+  }
+  function M(B) {
+    bubble.call(this, t, B);
+  }
+  function m(B) {
+    bubble.call(this, t, B);
+  }
+  function N(B) {
+    bubble.call(this, t, B);
+  }
+  function D(B) {
+    bubble.call(this, t, B);
+  }
+  function X(B) {
+    bubble.call(this, t, B);
+  }
+  function G(B) {
+    bubble.call(this, t, B);
+  }
+  function I(B) {
+    binding_callbacks$1[B ? "unshift" : "push"](() => {
+      P = B, i(7, P);
+    });
+  }
+  return t.$$set = (B) => {
+    "filetype" in B && i(0, l = B.filetype), "dragging" in B && i(11, h = B.dragging), "boundedheight" in B && i(1, _ = B.boundedheight), "center" in B && i(2, c = B.center), "flex" in B && i(3, o = B.flex), "file_count" in B && i(4, r = B.file_count), "disable_click" in B && i(12, T = B.disable_click), "root" in B && i(13, S = B.root), "hidden" in B && i(5, w = B.hidden), "$$scope" in B && i(15, s = B.$$scope);
+  }, [
+    l,
+    _,
+    c,
+    o,
+    r,
+    w,
+    F,
+    P,
+    k,
+    p,
+    E,
+    h,
+    T,
+    S,
+    y,
+    s,
+    n,
+    $,
+    M,
+    m,
+    N,
+    D,
+    X,
+    G,
+    I
+  ];
+}
+class Upload extends SvelteComponent$2 {
+  constructor(e) {
+    super(), init$2(this, e, instance$2, create_fragment$2, safe_not_equal$2, {
+      filetype: 0,
+      dragging: 11,
+      boundedheight: 1,
+      center: 2,
+      flex: 3,
+      file_count: 4,
+      disable_click: 12,
+      root: 13,
+      hidden: 5,
+      open_file_upload: 6,
+      load_files: 14
+    });
+  }
+  get open_file_upload() {
+    return this.$$.ctx[6];
+  }
+  get load_files() {
+    return this.$$.ctx[14];
+  }
+}
+const ModifyUpload_svelte_svelte_type_style_lang = "", {
+  SvelteComponent: SvelteComponent$1,
+  append: append$1,
+  attr: attr$1,
+  check_outros: check_outros$1,
+  create_component: create_component$1,
+  destroy_component: destroy_component$1,
+  detach: detach$1,
+  element: element$1,
+  group_outros: group_outros$1,
+  init: init$1,
+  insert: insert$1,
+  mount_component: mount_component$1,
+  safe_not_equal: safe_not_equal$1,
+  set_style: set_style$1,
+  space: space$1,
+  toggle_class,
+  transition_in: transition_in$1,
+  transition_out: transition_out$1
+} = window.__gradio__svelte__internal, { createEventDispatcher } = window.__gradio__svelte__internal;
+function create_if_block_1$1(t) {
+  let e, i;
+  return e = new IconButton({
+    props: {
+      Icon: Edit,
+      label: (
+        /*i18n*/
+        t[3]("common.edit")
+      )
+    }
+  }), e.$on(
+    "click",
+    /*click_handler*/
+    t[5]
+  ), {
+    c() {
+      create_component$1(e.$$.fragment);
+    },
+    m(n, s) {
+      mount_component$1(e, n, s), i = !0;
+    },
+    p(n, s) {
+      const l = {};
+      s & /*i18n*/
+      8 && (l.label = /*i18n*/
+      n[3]("common.edit")), e.$set(l);
+    },
+    i(n) {
+      i || (transition_in$1(e.$$.fragment, n), i = !0);
+    },
+    o(n) {
+      transition_out$1(e.$$.fragment, n), i = !1;
+    },
+    d(n) {
+      destroy_component$1(e, n);
+    }
+  };
+}
+function create_if_block$1(t) {
+  let e, i;
+  return e = new IconButton({
+    props: {
+      Icon: Undo,
+      label: (
+        /*i18n*/
+        t[3]("common.undo")
+      )
+    }
+  }), e.$on(
+    "click",
+    /*click_handler_1*/
+    t[6]
+  ), {
+    c() {
+      create_component$1(e.$$.fragment);
+    },
+    m(n, s) {
+      mount_component$1(e, n, s), i = !0;
+    },
+    p(n, s) {
+      const l = {};
+      s & /*i18n*/
+      8 && (l.label = /*i18n*/
+      n[3]("common.undo")), e.$set(l);
+    },
+    i(n) {
+      i || (transition_in$1(e.$$.fragment, n), i = !0);
+    },
+    o(n) {
+      transition_out$1(e.$$.fragment, n), i = !1;
+    },
+    d(n) {
+      destroy_component$1(e, n);
+    }
+  };
+}
+function create_fragment$1(t) {
+  let e, i, n, s, l, h = (
+    /*editable*/
+    t[0] && create_if_block_1$1(t)
+  ), _ = (
+    /*undoable*/
+    t[1] && create_if_block$1(t)
+  );
+  return s = new IconButton({
+    props: {
+      Icon: Clear,
+      label: (
+        /*i18n*/
+        t[3]("common.clear")
+      )
+    }
+  }), s.$on(
+    "click",
+    /*click_handler_2*/
+    t[7]
+  ), {
+    c() {
+      e = element$1("div"), h && h.c(), i = space$1(), _ && _.c(), n = space$1(), create_component$1(s.$$.fragment), attr$1(e, "class", "svelte-1wj0ocy"), toggle_class(e, "not-absolute", !/*absolute*/
+      t[2]), set_style$1(
+        e,
+        "position",
+        /*absolute*/
+        t[2] ? "absolute" : "static"
+      );
+    },
+    m(c, o) {
+      insert$1(c, e, o), h && h.m(e, null), append$1(e, i), _ && _.m(e, null), append$1(e, n), mount_component$1(s, e, null), l = !0;
+    },
+    p(c, [o]) {
+      /*editable*/
+      c[0] ? h ? (h.p(c, o), o & /*editable*/
+      1 && transition_in$1(h, 1)) : (h = create_if_block_1$1(c), h.c(), transition_in$1(h, 1), h.m(e, i)) : h && (group_outros$1(), transition_out$1(h, 1, 1, () => {
+        h = null;
+      }), check_outros$1()), /*undoable*/
+      c[1] ? _ ? (_.p(c, o), o & /*undoable*/
+      2 && transition_in$1(_, 1)) : (_ = create_if_block$1(c), _.c(), transition_in$1(_, 1), _.m(e, n)) : _ && (group_outros$1(), transition_out$1(_, 1, 1, () => {
+        _ = null;
+      }), check_outros$1());
+      const r = {};
+      o & /*i18n*/
+      8 && (r.label = /*i18n*/
+      c[3]("common.clear")), s.$set(r), (!l || o & /*absolute*/
+      4) && toggle_class(e, "not-absolute", !/*absolute*/
+      c[2]), o & /*absolute*/
+      4 && set_style$1(
+        e,
+        "position",
+        /*absolute*/
+        c[2] ? "absolute" : "static"
+      );
+    },
+    i(c) {
+      l || (transition_in$1(h), transition_in$1(_), transition_in$1(s.$$.fragment, c), l = !0);
+    },
+    o(c) {
+      transition_out$1(h), transition_out$1(_), transition_out$1(s.$$.fragment, c), l = !1;
+    },
+    d(c) {
+      c && detach$1(e), h && h.d(), _ && _.d(), destroy_component$1(s);
+    }
+  };
+}
+function instance$1(t, e, i) {
+  let { editable: n = !1 } = e, { undoable: s = !1 } = e, { absolute: l = !0 } = e, { i18n: h } = e;
+  const _ = createEventDispatcher(), c = () => _("edit"), o = () => _("undo"), r = (T) => {
+    _("clear"), T.stopPropagation();
+  };
+  return t.$$set = (T) => {
+    "editable" in T && i(0, n = T.editable), "undoable" in T && i(1, s = T.undoable), "absolute" in T && i(2, l = T.absolute), "i18n" in T && i(3, h = T.i18n);
+  }, [
+    n,
+    s,
+    l,
+    h,
+    _,
+    c,
+    o,
+    r
+  ];
+}
+class ModifyUpload extends SvelteComponent$1 {
+  constructor(e) {
+    super(), init$1(this, e, instance$1, create_fragment$1, safe_not_equal$1, {
+      editable: 0,
+      undoable: 1,
+      absolute: 2,
+      i18n: 3
+    });
+  }
+}
+function commonjsRequire(t) {
+  throw new Error('Could not dynamically require "' + t + '". Please configure the dynamicRequireTargets or/and ignoreDynamicRequires option of @rollup/plugin-commonjs appropriately for this require call to work.');
+}
+var pdf = { exports: {} };
+const require$$5$1 = {}, __viteBrowserExternal = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
+  __proto__: null,
+  default: require$$5$1
+}, Symbol.toStringTag, { value: "Module" })), require$$5 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal);
+(function(module, exports) {
+  (function(e, i) {
+    module.exports = e.pdfjsLib = i();
+  })(globalThis, () => (
+    /******/
+    (() => {
+      var __webpack_modules__ = [
+        ,
+        /* 1 */
+        /***/
+        (t, e) => {
+          var Ye;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.VerbosityLevel = e.Util = e.UnknownErrorException = e.UnexpectedResponseException = e.TextRenderingMode = e.RenderingIntentFlag = e.PromiseCapability = e.PermissionFlag = e.PasswordResponses = e.PasswordException = e.PageActionEventType = e.OPS = e.MissingPDFException = e.MAX_IMAGE_SIZE_TO_CACHE = e.LINE_FACTOR = e.LINE_DESCENT_FACTOR = e.InvalidPDFException = e.ImageKind = e.IDENTITY_MATRIX = e.FormatError = e.FeatureTest = e.FONT_IDENTITY_MATRIX = e.DocumentActionEventType = e.CMapCompressionType = e.BaseException = e.BASELINE_FACTOR = e.AnnotationType = e.AnnotationReplyType = e.AnnotationPrefix = e.AnnotationMode = e.AnnotationFlag = e.AnnotationFieldFlag = e.AnnotationEditorType = e.AnnotationEditorPrefix = e.AnnotationEditorParamsType = e.AnnotationBorderStyleType = e.AnnotationActionEventType = e.AbortException = void 0, e.assert = le, e.bytesToString = z, e.createValidAbsoluteUrl = we, e.getModificationDate = xe, e.getUuid = Xe, e.getVerbosityLevel = B, e.info = ee, e.isArrayBuffer = ge, e.isArrayEqual = Ce, e.isNodeJS = void 0, e.normalizeUnicode = ze, e.objectFromMap = ue, e.objectSize = ce, e.setVerbosityLevel = I, e.shadow = be, e.string32 = Q, e.stringToBytes = ae, e.stringToPDFString = _e, e.stringToUTF8String = ie, e.unreachable = q, e.utf8StringToString = se, e.warn = Y;
+          const i = typeof process == "object" && process + "" == "[object process]" && !process.versions.nw && !(process.versions.electron && process.type && process.type !== "browser");
+          e.isNodeJS = i;
+          const n = [1, 0, 0, 1, 0, 0];
+          e.IDENTITY_MATRIX = n;
+          const s = [1e-3, 0, 0, 1e-3, 0, 0];
+          e.FONT_IDENTITY_MATRIX = s;
+          const l = 1e7;
+          e.MAX_IMAGE_SIZE_TO_CACHE = l;
+          const h = 1.35;
+          e.LINE_FACTOR = h;
+          const _ = 0.35;
+          e.LINE_DESCENT_FACTOR = _;
+          const c = _ / h;
+          e.BASELINE_FACTOR = c;
+          const o = {
+            ANY: 1,
+            DISPLAY: 2,
+            PRINT: 4,
+            SAVE: 8,
+            ANNOTATIONS_FORMS: 16,
+            ANNOTATIONS_STORAGE: 32,
+            ANNOTATIONS_DISABLE: 64,
+            OPLIST: 256
+          };
+          e.RenderingIntentFlag = o;
+          const r = {
+            DISABLE: 0,
+            ENABLE: 1,
+            ENABLE_FORMS: 2,
+            ENABLE_STORAGE: 3
+          };
+          e.AnnotationMode = r;
+          const T = "pdfjs_internal_editor_";
+          e.AnnotationEditorPrefix = T;
+          const S = {
+            DISABLE: -1,
+            NONE: 0,
+            FREETEXT: 3,
+            STAMP: 13,
+            INK: 15
+          };
+          e.AnnotationEditorType = S;
+          const w = {
+            RESIZE: 1,
+            CREATE: 2,
+            FREETEXT_SIZE: 11,
+            FREETEXT_COLOR: 12,
+            FREETEXT_OPACITY: 13,
+            INK_COLOR: 21,
+            INK_THICKNESS: 22,
+            INK_OPACITY: 23
+          };
+          e.AnnotationEditorParamsType = w;
+          const C = {
+            PRINT: 4,
+            MODIFY_CONTENTS: 8,
+            COPY: 16,
+            MODIFY_ANNOTATIONS: 32,
+            FILL_INTERACTIVE_FORMS: 256,
+            COPY_FOR_ACCESSIBILITY: 512,
+            ASSEMBLE: 1024,
+            PRINT_HIGH_QUALITY: 2048
+          };
+          e.PermissionFlag = C;
+          const P = {
+            FILL: 0,
+            STROKE: 1,
+            FILL_STROKE: 2,
+            INVISIBLE: 3,
+            FILL_ADD_TO_PATH: 4,
+            STROKE_ADD_TO_PATH: 5,
+            FILL_STROKE_ADD_TO_PATH: 6,
+            ADD_TO_PATH: 7,
+            FILL_STROKE_MASK: 3,
+            ADD_TO_PATH_FLAG: 4
+          };
+          e.TextRenderingMode = P;
+          const b = {
+            GRAYSCALE_1BPP: 1,
+            RGB_24BPP: 2,
+            RGBA_32BPP: 3
+          };
+          e.ImageKind = b;
+          const k = {
+            TEXT: 1,
+            LINK: 2,
+            FREETEXT: 3,
+            LINE: 4,
+            SQUARE: 5,
+            CIRCLE: 6,
+            POLYGON: 7,
+            POLYLINE: 8,
+            HIGHLIGHT: 9,
+            UNDERLINE: 10,
+            SQUIGGLY: 11,
+            STRIKEOUT: 12,
+            STAMP: 13,
+            CARET: 14,
+            INK: 15,
+            POPUP: 16,
+            FILEATTACHMENT: 17,
+            SOUND: 18,
+            MOVIE: 19,
+            WIDGET: 20,
+            SCREEN: 21,
+            PRINTERMARK: 22,
+            TRAPNET: 23,
+            WATERMARK: 24,
+            THREED: 25,
+            REDACT: 26
+          };
+          e.AnnotationType = k;
+          const F = {
+            GROUP: "Group",
+            REPLY: "R"
+          };
+          e.AnnotationReplyType = F;
+          const x = {
+            INVISIBLE: 1,
+            HIDDEN: 2,
+            PRINT: 4,
+            NOZOOM: 8,
+            NOROTATE: 16,
+            NOVIEW: 32,
+            READONLY: 64,
+            LOCKED: 128,
+            TOGGLENOVIEW: 256,
+            LOCKEDCONTENTS: 512
+          };
+          e.AnnotationFlag = x;
+          const y = {
+            READONLY: 1,
+            REQUIRED: 2,
+            NOEXPORT: 4,
+            MULTILINE: 4096,
+            PASSWORD: 8192,
+            NOTOGGLETOOFF: 16384,
+            RADIO: 32768,
+            PUSHBUTTON: 65536,
+            COMBO: 131072,
+            EDIT: 262144,
+            SORT: 524288,
+            FILESELECT: 1048576,
+            MULTISELECT: 2097152,
+            DONOTSPELLCHECK: 4194304,
+            DONOTSCROLL: 8388608,
+            COMB: 16777216,
+            RICHTEXT: 33554432,
+            RADIOSINUNISON: 33554432,
+            COMMITONSELCHANGE: 67108864
+          };
+          e.AnnotationFieldFlag = y;
+          const p = {
+            SOLID: 1,
+            DASHED: 2,
+            BEVELED: 3,
+            INSET: 4,
+            UNDERLINE: 5
+          };
+          e.AnnotationBorderStyleType = p;
+          const E = {
+            E: "Mouse Enter",
+            X: "Mouse Exit",
+            D: "Mouse Down",
+            U: "Mouse Up",
+            Fo: "Focus",
+            Bl: "Blur",
+            PO: "PageOpen",
+            PC: "PageClose",
+            PV: "PageVisible",
+            PI: "PageInvisible",
+            K: "Keystroke",
+            F: "Format",
+            V: "Validate",
+            C: "Calculate"
+          };
+          e.AnnotationActionEventType = E;
+          const $ = {
+            WC: "WillClose",
+            WS: "WillSave",
+            DS: "DidSave",
+            WP: "WillPrint",
+            DP: "DidPrint"
+          };
+          e.DocumentActionEventType = $;
+          const M = {
+            O: "PageOpen",
+            C: "PageClose"
+          };
+          e.PageActionEventType = M;
+          const m = {
+            ERRORS: 0,
+            WARNINGS: 1,
+            INFOS: 5
+          };
+          e.VerbosityLevel = m;
+          const N = {
+            NONE: 0,
+            BINARY: 1
+          };
+          e.CMapCompressionType = N;
+          const D = {
+            dependency: 1,
+            setLineWidth: 2,
+            setLineCap: 3,
+            setLineJoin: 4,
+            setMiterLimit: 5,
+            setDash: 6,
+            setRenderingIntent: 7,
+            setFlatness: 8,
+            setGState: 9,
+            save: 10,
+            restore: 11,
+            transform: 12,
+            moveTo: 13,
+            lineTo: 14,
+            curveTo: 15,
+            curveTo2: 16,
+            curveTo3: 17,
+            closePath: 18,
+            rectangle: 19,
+            stroke: 20,
+            closeStroke: 21,
+            fill: 22,
+            eoFill: 23,
+            fillStroke: 24,
+            eoFillStroke: 25,
+            closeFillStroke: 26,
+            closeEOFillStroke: 27,
+            endPath: 28,
+            clip: 29,
+            eoClip: 30,
+            beginText: 31,
+            endText: 32,
+            setCharSpacing: 33,
+            setWordSpacing: 34,
+            setHScale: 35,
+            setLeading: 36,
+            setFont: 37,
+            setTextRenderingMode: 38,
+            setTextRise: 39,
+            moveText: 40,
+            setLeadingMoveText: 41,
+            setTextMatrix: 42,
+            nextLine: 43,
+            showText: 44,
+            showSpacedText: 45,
+            nextLineShowText: 46,
+            nextLineSetSpacingShowText: 47,
+            setCharWidth: 48,
+            setCharWidthAndBounds: 49,
+            setStrokeColorSpace: 50,
+            setFillColorSpace: 51,
+            setStrokeColor: 52,
+            setStrokeColorN: 53,
+            setFillColor: 54,
+            setFillColorN: 55,
+            setStrokeGray: 56,
+            setFillGray: 57,
+            setStrokeRGBColor: 58,
+            setFillRGBColor: 59,
+            setStrokeCMYKColor: 60,
+            setFillCMYKColor: 61,
+            shadingFill: 62,
+            beginInlineImage: 63,
+            beginImageData: 64,
+            endInlineImage: 65,
+            paintXObject: 66,
+            markPoint: 67,
+            markPointProps: 68,
+            beginMarkedContent: 69,
+            beginMarkedContentProps: 70,
+            endMarkedContent: 71,
+            beginCompat: 72,
+            endCompat: 73,
+            paintFormXObjectBegin: 74,
+            paintFormXObjectEnd: 75,
+            beginGroup: 76,
+            endGroup: 77,
+            beginAnnotation: 80,
+            endAnnotation: 81,
+            paintImageMaskXObject: 83,
+            paintImageMaskXObjectGroup: 84,
+            paintImageXObject: 85,
+            paintInlineImageXObject: 86,
+            paintInlineImageXObjectGroup: 87,
+            paintImageXObjectRepeat: 88,
+            paintImageMaskXObjectRepeat: 89,
+            paintSolidColorImageMask: 90,
+            constructPath: 91
+          };
+          e.OPS = D;
+          const X = {
+            NEED_PASSWORD: 1,
+            INCORRECT_PASSWORD: 2
+          };
+          e.PasswordResponses = X;
+          let G = m.WARNINGS;
+          function I(de) {
+            Number.isInteger(de) && (G = de);
+          }
+          function B() {
+            return G;
+          }
+          function ee(de) {
+            G >= m.INFOS && console.log(`Info: ${de}`);
+          }
+          function Y(de) {
+            G >= m.WARNINGS && console.log(`Warning: ${de}`);
+          }
+          function q(de) {
+            throw new Error(de);
+          }
+          function le(de, ne) {
+            de || q(ne);
+          }
+          function pe(de) {
+            switch (de == null ? void 0 : de.protocol) {
+              case "http:":
+              case "https:":
+              case "ftp:":
+              case "mailto:":
+              case "tel:":
+                return !0;
+              default:
+                return !1;
+            }
+          }
+          function we(de, ne = null, J = null) {
+            if (!de)
+              return null;
+            try {
+              if (J && typeof de == "string") {
+                if (J.addDefaultProtocol && de.startsWith("www.")) {
+                  const Se = de.match(/\./g);
+                  (Se == null ? void 0 : Se.length) >= 2 && (de = `http://${de}`);
+                }
+                if (J.tryConvertEncoding)
+                  try {
+                    de = ie(de);
+                  } catch {
+                  }
+              }
+              const ve = ne ? new URL(de, ne) : new URL(de);
+              if (pe(ve))
+                return ve;
+            } catch {
+            }
+            return null;
+          }
+          function be(de, ne, J, ve = !1) {
+            return Object.defineProperty(de, ne, {
+              value: J,
+              enumerable: !ve,
+              configurable: !0,
+              writable: !1
+            }), J;
+          }
+          const R = function() {
+            function ne(J, ve) {
+              this.constructor === ne && q("Cannot initialize BaseException."), this.message = J, this.name = ve;
+            }
+            return ne.prototype = new Error(), ne.constructor = ne, ne;
+          }();
+          e.BaseException = R;
+          class d extends R {
+            constructor(ne, J) {
+              super(ne, "PasswordException"), this.code = J;
+            }
+          }
+          e.PasswordException = d;
+          class g extends R {
+            constructor(ne, J) {
+              super(ne, "UnknownErrorException"), this.details = J;
+            }
+          }
+          e.UnknownErrorException = g;
+          class f extends R {
+            constructor(ne) {
+              super(ne, "InvalidPDFException");
+            }
+          }
+          e.InvalidPDFException = f;
+          class v extends R {
+            constructor(ne) {
+              super(ne, "MissingPDFException");
+            }
+          }
+          e.MissingPDFException = v;
+          class A extends R {
+            constructor(ne, J) {
+              super(ne, "UnexpectedResponseException"), this.status = J;
+            }
+          }
+          e.UnexpectedResponseException = A;
+          class O extends R {
+            constructor(ne) {
+              super(ne, "FormatError");
+            }
+          }
+          e.FormatError = O;
+          class H extends R {
+            constructor(ne) {
+              super(ne, "AbortException");
+            }
+          }
+          e.AbortException = H;
+          function z(de) {
+            (typeof de != "object" || (de == null ? void 0 : de.length) === void 0) && q("Invalid argument for bytesToString");
+            const ne = de.length, J = 8192;
+            if (ne < J)
+              return String.fromCharCode.apply(null, de);
+            const ve = [];
+            for (let Se = 0; Se < ne; Se += J) {
+              const tt = Math.min(Se + J, ne), et = de.subarray(Se, tt);
+              ve.push(String.fromCharCode.apply(null, et));
+            }
+            return ve.join("");
+          }
+          function ae(de) {
+            typeof de != "string" && q("Invalid argument for stringToBytes");
+            const ne = de.length, J = new Uint8Array(ne);
+            for (let ve = 0; ve < ne; ++ve)
+              J[ve] = de.charCodeAt(ve) & 255;
+            return J;
+          }
+          function Q(de) {
+            return String.fromCharCode(de >> 24 & 255, de >> 16 & 255, de >> 8 & 255, de & 255);
+          }
+          function ce(de) {
+            return Object.keys(de).length;
+          }
+          function ue(de) {
+            const ne = /* @__PURE__ */ Object.create(null);
+            for (const [J, ve] of de)
+              ne[J] = ve;
+            return ne;
+          }
+          function me() {
+            const de = new Uint8Array(4);
+            return de[0] = 1, new Uint32Array(de.buffer, 0, 1)[0] === 1;
+          }
+          function fe() {
+            try {
+              return new Function(""), !0;
+            } catch {
+              return !1;
+            }
+          }
+          class Pe {
+            static get isLittleEndian() {
+              return be(this, "isLittleEndian", me());
+            }
+            static get isEvalSupported() {
+              return be(this, "isEvalSupported", fe());
+            }
+            static get isOffscreenCanvasSupported() {
+              return be(this, "isOffscreenCanvasSupported", typeof OffscreenCanvas < "u");
+            }
+            static get platform() {
+              return typeof navigator > "u" ? be(this, "platform", {
+                isWin: !1,
+                isMac: !1
+              }) : be(this, "platform", {
+                isWin: navigator.platform.includes("Win"),
+                isMac: navigator.platform.includes("Mac")
+              });
+            }
+            static get isCSSRoundSupported() {
+              var ne, J;
+              return be(this, "isCSSRoundSupported", (J = (ne = globalThis.CSS) == null ? void 0 : ne.supports) == null ? void 0 : J.call(ne, "width: round(1.5px, 1px)"));
+            }
+          }
+          e.FeatureTest = Pe;
+          const Fe = [...Array(256).keys()].map((de) => de.toString(16).padStart(2, "0"));
+          class Ee {
+            static makeHexColor(ne, J, ve) {
+              return `#${Fe[ne]}${Fe[J]}${Fe[ve]}`;
+            }
+            static scaleMinMax(ne, J) {
+              let ve;
+              ne[0] ? (ne[0] < 0 && (ve = J[0], J[0] = J[1], J[1] = ve), J[0] *= ne[0], J[1] *= ne[0], ne[3] < 0 && (ve = J[2], J[2] = J[3], J[3] = ve), J[2] *= ne[3], J[3] *= ne[3]) : (ve = J[0], J[0] = J[2], J[2] = ve, ve = J[1], J[1] = J[3], J[3] = ve, ne[1] < 0 && (ve = J[2], J[2] = J[3], J[3] = ve), J[2] *= ne[1], J[3] *= ne[1], ne[2] < 0 && (ve = J[0], J[0] = J[1], J[1] = ve), J[0] *= ne[2], J[1] *= ne[2]), J[0] += ne[4], J[1] += ne[4], J[2] += ne[5], J[3] += ne[5];
+            }
+            static transform(ne, J) {
+              return [ne[0] * J[0] + ne[2] * J[1], ne[1] * J[0] + ne[3] * J[1], ne[0] * J[2] + ne[2] * J[3], ne[1] * J[2] + ne[3] * J[3], ne[0] * J[4] + ne[2] * J[5] + ne[4], ne[1] * J[4] + ne[3] * J[5] + ne[5]];
+            }
+            static applyTransform(ne, J) {
+              const ve = ne[0] * J[0] + ne[1] * J[2] + J[4], Se = ne[0] * J[1] + ne[1] * J[3] + J[5];
+              return [ve, Se];
+            }
+            static applyInverseTransform(ne, J) {
+              const ve = J[0] * J[3] - J[1] * J[2], Se = (ne[0] * J[3] - ne[1] * J[2] + J[2] * J[5] - J[4] * J[3]) / ve, tt = (-ne[0] * J[1] + ne[1] * J[0] + J[4] * J[1] - J[5] * J[0]) / ve;
+              return [Se, tt];
+            }
+            static getAxialAlignedBoundingBox(ne, J) {
+              const ve = this.applyTransform(ne, J), Se = this.applyTransform(ne.slice(2, 4), J), tt = this.applyTransform([ne[0], ne[3]], J), et = this.applyTransform([ne[2], ne[1]], J);
+              return [Math.min(ve[0], Se[0], tt[0], et[0]), Math.min(ve[1], Se[1], tt[1], et[1]), Math.max(ve[0], Se[0], tt[0], et[0]), Math.max(ve[1], Se[1], tt[1], et[1])];
+            }
+            static inverseTransform(ne) {
+              const J = ne[0] * ne[3] - ne[1] * ne[2];
+              return [ne[3] / J, -ne[1] / J, -ne[2] / J, ne[0] / J, (ne[2] * ne[5] - ne[4] * ne[3]) / J, (ne[4] * ne[1] - ne[5] * ne[0]) / J];
+            }
+            static singularValueDecompose2dScale(ne) {
+              const J = [ne[0], ne[2], ne[1], ne[3]], ve = ne[0] * J[0] + ne[1] * J[2], Se = ne[0] * J[1] + ne[1] * J[3], tt = ne[2] * J[0] + ne[3] * J[2], et = ne[2] * J[1] + ne[3] * J[3], te = (ve + et) / 2, Te = Math.sqrt((ve + et) ** 2 - 4 * (ve * et - tt * Se)) / 2, Ne = te + Te || 1, ke = te - Te || 1;
+              return [Math.sqrt(Ne), Math.sqrt(ke)];
+            }
+            static normalizeRect(ne) {
+              const J = ne.slice(0);
+              return ne[0] > ne[2] && (J[0] = ne[2], J[2] = ne[0]), ne[1] > ne[3] && (J[1] = ne[3], J[3] = ne[1]), J;
+            }
+            static intersect(ne, J) {
+              const ve = Math.max(Math.min(ne[0], ne[2]), Math.min(J[0], J[2])), Se = Math.min(Math.max(ne[0], ne[2]), Math.max(J[0], J[2]));
+              if (ve > Se)
+                return null;
+              const tt = Math.max(Math.min(ne[1], ne[3]), Math.min(J[1], J[3])), et = Math.min(Math.max(ne[1], ne[3]), Math.max(J[1], J[3]));
+              return tt > et ? null : [ve, tt, Se, et];
+            }
+            static bezierBoundingBox(ne, J, ve, Se, tt, et, te, Te) {
+              const Ne = [], ke = [[], []];
+              let $e, Be, Qe, Ae, Ke, Oe, U, u;
+              for (let Z = 0; Z < 2; ++Z) {
+                if (Z === 0 ? (Be = 6 * ne - 12 * ve + 6 * tt, $e = -3 * ne + 9 * ve - 9 * tt + 3 * te, Qe = 3 * ve - 3 * ne) : (Be = 6 * J - 12 * Se + 6 * et, $e = -3 * J + 9 * Se - 9 * et + 3 * Te, Qe = 3 * Se - 3 * J), Math.abs($e) < 1e-12) {
+                  if (Math.abs(Be) < 1e-12)
+                    continue;
+                  Ae = -Qe / Be, 0 < Ae && Ae < 1 && Ne.push(Ae);
+                  continue;
+                }
+                U = Be * Be - 4 * Qe * $e, u = Math.sqrt(U), !(U < 0) && (Ke = (-Be + u) / (2 * $e), 0 < Ke && Ke < 1 && Ne.push(Ke), Oe = (-Be - u) / (2 * $e), 0 < Oe && Oe < 1 && Ne.push(Oe));
+              }
+              let L = Ne.length, j;
+              const V = L;
+              for (; L--; )
+                Ae = Ne[L], j = 1 - Ae, ke[0][L] = j * j * j * ne + 3 * j * j * Ae * ve + 3 * j * Ae * Ae * tt + Ae * Ae * Ae * te, ke[1][L] = j * j * j * J + 3 * j * j * Ae * Se + 3 * j * Ae * Ae * et + Ae * Ae * Ae * Te;
+              return ke[0][V] = ne, ke[1][V] = J, ke[0][V + 1] = te, ke[1][V + 1] = Te, ke[0].length = ke[1].length = V + 2, [Math.min(...ke[0]), Math.min(...ke[1]), Math.max(...ke[0]), Math.max(...ke[1])];
+            }
+          }
+          e.Util = Ee;
+          const De = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 728, 711, 710, 729, 733, 731, 730, 732, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8226, 8224, 8225, 8230, 8212, 8211, 402, 8260, 8249, 8250, 8722, 8240, 8222, 8220, 8221, 8216, 8217, 8218, 8482, 64257, 64258, 321, 338, 352, 376, 381, 305, 322, 339, 353, 382, 0, 8364];
+          function _e(de) {
+            if (de[0] >= "ï") {
+              let J;
+              if (de[0] === "þ" && de[1] === "ÿ" ? J = "utf-16be" : de[0] === "ÿ" && de[1] === "þ" ? J = "utf-16le" : de[0] === "ï" && de[1] === "»" && de[2] === "¿" && (J = "utf-8"), J)
+                try {
+                  const ve = new TextDecoder(J, {
+                    fatal: !0
+                  }), Se = ae(de);
+                  return ve.decode(Se);
+                } catch (ve) {
+                  Y(`stringToPDFString: "${ve}".`);
+                }
+            }
+            const ne = [];
+            for (let J = 0, ve = de.length; J < ve; J++) {
+              const Se = De[de.charCodeAt(J)];
+              ne.push(Se ? String.fromCharCode(Se) : de.charAt(J));
+            }
+            return ne.join("");
+          }
+          function ie(de) {
+            return decodeURIComponent(escape(de));
+          }
+          function se(de) {
+            return unescape(encodeURIComponent(de));
+          }
+          function ge(de) {
+            return typeof de == "object" && (de == null ? void 0 : de.byteLength) !== void 0;
+          }
+          function Ce(de, ne) {
+            if (de.length !== ne.length)
+              return !1;
+            for (let J = 0, ve = de.length; J < ve; J++)
+              if (de[J] !== ne[J])
+                return !1;
+            return !0;
+          }
+          function xe(de = /* @__PURE__ */ new Date()) {
+            return [de.getUTCFullYear().toString(), (de.getUTCMonth() + 1).toString().padStart(2, "0"), de.getUTCDate().toString().padStart(2, "0"), de.getUTCHours().toString().padStart(2, "0"), de.getUTCMinutes().toString().padStart(2, "0"), de.getUTCSeconds().toString().padStart(2, "0")].join("");
+          }
+          class Ue {
+            constructor() {
+              W(this, Ye, !1);
+              this.promise = new Promise((ne, J) => {
+                this.resolve = (ve) => {
+                  oe(this, Ye, !0), ne(ve);
+                }, this.reject = (ve) => {
+                  oe(this, Ye, !0), J(ve);
+                };
+              });
+            }
+            get settled() {
+              return a(this, Ye);
+            }
+          }
+          Ye = new WeakMap(), e.PromiseCapability = Ue;
+          let We = null, je = null;
+          function ze(de) {
+            return We || (We = /([\u00a0\u00b5\u037e\u0eb3\u2000-\u200a\u202f\u2126\ufb00-\ufb04\ufb06\ufb20-\ufb36\ufb38-\ufb3c\ufb3e\ufb40-\ufb41\ufb43-\ufb44\ufb46-\ufba1\ufba4-\ufba9\ufbae-\ufbb1\ufbd3-\ufbdc\ufbde-\ufbe7\ufbea-\ufbf8\ufbfc-\ufbfd\ufc00-\ufc5d\ufc64-\ufcf1\ufcf5-\ufd3d\ufd88\ufdf4\ufdfa-\ufdfb\ufe71\ufe77\ufe79\ufe7b\ufe7d]+)|(\ufb05+)/gu, je = /* @__PURE__ */ new Map([["ſt", "ſt"]])), de.replaceAll(We, (ne, J, ve) => J ? J.normalize("NFKC") : je.get(ve));
+          }
+          function Xe() {
+            if (typeof crypto < "u" && typeof (crypto == null ? void 0 : crypto.randomUUID) == "function")
+              return crypto.randomUUID();
+            const de = new Uint8Array(32);
+            if (typeof crypto < "u" && typeof (crypto == null ? void 0 : crypto.getRandomValues) == "function")
+              crypto.getRandomValues(de);
+            else
+              for (let ne = 0; ne < 32; ne++)
+                de[ne] = Math.floor(Math.random() * 255);
+            return z(de);
+          }
+          const Ge = "pdfjs_internal_id_";
+          e.AnnotationPrefix = Ge;
+        },
+        /* 2 */
+        /***/
+        (__unused_webpack_module, exports, __w_pdfjs_require__) => {
+          var t, i, n, s, ut, h, wt, c, o, r, T, S, w, C, P, b, Tt, F, x, Bt, p, E;
+          Object.defineProperty(exports, "__esModule", {
+            value: !0
+          }), exports.RenderTask = exports.PDFWorkerUtil = exports.PDFWorker = exports.PDFPageProxy = exports.PDFDocumentProxy = exports.PDFDocumentLoadingTask = exports.PDFDataRangeTransport = exports.LoopbackPort = exports.DefaultStandardFontDataFactory = exports.DefaultFilterFactory = exports.DefaultCanvasFactory = exports.DefaultCMapReaderFactory = void 0, Object.defineProperty(exports, "SVGGraphics", {
+            enumerable: !0,
+            get: function() {
+              return _displaySvg.SVGGraphics;
+            }
+          }), exports.build = void 0, exports.getDocument = getDocument, exports.version = void 0;
+          var _util = __w_pdfjs_require__(1), _annotation_storage = __w_pdfjs_require__(3), _display_utils = __w_pdfjs_require__(6), _font_loader = __w_pdfjs_require__(9), _displayNode_utils = __w_pdfjs_require__(10), _canvas = __w_pdfjs_require__(11), _worker_options = __w_pdfjs_require__(14), _message_handler = __w_pdfjs_require__(15), _metadata = __w_pdfjs_require__(16), _optional_content_config = __w_pdfjs_require__(17), _transport_stream = __w_pdfjs_require__(18), _displayFetch_stream = __w_pdfjs_require__(19), _displayNetwork = __w_pdfjs_require__(22), _displayNode_stream = __w_pdfjs_require__(23), _displaySvg = __w_pdfjs_require__(24), _xfa_text = __w_pdfjs_require__(25);
+          const DEFAULT_RANGE_CHUNK_SIZE = 65536, RENDERING_CANCELLED_TIMEOUT = 100, DELAYED_CLEANUP_TIMEOUT = 5e3, DefaultCanvasFactory = _util.isNodeJS ? _displayNode_utils.NodeCanvasFactory : _display_utils.DOMCanvasFactory;
+          exports.DefaultCanvasFactory = DefaultCanvasFactory;
+          const DefaultCMapReaderFactory = _util.isNodeJS ? _displayNode_utils.NodeCMapReaderFactory : _display_utils.DOMCMapReaderFactory;
+          exports.DefaultCMapReaderFactory = DefaultCMapReaderFactory;
+          const DefaultFilterFactory = _util.isNodeJS ? _displayNode_utils.NodeFilterFactory : _display_utils.DOMFilterFactory;
+          exports.DefaultFilterFactory = DefaultFilterFactory;
+          const DefaultStandardFontDataFactory = _util.isNodeJS ? _displayNode_utils.NodeStandardFontDataFactory : _display_utils.DOMStandardFontDataFactory;
+          exports.DefaultStandardFontDataFactory = DefaultStandardFontDataFactory;
+          function getDocument(M) {
+            if (typeof M == "string" || M instanceof URL ? M = {
+              url: M
+            } : (0, _util.isArrayBuffer)(M) && (M = {
+              data: M
+            }), typeof M != "object")
+              throw new Error("Invalid parameter in getDocument, need parameter object.");
+            if (!M.url && !M.data && !M.range)
+              throw new Error("Invalid parameter object: need either .data, .range or .url");
+            const m = new PDFDocumentLoadingTask(), {
+              docId: N
+            } = m, D = M.url ? getUrlProp(M.url) : null, X = M.data ? getDataProp(M.data) : null, G = M.httpHeaders || null, I = M.withCredentials === !0, B = M.password ?? null, ee = M.range instanceof PDFDataRangeTransport ? M.range : null, Y = Number.isInteger(M.rangeChunkSize) && M.rangeChunkSize > 0 ? M.rangeChunkSize : DEFAULT_RANGE_CHUNK_SIZE;
+            let q = M.worker instanceof PDFWorker ? M.worker : null;
+            const le = M.verbosity, pe = typeof M.docBaseUrl == "string" && !(0, _display_utils.isDataScheme)(M.docBaseUrl) ? M.docBaseUrl : null, we = typeof M.cMapUrl == "string" ? M.cMapUrl : null, be = M.cMapPacked !== !1, R = M.CMapReaderFactory || DefaultCMapReaderFactory, d = typeof M.standardFontDataUrl == "string" ? M.standardFontDataUrl : null, g = M.StandardFontDataFactory || DefaultStandardFontDataFactory, f = M.stopAtErrors !== !0, v = Number.isInteger(M.maxImageSize) && M.maxImageSize > -1 ? M.maxImageSize : -1, A = M.isEvalSupported !== !1, O = typeof M.isOffscreenCanvasSupported == "boolean" ? M.isOffscreenCanvasSupported : !_util.isNodeJS, H = Number.isInteger(M.canvasMaxAreaInBytes) ? M.canvasMaxAreaInBytes : -1, z = typeof M.disableFontFace == "boolean" ? M.disableFontFace : _util.isNodeJS, ae = M.fontExtraProperties === !0, Q = M.enableXfa === !0, ce = M.ownerDocument || globalThis.document, ue = M.disableRange === !0, me = M.disableStream === !0, fe = M.disableAutoFetch === !0, Pe = M.pdfBug === !0, Fe = ee ? ee.length : M.length ?? NaN, Ee = typeof M.useSystemFonts == "boolean" ? M.useSystemFonts : !_util.isNodeJS && !z, De = typeof M.useWorkerFetch == "boolean" ? M.useWorkerFetch : R === _display_utils.DOMCMapReaderFactory && g === _display_utils.DOMStandardFontDataFactory && we && d && (0, _display_utils.isValidFetchUrl)(we, document.baseURI) && (0, _display_utils.isValidFetchUrl)(d, document.baseURI), _e = M.canvasFactory || new DefaultCanvasFactory({
+              ownerDocument: ce
+            }), ie = M.filterFactory || new DefaultFilterFactory({
+              docId: N,
+              ownerDocument: ce
+            }), se = null;
+            (0, _util.setVerbosityLevel)(le);
+            const ge = {
+              canvasFactory: _e,
+              filterFactory: ie
+            };
+            if (De || (ge.cMapReaderFactory = new R({
+              baseUrl: we,
+              isCompressed: be
+            }), ge.standardFontDataFactory = new g({
+              baseUrl: d
+            })), !q) {
+              const Ue = {
+                verbosity: le,
+                port: _worker_options.GlobalWorkerOptions.workerPort
+              };
+              q = Ue.port ? PDFWorker.fromPort(Ue) : new PDFWorker(Ue), m._worker = q;
+            }
+            const Ce = {
+              docId: N,
+              apiVersion: "3.11.174",
+              data: X,
+              password: B,
+              disableAutoFetch: fe,
+              rangeChunkSize: Y,
+              length: Fe,
+              docBaseUrl: pe,
+              enableXfa: Q,
+              evaluatorOptions: {
+                maxImageSize: v,
+                disableFontFace: z,
+                ignoreErrors: f,
+                isEvalSupported: A,
+                isOffscreenCanvasSupported: O,
+                canvasMaxAreaInBytes: H,
+                fontExtraProperties: ae,
+                useSystemFonts: Ee,
+                cMapUrl: De ? we : null,
+                standardFontDataUrl: De ? d : null
+              }
+            }, xe = {
+              ignoreErrors: f,
+              isEvalSupported: A,
+              disableFontFace: z,
+              fontExtraProperties: ae,
+              enableXfa: Q,
+              ownerDocument: ce,
+              disableAutoFetch: fe,
+              pdfBug: Pe,
+              styleElement: se
+            };
+            return q.promise.then(function() {
+              if (m.destroyed)
+                throw new Error("Loading aborted");
+              const Ue = _fetchDocument(q, Ce), We = new Promise(function(je) {
+                let ze;
+                ee ? ze = new _transport_stream.PDFDataTransportStream({
+                  length: Fe,
+                  initialData: ee.initialData,
+                  progressiveDone: ee.progressiveDone,
+                  contentDispositionFilename: ee.contentDispositionFilename,
+                  disableRange: ue,
+                  disableStream: me
+                }, ee) : X || (ze = ((Ge) => _util.isNodeJS ? new _displayNode_stream.PDFNodeStream(Ge) : (0, _display_utils.isValidFetchUrl)(Ge.url) ? new _displayFetch_stream.PDFFetchStream(Ge) : new _displayNetwork.PDFNetworkStream(Ge))({
+                  url: D,
+                  length: Fe,
+                  httpHeaders: G,
+                  withCredentials: I,
+                  rangeChunkSize: Y,
+                  disableRange: ue,
+                  disableStream: me
+                })), je(ze);
+              });
+              return Promise.all([Ue, We]).then(function([je, ze]) {
+                if (m.destroyed)
+                  throw new Error("Loading aborted");
+                const Xe = new _message_handler.MessageHandler(N, je, q.port), Ge = new WorkerTransport(Xe, m, ze, xe, ge);
+                m._transport = Ge, Xe.send("Ready", null);
+              });
+            }).catch(m._capability.reject), m;
+          }
+          async function _fetchDocument(M, m) {
+            if (M.destroyed)
+              throw new Error("Worker was destroyed");
+            const N = await M.messageHandler.sendWithPromise("GetDocRequest", m, m.data ? [m.data.buffer] : null);
+            if (M.destroyed)
+              throw new Error("Worker was destroyed");
+            return N;
+          }
+          function getUrlProp(M) {
+            if (M instanceof URL)
+              return M.href;
+            try {
+              return new URL(M, window.location).href;
+            } catch {
+              if (_util.isNodeJS && typeof M == "string")
+                return M;
+            }
+            throw new Error("Invalid PDF url data: either string or URL-object is expected in the url property.");
+          }
+          function getDataProp(M) {
+            if (_util.isNodeJS && typeof Buffer < "u" && M instanceof Buffer)
+              throw new Error("Please provide binary data as `Uint8Array`, rather than `Buffer`.");
+            if (M instanceof Uint8Array && M.byteLength === M.buffer.byteLength)
+              return M;
+            if (typeof M == "string")
+              return (0, _util.stringToBytes)(M);
+            if (typeof M == "object" && !isNaN(M == null ? void 0 : M.length) || (0, _util.isArrayBuffer)(M))
+              return new Uint8Array(M);
+            throw new Error("Invalid PDF binary data: either TypedArray, string, or array-like object is expected in the data property.");
+          }
+          const e = class e {
+            constructor() {
+              this._capability = new _util.PromiseCapability(), this._transport = null, this._worker = null, this.docId = `d${_t(e, t)._++}`, this.destroyed = !1, this.onPassword = null, this.onProgress = null;
+            }
+            get promise() {
+              return this._capability.promise;
+            }
+            async destroy() {
+              var m, N, D;
+              this.destroyed = !0;
+              try {
+                (m = this._worker) != null && m.port && (this._worker._pendingDestroy = !0), await ((N = this._transport) == null ? void 0 : N.destroy());
+              } catch (X) {
+                throw (D = this._worker) != null && D.port && delete this._worker._pendingDestroy, X;
+              }
+              this._transport = null, this._worker && (this._worker.destroy(), this._worker = null);
+            }
+          };
+          t = new WeakMap(), W(e, t, 0);
+          let PDFDocumentLoadingTask = e;
+          exports.PDFDocumentLoadingTask = PDFDocumentLoadingTask;
+          class PDFDataRangeTransport {
+            constructor(m, N, D = !1, X = null) {
+              this.length = m, this.initialData = N, this.progressiveDone = D, this.contentDispositionFilename = X, this._rangeListeners = [], this._progressListeners = [], this._progressiveReadListeners = [], this._progressiveDoneListeners = [], this._readyCapability = new _util.PromiseCapability();
+            }
+            addRangeListener(m) {
+              this._rangeListeners.push(m);
+            }
+            addProgressListener(m) {
+              this._progressListeners.push(m);
+            }
+            addProgressiveReadListener(m) {
+              this._progressiveReadListeners.push(m);
+            }
+            addProgressiveDoneListener(m) {
+              this._progressiveDoneListeners.push(m);
+            }
+            onDataRange(m, N) {
+              for (const D of this._rangeListeners)
+                D(m, N);
+            }
+            onDataProgress(m, N) {
+              this._readyCapability.promise.then(() => {
+                for (const D of this._progressListeners)
+                  D(m, N);
+              });
+            }
+            onDataProgressiveRead(m) {
+              this._readyCapability.promise.then(() => {
+                for (const N of this._progressiveReadListeners)
+                  N(m);
+              });
+            }
+            onDataProgressiveDone() {
+              this._readyCapability.promise.then(() => {
+                for (const m of this._progressiveDoneListeners)
+                  m();
+              });
+            }
+            transportReady() {
+              this._readyCapability.resolve();
+            }
+            requestDataRange(m, N) {
+              (0, _util.unreachable)("Abstract method PDFDataRangeTransport.requestDataRange");
+            }
+            abort() {
+            }
+          }
+          exports.PDFDataRangeTransport = PDFDataRangeTransport;
+          class PDFDocumentProxy {
+            constructor(m, N) {
+              this._pdfInfo = m, this._transport = N, Object.defineProperty(this, "getJavaScript", {
+                value: () => ((0, _display_utils.deprecated)("`PDFDocumentProxy.getJavaScript`, please use `PDFDocumentProxy.getJSActions` instead."), this.getJSActions().then((D) => {
+                  if (!D)
+                    return D;
+                  const X = [];
+                  for (const G in D)
+                    X.push(...D[G]);
+                  return X;
+                }))
+              });
+            }
+            get annotationStorage() {
+              return this._transport.annotationStorage;
+            }
+            get filterFactory() {
+              return this._transport.filterFactory;
+            }
+            get numPages() {
+              return this._pdfInfo.numPages;
+            }
+            get fingerprints() {
+              return this._pdfInfo.fingerprints;
+            }
+            get isPureXfa() {
+              return (0, _util.shadow)(this, "isPureXfa", !!this._transport._htmlForXfa);
+            }
+            get allXfaHtml() {
+              return this._transport._htmlForXfa;
+            }
+            getPage(m) {
+              return this._transport.getPage(m);
+            }
+            getPageIndex(m) {
+              return this._transport.getPageIndex(m);
+            }
+            getDestinations() {
+              return this._transport.getDestinations();
+            }
+            getDestination(m) {
+              return this._transport.getDestination(m);
+            }
+            getPageLabels() {
+              return this._transport.getPageLabels();
+            }
+            getPageLayout() {
+              return this._transport.getPageLayout();
+            }
+            getPageMode() {
+              return this._transport.getPageMode();
+            }
+            getViewerPreferences() {
+              return this._transport.getViewerPreferences();
+            }
+            getOpenAction() {
+              return this._transport.getOpenAction();
+            }
+            getAttachments() {
+              return this._transport.getAttachments();
+            }
+            getJSActions() {
+              return this._transport.getDocJSActions();
+            }
+            getOutline() {
+              return this._transport.getOutline();
+            }
+            getOptionalContentConfig() {
+              return this._transport.getOptionalContentConfig();
+            }
+            getPermissions() {
+              return this._transport.getPermissions();
+            }
+            getMetadata() {
+              return this._transport.getMetadata();
+            }
+            getMarkInfo() {
+              return this._transport.getMarkInfo();
+            }
+            getData() {
+              return this._transport.getData();
+            }
+            saveDocument() {
+              return this._transport.saveDocument();
+            }
+            getDownloadInfo() {
+              return this._transport.downloadInfoCapability.promise;
+            }
+            cleanup(m = !1) {
+              return this._transport.startCleanup(m || this.isPureXfa);
+            }
+            destroy() {
+              return this.loadingTask.destroy();
+            }
+            get loadingParams() {
+              return this._transport.loadingParams;
+            }
+            get loadingTask() {
+              return this._transport.loadingTask;
+            }
+            getFieldObjects() {
+              return this._transport.getFieldObjects();
+            }
+            hasJSActions() {
+              return this._transport.hasJSActions();
+            }
+            getCalculationOrderIds() {
+              return this._transport.getCalculationOrderIds();
+            }
+          }
+          exports.PDFDocumentProxy = PDFDocumentProxy;
+          class PDFPageProxy {
+            constructor(m, N, D, X = !1) {
+              W(this, s);
+              W(this, h);
+              W(this, i, null);
+              W(this, n, !1);
+              this._pageIndex = m, this._pageInfo = N, this._transport = D, this._stats = X ? new _display_utils.StatTimer() : null, this._pdfBug = X, this.commonObjs = D.commonObjs, this.objs = new PDFObjects(), this._maybeCleanupAfterRender = !1, this._intentStates = /* @__PURE__ */ new Map(), this.destroyed = !1;
+            }
+            get pageNumber() {
+              return this._pageIndex + 1;
+            }
+            get rotate() {
+              return this._pageInfo.rotate;
+            }
+            get ref() {
+              return this._pageInfo.ref;
+            }
+            get userUnit() {
+              return this._pageInfo.userUnit;
+            }
+            get view() {
+              return this._pageInfo.view;
+            }
+            getViewport({
+              scale: m,
+              rotation: N = this.rotate,
+              offsetX: D = 0,
+              offsetY: X = 0,
+              dontFlip: G = !1
+            } = {}) {
+              return new _display_utils.PageViewport({
+                viewBox: this.view,
+                scale: m,
+                rotation: N,
+                offsetX: D,
+                offsetY: X,
+                dontFlip: G
+              });
+            }
+            getAnnotations({
+              intent: m = "display"
+            } = {}) {
+              const N = this._transport.getRenderingIntent(m);
+              return this._transport.getAnnotations(this._pageIndex, N.renderingIntent);
+            }
+            getJSActions() {
+              return this._transport.getPageJSActions(this._pageIndex);
+            }
+            get filterFactory() {
+              return this._transport.filterFactory;
+            }
+            get isPureXfa() {
+              return (0, _util.shadow)(this, "isPureXfa", !!this._transport._htmlForXfa);
+            }
+            async getXfa() {
+              var m;
+              return ((m = this._transport._htmlForXfa) == null ? void 0 : m.children[this._pageIndex]) || null;
+            }
+            render({
+              canvasContext: m,
+              viewport: N,
+              intent: D = "display",
+              annotationMode: X = _util.AnnotationMode.ENABLE,
+              transform: G = null,
+              background: I = null,
+              optionalContentConfigPromise: B = null,
+              annotationCanvasMap: ee = null,
+              pageColors: Y = null,
+              printAnnotationStorage: q = null
+            }) {
+              var g, f;
+              (g = this._stats) == null || g.time("Overall");
+              const le = this._transport.getRenderingIntent(D, X, q);
+              oe(this, n, !1), K(this, h, wt).call(this), B || (B = this._transport.getOptionalContentConfig());
+              let pe = this._intentStates.get(le.cacheKey);
+              pe || (pe = /* @__PURE__ */ Object.create(null), this._intentStates.set(le.cacheKey, pe)), pe.streamReaderCancelTimeout && (clearTimeout(pe.streamReaderCancelTimeout), pe.streamReaderCancelTimeout = null);
+              const we = !!(le.renderingIntent & _util.RenderingIntentFlag.PRINT);
+              pe.displayReadyCapability || (pe.displayReadyCapability = new _util.PromiseCapability(), pe.operatorList = {
+                fnArray: [],
+                argsArray: [],
+                lastChunk: !1,
+                separateAnnots: null
+              }, (f = this._stats) == null || f.time("Page Request"), this._pumpOperatorList(le));
+              const be = (v) => {
+                var A, O;
+                pe.renderTasks.delete(R), (this._maybeCleanupAfterRender || we) && oe(this, n, !0), K(this, s, ut).call(this, !we), v ? (R.capability.reject(v), this._abortOperatorList({
+                  intentState: pe,
+                  reason: v instanceof Error ? v : new Error(v)
+                })) : R.capability.resolve(), (A = this._stats) == null || A.timeEnd("Rendering"), (O = this._stats) == null || O.timeEnd("Overall");
+              }, R = new InternalRenderTask({
+                callback: be,
+                params: {
+                  canvasContext: m,
+                  viewport: N,
+                  transform: G,
+                  background: I
+                },
+                objs: this.objs,
+                commonObjs: this.commonObjs,
+                annotationCanvasMap: ee,
+                operatorList: pe.operatorList,
+                pageIndex: this._pageIndex,
+                canvasFactory: this._transport.canvasFactory,
+                filterFactory: this._transport.filterFactory,
+                useRequestAnimationFrame: !we,
+                pdfBug: this._pdfBug,
+                pageColors: Y
+              });
+              (pe.renderTasks || (pe.renderTasks = /* @__PURE__ */ new Set())).add(R);
+              const d = R.task;
+              return Promise.all([pe.displayReadyCapability.promise, B]).then(([v, A]) => {
+                var O;
+                if (this.destroyed) {
+                  be();
+                  return;
+                }
+                (O = this._stats) == null || O.time("Rendering"), R.initializeGraphics({
+                  transparency: v,
+                  optionalContentConfig: A
+                }), R.operatorListChanged();
+              }).catch(be), d;
+            }
+            getOperatorList({
+              intent: m = "display",
+              annotationMode: N = _util.AnnotationMode.ENABLE,
+              printAnnotationStorage: D = null
+            } = {}) {
+              var ee;
+              function X() {
+                I.operatorList.lastChunk && (I.opListReadCapability.resolve(I.operatorList), I.renderTasks.delete(B));
+              }
+              const G = this._transport.getRenderingIntent(m, N, D, !0);
+              let I = this._intentStates.get(G.cacheKey);
+              I || (I = /* @__PURE__ */ Object.create(null), this._intentStates.set(G.cacheKey, I));
+              let B;
+              return I.opListReadCapability || (B = /* @__PURE__ */ Object.create(null), B.operatorListChanged = X, I.opListReadCapability = new _util.PromiseCapability(), (I.renderTasks || (I.renderTasks = /* @__PURE__ */ new Set())).add(B), I.operatorList = {
+                fnArray: [],
+                argsArray: [],
+                lastChunk: !1,
+                separateAnnots: null
+              }, (ee = this._stats) == null || ee.time("Page Request"), this._pumpOperatorList(G)), I.opListReadCapability.promise;
+            }
+            streamTextContent({
+              includeMarkedContent: m = !1,
+              disableNormalization: N = !1
+            } = {}) {
+              return this._transport.messageHandler.sendWithStream("GetTextContent", {
+                pageIndex: this._pageIndex,
+                includeMarkedContent: m === !0,
+                disableNormalization: N === !0
+              }, {
+                highWaterMark: 100,
+                size(X) {
+                  return X.items.length;
+                }
+              });
+            }
+            getTextContent(m = {}) {
+              if (this._transport._htmlForXfa)
+                return this.getXfa().then((D) => _xfa_text.XfaText.textContent(D));
+              const N = this.streamTextContent(m);
+              return new Promise(function(D, X) {
+                function G() {
+                  I.read().then(function({
+                    value: ee,
+                    done: Y
+                  }) {
+                    if (Y) {
+                      D(B);
+                      return;
+                    }
+                    Object.assign(B.styles, ee.styles), B.items.push(...ee.items), G();
+                  }, X);
+                }
+                const I = N.getReader(), B = {
+                  items: [],
+                  styles: /* @__PURE__ */ Object.create(null)
+                };
+                G();
+              });
+            }
+            getStructTree() {
+              return this._transport.getStructTree(this._pageIndex);
+            }
+            _destroy() {
+              this.destroyed = !0;
+              const m = [];
+              for (const N of this._intentStates.values())
+                if (this._abortOperatorList({
+                  intentState: N,
+                  reason: new Error("Page was destroyed."),
+                  force: !0
+                }), !N.opListReadCapability)
+                  for (const D of N.renderTasks)
+                    m.push(D.completed), D.cancel();
+              return this.objs.clear(), oe(this, n, !1), K(this, h, wt).call(this), Promise.all(m);
+            }
+            cleanup(m = !1) {
+              oe(this, n, !0);
+              const N = K(this, s, ut).call(this, !1);
+              return m && N && this._stats && (this._stats = new _display_utils.StatTimer()), N;
+            }
+            _startRenderPage(m, N) {
+              var X, G;
+              const D = this._intentStates.get(N);
+              D && ((X = this._stats) == null || X.timeEnd("Page Request"), (G = D.displayReadyCapability) == null || G.resolve(m));
+            }
+            _renderPageChunk(m, N) {
+              for (let D = 0, X = m.length; D < X; D++)
+                N.operatorList.fnArray.push(m.fnArray[D]), N.operatorList.argsArray.push(m.argsArray[D]);
+              N.operatorList.lastChunk = m.lastChunk, N.operatorList.separateAnnots = m.separateAnnots;
+              for (const D of N.renderTasks)
+                D.operatorListChanged();
+              m.lastChunk && K(this, s, ut).call(this, !0);
+            }
+            _pumpOperatorList({
+              renderingIntent: m,
+              cacheKey: N,
+              annotationStorageSerializable: D
+            }) {
+              const {
+                map: X,
+                transfers: G
+              } = D, B = this._transport.messageHandler.sendWithStream("GetOperatorList", {
+                pageIndex: this._pageIndex,
+                intent: m,
+                cacheKey: N,
+                annotationStorage: X
+              }, G).getReader(), ee = this._intentStates.get(N);
+              ee.streamReader = B;
+              const Y = () => {
+                B.read().then(({
+                  value: q,
+                  done: le
+                }) => {
+                  if (le) {
+                    ee.streamReader = null;
+                    return;
+                  }
+                  this._transport.destroyed || (this._renderPageChunk(q, ee), Y());
+                }, (q) => {
+                  if (ee.streamReader = null, !this._transport.destroyed) {
+                    if (ee.operatorList) {
+                      ee.operatorList.lastChunk = !0;
+                      for (const le of ee.renderTasks)
+                        le.operatorListChanged();
+                      K(this, s, ut).call(this, !0);
+                    }
+                    if (ee.displayReadyCapability)
+                      ee.displayReadyCapability.reject(q);
+                    else if (ee.opListReadCapability)
+                      ee.opListReadCapability.reject(q);
+                    else
+                      throw q;
+                  }
+                });
+              };
+              Y();
+            }
+            _abortOperatorList({
+              intentState: m,
+              reason: N,
+              force: D = !1
+            }) {
+              if (m.streamReader) {
+                if (m.streamReaderCancelTimeout && (clearTimeout(m.streamReaderCancelTimeout), m.streamReaderCancelTimeout = null), !D) {
+                  if (m.renderTasks.size > 0)
+                    return;
+                  if (N instanceof _display_utils.RenderingCancelledException) {
+                    let X = RENDERING_CANCELLED_TIMEOUT;
+                    N.extraDelay > 0 && N.extraDelay < 1e3 && (X += N.extraDelay), m.streamReaderCancelTimeout = setTimeout(() => {
+                      m.streamReaderCancelTimeout = null, this._abortOperatorList({
+                        intentState: m,
+                        reason: N,
+                        force: !0
+                      });
+                    }, X);
+                    return;
+                  }
+                }
+                if (m.streamReader.cancel(new _util.AbortException(N.message)).catch(() => {
+                }), m.streamReader = null, !this._transport.destroyed) {
+                  for (const [X, G] of this._intentStates)
+                    if (G === m) {
+                      this._intentStates.delete(X);
+                      break;
+                    }
+                  this.cleanup();
+                }
+              }
+            }
+            get stats() {
+              return this._stats;
+            }
+          }
+          i = new WeakMap(), n = new WeakMap(), s = new WeakSet(), ut = function(m = !1) {
+            if (K(this, h, wt).call(this), !a(this, n) || this.destroyed)
+              return !1;
+            if (m)
+              return oe(this, i, setTimeout(() => {
+                oe(this, i, null), K(this, s, ut).call(this, !1);
+              }, DELAYED_CLEANUP_TIMEOUT)), !1;
+            for (const {
+              renderTasks: N,
+              operatorList: D
+            } of this._intentStates.values())
+              if (N.size > 0 || !D.lastChunk)
+                return !1;
+            return this._intentStates.clear(), this.objs.clear(), oe(this, n, !1), !0;
+          }, h = new WeakSet(), wt = function() {
+            a(this, i) && (clearTimeout(a(this, i)), oe(this, i, null));
+          }, exports.PDFPageProxy = PDFPageProxy;
+          class LoopbackPort {
+            constructor() {
+              W(this, c, /* @__PURE__ */ new Set());
+              W(this, o, Promise.resolve());
+            }
+            postMessage(m, N) {
+              const D = {
+                data: structuredClone(m, N ? {
+                  transfer: N
+                } : null)
+              };
+              a(this, o).then(() => {
+                for (const X of a(this, c))
+                  X.call(this, D);
+              });
+            }
+            addEventListener(m, N) {
+              a(this, c).add(N);
+            }
+            removeEventListener(m, N) {
+              a(this, c).delete(N);
+            }
+            terminate() {
+              a(this, c).clear();
+            }
+          }
+          c = new WeakMap(), o = new WeakMap(), exports.LoopbackPort = LoopbackPort;
+          const PDFWorkerUtil = {
+            isWorkerDisabled: !1,
+            fallbackWorkerSrc: null,
+            fakeWorkerId: 0
+          };
+          exports.PDFWorkerUtil = PDFWorkerUtil;
+          {
+            if (_util.isNodeJS && typeof commonjsRequire == "function")
+              PDFWorkerUtil.isWorkerDisabled = !0, PDFWorkerUtil.fallbackWorkerSrc = "./pdf.worker.js";
+            else if (typeof document == "object") {
+              const M = (r = document == null ? void 0 : document.currentScript) == null ? void 0 : r.src;
+              M && (PDFWorkerUtil.fallbackWorkerSrc = M.replace(/(\.(?:min\.)?js)(\?.*)?$/i, ".worker$1$2"));
+            }
+            PDFWorkerUtil.isSameOrigin = function(M, m) {
+              let N;
+              try {
+                if (N = new URL(M), !N.origin || N.origin === "null")
+                  return !1;
+              } catch {
+                return !1;
+              }
+              const D = new URL(m, N);
+              return N.origin === D.origin;
+            }, PDFWorkerUtil.createCDNWrapper = function(M) {
+              const m = `importScripts("${M}");`;
+              return URL.createObjectURL(new Blob([m]));
+            };
+          }
+          const _PDFWorker = class _PDFWorker {
+            constructor({
+              name: M = null,
+              port: m = null,
+              verbosity: N = (0, _util.getVerbosityLevel)()
+            } = {}) {
+              var D;
+              if (this.name = M, this.destroyed = !1, this.verbosity = N, this._readyCapability = new _util.PromiseCapability(), this._port = null, this._webWorker = null, this._messageHandler = null, m) {
+                if ((D = a(_PDFWorker, T)) != null && D.has(m))
+                  throw new Error("Cannot use more than one PDFWorker per port.");
+                (a(_PDFWorker, T) || oe(_PDFWorker, T, /* @__PURE__ */ new WeakMap())).set(m, this), this._initializeFromPort(m);
+                return;
+              }
+              this._initialize();
+            }
+            get promise() {
+              return this._readyCapability.promise;
+            }
+            get port() {
+              return this._port;
+            }
+            get messageHandler() {
+              return this._messageHandler;
+            }
+            _initializeFromPort(M) {
+              this._port = M, this._messageHandler = new _message_handler.MessageHandler("main", "worker", M), this._messageHandler.on("ready", function() {
+              }), this._readyCapability.resolve(), this._messageHandler.send("configure", {
+                verbosity: this.verbosity
+              });
+            }
+            _initialize() {
+              if (!PDFWorkerUtil.isWorkerDisabled && !_PDFWorker._mainThreadWorkerMessageHandler) {
+                let {
+                  workerSrc: M
+                } = _PDFWorker;
+                try {
+                  PDFWorkerUtil.isSameOrigin(window.location.href, M) || (M = PDFWorkerUtil.createCDNWrapper(new URL(M, window.location).href));
+                  const m = new Worker(M), N = new _message_handler.MessageHandler("main", "worker", m), D = () => {
+                    m.removeEventListener("error", X), N.destroy(), m.terminate(), this.destroyed ? this._readyCapability.reject(new Error("Worker was destroyed")) : this._setupFakeWorker();
+                  }, X = () => {
+                    this._webWorker || D();
+                  };
+                  m.addEventListener("error", X), N.on("test", (I) => {
+                    if (m.removeEventListener("error", X), this.destroyed) {
+                      D();
+                      return;
+                    }
+                    I ? (this._messageHandler = N, this._port = m, this._webWorker = m, this._readyCapability.resolve(), N.send("configure", {
+                      verbosity: this.verbosity
+                    })) : (this._setupFakeWorker(), N.destroy(), m.terminate());
+                  }), N.on("ready", (I) => {
+                    if (m.removeEventListener("error", X), this.destroyed) {
+                      D();
+                      return;
+                    }
+                    try {
+                      G();
+                    } catch {
+                      this._setupFakeWorker();
+                    }
+                  });
+                  const G = () => {
+                    const I = new Uint8Array();
+                    N.send("test", I, [I.buffer]);
+                  };
+                  G();
+                  return;
+                } catch {
+                  (0, _util.info)("The worker has been disabled.");
+                }
+              }
+              this._setupFakeWorker();
+            }
+            _setupFakeWorker() {
+              PDFWorkerUtil.isWorkerDisabled || ((0, _util.warn)("Setting up fake worker."), PDFWorkerUtil.isWorkerDisabled = !0), _PDFWorker._setupFakeWorkerGlobal.then((M) => {
+                if (this.destroyed) {
+                  this._readyCapability.reject(new Error("Worker was destroyed"));
+                  return;
+                }
+                const m = new LoopbackPort();
+                this._port = m;
+                const N = `fake${PDFWorkerUtil.fakeWorkerId++}`, D = new _message_handler.MessageHandler(N + "_worker", N, m);
+                M.setup(D, m);
+                const X = new _message_handler.MessageHandler(N, N + "_worker", m);
+                this._messageHandler = X, this._readyCapability.resolve(), X.send("configure", {
+                  verbosity: this.verbosity
+                });
+              }).catch((M) => {
+                this._readyCapability.reject(new Error(`Setting up fake worker failed: "${M.message}".`));
+              });
+            }
+            destroy() {
+              var M;
+              this.destroyed = !0, this._webWorker && (this._webWorker.terminate(), this._webWorker = null), (M = a(_PDFWorker, T)) == null || M.delete(this._port), this._port = null, this._messageHandler && (this._messageHandler.destroy(), this._messageHandler = null);
+            }
+            static fromPort(M) {
+              var N;
+              if (!(M != null && M.port))
+                throw new Error("PDFWorker.fromPort - invalid method signature.");
+              const m = (N = a(this, T)) == null ? void 0 : N.get(M.port);
+              if (m) {
+                if (m._pendingDestroy)
+                  throw new Error("PDFWorker.fromPort - the worker is being destroyed.\nPlease remember to await `PDFDocumentLoadingTask.destroy()`-calls.");
+                return m;
+              }
+              return new _PDFWorker(M);
+            }
+            static get workerSrc() {
+              if (_worker_options.GlobalWorkerOptions.workerSrc)
+                return _worker_options.GlobalWorkerOptions.workerSrc;
+              if (PDFWorkerUtil.fallbackWorkerSrc !== null)
+                return _util.isNodeJS || (0, _display_utils.deprecated)('No "GlobalWorkerOptions.workerSrc" specified.'), PDFWorkerUtil.fallbackWorkerSrc;
+              throw new Error('No "GlobalWorkerOptions.workerSrc" specified.');
+            }
+            static get _mainThreadWorkerMessageHandler() {
+              var M;
+              try {
+                return ((M = globalThis.pdfjsWorker) == null ? void 0 : M.WorkerMessageHandler) || null;
+              } catch {
+                return null;
+              }
+            }
+            static get _setupFakeWorkerGlobal() {
+              const loader = async () => {
+                const mainWorkerMessageHandler = this._mainThreadWorkerMessageHandler;
+                if (mainWorkerMessageHandler)
+                  return mainWorkerMessageHandler;
+                if (_util.isNodeJS && typeof commonjsRequire == "function") {
+                  const worker = eval("require")(this.workerSrc);
+                  return worker.WorkerMessageHandler;
+                }
+                return await (0, _display_utils.loadScript)(this.workerSrc), window.pdfjsWorker.WorkerMessageHandler;
+              };
+              return (0, _util.shadow)(this, "_setupFakeWorkerGlobal", loader());
+            }
+          };
+          T = new WeakMap(), W(_PDFWorker, T, void 0);
+          let PDFWorker = _PDFWorker;
+          exports.PDFWorker = PDFWorker;
+          class WorkerTransport {
+            constructor(m, N, D, X, G) {
+              W(this, b);
+              W(this, S, /* @__PURE__ */ new Map());
+              W(this, w, /* @__PURE__ */ new Map());
+              W(this, C, /* @__PURE__ */ new Map());
+              W(this, P, null);
+              this.messageHandler = m, this.loadingTask = N, this.commonObjs = new PDFObjects(), this.fontLoader = new _font_loader.FontLoader({
+                ownerDocument: X.ownerDocument,
+                styleElement: X.styleElement
+              }), this._params = X, this.canvasFactory = G.canvasFactory, this.filterFactory = G.filterFactory, this.cMapReaderFactory = G.cMapReaderFactory, this.standardFontDataFactory = G.standardFontDataFactory, this.destroyed = !1, this.destroyCapability = null, this._networkStream = D, this._fullReader = null, this._lastProgress = null, this.downloadInfoCapability = new _util.PromiseCapability(), this.setupMessageHandler();
+            }
+            get annotationStorage() {
+              return (0, _util.shadow)(this, "annotationStorage", new _annotation_storage.AnnotationStorage());
+            }
+            getRenderingIntent(m, N = _util.AnnotationMode.ENABLE, D = null, X = !1) {
+              let G = _util.RenderingIntentFlag.DISPLAY, I = _annotation_storage.SerializableEmpty;
+              switch (m) {
+                case "any":
+                  G = _util.RenderingIntentFlag.ANY;
+                  break;
+                case "display":
+                  break;
+                case "print":
+                  G = _util.RenderingIntentFlag.PRINT;
+                  break;
+                default:
+                  (0, _util.warn)(`getRenderingIntent - invalid intent: ${m}`);
+              }
+              switch (N) {
+                case _util.AnnotationMode.DISABLE:
+                  G += _util.RenderingIntentFlag.ANNOTATIONS_DISABLE;
+                  break;
+                case _util.AnnotationMode.ENABLE:
+                  break;
+                case _util.AnnotationMode.ENABLE_FORMS:
+                  G += _util.RenderingIntentFlag.ANNOTATIONS_FORMS;
+                  break;
+                case _util.AnnotationMode.ENABLE_STORAGE:
+                  G += _util.RenderingIntentFlag.ANNOTATIONS_STORAGE, I = (G & _util.RenderingIntentFlag.PRINT && D instanceof _annotation_storage.PrintAnnotationStorage ? D : this.annotationStorage).serializable;
+                  break;
+                default:
+                  (0, _util.warn)(`getRenderingIntent - invalid annotationMode: ${N}`);
+              }
+              return X && (G += _util.RenderingIntentFlag.OPLIST), {
+                renderingIntent: G,
+                cacheKey: `${G}_${I.hash}`,
+                annotationStorageSerializable: I
+              };
+            }
+            destroy() {
+              var D;
+              if (this.destroyCapability)
+                return this.destroyCapability.promise;
+              this.destroyed = !0, this.destroyCapability = new _util.PromiseCapability(), (D = a(this, P)) == null || D.reject(new Error("Worker was destroyed during onPassword callback"));
+              const m = [];
+              for (const X of a(this, w).values())
+                m.push(X._destroy());
+              a(this, w).clear(), a(this, C).clear(), this.hasOwnProperty("annotationStorage") && this.annotationStorage.resetModified();
+              const N = this.messageHandler.sendWithPromise("Terminate", null);
+              return m.push(N), Promise.all(m).then(() => {
+                var X;
+                this.commonObjs.clear(), this.fontLoader.clear(), a(this, S).clear(), this.filterFactory.destroy(), (X = this._networkStream) == null || X.cancelAllRequests(new _util.AbortException("Worker was terminated.")), this.messageHandler && (this.messageHandler.destroy(), this.messageHandler = null), this.destroyCapability.resolve();
+              }, this.destroyCapability.reject), this.destroyCapability.promise;
+            }
+            setupMessageHandler() {
+              const {
+                messageHandler: m,
+                loadingTask: N
+              } = this;
+              m.on("GetReader", (D, X) => {
+                (0, _util.assert)(this._networkStream, "GetReader - no `IPDFStream` instance available."), this._fullReader = this._networkStream.getFullReader(), this._fullReader.onProgress = (G) => {
+                  this._lastProgress = {
+                    loaded: G.loaded,
+                    total: G.total
+                  };
+                }, X.onPull = () => {
+                  this._fullReader.read().then(function({
+                    value: G,
+                    done: I
+                  }) {
+                    if (I) {
+                      X.close();
+                      return;
+                    }
+                    (0, _util.assert)(G instanceof ArrayBuffer, "GetReader - expected an ArrayBuffer."), X.enqueue(new Uint8Array(G), 1, [G]);
+                  }).catch((G) => {
+                    X.error(G);
+                  });
+                }, X.onCancel = (G) => {
+                  this._fullReader.cancel(G), X.ready.catch((I) => {
+                    if (!this.destroyed)
+                      throw I;
+                  });
+                };
+              }), m.on("ReaderHeadersReady", (D) => {
+                const X = new _util.PromiseCapability(), G = this._fullReader;
+                return G.headersReady.then(() => {
+                  var I;
+                  (!G.isStreamingSupported || !G.isRangeSupported) && (this._lastProgress && ((I = N.onProgress) == null || I.call(N, this._lastProgress)), G.onProgress = (B) => {
+                    var ee;
+                    (ee = N.onProgress) == null || ee.call(N, {
+                      loaded: B.loaded,
+                      total: B.total
+                    });
+                  }), X.resolve({
+                    isStreamingSupported: G.isStreamingSupported,
+                    isRangeSupported: G.isRangeSupported,
+                    contentLength: G.contentLength
+                  });
+                }, X.reject), X.promise;
+              }), m.on("GetRangeReader", (D, X) => {
+                (0, _util.assert)(this._networkStream, "GetRangeReader - no `IPDFStream` instance available.");
+                const G = this._networkStream.getRangeReader(D.begin, D.end);
+                if (!G) {
+                  X.close();
+                  return;
+                }
+                X.onPull = () => {
+                  G.read().then(function({
+                    value: I,
+                    done: B
+                  }) {
+                    if (B) {
+                      X.close();
+                      return;
+                    }
+                    (0, _util.assert)(I instanceof ArrayBuffer, "GetRangeReader - expected an ArrayBuffer."), X.enqueue(new Uint8Array(I), 1, [I]);
+                  }).catch((I) => {
+                    X.error(I);
+                  });
+                }, X.onCancel = (I) => {
+                  G.cancel(I), X.ready.catch((B) => {
+                    if (!this.destroyed)
+                      throw B;
+                  });
+                };
+              }), m.on("GetDoc", ({
+                pdfInfo: D
+              }) => {
+                this._numPages = D.numPages, this._htmlForXfa = D.htmlForXfa, delete D.htmlForXfa, N._capability.resolve(new PDFDocumentProxy(D, this));
+              }), m.on("DocException", function(D) {
+                let X;
+                switch (D.name) {
+                  case "PasswordException":
+                    X = new _util.PasswordException(D.message, D.code);
+                    break;
+                  case "InvalidPDFException":
+                    X = new _util.InvalidPDFException(D.message);
+                    break;
+                  case "MissingPDFException":
+                    X = new _util.MissingPDFException(D.message);
+                    break;
+                  case "UnexpectedResponseException":
+                    X = new _util.UnexpectedResponseException(D.message, D.status);
+                    break;
+                  case "UnknownErrorException":
+                    X = new _util.UnknownErrorException(D.message, D.details);
+                    break;
+                  default:
+                    (0, _util.unreachable)("DocException - expected a valid Error.");
+                }
+                N._capability.reject(X);
+              }), m.on("PasswordRequest", (D) => {
+                if (oe(this, P, new _util.PromiseCapability()), N.onPassword) {
+                  const X = (G) => {
+                    G instanceof Error ? a(this, P).reject(G) : a(this, P).resolve({
+                      password: G
+                    });
+                  };
+                  try {
+                    N.onPassword(X, D.code);
+                  } catch (G) {
+                    a(this, P).reject(G);
+                  }
+                } else
+                  a(this, P).reject(new _util.PasswordException(D.message, D.code));
+                return a(this, P).promise;
+              }), m.on("DataLoaded", (D) => {
+                var X;
+                (X = N.onProgress) == null || X.call(N, {
+                  loaded: D.length,
+                  total: D.length
+                }), this.downloadInfoCapability.resolve(D);
+              }), m.on("StartRenderPage", (D) => {
+                if (this.destroyed)
+                  return;
+                a(this, w).get(D.pageIndex)._startRenderPage(D.transparency, D.cacheKey);
+              }), m.on("commonobj", ([D, X, G]) => {
+                var I;
+                if (!this.destroyed && !this.commonObjs.has(D))
+                  switch (X) {
+                    case "Font":
+                      const B = this._params;
+                      if ("error" in G) {
+                        const q = G.error;
+                        (0, _util.warn)(`Error during font loading: ${q}`), this.commonObjs.resolve(D, q);
+                        break;
+                      }
+                      const ee = B.pdfBug && ((I = globalThis.FontInspector) != null && I.enabled) ? (q, le) => globalThis.FontInspector.fontAdded(q, le) : null, Y = new _font_loader.FontFaceObject(G, {
+                        isEvalSupported: B.isEvalSupported,
+                        disableFontFace: B.disableFontFace,
+                        ignoreErrors: B.ignoreErrors,
+                        inspectFont: ee
+                      });
+                      this.fontLoader.bind(Y).catch((q) => m.sendWithPromise("FontFallback", {
+                        id: D
+                      })).finally(() => {
+                        !B.fontExtraProperties && Y.data && (Y.data = null), this.commonObjs.resolve(D, Y);
+                      });
+                      break;
+                    case "FontPath":
+                    case "Image":
+                    case "Pattern":
+                      this.commonObjs.resolve(D, G);
+                      break;
+                    default:
+                      throw new Error(`Got unknown common object type ${X}`);
+                  }
+              }), m.on("obj", ([D, X, G, I]) => {
+                var ee;
+                if (this.destroyed)
+                  return;
+                const B = a(this, w).get(X);
+                if (!B.objs.has(D))
+                  switch (G) {
+                    case "Image":
+                      if (B.objs.resolve(D, I), I) {
+                        let Y;
+                        if (I.bitmap) {
+                          const {
+                            width: q,
+                            height: le
+                          } = I;
+                          Y = q * le * 4;
+                        } else
+                          Y = ((ee = I.data) == null ? void 0 : ee.length) || 0;
+                        Y > _util.MAX_IMAGE_SIZE_TO_CACHE && (B._maybeCleanupAfterRender = !0);
+                      }
+                      break;
+                    case "Pattern":
+                      B.objs.resolve(D, I);
+                      break;
+                    default:
+                      throw new Error(`Got unknown object type ${G}`);
+                  }
+              }), m.on("DocProgress", (D) => {
+                var X;
+                this.destroyed || (X = N.onProgress) == null || X.call(N, {
+                  loaded: D.loaded,
+                  total: D.total
+                });
+              }), m.on("FetchBuiltInCMap", (D) => this.destroyed ? Promise.reject(new Error("Worker was destroyed.")) : this.cMapReaderFactory ? this.cMapReaderFactory.fetch(D) : Promise.reject(new Error("CMapReaderFactory not initialized, see the `useWorkerFetch` parameter."))), m.on("FetchStandardFontData", (D) => this.destroyed ? Promise.reject(new Error("Worker was destroyed.")) : this.standardFontDataFactory ? this.standardFontDataFactory.fetch(D) : Promise.reject(new Error("StandardFontDataFactory not initialized, see the `useWorkerFetch` parameter.")));
+            }
+            getData() {
+              return this.messageHandler.sendWithPromise("GetData", null);
+            }
+            saveDocument() {
+              var D;
+              this.annotationStorage.size <= 0 && (0, _util.warn)("saveDocument called while `annotationStorage` is empty, please use the getData-method instead.");
+              const {
+                map: m,
+                transfers: N
+              } = this.annotationStorage.serializable;
+              return this.messageHandler.sendWithPromise("SaveDocument", {
+                isPureXfa: !!this._htmlForXfa,
+                numPages: this._numPages,
+                annotationStorage: m,
+                filename: ((D = this._fullReader) == null ? void 0 : D.filename) ?? null
+              }, N).finally(() => {
+                this.annotationStorage.resetModified();
+              });
+            }
+            getPage(m) {
+              if (!Number.isInteger(m) || m <= 0 || m > this._numPages)
+                return Promise.reject(new Error("Invalid page request."));
+              const N = m - 1, D = a(this, C).get(N);
+              if (D)
+                return D;
+              const X = this.messageHandler.sendWithPromise("GetPage", {
+                pageIndex: N
+              }).then((G) => {
+                if (this.destroyed)
+                  throw new Error("Transport destroyed");
+                const I = new PDFPageProxy(N, G, this, this._params.pdfBug);
+                return a(this, w).set(N, I), I;
+              });
+              return a(this, C).set(N, X), X;
+            }
+            getPageIndex(m) {
+              return typeof m != "object" || m === null || !Number.isInteger(m.num) || m.num < 0 || !Number.isInteger(m.gen) || m.gen < 0 ? Promise.reject(new Error("Invalid pageIndex request.")) : this.messageHandler.sendWithPromise("GetPageIndex", {
+                num: m.num,
+                gen: m.gen
+              });
+            }
+            getAnnotations(m, N) {
+              return this.messageHandler.sendWithPromise("GetAnnotations", {
+                pageIndex: m,
+                intent: N
+              });
+            }
+            getFieldObjects() {
+              return K(this, b, Tt).call(this, "GetFieldObjects");
+            }
+            hasJSActions() {
+              return K(this, b, Tt).call(this, "HasJSActions");
+            }
+            getCalculationOrderIds() {
+              return this.messageHandler.sendWithPromise("GetCalculationOrderIds", null);
+            }
+            getDestinations() {
+              return this.messageHandler.sendWithPromise("GetDestinations", null);
+            }
+            getDestination(m) {
+              return typeof m != "string" ? Promise.reject(new Error("Invalid destination request.")) : this.messageHandler.sendWithPromise("GetDestination", {
+                id: m
+              });
+            }
+            getPageLabels() {
+              return this.messageHandler.sendWithPromise("GetPageLabels", null);
+            }
+            getPageLayout() {
+              return this.messageHandler.sendWithPromise("GetPageLayout", null);
+            }
+            getPageMode() {
+              return this.messageHandler.sendWithPromise("GetPageMode", null);
+            }
+            getViewerPreferences() {
+              return this.messageHandler.sendWithPromise("GetViewerPreferences", null);
+            }
+            getOpenAction() {
+              return this.messageHandler.sendWithPromise("GetOpenAction", null);
+            }
+            getAttachments() {
+              return this.messageHandler.sendWithPromise("GetAttachments", null);
+            }
+            getDocJSActions() {
+              return K(this, b, Tt).call(this, "GetDocJSActions");
+            }
+            getPageJSActions(m) {
+              return this.messageHandler.sendWithPromise("GetPageJSActions", {
+                pageIndex: m
+              });
+            }
+            getStructTree(m) {
+              return this.messageHandler.sendWithPromise("GetStructTree", {
+                pageIndex: m
+              });
+            }
+            getOutline() {
+              return this.messageHandler.sendWithPromise("GetOutline", null);
+            }
+            getOptionalContentConfig() {
+              return this.messageHandler.sendWithPromise("GetOptionalContentConfig", null).then((m) => new _optional_content_config.OptionalContentConfig(m));
+            }
+            getPermissions() {
+              return this.messageHandler.sendWithPromise("GetPermissions", null);
+            }
+            getMetadata() {
+              const m = "GetMetadata", N = a(this, S).get(m);
+              if (N)
+                return N;
+              const D = this.messageHandler.sendWithPromise(m, null).then((X) => {
+                var G, I;
+                return {
+                  info: X[0],
+                  metadata: X[1] ? new _metadata.Metadata(X[1]) : null,
+                  contentDispositionFilename: ((G = this._fullReader) == null ? void 0 : G.filename) ?? null,
+                  contentLength: ((I = this._fullReader) == null ? void 0 : I.contentLength) ?? null
+                };
+              });
+              return a(this, S).set(m, D), D;
+            }
+            getMarkInfo() {
+              return this.messageHandler.sendWithPromise("GetMarkInfo", null);
+            }
+            async startCleanup(m = !1) {
+              if (!this.destroyed) {
+                await this.messageHandler.sendWithPromise("Cleanup", null);
+                for (const N of a(this, w).values())
+                  if (!N.cleanup())
+                    throw new Error(`startCleanup: Page ${N.pageNumber} is currently rendering.`);
+                this.commonObjs.clear(), m || this.fontLoader.clear(), a(this, S).clear(), this.filterFactory.destroy(!0);
+              }
+            }
+            get loadingParams() {
+              const {
+                disableAutoFetch: m,
+                enableXfa: N
+              } = this._params;
+              return (0, _util.shadow)(this, "loadingParams", {
+                disableAutoFetch: m,
+                enableXfa: N
+              });
+            }
+          }
+          S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakSet(), Tt = function(m, N = null) {
+            const D = a(this, S).get(m);
+            if (D)
+              return D;
+            const X = this.messageHandler.sendWithPromise(m, N);
+            return a(this, S).set(m, X), X;
+          };
+          class PDFObjects {
+            constructor() {
+              W(this, x);
+              W(this, F, /* @__PURE__ */ Object.create(null));
+            }
+            get(m, N = null) {
+              if (N) {
+                const X = K(this, x, Bt).call(this, m);
+                return X.capability.promise.then(() => N(X.data)), null;
+              }
+              const D = a(this, F)[m];
+              if (!(D != null && D.capability.settled))
+                throw new Error(`Requesting object that isn't resolved yet ${m}.`);
+              return D.data;
+            }
+            has(m) {
+              const N = a(this, F)[m];
+              return (N == null ? void 0 : N.capability.settled) || !1;
+            }
+            resolve(m, N = null) {
+              const D = K(this, x, Bt).call(this, m);
+              D.data = N, D.capability.resolve();
+            }
+            clear() {
+              var m;
+              for (const N in a(this, F)) {
+                const {
+                  data: D
+                } = a(this, F)[N];
+                (m = D == null ? void 0 : D.bitmap) == null || m.close();
+              }
+              oe(this, F, /* @__PURE__ */ Object.create(null));
+            }
+          }
+          F = new WeakMap(), x = new WeakSet(), Bt = function(m) {
+            var N;
+            return (N = a(this, F))[m] || (N[m] = {
+              capability: new _util.PromiseCapability(),
+              data: null
+            });
+          };
+          class RenderTask {
+            constructor(m) {
+              W(this, p, null);
+              oe(this, p, m), this.onContinue = null;
+            }
+            get promise() {
+              return a(this, p).capability.promise;
+            }
+            cancel(m = 0) {
+              a(this, p).cancel(null, m);
+            }
+            get separateAnnots() {
+              const {
+                separateAnnots: m
+              } = a(this, p).operatorList;
+              if (!m)
+                return !1;
+              const {
+                annotationCanvasMap: N
+              } = a(this, p);
+              return m.form || m.canvas && (N == null ? void 0 : N.size) > 0;
+            }
+          }
+          p = new WeakMap(), exports.RenderTask = RenderTask;
+          const $ = class $ {
+            constructor({
+              callback: m,
+              params: N,
+              objs: D,
+              commonObjs: X,
+              annotationCanvasMap: G,
+              operatorList: I,
+              pageIndex: B,
+              canvasFactory: ee,
+              filterFactory: Y,
+              useRequestAnimationFrame: q = !1,
+              pdfBug: le = !1,
+              pageColors: pe = null
+            }) {
+              this.callback = m, this.params = N, this.objs = D, this.commonObjs = X, this.annotationCanvasMap = G, this.operatorListIdx = null, this.operatorList = I, this._pageIndex = B, this.canvasFactory = ee, this.filterFactory = Y, this._pdfBug = le, this.pageColors = pe, this.running = !1, this.graphicsReadyCallback = null, this.graphicsReady = !1, this._useRequestAnimationFrame = q === !0 && typeof window < "u", this.cancelled = !1, this.capability = new _util.PromiseCapability(), this.task = new RenderTask(this), this._cancelBound = this.cancel.bind(this), this._continueBound = this._continue.bind(this), this._scheduleNextBound = this._scheduleNext.bind(this), this._nextBound = this._next.bind(this), this._canvas = N.canvasContext.canvas;
+            }
+            get completed() {
+              return this.capability.promise.catch(function() {
+              });
+            }
+            initializeGraphics({
+              transparency: m = !1,
+              optionalContentConfig: N
+            }) {
+              var B, ee;
+              if (this.cancelled)
+                return;
+              if (this._canvas) {
+                if (a($, E).has(this._canvas))
+                  throw new Error("Cannot use the same canvas during multiple render() operations. Use different canvas or ensure previous operations were cancelled or completed.");
+                a($, E).add(this._canvas);
+              }
+              this._pdfBug && ((B = globalThis.StepperManager) != null && B.enabled) && (this.stepper = globalThis.StepperManager.create(this._pageIndex), this.stepper.init(this.operatorList), this.stepper.nextBreakPoint = this.stepper.getNextBreakPoint());
+              const {
+                canvasContext: D,
+                viewport: X,
+                transform: G,
+                background: I
+              } = this.params;
+              this.gfx = new _canvas.CanvasGraphics(D, this.commonObjs, this.objs, this.canvasFactory, this.filterFactory, {
+                optionalContentConfig: N
+              }, this.annotationCanvasMap, this.pageColors), this.gfx.beginDrawing({
+                transform: G,
+                viewport: X,
+                transparency: m,
+                background: I
+              }), this.operatorListIdx = 0, this.graphicsReady = !0, (ee = this.graphicsReadyCallback) == null || ee.call(this);
+            }
+            cancel(m = null, N = 0) {
+              var D;
+              this.running = !1, this.cancelled = !0, (D = this.gfx) == null || D.endDrawing(), a($, E).delete(this._canvas), this.callback(m || new _display_utils.RenderingCancelledException(`Rendering cancelled, page ${this._pageIndex + 1}`, N));
+            }
+            operatorListChanged() {
+              var m;
+              if (!this.graphicsReady) {
+                this.graphicsReadyCallback || (this.graphicsReadyCallback = this._continueBound);
+                return;
+              }
+              (m = this.stepper) == null || m.updateOperatorList(this.operatorList), !this.running && this._continue();
+            }
+            _continue() {
+              this.running = !0, !this.cancelled && (this.task.onContinue ? this.task.onContinue(this._scheduleNextBound) : this._scheduleNext());
+            }
+            _scheduleNext() {
+              this._useRequestAnimationFrame ? window.requestAnimationFrame(() => {
+                this._nextBound().catch(this._cancelBound);
+              }) : Promise.resolve().then(this._nextBound).catch(this._cancelBound);
+            }
+            async _next() {
+              this.cancelled || (this.operatorListIdx = this.gfx.executeOperatorList(this.operatorList, this.operatorListIdx, this._continueBound, this.stepper), this.operatorListIdx === this.operatorList.argsArray.length && (this.running = !1, this.operatorList.lastChunk && (this.gfx.endDrawing(), a($, E).delete(this._canvas), this.callback())));
+            }
+          };
+          E = new WeakMap(), W($, E, /* @__PURE__ */ new WeakSet());
+          let InternalRenderTask = $;
+          const version = "3.11.174";
+          exports.version = version;
+          const build = "ce8716743";
+          exports.build = build;
+        },
+        /* 3 */
+        /***/
+        (t, e, i) => {
+          var o, r, T, En, w;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.SerializableEmpty = e.PrintAnnotationStorage = e.AnnotationStorage = void 0;
+          var n = i(1), s = i(4), l = i(8);
+          const h = Object.freeze({
+            map: null,
+            hash: "",
+            transfers: void 0
+          });
+          e.SerializableEmpty = h;
+          class _ {
+            constructor() {
+              W(this, T);
+              W(this, o, !1);
+              W(this, r, /* @__PURE__ */ new Map());
+              this.onSetModified = null, this.onResetModified = null, this.onAnnotationEditor = null;
+            }
+            getValue(P, b) {
+              const k = a(this, r).get(P);
+              return k === void 0 ? b : Object.assign(b, k);
+            }
+            getRawValue(P) {
+              return a(this, r).get(P);
+            }
+            remove(P) {
+              if (a(this, r).delete(P), a(this, r).size === 0 && this.resetModified(), typeof this.onAnnotationEditor == "function") {
+                for (const b of a(this, r).values())
+                  if (b instanceof s.AnnotationEditor)
+                    return;
+                this.onAnnotationEditor(null);
+              }
+            }
+            setValue(P, b) {
+              const k = a(this, r).get(P);
+              let F = !1;
+              if (k !== void 0)
+                for (const [x, y] of Object.entries(b))
+                  k[x] !== y && (F = !0, k[x] = y);
+              else
+                F = !0, a(this, r).set(P, b);
+              F && K(this, T, En).call(this), b instanceof s.AnnotationEditor && typeof this.onAnnotationEditor == "function" && this.onAnnotationEditor(b.constructor._type);
+            }
+            has(P) {
+              return a(this, r).has(P);
+            }
+            getAll() {
+              return a(this, r).size > 0 ? (0, n.objectFromMap)(a(this, r)) : null;
+            }
+            setAll(P) {
+              for (const [b, k] of Object.entries(P))
+                this.setValue(b, k);
+            }
+            get size() {
+              return a(this, r).size;
+            }
+            resetModified() {
+              a(this, o) && (oe(this, o, !1), typeof this.onResetModified == "function" && this.onResetModified());
+            }
+            get print() {
+              return new c(this);
+            }
+            get serializable() {
+              if (a(this, r).size === 0)
+                return h;
+              const P = /* @__PURE__ */ new Map(), b = new l.MurmurHash3_64(), k = [], F = /* @__PURE__ */ Object.create(null);
+              let x = !1;
+              for (const [y, p] of a(this, r)) {
+                const E = p instanceof s.AnnotationEditor ? p.serialize(!1, F) : p;
+                E && (P.set(y, E), b.update(`${y}:${JSON.stringify(E)}`), x || (x = !!E.bitmap));
+              }
+              if (x)
+                for (const y of P.values())
+                  y.bitmap && k.push(y.bitmap);
+              return P.size > 0 ? {
+                map: P,
+                hash: b.hexdigest(),
+                transfers: k
+              } : h;
+            }
+          }
+          o = new WeakMap(), r = new WeakMap(), T = new WeakSet(), En = function() {
+            a(this, o) || (oe(this, o, !0), typeof this.onSetModified == "function" && this.onSetModified());
+          }, e.AnnotationStorage = _;
+          class c extends _ {
+            constructor(b) {
+              super();
+              W(this, w, void 0);
+              const {
+                map: k,
+                hash: F,
+                transfers: x
+              } = b.serializable, y = structuredClone(k, x ? {
+                transfer: x
+              } : null);
+              oe(this, w, {
+                map: y,
+                hash: F,
+                transfers: x
+              });
+            }
+            get print() {
+              (0, n.unreachable)("Should not call PrintAnnotationStorage.print");
+            }
+            get serializable() {
+              return a(this, w);
+            }
+          }
+          w = new WeakMap(), e.PrintAnnotationStorage = c;
+        },
+        /* 4 */
+        /***/
+        (t, e, i) => {
+          var c, o, r, T, S, w, C, P, b, k, F, x, y, p, E, Ht, M, Ut, N, jt, X, Gt, I, Sn, ee, wn, q, Tn, pe, Wt, be, Cn;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.AnnotationEditor = void 0;
+          var n = i(5), s = i(1), l = i(6);
+          const d = class d {
+            constructor(f) {
+              W(this, E);
+              W(this, M);
+              W(this, X);
+              W(this, I);
+              W(this, ee);
+              W(this, q);
+              W(this, pe);
+              W(this, be);
+              W(this, c, "");
+              W(this, o, !1);
+              W(this, r, null);
+              W(this, T, null);
+              W(this, S, null);
+              W(this, w, !1);
+              W(this, C, null);
+              W(this, P, this.focusin.bind(this));
+              W(this, b, this.focusout.bind(this));
+              W(this, k, !1);
+              W(this, F, !1);
+              W(this, x, !1);
+              nt(this, "_initialOptions", /* @__PURE__ */ Object.create(null));
+              nt(this, "_uiManager", null);
+              nt(this, "_focusEventsAllowed", !0);
+              nt(this, "_l10nPromise", null);
+              W(this, y, !1);
+              W(this, p, d._zIndex++);
+              this.constructor === d && (0, s.unreachable)("Cannot initialize AnnotationEditor."), this.parent = f.parent, this.id = f.id, this.width = this.height = null, this.pageIndex = f.parent.pageIndex, this.name = f.name, this.div = null, this._uiManager = f.uiManager, this.annotationElementId = null, this._willKeepAspectRatio = !1, this._initialOptions.isCentered = f.isCentered, this._structTreeParentId = null;
+              const {
+                rotation: v,
+                rawDims: {
+                  pageWidth: A,
+                  pageHeight: O,
+                  pageX: H,
+                  pageY: z
+                }
+              } = this.parent.viewport;
+              this.rotation = v, this.pageRotation = (360 + v - this._uiManager.viewParameters.rotation) % 360, this.pageDimensions = [A, O], this.pageTranslation = [H, z];
+              const [ae, Q] = this.parentDimensions;
+              this.x = f.x / ae, this.y = f.y / Q, this.isAttachedToDOM = !1, this.deleted = !1;
+            }
+            get editorType() {
+              return Object.getPrototypeOf(this).constructor._type;
+            }
+            static get _defaultLineColor() {
+              return (0, s.shadow)(this, "_defaultLineColor", this._colorManager.getHexCode("CanvasText"));
+            }
+            static deleteAnnotationElement(f) {
+              const v = new _({
+                id: f.parent.getNextId(),
+                parent: f.parent,
+                uiManager: f._uiManager
+              });
+              v.annotationElementId = f.annotationElementId, v.deleted = !0, v._uiManager.addToAnnotationStorage(v);
+            }
+            static initialize(f, v = null) {
+              if (d._l10nPromise || (d._l10nPromise = new Map(["editor_alt_text_button_label", "editor_alt_text_edit_button_label", "editor_alt_text_decorative_tooltip"].map((O) => [O, f.get(O)]))), v != null && v.strings)
+                for (const O of v.strings)
+                  d._l10nPromise.set(O, f.get(O));
+              if (d._borderLineWidth !== -1)
+                return;
+              const A = getComputedStyle(document.documentElement);
+              d._borderLineWidth = parseFloat(A.getPropertyValue("--outline-width")) || 0;
+            }
+            static updateDefaultParams(f, v) {
+            }
+            static get defaultPropertiesToUpdate() {
+              return [];
+            }
+            static isHandlingMimeForPasting(f) {
+              return !1;
+            }
+            static paste(f, v) {
+              (0, s.unreachable)("Not implemented");
+            }
+            get propertiesToUpdate() {
+              return [];
+            }
+            get _isDraggable() {
+              return a(this, y);
+            }
+            set _isDraggable(f) {
+              var v;
+              oe(this, y, f), (v = this.div) == null || v.classList.toggle("draggable", f);
+            }
+            center() {
+              const [f, v] = this.pageDimensions;
+              switch (this.parentRotation) {
+                case 90:
+                  this.x -= this.height * v / (f * 2), this.y += this.width * f / (v * 2);
+                  break;
+                case 180:
+                  this.x += this.width / 2, this.y += this.height / 2;
+                  break;
+                case 270:
+                  this.x += this.height * v / (f * 2), this.y -= this.width * f / (v * 2);
+                  break;
+                default:
+                  this.x -= this.width / 2, this.y -= this.height / 2;
+                  break;
+              }
+              this.fixAndSetPosition();
+            }
+            addCommands(f) {
+              this._uiManager.addCommands(f);
+            }
+            get currentLayer() {
+              return this._uiManager.currentLayer;
+            }
+            setInBackground() {
+              this.div.style.zIndex = 0;
+            }
+            setInForeground() {
+              this.div.style.zIndex = a(this, p);
+            }
+            setParent(f) {
+              f !== null && (this.pageIndex = f.pageIndex, this.pageDimensions = f.pageDimensions), this.parent = f;
+            }
+            focusin(f) {
+              this._focusEventsAllowed && (a(this, k) ? oe(this, k, !1) : this.parent.setSelected(this));
+            }
+            focusout(f) {
+              var A;
+              if (!this._focusEventsAllowed || !this.isAttachedToDOM)
+                return;
+              const v = f.relatedTarget;
+              v != null && v.closest(`#${this.id}`) || (f.preventDefault(), (A = this.parent) != null && A.isMultipleSelection || this.commitOrRemove());
+            }
+            commitOrRemove() {
+              this.isEmpty() ? this.remove() : this.commit();
+            }
+            commit() {
+              this.addToAnnotationStorage();
+            }
+            addToAnnotationStorage() {
+              this._uiManager.addToAnnotationStorage(this);
+            }
+            setAt(f, v, A, O) {
+              const [H, z] = this.parentDimensions;
+              [A, O] = this.screenToPageTranslation(A, O), this.x = (f + A) / H, this.y = (v + O) / z, this.fixAndSetPosition();
+            }
+            translate(f, v) {
+              K(this, E, Ht).call(this, this.parentDimensions, f, v);
+            }
+            translateInPage(f, v) {
+              K(this, E, Ht).call(this, this.pageDimensions, f, v), this.div.scrollIntoView({
+                block: "nearest"
+              });
+            }
+            drag(f, v) {
+              const [A, O] = this.parentDimensions;
+              if (this.x += f / A, this.y += v / O, this.parent && (this.x < 0 || this.x > 1 || this.y < 0 || this.y > 1)) {
+                const {
+                  x: ce,
+                  y: ue
+                } = this.div.getBoundingClientRect();
+                this.parent.findNewParent(this, ce, ue) && (this.x -= Math.floor(this.x), this.y -= Math.floor(this.y));
+              }
+              let {
+                x: H,
+                y: z
+              } = this;
+              const [ae, Q] = K(this, M, Ut).call(this);
+              H += ae, z += Q, this.div.style.left = `${(100 * H).toFixed(2)}%`, this.div.style.top = `${(100 * z).toFixed(2)}%`, this.div.scrollIntoView({
+                block: "nearest"
+              });
+            }
+            fixAndSetPosition() {
+              const [f, v] = this.pageDimensions;
+              let {
+                x: A,
+                y: O,
+                width: H,
+                height: z
+              } = this;
+              switch (H *= f, z *= v, A *= f, O *= v, this.rotation) {
+                case 0:
+                  A = Math.max(0, Math.min(f - H, A)), O = Math.max(0, Math.min(v - z, O));
+                  break;
+                case 90:
+                  A = Math.max(0, Math.min(f - z, A)), O = Math.min(v, Math.max(H, O));
+                  break;
+                case 180:
+                  A = Math.min(f, Math.max(H, A)), O = Math.min(v, Math.max(z, O));
+                  break;
+                case 270:
+                  A = Math.min(f, Math.max(z, A)), O = Math.max(0, Math.min(v - H, O));
+                  break;
+              }
+              this.x = A /= f, this.y = O /= v;
+              const [ae, Q] = K(this, M, Ut).call(this);
+              A += ae, O += Q;
+              const {
+                style: ce
+              } = this.div;
+              ce.left = `${(100 * A).toFixed(2)}%`, ce.top = `${(100 * O).toFixed(2)}%`, this.moveInDOM();
+            }
+            screenToPageTranslation(f, v) {
+              var A;
+              return K(A = d, N, jt).call(A, f, v, this.parentRotation);
+            }
+            pageTranslationToScreen(f, v) {
+              var A;
+              return K(A = d, N, jt).call(A, f, v, 360 - this.parentRotation);
+            }
+            get parentScale() {
+              return this._uiManager.viewParameters.realScale;
+            }
+            get parentRotation() {
+              return (this._uiManager.viewParameters.rotation + this.pageRotation) % 360;
+            }
+            get parentDimensions() {
+              const {
+                parentScale: f,
+                pageDimensions: [v, A]
+              } = this, O = v * f, H = A * f;
+              return s.FeatureTest.isCSSRoundSupported ? [Math.round(O), Math.round(H)] : [O, H];
+            }
+            setDims(f, v) {
+              var H;
+              const [A, O] = this.parentDimensions;
+              this.div.style.width = `${(100 * f / A).toFixed(2)}%`, a(this, w) || (this.div.style.height = `${(100 * v / O).toFixed(2)}%`), (H = a(this, r)) == null || H.classList.toggle("small", f < d.SMALL_EDITOR_SIZE || v < d.SMALL_EDITOR_SIZE);
+            }
+            fixDims() {
+              const {
+                style: f
+              } = this.div, {
+                height: v,
+                width: A
+              } = f, O = A.endsWith("%"), H = !a(this, w) && v.endsWith("%");
+              if (O && H)
+                return;
+              const [z, ae] = this.parentDimensions;
+              O || (f.width = `${(100 * parseFloat(A) / z).toFixed(2)}%`), !a(this, w) && !H && (f.height = `${(100 * parseFloat(v) / ae).toFixed(2)}%`);
+            }
+            getInitialTranslation() {
+              return [0, 0];
+            }
+            async addAltTextButton() {
+              if (a(this, r))
+                return;
+              const f = oe(this, r, document.createElement("button"));
+              f.className = "altText";
+              const v = await d._l10nPromise.get("editor_alt_text_button_label");
+              f.textContent = v, f.setAttribute("aria-label", v), f.tabIndex = "0", f.addEventListener("contextmenu", l.noContextMenu), f.addEventListener("pointerdown", (A) => A.stopPropagation()), f.addEventListener("click", (A) => {
+                A.preventDefault(), this._uiManager.editAltText(this);
+              }, {
+                capture: !0
+              }), f.addEventListener("keydown", (A) => {
+                A.target === f && A.key === "Enter" && (A.preventDefault(), this._uiManager.editAltText(this));
+              }), K(this, pe, Wt).call(this), this.div.append(f), d.SMALL_EDITOR_SIZE || (d.SMALL_EDITOR_SIZE = Math.min(128, Math.round(f.getBoundingClientRect().width * 1.4)));
+            }
+            getClientDimensions() {
+              return this.div.getBoundingClientRect();
+            }
+            get altTextData() {
+              return {
+                altText: a(this, c),
+                decorative: a(this, o)
+              };
+            }
+            set altTextData({
+              altText: f,
+              decorative: v
+            }) {
+              a(this, c) === f && a(this, o) === v || (oe(this, c, f), oe(this, o, v), K(this, pe, Wt).call(this));
+            }
+            render() {
+              this.div = document.createElement("div"), this.div.setAttribute("data-editor-rotation", (360 - this.rotation) % 360), this.div.className = this.name, this.div.setAttribute("id", this.id), this.div.setAttribute("tabIndex", 0), this.setInForeground(), this.div.addEventListener("focusin", a(this, P)), this.div.addEventListener("focusout", a(this, b));
+              const [f, v] = this.parentDimensions;
+              this.parentRotation % 180 !== 0 && (this.div.style.maxWidth = `${(100 * v / f).toFixed(2)}%`, this.div.style.maxHeight = `${(100 * f / v).toFixed(2)}%`);
+              const [A, O] = this.getInitialTranslation();
+              return this.translate(A, O), (0, n.bindEvents)(this, this.div, ["pointerdown"]), this.div;
+            }
+            pointerdown(f) {
+              const {
+                isMac: v
+              } = s.FeatureTest.platform;
+              if (f.button !== 0 || f.ctrlKey && v) {
+                f.preventDefault();
+                return;
+              }
+              oe(this, k, !0), K(this, be, Cn).call(this, f);
+            }
+            moveInDOM() {
+              var f;
+              (f = this.parent) == null || f.moveEditorInDOM(this);
+            }
+            _setParentAndPosition(f, v, A) {
+              f.changeParent(this), this.x = v, this.y = A, this.fixAndSetPosition();
+            }
+            getRect(f, v) {
+              const A = this.parentScale, [O, H] = this.pageDimensions, [z, ae] = this.pageTranslation, Q = f / A, ce = v / A, ue = this.x * O, me = this.y * H, fe = this.width * O, Pe = this.height * H;
+              switch (this.rotation) {
+                case 0:
+                  return [ue + Q + z, H - me - ce - Pe + ae, ue + Q + fe + z, H - me - ce + ae];
+                case 90:
+                  return [ue + ce + z, H - me + Q + ae, ue + ce + Pe + z, H - me + Q + fe + ae];
+                case 180:
+                  return [ue - Q - fe + z, H - me + ce + ae, ue - Q + z, H - me + ce + Pe + ae];
+                case 270:
+                  return [ue - ce - Pe + z, H - me - Q - fe + ae, ue - ce + z, H - me - Q + ae];
+                default:
+                  throw new Error("Invalid rotation");
+              }
+            }
+            getRectInCurrentCoords(f, v) {
+              const [A, O, H, z] = f, ae = H - A, Q = z - O;
+              switch (this.rotation) {
+                case 0:
+                  return [A, v - z, ae, Q];
+                case 90:
+                  return [A, v - O, Q, ae];
+                case 180:
+                  return [H, v - O, ae, Q];
+                case 270:
+                  return [H, v - z, Q, ae];
+                default:
+                  throw new Error("Invalid rotation");
+              }
+            }
+            onceAdded() {
+            }
+            isEmpty() {
+              return !1;
+            }
+            enableEditMode() {
+              oe(this, x, !0);
+            }
+            disableEditMode() {
+              oe(this, x, !1);
+            }
+            isInEditMode() {
+              return a(this, x);
+            }
+            shouldGetKeyboardEvents() {
+              return !1;
+            }
+            needsToBeRebuilt() {
+              return this.div && !this.isAttachedToDOM;
+            }
+            rebuild() {
+              var f, v;
+              (f = this.div) == null || f.addEventListener("focusin", a(this, P)), (v = this.div) == null || v.addEventListener("focusout", a(this, b));
+            }
+            serialize(f = !1, v = null) {
+              (0, s.unreachable)("An editor must be serializable");
+            }
+            static deserialize(f, v, A) {
+              const O = new this.prototype.constructor({
+                parent: v,
+                id: v.getNextId(),
+                uiManager: A
+              });
+              O.rotation = f.rotation;
+              const [H, z] = O.pageDimensions, [ae, Q, ce, ue] = O.getRectInCurrentCoords(f.rect, z);
+              return O.x = ae / H, O.y = Q / z, O.width = ce / H, O.height = ue / z, O;
+            }
+            remove() {
+              var f;
+              this.div.removeEventListener("focusin", a(this, P)), this.div.removeEventListener("focusout", a(this, b)), this.isEmpty() || this.commit(), this.parent ? this.parent.remove(this) : this._uiManager.removeEditor(this), (f = a(this, r)) == null || f.remove(), oe(this, r, null), oe(this, T, null);
+            }
+            get isResizable() {
+              return !1;
+            }
+            makeResizable() {
+              this.isResizable && (K(this, I, Sn).call(this), a(this, C).classList.remove("hidden"));
+            }
+            select() {
+              var f;
+              this.makeResizable(), (f = this.div) == null || f.classList.add("selectedEditor");
+            }
+            unselect() {
+              var f, v, A;
+              (f = a(this, C)) == null || f.classList.add("hidden"), (v = this.div) == null || v.classList.remove("selectedEditor"), (A = this.div) != null && A.contains(document.activeElement) && this._uiManager.currentLayer.div.focus();
+            }
+            updateParams(f, v) {
+            }
+            disableEditing() {
+              a(this, r) && (a(this, r).hidden = !0);
+            }
+            enableEditing() {
+              a(this, r) && (a(this, r).hidden = !1);
+            }
+            enterInEditMode() {
+            }
+            get contentDiv() {
+              return this.div;
+            }
+            get isEditing() {
+              return a(this, F);
+            }
+            set isEditing(f) {
+              oe(this, F, f), this.parent && (f ? (this.parent.setSelected(this), this.parent.setActiveEditor(this)) : this.parent.setActiveEditor(null));
+            }
+            setAspectRatio(f, v) {
+              oe(this, w, !0);
+              const A = f / v, {
+                style: O
+              } = this.div;
+              O.aspectRatio = A, O.height = "auto";
+            }
+            static get MIN_SIZE() {
+              return 16;
+            }
+          };
+          c = new WeakMap(), o = new WeakMap(), r = new WeakMap(), T = new WeakMap(), S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakMap(), k = new WeakMap(), F = new WeakMap(), x = new WeakMap(), y = new WeakMap(), p = new WeakMap(), E = new WeakSet(), Ht = function([f, v], A, O) {
+            [A, O] = this.screenToPageTranslation(A, O), this.x += A / f, this.y += O / v, this.fixAndSetPosition();
+          }, M = new WeakSet(), Ut = function() {
+            const [f, v] = this.parentDimensions, {
+              _borderLineWidth: A
+            } = d, O = A / f, H = A / v;
+            switch (this.rotation) {
+              case 90:
+                return [-O, H];
+              case 180:
+                return [O, H];
+              case 270:
+                return [O, -H];
+              default:
+                return [-O, -H];
+            }
+          }, N = new WeakSet(), jt = function(f, v, A) {
+            switch (A) {
+              case 90:
+                return [v, -f];
+              case 180:
+                return [-f, -v];
+              case 270:
+                return [-v, f];
+              default:
+                return [f, v];
+            }
+          }, X = new WeakSet(), Gt = function(f) {
+            switch (f) {
+              case 90: {
+                const [v, A] = this.pageDimensions;
+                return [0, -v / A, A / v, 0];
+              }
+              case 180:
+                return [-1, 0, 0, -1];
+              case 270: {
+                const [v, A] = this.pageDimensions;
+                return [0, v / A, -A / v, 0];
+              }
+              default:
+                return [1, 0, 0, 1];
+            }
+          }, I = new WeakSet(), Sn = function() {
+            if (a(this, C))
+              return;
+            oe(this, C, document.createElement("div")), a(this, C).classList.add("resizers");
+            const f = ["topLeft", "topRight", "bottomRight", "bottomLeft"];
+            this._willKeepAspectRatio || f.push("topMiddle", "middleRight", "bottomMiddle", "middleLeft");
+            for (const v of f) {
+              const A = document.createElement("div");
+              a(this, C).append(A), A.classList.add("resizer", v), A.addEventListener("pointerdown", K(this, ee, wn).bind(this, v)), A.addEventListener("contextmenu", l.noContextMenu);
+            }
+            this.div.prepend(a(this, C));
+          }, ee = new WeakSet(), wn = function(f, v) {
+            v.preventDefault();
+            const {
+              isMac: A
+            } = s.FeatureTest.platform;
+            if (v.button !== 0 || v.ctrlKey && A)
+              return;
+            const O = K(this, q, Tn).bind(this, f), H = this._isDraggable;
+            this._isDraggable = !1;
+            const z = {
+              passive: !0,
+              capture: !0
+            };
+            window.addEventListener("pointermove", O, z);
+            const ae = this.x, Q = this.y, ce = this.width, ue = this.height, me = this.parent.div.style.cursor, fe = this.div.style.cursor;
+            this.div.style.cursor = this.parent.div.style.cursor = window.getComputedStyle(v.target).cursor;
+            const Pe = () => {
+              this._isDraggable = H, window.removeEventListener("pointerup", Pe), window.removeEventListener("blur", Pe), window.removeEventListener("pointermove", O, z), this.parent.div.style.cursor = me, this.div.style.cursor = fe;
+              const Fe = this.x, Ee = this.y, De = this.width, _e = this.height;
+              Fe === ae && Ee === Q && De === ce && _e === ue || this.addCommands({
+                cmd: () => {
+                  this.width = De, this.height = _e, this.x = Fe, this.y = Ee;
+                  const [ie, se] = this.parentDimensions;
+                  this.setDims(ie * De, se * _e), this.fixAndSetPosition();
+                },
+                undo: () => {
+                  this.width = ce, this.height = ue, this.x = ae, this.y = Q;
+                  const [ie, se] = this.parentDimensions;
+                  this.setDims(ie * ce, se * ue), this.fixAndSetPosition();
+                },
+                mustExec: !0
+              });
+            };
+            window.addEventListener("pointerup", Pe), window.addEventListener("blur", Pe);
+          }, q = new WeakSet(), Tn = function(f, v) {
+            const [A, O] = this.parentDimensions, H = this.x, z = this.y, ae = this.width, Q = this.height, ce = d.MIN_SIZE / A, ue = d.MIN_SIZE / O, me = (ve) => Math.round(ve * 1e4) / 1e4, fe = K(this, X, Gt).call(this, this.rotation), Pe = (ve, Se) => [fe[0] * ve + fe[2] * Se, fe[1] * ve + fe[3] * Se], Fe = K(this, X, Gt).call(this, 360 - this.rotation), Ee = (ve, Se) => [Fe[0] * ve + Fe[2] * Se, Fe[1] * ve + Fe[3] * Se];
+            let De, _e, ie = !1, se = !1;
+            switch (f) {
+              case "topLeft":
+                ie = !0, De = (ve, Se) => [0, 0], _e = (ve, Se) => [ve, Se];
+                break;
+              case "topMiddle":
+                De = (ve, Se) => [ve / 2, 0], _e = (ve, Se) => [ve / 2, Se];
+                break;
+              case "topRight":
+                ie = !0, De = (ve, Se) => [ve, 0], _e = (ve, Se) => [0, Se];
+                break;
+              case "middleRight":
+                se = !0, De = (ve, Se) => [ve, Se / 2], _e = (ve, Se) => [0, Se / 2];
+                break;
+              case "bottomRight":
+                ie = !0, De = (ve, Se) => [ve, Se], _e = (ve, Se) => [0, 0];
+                break;
+              case "bottomMiddle":
+                De = (ve, Se) => [ve / 2, Se], _e = (ve, Se) => [ve / 2, 0];
+                break;
+              case "bottomLeft":
+                ie = !0, De = (ve, Se) => [0, Se], _e = (ve, Se) => [ve, 0];
+                break;
+              case "middleLeft":
+                se = !0, De = (ve, Se) => [0, Se / 2], _e = (ve, Se) => [ve, Se / 2];
+                break;
+            }
+            const ge = De(ae, Q), Ce = _e(ae, Q);
+            let xe = Pe(...Ce);
+            const Ue = me(H + xe[0]), We = me(z + xe[1]);
+            let je = 1, ze = 1, [Xe, Ge] = this.screenToPageTranslation(v.movementX, v.movementY);
+            if ([Xe, Ge] = Ee(Xe / A, Ge / O), ie) {
+              const ve = Math.hypot(ae, Q);
+              je = ze = Math.max(Math.min(Math.hypot(Ce[0] - ge[0] - Xe, Ce[1] - ge[1] - Ge) / ve, 1 / ae, 1 / Q), ce / ae, ue / Q);
+            } else
+              se ? je = Math.max(ce, Math.min(1, Math.abs(Ce[0] - ge[0] - Xe))) / ae : ze = Math.max(ue, Math.min(1, Math.abs(Ce[1] - ge[1] - Ge))) / Q;
+            const Ye = me(ae * je), de = me(Q * ze);
+            xe = Pe(..._e(Ye, de));
+            const ne = Ue - xe[0], J = We - xe[1];
+            this.width = Ye, this.height = de, this.x = ne, this.y = J, this.setDims(A * Ye, O * de), this.fixAndSetPosition();
+          }, pe = new WeakSet(), Wt = async function() {
+            var A;
+            const f = a(this, r);
+            if (!f)
+              return;
+            if (!a(this, c) && !a(this, o)) {
+              f.classList.remove("done"), (A = a(this, T)) == null || A.remove();
+              return;
+            }
+            d._l10nPromise.get("editor_alt_text_edit_button_label").then((O) => {
+              f.setAttribute("aria-label", O);
+            });
+            let v = a(this, T);
+            if (!v) {
+              oe(this, T, v = document.createElement("span")), v.className = "tooltip", v.setAttribute("role", "tooltip");
+              const O = v.id = `alt-text-tooltip-${this.id}`;
+              f.setAttribute("aria-describedby", O);
+              const H = 100;
+              f.addEventListener("mouseenter", () => {
+                oe(this, S, setTimeout(() => {
+                  oe(this, S, null), a(this, T).classList.add("show"), this._uiManager._eventBus.dispatch("reporttelemetry", {
+                    source: this,
+                    details: {
+                      type: "editing",
+                      subtype: this.editorType,
+                      data: {
+                        action: "alt_text_tooltip"
+                      }
+                    }
+                  });
+                }, H));
+              }), f.addEventListener("mouseleave", () => {
+                var z;
+                clearTimeout(a(this, S)), oe(this, S, null), (z = a(this, T)) == null || z.classList.remove("show");
+              });
+            }
+            f.classList.add("done"), v.innerText = a(this, o) ? await d._l10nPromise.get("editor_alt_text_decorative_tooltip") : a(this, c), v.parentNode || f.append(v);
+          }, be = new WeakSet(), Cn = function(f) {
+            if (!this._isDraggable)
+              return;
+            const v = this._uiManager.isSelected(this);
+            this._uiManager.setUpDragSession();
+            let A, O;
+            v && (A = {
+              passive: !0,
+              capture: !0
+            }, O = (z) => {
+              const [ae, Q] = this.screenToPageTranslation(z.movementX, z.movementY);
+              this._uiManager.dragSelectedEditors(ae, Q);
+            }, window.addEventListener("pointermove", O, A));
+            const H = () => {
+              if (window.removeEventListener("pointerup", H), window.removeEventListener("blur", H), v && window.removeEventListener("pointermove", O, A), oe(this, k, !1), !this._uiManager.endDragSession()) {
+                const {
+                  isMac: z
+                } = s.FeatureTest.platform;
+                f.ctrlKey && !z || f.shiftKey || f.metaKey && z ? this.parent.toggleSelected(this) : this.parent.setSelected(this);
+              }
+            };
+            window.addEventListener("pointerup", H), window.addEventListener("blur", H);
+          }, W(d, N), nt(d, "_borderLineWidth", -1), nt(d, "_colorManager", new n.ColorManager()), nt(d, "_zIndex", 1), nt(d, "SMALL_EDITOR_SIZE", 0);
+          let h = d;
+          e.AnnotationEditor = h;
+          class _ extends h {
+            constructor(f) {
+              super(f), this.annotationElementId = f.annotationElementId, this.deleted = !0;
+            }
+            serialize() {
+              return {
+                id: this.annotationElementId,
+                deleted: !0,
+                pageIndex: this.pageIndex
+              };
+            }
+          }
+        },
+        /* 5 */
+        /***/
+        (t, e, i) => {
+          var w, C, P, b, k, qt, y, p, E, $, M, Pn, D, X, G, I, B, ee, Y, q, le, pe, we, be, R, d, g, f, v, A, O, H, z, ae, Q, ce, ue, me, fe, Pe, Fe, Ee, De, _e, ie, se, ge, xn, xe, zt, We, Xt, ze, Ct, Ge, Vt, de, Yt, J, at, Se, mt, et, kn, Te, Rn, ke, Kt, Be, bt, Ae, Jt;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.KeyboardManager = e.CommandManager = e.ColorManager = e.AnnotationEditorUIManager = void 0, e.bindEvents = l, e.opacityToHex = h;
+          var n = i(1), s = i(6);
+          function l(U, u, L) {
+            for (const j of L)
+              u.addEventListener(j, U[j].bind(U));
+          }
+          function h(U) {
+            return Math.round(Math.min(255, Math.max(1, 255 * U))).toString(16).padStart(2, "0");
+          }
+          class _ {
+            constructor() {
+              W(this, w, 0);
+            }
+            getId() {
+              return `${n.AnnotationEditorPrefix}${_t(this, w)._++}`;
+            }
+          }
+          w = new WeakMap();
+          const x = class x {
+            constructor() {
+              W(this, k);
+              W(this, C, (0, n.getUuid)());
+              W(this, P, 0);
+              W(this, b, null);
+            }
+            static get _isSVGFittingCanvas() {
+              const u = 'data:image/svg+xml;charset=UTF-8,<svg viewBox="0 0 1 1" width="1" height="1" xmlns="http://www.w3.org/2000/svg"><rect width="1" height="1" style="fill:red;"/></svg>', j = new OffscreenCanvas(1, 3).getContext("2d"), V = new Image();
+              V.src = u;
+              const Z = V.decode().then(() => (j.drawImage(V, 0, 0, 1, 1, 0, 0, 1, 3), new Uint32Array(j.getImageData(0, 0, 1, 1).data.buffer)[0] === 0));
+              return (0, n.shadow)(this, "_isSVGFittingCanvas", Z);
+            }
+            async getFromFile(u) {
+              const {
+                lastModified: L,
+                name: j,
+                size: V,
+                type: Z
+              } = u;
+              return K(this, k, qt).call(this, `${L}_${j}_${V}_${Z}`, u);
+            }
+            async getFromUrl(u) {
+              return K(this, k, qt).call(this, u, u);
+            }
+            async getFromId(u) {
+              a(this, b) || oe(this, b, /* @__PURE__ */ new Map());
+              const L = a(this, b).get(u);
+              return L ? L.bitmap ? (L.refCounter += 1, L) : L.file ? this.getFromFile(L.file) : this.getFromUrl(L.url) : null;
+            }
+            getSvgUrl(u) {
+              const L = a(this, b).get(u);
+              return L != null && L.isSvg ? L.svgUrl : null;
+            }
+            deleteId(u) {
+              a(this, b) || oe(this, b, /* @__PURE__ */ new Map());
+              const L = a(this, b).get(u);
+              L && (L.refCounter -= 1, L.refCounter === 0 && (L.bitmap = null));
+            }
+            isValidId(u) {
+              return u.startsWith(`image_${a(this, C)}_`);
+            }
+          };
+          C = new WeakMap(), P = new WeakMap(), b = new WeakMap(), k = new WeakSet(), qt = async function(u, L) {
+            a(this, b) || oe(this, b, /* @__PURE__ */ new Map());
+            let j = a(this, b).get(u);
+            if (j === null)
+              return null;
+            if (j != null && j.bitmap)
+              return j.refCounter += 1, j;
+            try {
+              j || (j = {
+                bitmap: null,
+                id: `image_${a(this, C)}_${_t(this, P)._++}`,
+                refCounter: 0,
+                isSvg: !1
+              });
+              let V;
+              if (typeof L == "string") {
+                j.url = L;
+                const Z = await fetch(L);
+                if (!Z.ok)
+                  throw new Error(Z.statusText);
+                V = await Z.blob();
+              } else
+                V = j.file = L;
+              if (V.type === "image/svg+xml") {
+                const Z = x._isSVGFittingCanvas, he = new FileReader(), ye = new Image(), Me = new Promise((Re, qe) => {
+                  ye.onload = () => {
+                    j.bitmap = ye, j.isSvg = !0, Re();
+                  }, he.onload = async () => {
+                    const Ie = j.svgUrl = he.result;
+                    ye.src = await Z ? `${Ie}#svgView(preserveAspectRatio(none))` : Ie;
+                  }, ye.onerror = he.onerror = qe;
+                });
+                he.readAsDataURL(V), await Me;
+              } else
+                j.bitmap = await createImageBitmap(V);
+              j.refCounter = 1;
+            } catch (V) {
+              console.error(V), j = null;
+            }
+            return a(this, b).set(u, j), j && a(this, b).set(j.id, j), j;
+          };
+          let c = x;
+          class o {
+            constructor(u = 128) {
+              W(this, y, []);
+              W(this, p, !1);
+              W(this, E, void 0);
+              W(this, $, -1);
+              oe(this, E, u);
+            }
+            add({
+              cmd: u,
+              undo: L,
+              mustExec: j,
+              type: V = NaN,
+              overwriteIfSameType: Z = !1,
+              keepUndo: he = !1
+            }) {
+              if (j && u(), a(this, p))
+                return;
+              const ye = {
+                cmd: u,
+                undo: L,
+                type: V
+              };
+              if (a(this, $) === -1) {
+                a(this, y).length > 0 && (a(this, y).length = 0), oe(this, $, 0), a(this, y).push(ye);
+                return;
+              }
+              if (Z && a(this, y)[a(this, $)].type === V) {
+                he && (ye.undo = a(this, y)[a(this, $)].undo), a(this, y)[a(this, $)] = ye;
+                return;
+              }
+              const Me = a(this, $) + 1;
+              Me === a(this, E) ? a(this, y).splice(0, 1) : (oe(this, $, Me), Me < a(this, y).length && a(this, y).splice(Me)), a(this, y).push(ye);
+            }
+            undo() {
+              a(this, $) !== -1 && (oe(this, p, !0), a(this, y)[a(this, $)].undo(), oe(this, p, !1), oe(this, $, a(this, $) - 1));
+            }
+            redo() {
+              a(this, $) < a(this, y).length - 1 && (oe(this, $, a(this, $) + 1), oe(this, p, !0), a(this, y)[a(this, $)].cmd(), oe(this, p, !1));
+            }
+            hasSomethingToUndo() {
+              return a(this, $) !== -1;
+            }
+            hasSomethingToRedo() {
+              return a(this, $) < a(this, y).length - 1;
+            }
+            destroy() {
+              oe(this, y, null);
+            }
+          }
+          y = new WeakMap(), p = new WeakMap(), E = new WeakMap(), $ = new WeakMap(), e.CommandManager = o;
+          class r {
+            constructor(u) {
+              W(this, M);
+              this.buffer = [], this.callbacks = /* @__PURE__ */ new Map(), this.allKeys = /* @__PURE__ */ new Set();
+              const {
+                isMac: L
+              } = n.FeatureTest.platform;
+              for (const [j, V, Z = {}] of u)
+                for (const he of j) {
+                  const ye = he.startsWith("mac+");
+                  L && ye ? (this.callbacks.set(he.slice(4), {
+                    callback: V,
+                    options: Z
+                  }), this.allKeys.add(he.split("+").at(-1))) : !L && !ye && (this.callbacks.set(he, {
+                    callback: V,
+                    options: Z
+                  }), this.allKeys.add(he.split("+").at(-1)));
+                }
+            }
+            exec(u, L) {
+              if (!this.allKeys.has(L.key))
+                return;
+              const j = this.callbacks.get(K(this, M, Pn).call(this, L));
+              if (!j)
+                return;
+              const {
+                callback: V,
+                options: {
+                  bubbles: Z = !1,
+                  args: he = [],
+                  checker: ye = null
+                }
+              } = j;
+              ye && !ye(u, L) || (V.bind(u, ...he)(), Z || (L.stopPropagation(), L.preventDefault()));
+            }
+          }
+          M = new WeakSet(), Pn = function(u) {
+            u.altKey && this.buffer.push("alt"), u.ctrlKey && this.buffer.push("ctrl"), u.metaKey && this.buffer.push("meta"), u.shiftKey && this.buffer.push("shift"), this.buffer.push(u.key);
+            const L = this.buffer.join("+");
+            return this.buffer.length = 0, L;
+          }, e.KeyboardManager = r;
+          const N = class N {
+            get _colors() {
+              const u = /* @__PURE__ */ new Map([["CanvasText", null], ["Canvas", null]]);
+              return (0, s.getColorValues)(u), (0, n.shadow)(this, "_colors", u);
+            }
+            convert(u) {
+              const L = (0, s.getRGB)(u);
+              if (!window.matchMedia("(forced-colors: active)").matches)
+                return L;
+              for (const [j, V] of this._colors)
+                if (V.every((Z, he) => Z === L[he]))
+                  return N._colorsMapping.get(j);
+              return L;
+            }
+            getHexCode(u) {
+              const L = this._colors.get(u);
+              return L ? n.Util.makeHexColor(...L) : u;
+            }
+          };
+          nt(N, "_colorsMapping", /* @__PURE__ */ new Map([["CanvasText", [0, 0, 0]], ["Canvas", [255, 255, 255]]]));
+          let T = N;
+          e.ColorManager = T;
+          const Oe = class Oe {
+            constructor(u, L, j, V, Z, he) {
+              W(this, ge);
+              W(this, xe);
+              W(this, We);
+              W(this, ze);
+              W(this, Ge);
+              W(this, de);
+              W(this, J);
+              W(this, Se);
+              W(this, et);
+              W(this, Te);
+              W(this, ke);
+              W(this, Be);
+              W(this, Ae);
+              W(this, D, null);
+              W(this, X, /* @__PURE__ */ new Map());
+              W(this, G, /* @__PURE__ */ new Map());
+              W(this, I, null);
+              W(this, B, null);
+              W(this, ee, new o());
+              W(this, Y, 0);
+              W(this, q, /* @__PURE__ */ new Set());
+              W(this, le, null);
+              W(this, pe, null);
+              W(this, we, /* @__PURE__ */ new Set());
+              W(this, be, null);
+              W(this, R, new _());
+              W(this, d, !1);
+              W(this, g, !1);
+              W(this, f, null);
+              W(this, v, n.AnnotationEditorType.NONE);
+              W(this, A, /* @__PURE__ */ new Set());
+              W(this, O, null);
+              W(this, H, this.blur.bind(this));
+              W(this, z, this.focus.bind(this));
+              W(this, ae, this.copy.bind(this));
+              W(this, Q, this.cut.bind(this));
+              W(this, ce, this.paste.bind(this));
+              W(this, ue, this.keydown.bind(this));
+              W(this, me, this.onEditingAction.bind(this));
+              W(this, fe, this.onPageChanging.bind(this));
+              W(this, Pe, this.onScaleChanging.bind(this));
+              W(this, Fe, this.onRotationChanging.bind(this));
+              W(this, Ee, {
+                isEditing: !1,
+                isEmpty: !0,
+                hasSomethingToUndo: !1,
+                hasSomethingToRedo: !1,
+                hasSelectedEditor: !1
+              });
+              W(this, De, [0, 0]);
+              W(this, _e, null);
+              W(this, ie, null);
+              W(this, se, null);
+              oe(this, ie, u), oe(this, se, L), oe(this, I, j), this._eventBus = V, this._eventBus._on("editingaction", a(this, me)), this._eventBus._on("pagechanging", a(this, fe)), this._eventBus._on("scalechanging", a(this, Pe)), this._eventBus._on("rotationchanging", a(this, Fe)), oe(this, B, Z.annotationStorage), oe(this, be, Z.filterFactory), oe(this, O, he), this.viewParameters = {
+                realScale: s.PixelsPerInch.PDF_TO_CSS_UNITS,
+                rotation: 0
+              };
+            }
+            static get _keyboardManager() {
+              const u = Oe.prototype, L = (Z) => {
+                const {
+                  activeElement: he
+                } = document;
+                return he && a(Z, ie).contains(he) && Z.hasSomethingToControl();
+              }, j = this.TRANSLATE_SMALL, V = this.TRANSLATE_BIG;
+              return (0, n.shadow)(this, "_keyboardManager", new r([[["ctrl+a", "mac+meta+a"], u.selectAll], [["ctrl+z", "mac+meta+z"], u.undo], [["ctrl+y", "ctrl+shift+z", "mac+meta+shift+z", "ctrl+shift+Z", "mac+meta+shift+Z"], u.redo], [["Backspace", "alt+Backspace", "ctrl+Backspace", "shift+Backspace", "mac+Backspace", "mac+alt+Backspace", "mac+ctrl+Backspace", "Delete", "ctrl+Delete", "shift+Delete", "mac+Delete"], u.delete], [["Escape", "mac+Escape"], u.unselectAll], [["ArrowLeft", "mac+ArrowLeft"], u.translateSelectedEditors, {
+                args: [-j, 0],
+                checker: L
+              }], [["ctrl+ArrowLeft", "mac+shift+ArrowLeft"], u.translateSelectedEditors, {
+                args: [-V, 0],
+                checker: L
+              }], [["ArrowRight", "mac+ArrowRight"], u.translateSelectedEditors, {
+                args: [j, 0],
+                checker: L
+              }], [["ctrl+ArrowRight", "mac+shift+ArrowRight"], u.translateSelectedEditors, {
+                args: [V, 0],
+                checker: L
+              }], [["ArrowUp", "mac+ArrowUp"], u.translateSelectedEditors, {
+                args: [0, -j],
+                checker: L
+              }], [["ctrl+ArrowUp", "mac+shift+ArrowUp"], u.translateSelectedEditors, {
+                args: [0, -V],
+                checker: L
+              }], [["ArrowDown", "mac+ArrowDown"], u.translateSelectedEditors, {
+                args: [0, j],
+                checker: L
+              }], [["ctrl+ArrowDown", "mac+shift+ArrowDown"], u.translateSelectedEditors, {
+                args: [0, V],
+                checker: L
+              }]]));
+            }
+            destroy() {
+              K(this, ze, Ct).call(this), K(this, xe, zt).call(this), this._eventBus._off("editingaction", a(this, me)), this._eventBus._off("pagechanging", a(this, fe)), this._eventBus._off("scalechanging", a(this, Pe)), this._eventBus._off("rotationchanging", a(this, Fe));
+              for (const u of a(this, G).values())
+                u.destroy();
+              a(this, G).clear(), a(this, X).clear(), a(this, we).clear(), oe(this, D, null), a(this, A).clear(), a(this, ee).destroy(), a(this, I).destroy();
+            }
+            get hcmFilter() {
+              return (0, n.shadow)(this, "hcmFilter", a(this, O) ? a(this, be).addHCMFilter(a(this, O).foreground, a(this, O).background) : "none");
+            }
+            get direction() {
+              return (0, n.shadow)(this, "direction", getComputedStyle(a(this, ie)).direction);
+            }
+            editAltText(u) {
+              var L;
+              (L = a(this, I)) == null || L.editAltText(this, u);
+            }
+            onPageChanging({
+              pageNumber: u
+            }) {
+              oe(this, Y, u - 1);
+            }
+            focusMainContainer() {
+              a(this, ie).focus();
+            }
+            findParent(u, L) {
+              for (const j of a(this, G).values()) {
+                const {
+                  x: V,
+                  y: Z,
+                  width: he,
+                  height: ye
+                } = j.div.getBoundingClientRect();
+                if (u >= V && u <= V + he && L >= Z && L <= Z + ye)
+                  return j;
+              }
+              return null;
+            }
+            disableUserSelect(u = !1) {
+              a(this, se).classList.toggle("noUserSelect", u);
+            }
+            addShouldRescale(u) {
+              a(this, we).add(u);
+            }
+            removeShouldRescale(u) {
+              a(this, we).delete(u);
+            }
+            onScaleChanging({
+              scale: u
+            }) {
+              this.commitOrRemove(), this.viewParameters.realScale = u * s.PixelsPerInch.PDF_TO_CSS_UNITS;
+              for (const L of a(this, we))
+                L.onScaleChanging();
+            }
+            onRotationChanging({
+              pagesRotation: u
+            }) {
+              this.commitOrRemove(), this.viewParameters.rotation = u;
+            }
+            addToAnnotationStorage(u) {
+              !u.isEmpty() && a(this, B) && !a(this, B).has(u.id) && a(this, B).setValue(u.id, u);
+            }
+            blur() {
+              if (!this.hasSelection)
+                return;
+              const {
+                activeElement: u
+              } = document;
+              for (const L of a(this, A))
+                if (L.div.contains(u)) {
+                  oe(this, f, [L, u]), L._focusEventsAllowed = !1;
+                  break;
+                }
+            }
+            focus() {
+              if (!a(this, f))
+                return;
+              const [u, L] = a(this, f);
+              oe(this, f, null), L.addEventListener("focusin", () => {
+                u._focusEventsAllowed = !0;
+              }, {
+                once: !0
+              }), L.focus();
+            }
+            addEditListeners() {
+              K(this, We, Xt).call(this), K(this, Ge, Vt).call(this);
+            }
+            removeEditListeners() {
+              K(this, ze, Ct).call(this), K(this, de, Yt).call(this);
+            }
+            copy(u) {
+              var j;
+              if (u.preventDefault(), (j = a(this, D)) == null || j.commitOrRemove(), !this.hasSelection)
+                return;
+              const L = [];
+              for (const V of a(this, A)) {
+                const Z = V.serialize(!0);
+                Z && L.push(Z);
+              }
+              L.length !== 0 && u.clipboardData.setData("application/pdfjs", JSON.stringify(L));
+            }
+            cut(u) {
+              this.copy(u), this.delete();
+            }
+            paste(u) {
+              u.preventDefault();
+              const {
+                clipboardData: L
+              } = u;
+              for (const Z of L.items)
+                for (const he of a(this, pe))
+                  if (he.isHandlingMimeForPasting(Z.type)) {
+                    he.paste(Z, this.currentLayer);
+                    return;
+                  }
+              let j = L.getData("application/pdfjs");
+              if (!j)
+                return;
+              try {
+                j = JSON.parse(j);
+              } catch (Z) {
+                (0, n.warn)(`paste: "${Z.message}".`);
+                return;
+              }
+              if (!Array.isArray(j))
+                return;
+              this.unselectAll();
+              const V = this.currentLayer;
+              try {
+                const Z = [];
+                for (const Me of j) {
+                  const Re = V.deserialize(Me);
+                  if (!Re)
+                    return;
+                  Z.push(Re);
+                }
+                const he = () => {
+                  for (const Me of Z)
+                    K(this, ke, Kt).call(this, Me);
+                  K(this, Ae, Jt).call(this, Z);
+                }, ye = () => {
+                  for (const Me of Z)
+                    Me.remove();
+                };
+                this.addCommands({
+                  cmd: he,
+                  undo: ye,
+                  mustExec: !0
+                });
+              } catch (Z) {
+                (0, n.warn)(`paste: "${Z.message}".`);
+              }
+            }
+            keydown(u) {
+              var L;
+              (L = this.getActive()) != null && L.shouldGetKeyboardEvents() || Oe._keyboardManager.exec(this, u);
+            }
+            onEditingAction(u) {
+              ["undo", "redo", "delete", "selectAll"].includes(u.name) && this[u.name]();
+            }
+            setEditingState(u) {
+              u ? (K(this, ge, xn).call(this), K(this, We, Xt).call(this), K(this, Ge, Vt).call(this), K(this, J, at).call(this, {
+                isEditing: a(this, v) !== n.AnnotationEditorType.NONE,
+                isEmpty: K(this, Be, bt).call(this),
+                hasSomethingToUndo: a(this, ee).hasSomethingToUndo(),
+                hasSomethingToRedo: a(this, ee).hasSomethingToRedo(),
+                hasSelectedEditor: !1
+              })) : (K(this, xe, zt).call(this), K(this, ze, Ct).call(this), K(this, de, Yt).call(this), K(this, J, at).call(this, {
+                isEditing: !1
+              }), this.disableUserSelect(!1));
+            }
+            registerEditorTypes(u) {
+              if (!a(this, pe)) {
+                oe(this, pe, u);
+                for (const L of a(this, pe))
+                  K(this, Se, mt).call(this, L.defaultPropertiesToUpdate);
+              }
+            }
+            getId() {
+              return a(this, R).getId();
+            }
+            get currentLayer() {
+              return a(this, G).get(a(this, Y));
+            }
+            getLayer(u) {
+              return a(this, G).get(u);
+            }
+            get currentPageIndex() {
+              return a(this, Y);
+            }
+            addLayer(u) {
+              a(this, G).set(u.pageIndex, u), a(this, d) ? u.enable() : u.disable();
+            }
+            removeLayer(u) {
+              a(this, G).delete(u.pageIndex);
+            }
+            updateMode(u, L = null) {
+              if (a(this, v) !== u) {
+                if (oe(this, v, u), u === n.AnnotationEditorType.NONE) {
+                  this.setEditingState(!1), K(this, Te, Rn).call(this);
+                  return;
+                }
+                this.setEditingState(!0), K(this, et, kn).call(this), this.unselectAll();
+                for (const j of a(this, G).values())
+                  j.updateMode(u);
+                if (L) {
+                  for (const j of a(this, X).values())
+                    if (j.annotationElementId === L) {
+                      this.setSelected(j), j.enterInEditMode();
+                      break;
+                    }
+                }
+              }
+            }
+            updateToolbar(u) {
+              u !== a(this, v) && this._eventBus.dispatch("switchannotationeditormode", {
+                source: this,
+                mode: u
+              });
+            }
+            updateParams(u, L) {
+              if (a(this, pe)) {
+                if (u === n.AnnotationEditorParamsType.CREATE) {
+                  this.currentLayer.addNewEditor(u);
+                  return;
+                }
+                for (const j of a(this, A))
+                  j.updateParams(u, L);
+                for (const j of a(this, pe))
+                  j.updateDefaultParams(u, L);
+              }
+            }
+            enableWaiting(u = !1) {
+              if (a(this, g) !== u) {
+                oe(this, g, u);
+                for (const L of a(this, G).values())
+                  u ? L.disableClick() : L.enableClick(), L.div.classList.toggle("waiting", u);
+              }
+            }
+            getEditors(u) {
+              const L = [];
+              for (const j of a(this, X).values())
+                j.pageIndex === u && L.push(j);
+              return L;
+            }
+            getEditor(u) {
+              return a(this, X).get(u);
+            }
+            addEditor(u) {
+              a(this, X).set(u.id, u);
+            }
+            removeEditor(u) {
+              var L;
+              a(this, X).delete(u.id), this.unselect(u), (!u.annotationElementId || !a(this, q).has(u.annotationElementId)) && ((L = a(this, B)) == null || L.remove(u.id));
+            }
+            addDeletedAnnotationElement(u) {
+              a(this, q).add(u.annotationElementId), u.deleted = !0;
+            }
+            isDeletedAnnotationElement(u) {
+              return a(this, q).has(u);
+            }
+            removeDeletedAnnotationElement(u) {
+              a(this, q).delete(u.annotationElementId), u.deleted = !1;
+            }
+            setActiveEditor(u) {
+              a(this, D) !== u && (oe(this, D, u), u && K(this, Se, mt).call(this, u.propertiesToUpdate));
+            }
+            toggleSelected(u) {
+              if (a(this, A).has(u)) {
+                a(this, A).delete(u), u.unselect(), K(this, J, at).call(this, {
+                  hasSelectedEditor: this.hasSelection
+                });
+                return;
+              }
+              a(this, A).add(u), u.select(), K(this, Se, mt).call(this, u.propertiesToUpdate), K(this, J, at).call(this, {
+                hasSelectedEditor: !0
+              });
+            }
+            setSelected(u) {
+              for (const L of a(this, A))
+                L !== u && L.unselect();
+              a(this, A).clear(), a(this, A).add(u), u.select(), K(this, Se, mt).call(this, u.propertiesToUpdate), K(this, J, at).call(this, {
+                hasSelectedEditor: !0
+              });
+            }
+            isSelected(u) {
+              return a(this, A).has(u);
+            }
+            unselect(u) {
+              u.unselect(), a(this, A).delete(u), K(this, J, at).call(this, {
+                hasSelectedEditor: this.hasSelection
+              });
+            }
+            get hasSelection() {
+              return a(this, A).size !== 0;
+            }
+            undo() {
+              a(this, ee).undo(), K(this, J, at).call(this, {
+                hasSomethingToUndo: a(this, ee).hasSomethingToUndo(),
+                hasSomethingToRedo: !0,
+                isEmpty: K(this, Be, bt).call(this)
+              });
+            }
+            redo() {
+              a(this, ee).redo(), K(this, J, at).call(this, {
+                hasSomethingToUndo: !0,
+                hasSomethingToRedo: a(this, ee).hasSomethingToRedo(),
+                isEmpty: K(this, Be, bt).call(this)
+              });
+            }
+            addCommands(u) {
+              a(this, ee).add(u), K(this, J, at).call(this, {
+                hasSomethingToUndo: !0,
+                hasSomethingToRedo: !1,
+                isEmpty: K(this, Be, bt).call(this)
+              });
+            }
+            delete() {
+              if (this.commitOrRemove(), !this.hasSelection)
+                return;
+              const u = [...a(this, A)], L = () => {
+                for (const V of u)
+                  V.remove();
+              }, j = () => {
+                for (const V of u)
+                  K(this, ke, Kt).call(this, V);
+              };
+              this.addCommands({
+                cmd: L,
+                undo: j,
+                mustExec: !0
+              });
+            }
+            commitOrRemove() {
+              var u;
+              (u = a(this, D)) == null || u.commitOrRemove();
+            }
+            hasSomethingToControl() {
+              return a(this, D) || this.hasSelection;
+            }
+            selectAll() {
+              for (const u of a(this, A))
+                u.commit();
+              K(this, Ae, Jt).call(this, a(this, X).values());
+            }
+            unselectAll() {
+              if (a(this, D)) {
+                a(this, D).commitOrRemove();
+                return;
+              }
+              if (this.hasSelection) {
+                for (const u of a(this, A))
+                  u.unselect();
+                a(this, A).clear(), K(this, J, at).call(this, {
+                  hasSelectedEditor: !1
+                });
+              }
+            }
+            translateSelectedEditors(u, L, j = !1) {
+              if (j || this.commitOrRemove(), !this.hasSelection)
+                return;
+              a(this, De)[0] += u, a(this, De)[1] += L;
+              const [V, Z] = a(this, De), he = [...a(this, A)], ye = 1e3;
+              a(this, _e) && clearTimeout(a(this, _e)), oe(this, _e, setTimeout(() => {
+                oe(this, _e, null), a(this, De)[0] = a(this, De)[1] = 0, this.addCommands({
+                  cmd: () => {
+                    for (const Me of he)
+                      a(this, X).has(Me.id) && Me.translateInPage(V, Z);
+                  },
+                  undo: () => {
+                    for (const Me of he)
+                      a(this, X).has(Me.id) && Me.translateInPage(-V, -Z);
+                  },
+                  mustExec: !1
+                });
+              }, ye));
+              for (const Me of he)
+                Me.translateInPage(u, L);
+            }
+            setUpDragSession() {
+              if (this.hasSelection) {
+                this.disableUserSelect(!0), oe(this, le, /* @__PURE__ */ new Map());
+                for (const u of a(this, A))
+                  a(this, le).set(u, {
+                    savedX: u.x,
+                    savedY: u.y,
+                    savedPageIndex: u.pageIndex,
+                    newX: 0,
+                    newY: 0,
+                    newPageIndex: -1
+                  });
+              }
+            }
+            endDragSession() {
+              if (!a(this, le))
+                return !1;
+              this.disableUserSelect(!1);
+              const u = a(this, le);
+              oe(this, le, null);
+              let L = !1;
+              for (const [{
+                x: V,
+                y: Z,
+                pageIndex: he
+              }, ye] of u)
+                ye.newX = V, ye.newY = Z, ye.newPageIndex = he, L || (L = V !== ye.savedX || Z !== ye.savedY || he !== ye.savedPageIndex);
+              if (!L)
+                return !1;
+              const j = (V, Z, he, ye) => {
+                if (a(this, X).has(V.id)) {
+                  const Me = a(this, G).get(ye);
+                  Me ? V._setParentAndPosition(Me, Z, he) : (V.pageIndex = ye, V.x = Z, V.y = he);
+                }
+              };
+              return this.addCommands({
+                cmd: () => {
+                  for (const [V, {
+                    newX: Z,
+                    newY: he,
+                    newPageIndex: ye
+                  }] of u)
+                    j(V, Z, he, ye);
+                },
+                undo: () => {
+                  for (const [V, {
+                    savedX: Z,
+                    savedY: he,
+                    savedPageIndex: ye
+                  }] of u)
+                    j(V, Z, he, ye);
+                },
+                mustExec: !0
+              }), !0;
+            }
+            dragSelectedEditors(u, L) {
+              if (a(this, le))
+                for (const j of a(this, le).keys())
+                  j.drag(u, L);
+            }
+            rebuild(u) {
+              if (u.parent === null) {
+                const L = this.getLayer(u.pageIndex);
+                L ? (L.changeParent(u), L.addOrRebuild(u)) : (this.addEditor(u), this.addToAnnotationStorage(u), u.rebuild());
+              } else
+                u.parent.addOrRebuild(u);
+            }
+            isActive(u) {
+              return a(this, D) === u;
+            }
+            getActive() {
+              return a(this, D);
+            }
+            getMode() {
+              return a(this, v);
+            }
+            get imageManager() {
+              return (0, n.shadow)(this, "imageManager", new c());
+            }
+          };
+          D = new WeakMap(), X = new WeakMap(), G = new WeakMap(), I = new WeakMap(), B = new WeakMap(), ee = new WeakMap(), Y = new WeakMap(), q = new WeakMap(), le = new WeakMap(), pe = new WeakMap(), we = new WeakMap(), be = new WeakMap(), R = new WeakMap(), d = new WeakMap(), g = new WeakMap(), f = new WeakMap(), v = new WeakMap(), A = new WeakMap(), O = new WeakMap(), H = new WeakMap(), z = new WeakMap(), ae = new WeakMap(), Q = new WeakMap(), ce = new WeakMap(), ue = new WeakMap(), me = new WeakMap(), fe = new WeakMap(), Pe = new WeakMap(), Fe = new WeakMap(), Ee = new WeakMap(), De = new WeakMap(), _e = new WeakMap(), ie = new WeakMap(), se = new WeakMap(), ge = new WeakSet(), xn = function() {
+            window.addEventListener("focus", a(this, z)), window.addEventListener("blur", a(this, H));
+          }, xe = new WeakSet(), zt = function() {
+            window.removeEventListener("focus", a(this, z)), window.removeEventListener("blur", a(this, H));
+          }, We = new WeakSet(), Xt = function() {
+            window.addEventListener("keydown", a(this, ue), {
+              capture: !0
+            });
+          }, ze = new WeakSet(), Ct = function() {
+            window.removeEventListener("keydown", a(this, ue), {
+              capture: !0
+            });
+          }, Ge = new WeakSet(), Vt = function() {
+            document.addEventListener("copy", a(this, ae)), document.addEventListener("cut", a(this, Q)), document.addEventListener("paste", a(this, ce));
+          }, de = new WeakSet(), Yt = function() {
+            document.removeEventListener("copy", a(this, ae)), document.removeEventListener("cut", a(this, Q)), document.removeEventListener("paste", a(this, ce));
+          }, J = new WeakSet(), at = function(u) {
+            Object.entries(u).some(([j, V]) => a(this, Ee)[j] !== V) && this._eventBus.dispatch("annotationeditorstateschanged", {
+              source: this,
+              details: Object.assign(a(this, Ee), u)
+            });
+          }, Se = new WeakSet(), mt = function(u) {
+            this._eventBus.dispatch("annotationeditorparamschanged", {
+              source: this,
+              details: u
+            });
+          }, et = new WeakSet(), kn = function() {
+            if (!a(this, d)) {
+              oe(this, d, !0);
+              for (const u of a(this, G).values())
+                u.enable();
+            }
+          }, Te = new WeakSet(), Rn = function() {
+            if (this.unselectAll(), a(this, d)) {
+              oe(this, d, !1);
+              for (const u of a(this, G).values())
+                u.disable();
+            }
+          }, ke = new WeakSet(), Kt = function(u) {
+            const L = a(this, G).get(u.pageIndex);
+            L ? L.addOrRebuild(u) : this.addEditor(u);
+          }, Be = new WeakSet(), bt = function() {
+            if (a(this, X).size === 0)
+              return !0;
+            if (a(this, X).size === 1)
+              for (const u of a(this, X).values())
+                return u.isEmpty();
+            return !1;
+          }, Ae = new WeakSet(), Jt = function(u) {
+            a(this, A).clear();
+            for (const L of u)
+              L.isEmpty() || (a(this, A).add(L), L.select());
+            K(this, J, at).call(this, {
+              hasSelectedEditor: !0
+            });
+          }, nt(Oe, "TRANSLATE_SMALL", 1), nt(Oe, "TRANSLATE_BIG", 10);
+          let S = Oe;
+          e.AnnotationEditorUIManager = S;
+        },
+        /* 6 */
+        /***/
+        (t, e, i) => {
+          var Y, q, le, pe, we, be, R, d, g, f, v, A, dt, H, ft, ae, Qt, ce, Pt, me, xt, Pe, yt, Ee, vt;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.StatTimer = e.RenderingCancelledException = e.PixelsPerInch = e.PageViewport = e.PDFDateString = e.DOMStandardFontDataFactory = e.DOMSVGFactory = e.DOMFilterFactory = e.DOMCanvasFactory = e.DOMCMapReaderFactory = void 0, e.deprecated = $, e.getColorValues = X, e.getCurrentTransform = G, e.getCurrentTransformInverse = I, e.getFilenameFromUrl = k, e.getPdfFilenameFromUrl = F, e.getRGB = D, e.getXfaPageViewport = N, e.isDataScheme = P, e.isPdfFile = b, e.isValidFetchUrl = y, e.loadScript = E, e.noContextMenu = p, e.setLayerDimensions = B;
+          var n = i(7), s = i(1);
+          const l = "http://www.w3.org/2000/svg", ee = class ee {
+          };
+          nt(ee, "CSS", 96), nt(ee, "PDF", 72), nt(ee, "PDF_TO_CSS_UNITS", ee.CSS / ee.PDF);
+          let h = ee;
+          e.PixelsPerInch = h;
+          class _ extends n.BaseFilterFactory {
+            constructor({
+              docId: se,
+              ownerDocument: ge = globalThis.document
+            } = {}) {
+              super();
+              W(this, A);
+              W(this, H);
+              W(this, ae);
+              W(this, ce);
+              W(this, me);
+              W(this, Pe);
+              W(this, Ee);
+              W(this, Y, void 0);
+              W(this, q, void 0);
+              W(this, le, void 0);
+              W(this, pe, void 0);
+              W(this, we, void 0);
+              W(this, be, void 0);
+              W(this, R, void 0);
+              W(this, d, void 0);
+              W(this, g, void 0);
+              W(this, f, void 0);
+              W(this, v, 0);
+              oe(this, le, se), oe(this, pe, ge);
+            }
+            addFilter(se) {
+              if (!se)
+                return "none";
+              let ge = a(this, A, dt).get(se);
+              if (ge)
+                return ge;
+              let Ce, xe, Ue, We;
+              if (se.length === 1) {
+                const Ge = se[0], Ye = new Array(256);
+                for (let de = 0; de < 256; de++)
+                  Ye[de] = Ge[de] / 255;
+                We = Ce = xe = Ue = Ye.join(",");
+              } else {
+                const [Ge, Ye, de] = se, ne = new Array(256), J = new Array(256), ve = new Array(256);
+                for (let Se = 0; Se < 256; Se++)
+                  ne[Se] = Ge[Se] / 255, J[Se] = Ye[Se] / 255, ve[Se] = de[Se] / 255;
+                Ce = ne.join(","), xe = J.join(","), Ue = ve.join(","), We = `${Ce}${xe}${Ue}`;
+              }
+              if (ge = a(this, A, dt).get(We), ge)
+                return a(this, A, dt).set(se, ge), ge;
+              const je = `g_${a(this, le)}_transfer_map_${_t(this, v)._++}`, ze = `url(#${je})`;
+              a(this, A, dt).set(se, ze), a(this, A, dt).set(We, ze);
+              const Xe = K(this, ce, Pt).call(this, je);
+              return K(this, Pe, yt).call(this, Ce, xe, Ue, Xe), ze;
+            }
+            addHCMFilter(se, ge) {
+              var Ye;
+              const Ce = `${se}-${ge}`;
+              if (a(this, be) === Ce)
+                return a(this, R);
+              if (oe(this, be, Ce), oe(this, R, "none"), (Ye = a(this, we)) == null || Ye.remove(), !se || !ge)
+                return a(this, R);
+              const xe = K(this, Ee, vt).call(this, se);
+              se = s.Util.makeHexColor(...xe);
+              const Ue = K(this, Ee, vt).call(this, ge);
+              if (ge = s.Util.makeHexColor(...Ue), a(this, H, ft).style.color = "", se === "#000000" && ge === "#ffffff" || se === ge)
+                return a(this, R);
+              const We = new Array(256);
+              for (let de = 0; de <= 255; de++) {
+                const ne = de / 255;
+                We[de] = ne <= 0.03928 ? ne / 12.92 : ((ne + 0.055) / 1.055) ** 2.4;
+              }
+              const je = We.join(","), ze = `g_${a(this, le)}_hcm_filter`, Xe = oe(this, d, K(this, ce, Pt).call(this, ze));
+              K(this, Pe, yt).call(this, je, je, je, Xe), K(this, ae, Qt).call(this, Xe);
+              const Ge = (de, ne) => {
+                const J = xe[de] / 255, ve = Ue[de] / 255, Se = new Array(ne + 1);
+                for (let tt = 0; tt <= ne; tt++)
+                  Se[tt] = J + tt / ne * (ve - J);
+                return Se.join(",");
+              };
+              return K(this, Pe, yt).call(this, Ge(0, 5), Ge(1, 5), Ge(2, 5), Xe), oe(this, R, `url(#${ze})`), a(this, R);
+            }
+            addHighlightHCMFilter(se, ge, Ce, xe) {
+              var ve;
+              const Ue = `${se}-${ge}-${Ce}-${xe}`;
+              if (a(this, g) === Ue)
+                return a(this, f);
+              if (oe(this, g, Ue), oe(this, f, "none"), (ve = a(this, d)) == null || ve.remove(), !se || !ge)
+                return a(this, f);
+              const [We, je] = [se, ge].map(K(this, Ee, vt).bind(this));
+              let ze = Math.round(0.2126 * We[0] + 0.7152 * We[1] + 0.0722 * We[2]), Xe = Math.round(0.2126 * je[0] + 0.7152 * je[1] + 0.0722 * je[2]), [Ge, Ye] = [Ce, xe].map(K(this, Ee, vt).bind(this));
+              Xe < ze && ([ze, Xe, Ge, Ye] = [Xe, ze, Ye, Ge]), a(this, H, ft).style.color = "";
+              const de = (Se, tt, et) => {
+                const te = new Array(256), Te = (Xe - ze) / et, Ne = Se / 255, ke = (tt - Se) / (255 * et);
+                let $e = 0;
+                for (let Be = 0; Be <= et; Be++) {
+                  const Qe = Math.round(ze + Be * Te), Ae = Ne + Be * ke;
+                  for (let Ke = $e; Ke <= Qe; Ke++)
+                    te[Ke] = Ae;
+                  $e = Qe + 1;
+                }
+                for (let Be = $e; Be < 256; Be++)
+                  te[Be] = te[$e - 1];
+                return te.join(",");
+              }, ne = `g_${a(this, le)}_hcm_highlight_filter`, J = oe(this, d, K(this, ce, Pt).call(this, ne));
+              return K(this, ae, Qt).call(this, J), K(this, Pe, yt).call(this, de(Ge[0], Ye[0], 5), de(Ge[1], Ye[1], 5), de(Ge[2], Ye[2], 5), J), oe(this, f, `url(#${ne})`), a(this, f);
+            }
+            destroy(se = !1) {
+              se && (a(this, R) || a(this, f)) || (a(this, q) && (a(this, q).parentNode.parentNode.remove(), oe(this, q, null)), a(this, Y) && (a(this, Y).clear(), oe(this, Y, null)), oe(this, v, 0));
+            }
+          }
+          Y = new WeakMap(), q = new WeakMap(), le = new WeakMap(), pe = new WeakMap(), we = new WeakMap(), be = new WeakMap(), R = new WeakMap(), d = new WeakMap(), g = new WeakMap(), f = new WeakMap(), v = new WeakMap(), A = new WeakSet(), dt = function() {
+            return a(this, Y) || oe(this, Y, /* @__PURE__ */ new Map());
+          }, H = new WeakSet(), ft = function() {
+            if (!a(this, q)) {
+              const se = a(this, pe).createElement("div"), {
+                style: ge
+              } = se;
+              ge.visibility = "hidden", ge.contain = "strict", ge.width = ge.height = 0, ge.position = "absolute", ge.top = ge.left = 0, ge.zIndex = -1;
+              const Ce = a(this, pe).createElementNS(l, "svg");
+              Ce.setAttribute("width", 0), Ce.setAttribute("height", 0), oe(this, q, a(this, pe).createElementNS(l, "defs")), se.append(Ce), Ce.append(a(this, q)), a(this, pe).body.append(se);
+            }
+            return a(this, q);
+          }, ae = new WeakSet(), Qt = function(se) {
+            const ge = a(this, pe).createElementNS(l, "feColorMatrix");
+            ge.setAttribute("type", "matrix"), ge.setAttribute("values", "0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0.2126 0.7152 0.0722 0 0 0 0 0 1 0"), se.append(ge);
+          }, ce = new WeakSet(), Pt = function(se) {
+            const ge = a(this, pe).createElementNS(l, "filter");
+            return ge.setAttribute("color-interpolation-filters", "sRGB"), ge.setAttribute("id", se), a(this, H, ft).append(ge), ge;
+          }, me = new WeakSet(), xt = function(se, ge, Ce) {
+            const xe = a(this, pe).createElementNS(l, ge);
+            xe.setAttribute("type", "discrete"), xe.setAttribute("tableValues", Ce), se.append(xe);
+          }, Pe = new WeakSet(), yt = function(se, ge, Ce, xe) {
+            const Ue = a(this, pe).createElementNS(l, "feComponentTransfer");
+            xe.append(Ue), K(this, me, xt).call(this, Ue, "feFuncR", se), K(this, me, xt).call(this, Ue, "feFuncG", ge), K(this, me, xt).call(this, Ue, "feFuncB", Ce);
+          }, Ee = new WeakSet(), vt = function(se) {
+            return a(this, H, ft).style.color = se, D(getComputedStyle(a(this, H, ft)).getPropertyValue("color"));
+          }, e.DOMFilterFactory = _;
+          class c extends n.BaseCanvasFactory {
+            constructor({
+              ownerDocument: ie = globalThis.document
+            } = {}) {
+              super(), this._document = ie;
+            }
+            _createCanvas(ie, se) {
+              const ge = this._document.createElement("canvas");
+              return ge.width = ie, ge.height = se, ge;
+            }
+          }
+          e.DOMCanvasFactory = c;
+          async function o(_e, ie = !1) {
+            if (y(_e, document.baseURI)) {
+              const se = await fetch(_e);
+              if (!se.ok)
+                throw new Error(se.statusText);
+              return ie ? new Uint8Array(await se.arrayBuffer()) : (0, s.stringToBytes)(await se.text());
+            }
+            return new Promise((se, ge) => {
+              const Ce = new XMLHttpRequest();
+              Ce.open("GET", _e, !0), ie && (Ce.responseType = "arraybuffer"), Ce.onreadystatechange = () => {
+                if (Ce.readyState === XMLHttpRequest.DONE) {
+                  if (Ce.status === 200 || Ce.status === 0) {
+                    let xe;
+                    if (ie && Ce.response ? xe = new Uint8Array(Ce.response) : !ie && Ce.responseText && (xe = (0, s.stringToBytes)(Ce.responseText)), xe) {
+                      se(xe);
+                      return;
+                    }
+                  }
+                  ge(new Error(Ce.statusText));
+                }
+              }, Ce.send(null);
+            });
+          }
+          class r extends n.BaseCMapReaderFactory {
+            _fetchData(ie, se) {
+              return o(ie, this.isCompressed).then((ge) => ({
+                cMapData: ge,
+                compressionType: se
+              }));
+            }
+          }
+          e.DOMCMapReaderFactory = r;
+          class T extends n.BaseStandardFontDataFactory {
+            _fetchData(ie) {
+              return o(ie, !0);
+            }
+          }
+          e.DOMStandardFontDataFactory = T;
+          class S extends n.BaseSVGFactory {
+            _createSVG(ie) {
+              return document.createElementNS(l, ie);
+            }
+          }
+          e.DOMSVGFactory = S;
+          class w {
+            constructor({
+              viewBox: ie,
+              scale: se,
+              rotation: ge,
+              offsetX: Ce = 0,
+              offsetY: xe = 0,
+              dontFlip: Ue = !1
+            }) {
+              this.viewBox = ie, this.scale = se, this.rotation = ge, this.offsetX = Ce, this.offsetY = xe;
+              const We = (ie[2] + ie[0]) / 2, je = (ie[3] + ie[1]) / 2;
+              let ze, Xe, Ge, Ye;
+              switch (ge %= 360, ge < 0 && (ge += 360), ge) {
+                case 180:
+                  ze = -1, Xe = 0, Ge = 0, Ye = 1;
+                  break;
+                case 90:
+                  ze = 0, Xe = 1, Ge = 1, Ye = 0;
+                  break;
+                case 270:
+                  ze = 0, Xe = -1, Ge = -1, Ye = 0;
+                  break;
+                case 0:
+                  ze = 1, Xe = 0, Ge = 0, Ye = -1;
+                  break;
+                default:
+                  throw new Error("PageViewport: Invalid rotation, must be a multiple of 90 degrees.");
+              }
+              Ue && (Ge = -Ge, Ye = -Ye);
+              let de, ne, J, ve;
+              ze === 0 ? (de = Math.abs(je - ie[1]) * se + Ce, ne = Math.abs(We - ie[0]) * se + xe, J = (ie[3] - ie[1]) * se, ve = (ie[2] - ie[0]) * se) : (de = Math.abs(We - ie[0]) * se + Ce, ne = Math.abs(je - ie[1]) * se + xe, J = (ie[2] - ie[0]) * se, ve = (ie[3] - ie[1]) * se), this.transform = [ze * se, Xe * se, Ge * se, Ye * se, de - ze * se * We - Ge * se * je, ne - Xe * se * We - Ye * se * je], this.width = J, this.height = ve;
+            }
+            get rawDims() {
+              const {
+                viewBox: ie
+              } = this;
+              return (0, s.shadow)(this, "rawDims", {
+                pageWidth: ie[2] - ie[0],
+                pageHeight: ie[3] - ie[1],
+                pageX: ie[0],
+                pageY: ie[1]
+              });
+            }
+            clone({
+              scale: ie = this.scale,
+              rotation: se = this.rotation,
+              offsetX: ge = this.offsetX,
+              offsetY: Ce = this.offsetY,
+              dontFlip: xe = !1
+            } = {}) {
+              return new w({
+                viewBox: this.viewBox.slice(),
+                scale: ie,
+                rotation: se,
+                offsetX: ge,
+                offsetY: Ce,
+                dontFlip: xe
+              });
+            }
+            convertToViewportPoint(ie, se) {
+              return s.Util.applyTransform([ie, se], this.transform);
+            }
+            convertToViewportRectangle(ie) {
+              const se = s.Util.applyTransform([ie[0], ie[1]], this.transform), ge = s.Util.applyTransform([ie[2], ie[3]], this.transform);
+              return [se[0], se[1], ge[0], ge[1]];
+            }
+            convertToPdfPoint(ie, se) {
+              return s.Util.applyInverseTransform([ie, se], this.transform);
+            }
+          }
+          e.PageViewport = w;
+          class C extends s.BaseException {
+            constructor(ie, se = 0) {
+              super(ie, "RenderingCancelledException"), this.extraDelay = se;
+            }
+          }
+          e.RenderingCancelledException = C;
+          function P(_e) {
+            const ie = _e.length;
+            let se = 0;
+            for (; se < ie && _e[se].trim() === ""; )
+              se++;
+            return _e.substring(se, se + 5).toLowerCase() === "data:";
+          }
+          function b(_e) {
+            return typeof _e == "string" && /\.pdf$/i.test(_e);
+          }
+          function k(_e, ie = !1) {
+            return ie || ([_e] = _e.split(/[#?]/, 1)), _e.substring(_e.lastIndexOf("/") + 1);
+          }
+          function F(_e, ie = "document.pdf") {
+            if (typeof _e != "string")
+              return ie;
+            if (P(_e))
+              return (0, s.warn)('getPdfFilenameFromUrl: ignore "data:"-URL for performance reasons.'), ie;
+            const se = /^(?:(?:[^:]+:)?\/\/[^/]+)?([^?#]*)(\?[^#]*)?(#.*)?$/, ge = /[^/?#=]+\.pdf\b(?!.*\.pdf\b)/i, Ce = se.exec(_e);
+            let xe = ge.exec(Ce[1]) || ge.exec(Ce[2]) || ge.exec(Ce[3]);
+            if (xe && (xe = xe[0], xe.includes("%")))
+              try {
+                xe = ge.exec(decodeURIComponent(xe))[0];
+              } catch {
+              }
+            return xe || ie;
+          }
+          class x {
+            constructor() {
+              nt(this, "started", /* @__PURE__ */ Object.create(null));
+              nt(this, "times", []);
+            }
+            time(ie) {
+              ie in this.started && (0, s.warn)(`Timer is already running for ${ie}`), this.started[ie] = Date.now();
+            }
+            timeEnd(ie) {
+              ie in this.started || (0, s.warn)(`Timer has not been started for ${ie}`), this.times.push({
+                name: ie,
+                start: this.started[ie],
+                end: Date.now()
+              }), delete this.started[ie];
+            }
+            toString() {
+              const ie = [];
+              let se = 0;
+              for (const {
+                name: ge
+              } of this.times)
+                se = Math.max(ge.length, se);
+              for (const {
+                name: ge,
+                start: Ce,
+                end: xe
+              } of this.times)
+                ie.push(`${ge.padEnd(se)} ${xe - Ce}ms
+`);
+              return ie.join("");
+            }
+          }
+          e.StatTimer = x;
+          function y(_e, ie) {
+            try {
+              const {
+                protocol: se
+              } = ie ? new URL(_e, ie) : new URL(_e);
+              return se === "http:" || se === "https:";
+            } catch {
+              return !1;
+            }
+          }
+          function p(_e) {
+            _e.preventDefault();
+          }
+          function E(_e, ie = !1) {
+            return new Promise((se, ge) => {
+              const Ce = document.createElement("script");
+              Ce.src = _e, Ce.onload = function(xe) {
+                ie && Ce.remove(), se(xe);
+              }, Ce.onerror = function() {
+                ge(new Error(`Cannot load script at: ${Ce.src}`));
+              }, (document.head || document.documentElement).append(Ce);
+            });
+          }
+          function $(_e) {
+            console.log("Deprecated API usage: " + _e);
+          }
+          let M;
+          class m {
+            static toDateObject(ie) {
+              if (!ie || typeof ie != "string")
+                return null;
+              M || (M = new RegExp("^D:(\\d{4})(\\d{2})?(\\d{2})?(\\d{2})?(\\d{2})?(\\d{2})?([Z|+|-])?(\\d{2})?'?(\\d{2})?'?"));
+              const se = M.exec(ie);
+              if (!se)
+                return null;
+              const ge = parseInt(se[1], 10);
+              let Ce = parseInt(se[2], 10);
+              Ce = Ce >= 1 && Ce <= 12 ? Ce - 1 : 0;
+              let xe = parseInt(se[3], 10);
+              xe = xe >= 1 && xe <= 31 ? xe : 1;
+              let Ue = parseInt(se[4], 10);
+              Ue = Ue >= 0 && Ue <= 23 ? Ue : 0;
+              let We = parseInt(se[5], 10);
+              We = We >= 0 && We <= 59 ? We : 0;
+              let je = parseInt(se[6], 10);
+              je = je >= 0 && je <= 59 ? je : 0;
+              const ze = se[7] || "Z";
+              let Xe = parseInt(se[8], 10);
+              Xe = Xe >= 0 && Xe <= 23 ? Xe : 0;
+              let Ge = parseInt(se[9], 10) || 0;
+              return Ge = Ge >= 0 && Ge <= 59 ? Ge : 0, ze === "-" ? (Ue += Xe, We += Ge) : ze === "+" && (Ue -= Xe, We -= Ge), new Date(Date.UTC(ge, Ce, xe, Ue, We, je));
+            }
+          }
+          e.PDFDateString = m;
+          function N(_e, {
+            scale: ie = 1,
+            rotation: se = 0
+          }) {
+            const {
+              width: ge,
+              height: Ce
+            } = _e.attributes.style, xe = [0, 0, parseInt(ge), parseInt(Ce)];
+            return new w({
+              viewBox: xe,
+              scale: ie,
+              rotation: se
+            });
+          }
+          function D(_e) {
+            if (_e.startsWith("#")) {
+              const ie = parseInt(_e.slice(1), 16);
+              return [(ie & 16711680) >> 16, (ie & 65280) >> 8, ie & 255];
+            }
+            return _e.startsWith("rgb(") ? _e.slice(4, -1).split(",").map((ie) => parseInt(ie)) : _e.startsWith("rgba(") ? _e.slice(5, -1).split(",").map((ie) => parseInt(ie)).slice(0, 3) : ((0, s.warn)(`Not a valid color format: "${_e}"`), [0, 0, 0]);
+          }
+          function X(_e) {
+            const ie = document.createElement("span");
+            ie.style.visibility = "hidden", document.body.append(ie);
+            for (const se of _e.keys()) {
+              ie.style.color = se;
+              const ge = window.getComputedStyle(ie).color;
+              _e.set(se, D(ge));
+            }
+            ie.remove();
+          }
+          function G(_e) {
+            const {
+              a: ie,
+              b: se,
+              c: ge,
+              d: Ce,
+              e: xe,
+              f: Ue
+            } = _e.getTransform();
+            return [ie, se, ge, Ce, xe, Ue];
+          }
+          function I(_e) {
+            const {
+              a: ie,
+              b: se,
+              c: ge,
+              d: Ce,
+              e: xe,
+              f: Ue
+            } = _e.getTransform().invertSelf();
+            return [ie, se, ge, Ce, xe, Ue];
+          }
+          function B(_e, ie, se = !1, ge = !0) {
+            if (ie instanceof w) {
+              const {
+                pageWidth: Ce,
+                pageHeight: xe
+              } = ie.rawDims, {
+                style: Ue
+              } = _e, We = s.FeatureTest.isCSSRoundSupported, je = `var(--scale-factor) * ${Ce}px`, ze = `var(--scale-factor) * ${xe}px`, Xe = We ? `round(${je}, 1px)` : `calc(${je})`, Ge = We ? `round(${ze}, 1px)` : `calc(${ze})`;
+              !se || ie.rotation % 180 === 0 ? (Ue.width = Xe, Ue.height = Ge) : (Ue.width = Ge, Ue.height = Xe);
+            }
+            ge && _e.setAttribute("data-main-rotation", ie.rotation);
+          }
+        },
+        /* 7 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.BaseStandardFontDataFactory = e.BaseSVGFactory = e.BaseFilterFactory = e.BaseCanvasFactory = e.BaseCMapReaderFactory = void 0;
+          var n = i(1);
+          class s {
+            constructor() {
+              this.constructor === s && (0, n.unreachable)("Cannot initialize BaseFilterFactory.");
+            }
+            addFilter(r) {
+              return "none";
+            }
+            addHCMFilter(r, T) {
+              return "none";
+            }
+            addHighlightHCMFilter(r, T, S, w) {
+              return "none";
+            }
+            destroy(r = !1) {
+            }
+          }
+          e.BaseFilterFactory = s;
+          class l {
+            constructor() {
+              this.constructor === l && (0, n.unreachable)("Cannot initialize BaseCanvasFactory.");
+            }
+            create(r, T) {
+              if (r <= 0 || T <= 0)
+                throw new Error("Invalid canvas size");
+              const S = this._createCanvas(r, T);
+              return {
+                canvas: S,
+                context: S.getContext("2d")
+              };
+            }
+            reset(r, T, S) {
+              if (!r.canvas)
+                throw new Error("Canvas is not specified");
+              if (T <= 0 || S <= 0)
+                throw new Error("Invalid canvas size");
+              r.canvas.width = T, r.canvas.height = S;
+            }
+            destroy(r) {
+              if (!r.canvas)
+                throw new Error("Canvas is not specified");
+              r.canvas.width = 0, r.canvas.height = 0, r.canvas = null, r.context = null;
+            }
+            _createCanvas(r, T) {
+              (0, n.unreachable)("Abstract method `_createCanvas` called.");
+            }
+          }
+          e.BaseCanvasFactory = l;
+          class h {
+            constructor({
+              baseUrl: r = null,
+              isCompressed: T = !0
+            }) {
+              this.constructor === h && (0, n.unreachable)("Cannot initialize BaseCMapReaderFactory."), this.baseUrl = r, this.isCompressed = T;
+            }
+            async fetch({
+              name: r
+            }) {
+              if (!this.baseUrl)
+                throw new Error('The CMap "baseUrl" parameter must be specified, ensure that the "cMapUrl" and "cMapPacked" API parameters are provided.');
+              if (!r)
+                throw new Error("CMap name must be specified.");
+              const T = this.baseUrl + r + (this.isCompressed ? ".bcmap" : ""), S = this.isCompressed ? n.CMapCompressionType.BINARY : n.CMapCompressionType.NONE;
+              return this._fetchData(T, S).catch((w) => {
+                throw new Error(`Unable to load ${this.isCompressed ? "binary " : ""}CMap at: ${T}`);
+              });
+            }
+            _fetchData(r, T) {
+              (0, n.unreachable)("Abstract method `_fetchData` called.");
+            }
+          }
+          e.BaseCMapReaderFactory = h;
+          class _ {
+            constructor({
+              baseUrl: r = null
+            }) {
+              this.constructor === _ && (0, n.unreachable)("Cannot initialize BaseStandardFontDataFactory."), this.baseUrl = r;
+            }
+            async fetch({
+              filename: r
+            }) {
+              if (!this.baseUrl)
+                throw new Error('The standard font "baseUrl" parameter must be specified, ensure that the "standardFontDataUrl" API parameter is provided.');
+              if (!r)
+                throw new Error("Font filename must be specified.");
+              const T = `${this.baseUrl}${r}`;
+              return this._fetchData(T).catch((S) => {
+                throw new Error(`Unable to load font data at: ${T}`);
+              });
+            }
+            _fetchData(r) {
+              (0, n.unreachable)("Abstract method `_fetchData` called.");
+            }
+          }
+          e.BaseStandardFontDataFactory = _;
+          class c {
+            constructor() {
+              this.constructor === c && (0, n.unreachable)("Cannot initialize BaseSVGFactory.");
+            }
+            create(r, T, S = !1) {
+              if (r <= 0 || T <= 0)
+                throw new Error("Invalid SVG dimensions");
+              const w = this._createSVG("svg:svg");
+              return w.setAttribute("version", "1.1"), S || (w.setAttribute("width", `${r}px`), w.setAttribute("height", `${T}px`)), w.setAttribute("preserveAspectRatio", "none"), w.setAttribute("viewBox", `0 0 ${r} ${T}`), w;
+            }
+            createElement(r) {
+              if (typeof r != "string")
+                throw new Error("Invalid SVG element type");
+              return this._createSVG(r);
+            }
+            _createSVG(r) {
+              (0, n.unreachable)("Abstract method `_createSVG` called.");
+            }
+          }
+          e.BaseSVGFactory = c;
+        },
+        /* 8 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.MurmurHash3_64 = void 0;
+          var n = i(1);
+          const s = 3285377520, l = 4294901760, h = 65535;
+          class _ {
+            constructor(o) {
+              this.h1 = o ? o & 4294967295 : s, this.h2 = o ? o & 4294967295 : s;
+            }
+            update(o) {
+              let r, T;
+              if (typeof o == "string") {
+                r = new Uint8Array(o.length * 2), T = 0;
+                for (let $ = 0, M = o.length; $ < M; $++) {
+                  const m = o.charCodeAt($);
+                  m <= 255 ? r[T++] = m : (r[T++] = m >>> 8, r[T++] = m & 255);
+                }
+              } else if ((0, n.isArrayBuffer)(o))
+                r = o.slice(), T = r.byteLength;
+              else
+                throw new Error("Wrong data format in MurmurHash3_64_update. Input must be a string or array.");
+              const S = T >> 2, w = T - S * 4, C = new Uint32Array(r.buffer, 0, S);
+              let P = 0, b = 0, k = this.h1, F = this.h2;
+              const x = 3432918353, y = 461845907, p = x & h, E = y & h;
+              for (let $ = 0; $ < S; $++)
+                $ & 1 ? (P = C[$], P = P * x & l | P * p & h, P = P << 15 | P >>> 17, P = P * y & l | P * E & h, k ^= P, k = k << 13 | k >>> 19, k = k * 5 + 3864292196) : (b = C[$], b = b * x & l | b * p & h, b = b << 15 | b >>> 17, b = b * y & l | b * E & h, F ^= b, F = F << 13 | F >>> 19, F = F * 5 + 3864292196);
+              switch (P = 0, w) {
+                case 3:
+                  P ^= r[S * 4 + 2] << 16;
+                case 2:
+                  P ^= r[S * 4 + 1] << 8;
+                case 1:
+                  P ^= r[S * 4], P = P * x & l | P * p & h, P = P << 15 | P >>> 17, P = P * y & l | P * E & h, S & 1 ? k ^= P : F ^= P;
+              }
+              this.h1 = k, this.h2 = F;
+            }
+            hexdigest() {
+              let o = this.h1, r = this.h2;
+              return o ^= r >>> 1, o = o * 3981806797 & l | o * 36045 & h, r = r * 4283543511 & l | ((r << 16 | o >>> 16) * 2950163797 & l) >>> 16, o ^= r >>> 1, o = o * 444984403 & l | o * 60499 & h, r = r * 3301882366 & l | ((r << 16 | o >>> 16) * 3120437893 & l) >>> 16, o ^= r >>> 1, (o >>> 0).toString(16).padStart(8, "0") + (r >>> 0).toString(16).padStart(8, "0");
+            }
+          }
+          e.MurmurHash3_64 = _;
+        },
+        /* 9 */
+        /***/
+        (t, e, i) => {
+          var h;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.FontLoader = e.FontFaceObject = void 0;
+          var n = i(1);
+          class s {
+            constructor({
+              ownerDocument: c = globalThis.document,
+              styleElement: o = null
+            }) {
+              W(this, h, /* @__PURE__ */ new Set());
+              this._document = c, this.nativeFontFaces = /* @__PURE__ */ new Set(), this.styleElement = null, this.loadingRequests = [], this.loadTestFontId = 0;
+            }
+            addNativeFontFace(c) {
+              this.nativeFontFaces.add(c), this._document.fonts.add(c);
+            }
+            removeNativeFontFace(c) {
+              this.nativeFontFaces.delete(c), this._document.fonts.delete(c);
+            }
+            insertRule(c) {
+              this.styleElement || (this.styleElement = this._document.createElement("style"), this._document.documentElement.getElementsByTagName("head")[0].append(this.styleElement));
+              const o = this.styleElement.sheet;
+              o.insertRule(c, o.cssRules.length);
+            }
+            clear() {
+              for (const c of this.nativeFontFaces)
+                this._document.fonts.delete(c);
+              this.nativeFontFaces.clear(), a(this, h).clear(), this.styleElement && (this.styleElement.remove(), this.styleElement = null);
+            }
+            async loadSystemFont(c) {
+              if (!(!c || a(this, h).has(c.loadedName))) {
+                if ((0, n.assert)(!this.disableFontFace, "loadSystemFont shouldn't be called when `disableFontFace` is set."), this.isFontLoadingAPISupported) {
+                  const {
+                    loadedName: o,
+                    src: r,
+                    style: T
+                  } = c, S = new FontFace(o, r, T);
+                  this.addNativeFontFace(S);
+                  try {
+                    await S.load(), a(this, h).add(o);
+                  } catch {
+                    (0, n.warn)(`Cannot load system font: ${c.baseFontName}, installing it could help to improve PDF rendering.`), this.removeNativeFontFace(S);
+                  }
+                  return;
+                }
+                (0, n.unreachable)("Not implemented: loadSystemFont without the Font Loading API.");
+              }
+            }
+            async bind(c) {
+              if (c.attached || c.missingFile && !c.systemFontInfo)
+                return;
+              if (c.attached = !0, c.systemFontInfo) {
+                await this.loadSystemFont(c.systemFontInfo);
+                return;
+              }
+              if (this.isFontLoadingAPISupported) {
+                const r = c.createNativeFontFace();
+                if (r) {
+                  this.addNativeFontFace(r);
+                  try {
+                    await r.loaded;
+                  } catch (T) {
+                    throw (0, n.warn)(`Failed to load font '${r.family}': '${T}'.`), c.disableFontFace = !0, T;
+                  }
+                }
+                return;
+              }
+              const o = c.createFontFaceRule();
+              if (o) {
+                if (this.insertRule(o), this.isSyncFontLoadingSupported)
+                  return;
+                await new Promise((r) => {
+                  const T = this._queueLoadingCallback(r);
+                  this._prepareFontLoadEvent(c, T);
+                });
+              }
+            }
+            get isFontLoadingAPISupported() {
+              var o;
+              const c = !!((o = this._document) != null && o.fonts);
+              return (0, n.shadow)(this, "isFontLoadingAPISupported", c);
+            }
+            get isSyncFontLoadingSupported() {
+              let c = !1;
+              return (n.isNodeJS || typeof navigator < "u" && /Mozilla\/5.0.*?rv:\d+.*? Gecko/.test(navigator.userAgent)) && (c = !0), (0, n.shadow)(this, "isSyncFontLoadingSupported", c);
+            }
+            _queueLoadingCallback(c) {
+              function o() {
+                for ((0, n.assert)(!T.done, "completeRequest() cannot be called twice."), T.done = !0; r.length > 0 && r[0].done; ) {
+                  const S = r.shift();
+                  setTimeout(S.callback, 0);
+                }
+              }
+              const {
+                loadingRequests: r
+              } = this, T = {
+                done: !1,
+                complete: o,
+                callback: c
+              };
+              return r.push(T), T;
+            }
+            get _loadTestFont() {
+              const c = atob("T1RUTwALAIAAAwAwQ0ZGIDHtZg4AAAOYAAAAgUZGVE1lkzZwAAAEHAAAABxHREVGABQAFQAABDgAAAAeT1MvMlYNYwkAAAEgAAAAYGNtYXABDQLUAAACNAAAAUJoZWFk/xVFDQAAALwAAAA2aGhlYQdkA+oAAAD0AAAAJGhtdHgD6AAAAAAEWAAAAAZtYXhwAAJQAAAAARgAAAAGbmFtZVjmdH4AAAGAAAAAsXBvc3T/hgAzAAADeAAAACAAAQAAAAEAALZRFsRfDzz1AAsD6AAAAADOBOTLAAAAAM4KHDwAAAAAA+gDIQAAAAgAAgAAAAAAAAABAAADIQAAAFoD6AAAAAAD6AABAAAAAAAAAAAAAAAAAAAAAQAAUAAAAgAAAAQD6AH0AAUAAAKKArwAAACMAooCvAAAAeAAMQECAAACAAYJAAAAAAAAAAAAAQAAAAAAAAAAAAAAAFBmRWQAwAAuAC4DIP84AFoDIQAAAAAAAQAAAAAAAAAAACAAIAABAAAADgCuAAEAAAAAAAAAAQAAAAEAAAAAAAEAAQAAAAEAAAAAAAIAAQAAAAEAAAAAAAMAAQAAAAEAAAAAAAQAAQAAAAEAAAAAAAUAAQAAAAEAAAAAAAYAAQAAAAMAAQQJAAAAAgABAAMAAQQJAAEAAgABAAMAAQQJAAIAAgABAAMAAQQJAAMAAgABAAMAAQQJAAQAAgABAAMAAQQJAAUAAgABAAMAAQQJAAYAAgABWABYAAAAAAAAAwAAAAMAAAAcAAEAAAAAADwAAwABAAAAHAAEACAAAAAEAAQAAQAAAC7//wAAAC7////TAAEAAAAAAAABBgAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMAAAAAAAD/gwAyAAAAAQAAAAAAAAAAAAAAAAAAAAABAAQEAAEBAQJYAAEBASH4DwD4GwHEAvgcA/gXBIwMAYuL+nz5tQXkD5j3CBLnEQACAQEBIVhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYAAABAQAADwACAQEEE/t3Dov6fAH6fAT+fPp8+nwHDosMCvm1Cvm1DAz6fBQAAAAAAAABAAAAAMmJbzEAAAAAzgTjFQAAAADOBOQpAAEAAAAAAAAADAAUAAQAAAABAAAAAgABAAAAAAAAAAAD6AAAAAAAAA==");
+              return (0, n.shadow)(this, "_loadTestFont", c);
+            }
+            _prepareFontLoadEvent(c, o) {
+              function r(D, X) {
+                return D.charCodeAt(X) << 24 | D.charCodeAt(X + 1) << 16 | D.charCodeAt(X + 2) << 8 | D.charCodeAt(X + 3) & 255;
+              }
+              function T(D, X, G, I) {
+                const B = D.substring(0, X), ee = D.substring(X + G);
+                return B + I + ee;
+              }
+              let S, w;
+              const C = this._document.createElement("canvas");
+              C.width = 1, C.height = 1;
+              const P = C.getContext("2d");
+              let b = 0;
+              function k(D, X) {
+                if (++b > 30) {
+                  (0, n.warn)("Load test font never loaded."), X();
+                  return;
+                }
+                if (P.font = "30px " + D, P.fillText(".", 0, 20), P.getImageData(0, 0, 1, 1).data[3] > 0) {
+                  X();
+                  return;
+                }
+                setTimeout(k.bind(null, D, X));
+              }
+              const F = `lt${Date.now()}${this.loadTestFontId++}`;
+              let x = this._loadTestFont;
+              x = T(x, 976, F.length, F);
+              const p = 16, E = 1482184792;
+              let $ = r(x, p);
+              for (S = 0, w = F.length - 3; S < w; S += 4)
+                $ = $ - E + r(F, S) | 0;
+              S < F.length && ($ = $ - E + r(F + "XXX", S) | 0), x = T(x, p, 4, (0, n.string32)($));
+              const M = `url(data:font/opentype;base64,${btoa(x)});`, m = `@font-face {font-family:"${F}";src:${M}}`;
+              this.insertRule(m);
+              const N = this._document.createElement("div");
+              N.style.visibility = "hidden", N.style.width = N.style.height = "10px", N.style.position = "absolute", N.style.top = N.style.left = "0px";
+              for (const D of [c.loadedName, F]) {
+                const X = this._document.createElement("span");
+                X.textContent = "Hi", X.style.fontFamily = D, N.append(X);
+              }
+              this._document.body.append(N), k(F, () => {
+                N.remove(), o.complete();
+              });
+            }
+          }
+          h = new WeakMap(), e.FontLoader = s;
+          class l {
+            constructor(c, {
+              isEvalSupported: o = !0,
+              disableFontFace: r = !1,
+              ignoreErrors: T = !1,
+              inspectFont: S = null
+            }) {
+              this.compiledGlyphs = /* @__PURE__ */ Object.create(null);
+              for (const w in c)
+                this[w] = c[w];
+              this.isEvalSupported = o !== !1, this.disableFontFace = r === !0, this.ignoreErrors = T === !0, this._inspectFont = S;
+            }
+            createNativeFontFace() {
+              var o;
+              if (!this.data || this.disableFontFace)
+                return null;
+              let c;
+              if (!this.cssFontInfo)
+                c = new FontFace(this.loadedName, this.data, {});
+              else {
+                const r = {
+                  weight: this.cssFontInfo.fontWeight
+                };
+                this.cssFontInfo.italicAngle && (r.style = `oblique ${this.cssFontInfo.italicAngle}deg`), c = new FontFace(this.cssFontInfo.fontFamily, this.data, r);
+              }
+              return (o = this._inspectFont) == null || o.call(this, this), c;
+            }
+            createFontFaceRule() {
+              var T;
+              if (!this.data || this.disableFontFace)
+                return null;
+              const c = (0, n.bytesToString)(this.data), o = `url(data:${this.mimetype};base64,${btoa(c)});`;
+              let r;
+              if (!this.cssFontInfo)
+                r = `@font-face {font-family:"${this.loadedName}";src:${o}}`;
+              else {
+                let S = `font-weight: ${this.cssFontInfo.fontWeight};`;
+                this.cssFontInfo.italicAngle && (S += `font-style: oblique ${this.cssFontInfo.italicAngle}deg;`), r = `@font-face {font-family:"${this.cssFontInfo.fontFamily}";${S}src:${o}}`;
+              }
+              return (T = this._inspectFont) == null || T.call(this, this, o), r;
+            }
+            getPathGenerator(c, o) {
+              if (this.compiledGlyphs[o] !== void 0)
+                return this.compiledGlyphs[o];
+              let r;
+              try {
+                r = c.get(this.loadedName + "_path_" + o);
+              } catch (T) {
+                if (!this.ignoreErrors)
+                  throw T;
+                return (0, n.warn)(`getPathGenerator - ignoring character: "${T}".`), this.compiledGlyphs[o] = function(S, w) {
+                };
+              }
+              if (this.isEvalSupported && n.FeatureTest.isEvalSupported) {
+                const T = [];
+                for (const S of r) {
+                  const w = S.args !== void 0 ? S.args.join(",") : "";
+                  T.push("c.", S.cmd, "(", w, `);
+`);
+                }
+                return this.compiledGlyphs[o] = new Function("c", "size", T.join(""));
+              }
+              return this.compiledGlyphs[o] = function(T, S) {
+                for (const w of r)
+                  w.cmd === "scale" && (w.args = [S, -S]), T[w.cmd].apply(T, w.args);
+              };
+            }
+          }
+          e.FontFaceObject = l;
+        },
+        /* 10 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.NodeStandardFontDataFactory = e.NodeFilterFactory = e.NodeCanvasFactory = e.NodeCMapReaderFactory = void 0;
+          var n = i(7);
+          i(1);
+          const s = function(o) {
+            return new Promise((r, T) => {
+              require$$5.readFile(o, (w, C) => {
+                if (w || !C) {
+                  T(new Error(w));
+                  return;
+                }
+                r(new Uint8Array(C));
+              });
+            });
+          };
+          class l extends n.BaseFilterFactory {
+          }
+          e.NodeFilterFactory = l;
+          class h extends n.BaseCanvasFactory {
+            _createCanvas(r, T) {
+              return require$$5.createCanvas(r, T);
+            }
+          }
+          e.NodeCanvasFactory = h;
+          class _ extends n.BaseCMapReaderFactory {
+            _fetchData(r, T) {
+              return s(r).then((S) => ({
+                cMapData: S,
+                compressionType: T
+              }));
+            }
+          }
+          e.NodeCMapReaderFactory = _;
+          class c extends n.BaseStandardFontDataFactory {
+            _fetchData(r) {
+              return s(r);
+            }
+          }
+          e.NodeStandardFontDataFactory = c;
+        },
+        /* 11 */
+        /***/
+        (t, e, i) => {
+          var q, Zt, pe, en;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.CanvasGraphics = void 0;
+          var n = i(1), s = i(6), l = i(12), h = i(13);
+          const _ = 16, c = 100, o = 4096, r = 15, T = 10, S = 1e3, w = 16;
+          function C(R, d) {
+            if (R._removeMirroring)
+              throw new Error("Context is already forwarding operations.");
+            R.__originalSave = R.save, R.__originalRestore = R.restore, R.__originalRotate = R.rotate, R.__originalScale = R.scale, R.__originalTranslate = R.translate, R.__originalTransform = R.transform, R.__originalSetTransform = R.setTransform, R.__originalResetTransform = R.resetTransform, R.__originalClip = R.clip, R.__originalMoveTo = R.moveTo, R.__originalLineTo = R.lineTo, R.__originalBezierCurveTo = R.bezierCurveTo, R.__originalRect = R.rect, R.__originalClosePath = R.closePath, R.__originalBeginPath = R.beginPath, R._removeMirroring = () => {
+              R.save = R.__originalSave, R.restore = R.__originalRestore, R.rotate = R.__originalRotate, R.scale = R.__originalScale, R.translate = R.__originalTranslate, R.transform = R.__originalTransform, R.setTransform = R.__originalSetTransform, R.resetTransform = R.__originalResetTransform, R.clip = R.__originalClip, R.moveTo = R.__originalMoveTo, R.lineTo = R.__originalLineTo, R.bezierCurveTo = R.__originalBezierCurveTo, R.rect = R.__originalRect, R.closePath = R.__originalClosePath, R.beginPath = R.__originalBeginPath, delete R._removeMirroring;
+            }, R.save = function() {
+              d.save(), this.__originalSave();
+            }, R.restore = function() {
+              d.restore(), this.__originalRestore();
+            }, R.translate = function(f, v) {
+              d.translate(f, v), this.__originalTranslate(f, v);
+            }, R.scale = function(f, v) {
+              d.scale(f, v), this.__originalScale(f, v);
+            }, R.transform = function(f, v, A, O, H, z) {
+              d.transform(f, v, A, O, H, z), this.__originalTransform(f, v, A, O, H, z);
+            }, R.setTransform = function(f, v, A, O, H, z) {
+              d.setTransform(f, v, A, O, H, z), this.__originalSetTransform(f, v, A, O, H, z);
+            }, R.resetTransform = function() {
+              d.resetTransform(), this.__originalResetTransform();
+            }, R.rotate = function(f) {
+              d.rotate(f), this.__originalRotate(f);
+            }, R.clip = function(f) {
+              d.clip(f), this.__originalClip(f);
+            }, R.moveTo = function(g, f) {
+              d.moveTo(g, f), this.__originalMoveTo(g, f);
+            }, R.lineTo = function(g, f) {
+              d.lineTo(g, f), this.__originalLineTo(g, f);
+            }, R.bezierCurveTo = function(g, f, v, A, O, H) {
+              d.bezierCurveTo(g, f, v, A, O, H), this.__originalBezierCurveTo(g, f, v, A, O, H);
+            }, R.rect = function(g, f, v, A) {
+              d.rect(g, f, v, A), this.__originalRect(g, f, v, A);
+            }, R.closePath = function() {
+              d.closePath(), this.__originalClosePath();
+            }, R.beginPath = function() {
+              d.beginPath(), this.__originalBeginPath();
+            };
+          }
+          class P {
+            constructor(d) {
+              this.canvasFactory = d, this.cache = /* @__PURE__ */ Object.create(null);
+            }
+            getCanvas(d, g, f) {
+              let v;
+              return this.cache[d] !== void 0 ? (v = this.cache[d], this.canvasFactory.reset(v, g, f)) : (v = this.canvasFactory.create(g, f), this.cache[d] = v), v;
+            }
+            delete(d) {
+              delete this.cache[d];
+            }
+            clear() {
+              for (const d in this.cache) {
+                const g = this.cache[d];
+                this.canvasFactory.destroy(g), delete this.cache[d];
+              }
+            }
+          }
+          function b(R, d, g, f, v, A, O, H, z, ae) {
+            const [Q, ce, ue, me, fe, Pe] = (0, s.getCurrentTransform)(R);
+            if (ce === 0 && ue === 0) {
+              const De = O * Q + fe, _e = Math.round(De), ie = H * me + Pe, se = Math.round(ie), ge = (O + z) * Q + fe, Ce = Math.abs(Math.round(ge) - _e) || 1, xe = (H + ae) * me + Pe, Ue = Math.abs(Math.round(xe) - se) || 1;
+              return R.setTransform(Math.sign(Q), 0, 0, Math.sign(me), _e, se), R.drawImage(d, g, f, v, A, 0, 0, Ce, Ue), R.setTransform(Q, ce, ue, me, fe, Pe), [Ce, Ue];
+            }
+            if (Q === 0 && me === 0) {
+              const De = H * ue + fe, _e = Math.round(De), ie = O * ce + Pe, se = Math.round(ie), ge = (H + ae) * ue + fe, Ce = Math.abs(Math.round(ge) - _e) || 1, xe = (O + z) * ce + Pe, Ue = Math.abs(Math.round(xe) - se) || 1;
+              return R.setTransform(0, Math.sign(ce), Math.sign(ue), 0, _e, se), R.drawImage(d, g, f, v, A, 0, 0, Ue, Ce), R.setTransform(Q, ce, ue, me, fe, Pe), [Ue, Ce];
+            }
+            R.drawImage(d, g, f, v, A, O, H, z, ae);
+            const Fe = Math.hypot(Q, ce), Ee = Math.hypot(ue, me);
+            return [Fe * z, Ee * ae];
+          }
+          function k(R) {
+            const {
+              width: d,
+              height: g
+            } = R;
+            if (d > S || g > S)
+              return null;
+            const f = 1e3, v = new Uint8Array([0, 2, 4, 0, 1, 0, 5, 4, 8, 10, 0, 8, 0, 2, 1, 0]), A = d + 1;
+            let O = new Uint8Array(A * (g + 1)), H, z, ae;
+            const Q = d + 7 & -8;
+            let ce = new Uint8Array(Q * g), ue = 0;
+            for (const Ee of R.data) {
+              let De = 128;
+              for (; De > 0; )
+                ce[ue++] = Ee & De ? 0 : 255, De >>= 1;
+            }
+            let me = 0;
+            for (ue = 0, ce[ue] !== 0 && (O[0] = 1, ++me), z = 1; z < d; z++)
+              ce[ue] !== ce[ue + 1] && (O[z] = ce[ue] ? 2 : 1, ++me), ue++;
+            for (ce[ue] !== 0 && (O[z] = 2, ++me), H = 1; H < g; H++) {
+              ue = H * Q, ae = H * A, ce[ue - Q] !== ce[ue] && (O[ae] = ce[ue] ? 1 : 8, ++me);
+              let Ee = (ce[ue] ? 4 : 0) + (ce[ue - Q] ? 8 : 0);
+              for (z = 1; z < d; z++)
+                Ee = (Ee >> 2) + (ce[ue + 1] ? 4 : 0) + (ce[ue - Q + 1] ? 8 : 0), v[Ee] && (O[ae + z] = v[Ee], ++me), ue++;
+              if (ce[ue - Q] !== ce[ue] && (O[ae + z] = ce[ue] ? 2 : 4, ++me), me > f)
+                return null;
+            }
+            for (ue = Q * (g - 1), ae = H * A, ce[ue] !== 0 && (O[ae] = 8, ++me), z = 1; z < d; z++)
+              ce[ue] !== ce[ue + 1] && (O[ae + z] = ce[ue] ? 4 : 8, ++me), ue++;
+            if (ce[ue] !== 0 && (O[ae + z] = 4, ++me), me > f)
+              return null;
+            const fe = new Int32Array([0, A, -1, 0, -A, 0, 0, 0, 1]), Pe = new Path2D();
+            for (H = 0; me && H <= g; H++) {
+              let Ee = H * A;
+              const De = Ee + d;
+              for (; Ee < De && !O[Ee]; )
+                Ee++;
+              if (Ee === De)
+                continue;
+              Pe.moveTo(Ee % A, H);
+              const _e = Ee;
+              let ie = O[Ee];
+              do {
+                const se = fe[ie];
+                do
+                  Ee += se;
+                while (!O[Ee]);
+                const ge = O[Ee];
+                ge !== 5 && ge !== 10 ? (ie = ge, O[Ee] = 0) : (ie = ge & 51 * ie >> 4, O[Ee] &= ie >> 2 | ie << 2), Pe.lineTo(Ee % A, Ee / A | 0), O[Ee] || --me;
+              } while (_e !== Ee);
+              --H;
+            }
+            return ce = null, O = null, function(Ee) {
+              Ee.save(), Ee.scale(1 / d, -1 / g), Ee.translate(0, -g), Ee.fill(Pe), Ee.beginPath(), Ee.restore();
+            };
+          }
+          class F {
+            constructor(d, g) {
+              this.alphaIsShape = !1, this.fontSize = 0, this.fontSizeScale = 1, this.textMatrix = n.IDENTITY_MATRIX, this.textMatrixScale = 1, this.fontMatrix = n.FONT_IDENTITY_MATRIX, this.leading = 0, this.x = 0, this.y = 0, this.lineX = 0, this.lineY = 0, this.charSpacing = 0, this.wordSpacing = 0, this.textHScale = 1, this.textRenderingMode = n.TextRenderingMode.FILL, this.textRise = 0, this.fillColor = "#000000", this.strokeColor = "#000000", this.patternFill = !1, this.fillAlpha = 1, this.strokeAlpha = 1, this.lineWidth = 1, this.activeSMask = null, this.transferMaps = "none", this.startNewPathAndClipBox([0, 0, d, g]);
+            }
+            clone() {
+              const d = Object.create(this);
+              return d.clipBox = this.clipBox.slice(), d;
+            }
+            setCurrentPoint(d, g) {
+              this.x = d, this.y = g;
+            }
+            updatePathMinMax(d, g, f) {
+              [g, f] = n.Util.applyTransform([g, f], d), this.minX = Math.min(this.minX, g), this.minY = Math.min(this.minY, f), this.maxX = Math.max(this.maxX, g), this.maxY = Math.max(this.maxY, f);
+            }
+            updateRectMinMax(d, g) {
+              const f = n.Util.applyTransform(g, d), v = n.Util.applyTransform(g.slice(2), d);
+              this.minX = Math.min(this.minX, f[0], v[0]), this.minY = Math.min(this.minY, f[1], v[1]), this.maxX = Math.max(this.maxX, f[0], v[0]), this.maxY = Math.max(this.maxY, f[1], v[1]);
+            }
+            updateScalingPathMinMax(d, g) {
+              n.Util.scaleMinMax(d, g), this.minX = Math.min(this.minX, g[0]), this.maxX = Math.max(this.maxX, g[1]), this.minY = Math.min(this.minY, g[2]), this.maxY = Math.max(this.maxY, g[3]);
+            }
+            updateCurvePathMinMax(d, g, f, v, A, O, H, z, ae, Q) {
+              const ce = n.Util.bezierBoundingBox(g, f, v, A, O, H, z, ae);
+              if (Q) {
+                Q[0] = Math.min(Q[0], ce[0], ce[2]), Q[1] = Math.max(Q[1], ce[0], ce[2]), Q[2] = Math.min(Q[2], ce[1], ce[3]), Q[3] = Math.max(Q[3], ce[1], ce[3]);
+                return;
+              }
+              this.updateRectMinMax(d, ce);
+            }
+            getPathBoundingBox(d = l.PathType.FILL, g = null) {
+              const f = [this.minX, this.minY, this.maxX, this.maxY];
+              if (d === l.PathType.STROKE) {
+                g || (0, n.unreachable)("Stroke bounding box must include transform.");
+                const v = n.Util.singularValueDecompose2dScale(g), A = v[0] * this.lineWidth / 2, O = v[1] * this.lineWidth / 2;
+                f[0] -= A, f[1] -= O, f[2] += A, f[3] += O;
+              }
+              return f;
+            }
+            updateClipFromPath() {
+              const d = n.Util.intersect(this.clipBox, this.getPathBoundingBox());
+              this.startNewPathAndClipBox(d || [0, 0, 0, 0]);
+            }
+            isEmptyClip() {
+              return this.minX === 1 / 0;
+            }
+            startNewPathAndClipBox(d) {
+              this.clipBox = d, this.minX = 1 / 0, this.minY = 1 / 0, this.maxX = 0, this.maxY = 0;
+            }
+            getClippedPathBoundingBox(d = l.PathType.FILL, g = null) {
+              return n.Util.intersect(this.clipBox, this.getPathBoundingBox(d, g));
+            }
+          }
+          function x(R, d) {
+            if (typeof ImageData < "u" && d instanceof ImageData) {
+              R.putImageData(d, 0, 0);
+              return;
+            }
+            const g = d.height, f = d.width, v = g % w, A = (g - v) / w, O = v === 0 ? A : A + 1, H = R.createImageData(f, w);
+            let z = 0, ae;
+            const Q = d.data, ce = H.data;
+            let ue, me, fe, Pe;
+            if (d.kind === n.ImageKind.GRAYSCALE_1BPP) {
+              const Fe = Q.byteLength, Ee = new Uint32Array(ce.buffer, 0, ce.byteLength >> 2), De = Ee.length, _e = f + 7 >> 3, ie = 4294967295, se = n.FeatureTest.isLittleEndian ? 4278190080 : 255;
+              for (ue = 0; ue < O; ue++) {
+                for (fe = ue < A ? w : v, ae = 0, me = 0; me < fe; me++) {
+                  const ge = Fe - z;
+                  let Ce = 0;
+                  const xe = ge > _e ? f : ge * 8 - 7, Ue = xe & -8;
+                  let We = 0, je = 0;
+                  for (; Ce < Ue; Ce += 8)
+                    je = Q[z++], Ee[ae++] = je & 128 ? ie : se, Ee[ae++] = je & 64 ? ie : se, Ee[ae++] = je & 32 ? ie : se, Ee[ae++] = je & 16 ? ie : se, Ee[ae++] = je & 8 ? ie : se, Ee[ae++] = je & 4 ? ie : se, Ee[ae++] = je & 2 ? ie : se, Ee[ae++] = je & 1 ? ie : se;
+                  for (; Ce < xe; Ce++)
+                    We === 0 && (je = Q[z++], We = 128), Ee[ae++] = je & We ? ie : se, We >>= 1;
+                }
+                for (; ae < De; )
+                  Ee[ae++] = 0;
+                R.putImageData(H, 0, ue * w);
+              }
+            } else if (d.kind === n.ImageKind.RGBA_32BPP) {
+              for (me = 0, Pe = f * w * 4, ue = 0; ue < A; ue++)
+                ce.set(Q.subarray(z, z + Pe)), z += Pe, R.putImageData(H, 0, me), me += w;
+              ue < O && (Pe = f * v * 4, ce.set(Q.subarray(z, z + Pe)), R.putImageData(H, 0, me));
+            } else if (d.kind === n.ImageKind.RGB_24BPP)
+              for (fe = w, Pe = f * fe, ue = 0; ue < O; ue++) {
+                for (ue >= A && (fe = v, Pe = f * fe), ae = 0, me = Pe; me--; )
+                  ce[ae++] = Q[z++], ce[ae++] = Q[z++], ce[ae++] = Q[z++], ce[ae++] = 255;
+                R.putImageData(H, 0, ue * w);
+              }
+            else
+              throw new Error(`bad image kind: ${d.kind}`);
+          }
+          function y(R, d) {
+            if (d.bitmap) {
+              R.drawImage(d.bitmap, 0, 0);
+              return;
+            }
+            const g = d.height, f = d.width, v = g % w, A = (g - v) / w, O = v === 0 ? A : A + 1, H = R.createImageData(f, w);
+            let z = 0;
+            const ae = d.data, Q = H.data;
+            for (let ce = 0; ce < O; ce++) {
+              const ue = ce < A ? w : v;
+              ({
+                srcPos: z
+              } = (0, h.convertBlackAndWhiteToRGBA)({
+                src: ae,
+                srcPos: z,
+                dest: Q,
+                width: f,
+                height: ue,
+                nonBlackColor: 0
+              })), R.putImageData(H, 0, ce * w);
+            }
+          }
+          function p(R, d) {
+            const g = ["strokeStyle", "fillStyle", "fillRule", "globalAlpha", "lineWidth", "lineCap", "lineJoin", "miterLimit", "globalCompositeOperation", "font", "filter"];
+            for (const f of g)
+              R[f] !== void 0 && (d[f] = R[f]);
+            R.setLineDash !== void 0 && (d.setLineDash(R.getLineDash()), d.lineDashOffset = R.lineDashOffset);
+          }
+          function E(R) {
+            if (R.strokeStyle = R.fillStyle = "#000000", R.fillRule = "nonzero", R.globalAlpha = 1, R.lineWidth = 1, R.lineCap = "butt", R.lineJoin = "miter", R.miterLimit = 10, R.globalCompositeOperation = "source-over", R.font = "10px sans-serif", R.setLineDash !== void 0 && (R.setLineDash([]), R.lineDashOffset = 0), !n.isNodeJS) {
+              const {
+                filter: d
+              } = R;
+              d !== "none" && d !== "" && (R.filter = "none");
+            }
+          }
+          function $(R, d, g, f) {
+            const v = R.length;
+            for (let A = 3; A < v; A += 4) {
+              const O = R[A];
+              if (O === 0)
+                R[A - 3] = d, R[A - 2] = g, R[A - 1] = f;
+              else if (O < 255) {
+                const H = 255 - O;
+                R[A - 3] = R[A - 3] * O + d * H >> 8, R[A - 2] = R[A - 2] * O + g * H >> 8, R[A - 1] = R[A - 1] * O + f * H >> 8;
+              }
+            }
+          }
+          function M(R, d, g) {
+            const f = R.length, v = 1 / 255;
+            for (let A = 3; A < f; A += 4) {
+              const O = g ? g[R[A]] : R[A];
+              d[A] = d[A] * O * v | 0;
+            }
+          }
+          function m(R, d, g) {
+            const f = R.length;
+            for (let v = 3; v < f; v += 4) {
+              const A = R[v - 3] * 77 + R[v - 2] * 152 + R[v - 1] * 28;
+              d[v] = g ? d[v] * g[A >> 8] >> 8 : d[v] * A >> 16;
+            }
+          }
+          function N(R, d, g, f, v, A, O, H, z, ae, Q) {
+            const ce = !!A, ue = ce ? A[0] : 0, me = ce ? A[1] : 0, fe = ce ? A[2] : 0, Pe = v === "Luminosity" ? m : M, Ee = Math.min(f, Math.ceil(1048576 / g));
+            for (let De = 0; De < f; De += Ee) {
+              const _e = Math.min(Ee, f - De), ie = R.getImageData(H - ae, De + (z - Q), g, _e), se = d.getImageData(H, De + z, g, _e);
+              ce && $(ie.data, ue, me, fe), Pe(ie.data, se.data, O), d.putImageData(se, H, De + z);
+            }
+          }
+          function D(R, d, g, f) {
+            const v = f[0], A = f[1], O = f[2] - v, H = f[3] - A;
+            O === 0 || H === 0 || (N(d.context, g, O, H, d.subtype, d.backdrop, d.transferMap, v, A, d.offsetX, d.offsetY), R.save(), R.globalAlpha = 1, R.globalCompositeOperation = "source-over", R.setTransform(1, 0, 0, 1, 0, 0), R.drawImage(g.canvas, 0, 0), R.restore());
+          }
+          function X(R, d) {
+            const g = n.Util.singularValueDecompose2dScale(R);
+            g[0] = Math.fround(g[0]), g[1] = Math.fround(g[1]);
+            const f = Math.fround((globalThis.devicePixelRatio || 1) * s.PixelsPerInch.PDF_TO_CSS_UNITS);
+            return d !== void 0 ? d : g[0] <= f || g[1] <= f;
+          }
+          const G = ["butt", "round", "square"], I = ["miter", "round", "bevel"], B = {}, ee = {}, be = class be {
+            constructor(d, g, f, v, A, {
+              optionalContentConfig: O,
+              markedContentStack: H = null
+            }, z, ae) {
+              W(this, q);
+              W(this, pe);
+              this.ctx = d, this.current = new F(this.ctx.canvas.width, this.ctx.canvas.height), this.stateStack = [], this.pendingClip = null, this.pendingEOFill = !1, this.res = null, this.xobjs = null, this.commonObjs = g, this.objs = f, this.canvasFactory = v, this.filterFactory = A, this.groupStack = [], this.processingType3 = null, this.baseTransform = null, this.baseTransformStack = [], this.groupLevel = 0, this.smaskStack = [], this.smaskCounter = 0, this.tempSMask = null, this.suspendedCtx = null, this.contentVisible = !0, this.markedContentStack = H || [], this.optionalContentConfig = O, this.cachedCanvases = new P(this.canvasFactory), this.cachedPatterns = /* @__PURE__ */ new Map(), this.annotationCanvasMap = z, this.viewportScale = 1, this.outputScaleX = 1, this.outputScaleY = 1, this.pageColors = ae, this._cachedScaleForStroking = [-1, 0], this._cachedGetSinglePixelWidth = null, this._cachedBitmapsMap = /* @__PURE__ */ new Map();
+            }
+            getObject(d, g = null) {
+              return typeof d == "string" ? d.startsWith("g_") ? this.commonObjs.get(d) : this.objs.get(d) : g;
+            }
+            beginDrawing({
+              transform: d,
+              viewport: g,
+              transparency: f = !1,
+              background: v = null
+            }) {
+              const A = this.ctx.canvas.width, O = this.ctx.canvas.height, H = this.ctx.fillStyle;
+              if (this.ctx.fillStyle = v || "#ffffff", this.ctx.fillRect(0, 0, A, O), this.ctx.fillStyle = H, f) {
+                const z = this.cachedCanvases.getCanvas("transparent", A, O);
+                this.compositeCtx = this.ctx, this.transparentCanvas = z.canvas, this.ctx = z.context, this.ctx.save(), this.ctx.transform(...(0, s.getCurrentTransform)(this.compositeCtx));
+              }
+              this.ctx.save(), E(this.ctx), d && (this.ctx.transform(...d), this.outputScaleX = d[0], this.outputScaleY = d[0]), this.ctx.transform(...g.transform), this.viewportScale = g.scale, this.baseTransform = (0, s.getCurrentTransform)(this.ctx);
+            }
+            executeOperatorList(d, g, f, v) {
+              const A = d.argsArray, O = d.fnArray;
+              let H = g || 0;
+              const z = A.length;
+              if (z === H)
+                return H;
+              const ae = z - H > T && typeof f == "function", Q = ae ? Date.now() + r : 0;
+              let ce = 0;
+              const ue = this.commonObjs, me = this.objs;
+              let fe;
+              for (; ; ) {
+                if (v !== void 0 && H === v.nextBreakPoint)
+                  return v.breakIt(H, f), H;
+                if (fe = O[H], fe !== n.OPS.dependency)
+                  this[fe].apply(this, A[H]);
+                else
+                  for (const Pe of A[H]) {
+                    const Fe = Pe.startsWith("g_") ? ue : me;
+                    if (!Fe.has(Pe))
+                      return Fe.get(Pe, f), H;
+                  }
+                if (H++, H === z)
+                  return H;
+                if (ae && ++ce > T) {
+                  if (Date.now() > Q)
+                    return f(), H;
+                  ce = 0;
+                }
+              }
+            }
+            endDrawing() {
+              K(this, q, Zt).call(this), this.cachedCanvases.clear(), this.cachedPatterns.clear();
+              for (const d of this._cachedBitmapsMap.values()) {
+                for (const g of d.values())
+                  typeof HTMLCanvasElement < "u" && g instanceof HTMLCanvasElement && (g.width = g.height = 0);
+                d.clear();
+              }
+              this._cachedBitmapsMap.clear(), K(this, pe, en).call(this);
+            }
+            _scaleImage(d, g) {
+              const f = d.width, v = d.height;
+              let A = Math.max(Math.hypot(g[0], g[1]), 1), O = Math.max(Math.hypot(g[2], g[3]), 1), H = f, z = v, ae = "prescale1", Q, ce;
+              for (; A > 2 && H > 1 || O > 2 && z > 1; ) {
+                let ue = H, me = z;
+                A > 2 && H > 1 && (ue = H >= 16384 ? Math.floor(H / 2) - 1 || 1 : Math.ceil(H / 2), A /= H / ue), O > 2 && z > 1 && (me = z >= 16384 ? Math.floor(z / 2) - 1 || 1 : Math.ceil(z) / 2, O /= z / me), Q = this.cachedCanvases.getCanvas(ae, ue, me), ce = Q.context, ce.clearRect(0, 0, ue, me), ce.drawImage(d, 0, 0, H, z, 0, 0, ue, me), d = Q.canvas, H = ue, z = me, ae = ae === "prescale1" ? "prescale2" : "prescale1";
+              }
+              return {
+                img: d,
+                paintWidth: H,
+                paintHeight: z
+              };
+            }
+            _createMaskCanvas(d) {
+              const g = this.ctx, {
+                width: f,
+                height: v
+              } = d, A = this.current.fillColor, O = this.current.patternFill, H = (0, s.getCurrentTransform)(g);
+              let z, ae, Q, ce;
+              if ((d.bitmap || d.data) && d.count > 1) {
+                const Ce = d.bitmap || d.data.buffer;
+                ae = JSON.stringify(O ? H : [H.slice(0, 4), A]), z = this._cachedBitmapsMap.get(Ce), z || (z = /* @__PURE__ */ new Map(), this._cachedBitmapsMap.set(Ce, z));
+                const xe = z.get(ae);
+                if (xe && !O) {
+                  const Ue = Math.round(Math.min(H[0], H[2]) + H[4]), We = Math.round(Math.min(H[1], H[3]) + H[5]);
+                  return {
+                    canvas: xe,
+                    offsetX: Ue,
+                    offsetY: We
+                  };
+                }
+                Q = xe;
+              }
+              Q || (ce = this.cachedCanvases.getCanvas("maskCanvas", f, v), y(ce.context, d));
+              let ue = n.Util.transform(H, [1 / f, 0, 0, -1 / v, 0, 0]);
+              ue = n.Util.transform(ue, [1, 0, 0, 1, 0, -v]);
+              const me = n.Util.applyTransform([0, 0], ue), fe = n.Util.applyTransform([f, v], ue), Pe = n.Util.normalizeRect([me[0], me[1], fe[0], fe[1]]), Fe = Math.round(Pe[2] - Pe[0]) || 1, Ee = Math.round(Pe[3] - Pe[1]) || 1, De = this.cachedCanvases.getCanvas("fillCanvas", Fe, Ee), _e = De.context, ie = Math.min(me[0], fe[0]), se = Math.min(me[1], fe[1]);
+              _e.translate(-ie, -se), _e.transform(...ue), Q || (Q = this._scaleImage(ce.canvas, (0, s.getCurrentTransformInverse)(_e)), Q = Q.img, z && O && z.set(ae, Q)), _e.imageSmoothingEnabled = X((0, s.getCurrentTransform)(_e), d.interpolate), b(_e, Q, 0, 0, Q.width, Q.height, 0, 0, f, v), _e.globalCompositeOperation = "source-in";
+              const ge = n.Util.transform((0, s.getCurrentTransformInverse)(_e), [1, 0, 0, 1, -ie, -se]);
+              return _e.fillStyle = O ? A.getPattern(g, this, ge, l.PathType.FILL) : A, _e.fillRect(0, 0, f, v), z && !O && (this.cachedCanvases.delete("fillCanvas"), z.set(ae, De.canvas)), {
+                canvas: De.canvas,
+                offsetX: Math.round(ie),
+                offsetY: Math.round(se)
+              };
+            }
+            setLineWidth(d) {
+              d !== this.current.lineWidth && (this._cachedScaleForStroking[0] = -1), this.current.lineWidth = d, this.ctx.lineWidth = d;
+            }
+            setLineCap(d) {
+              this.ctx.lineCap = G[d];
+            }
+            setLineJoin(d) {
+              this.ctx.lineJoin = I[d];
+            }
+            setMiterLimit(d) {
+              this.ctx.miterLimit = d;
+            }
+            setDash(d, g) {
+              const f = this.ctx;
+              f.setLineDash !== void 0 && (f.setLineDash(d), f.lineDashOffset = g);
+            }
+            setRenderingIntent(d) {
+            }
+            setFlatness(d) {
+            }
+            setGState(d) {
+              for (const [g, f] of d)
+                switch (g) {
+                  case "LW":
+                    this.setLineWidth(f);
+                    break;
+                  case "LC":
+                    this.setLineCap(f);
+                    break;
+                  case "LJ":
+                    this.setLineJoin(f);
+                    break;
+                  case "ML":
+                    this.setMiterLimit(f);
+                    break;
+                  case "D":
+                    this.setDash(f[0], f[1]);
+                    break;
+                  case "RI":
+                    this.setRenderingIntent(f);
+                    break;
+                  case "FL":
+                    this.setFlatness(f);
+                    break;
+                  case "Font":
+                    this.setFont(f[0], f[1]);
+                    break;
+                  case "CA":
+                    this.current.strokeAlpha = f;
+                    break;
+                  case "ca":
+                    this.current.fillAlpha = f, this.ctx.globalAlpha = f;
+                    break;
+                  case "BM":
+                    this.ctx.globalCompositeOperation = f;
+                    break;
+                  case "SMask":
+                    this.current.activeSMask = f ? this.tempSMask : null, this.tempSMask = null, this.checkSMaskState();
+                    break;
+                  case "TR":
+                    this.ctx.filter = this.current.transferMaps = this.filterFactory.addFilter(f);
+                    break;
+                }
+            }
+            get inSMaskMode() {
+              return !!this.suspendedCtx;
+            }
+            checkSMaskState() {
+              const d = this.inSMaskMode;
+              this.current.activeSMask && !d ? this.beginSMaskMode() : !this.current.activeSMask && d && this.endSMaskMode();
+            }
+            beginSMaskMode() {
+              if (this.inSMaskMode)
+                throw new Error("beginSMaskMode called while already in smask mode");
+              const d = this.ctx.canvas.width, g = this.ctx.canvas.height, f = "smaskGroupAt" + this.groupLevel, v = this.cachedCanvases.getCanvas(f, d, g);
+              this.suspendedCtx = this.ctx, this.ctx = v.context;
+              const A = this.ctx;
+              A.setTransform(...(0, s.getCurrentTransform)(this.suspendedCtx)), p(this.suspendedCtx, A), C(A, this.suspendedCtx), this.setGState([["BM", "source-over"], ["ca", 1], ["CA", 1]]);
+            }
+            endSMaskMode() {
+              if (!this.inSMaskMode)
+                throw new Error("endSMaskMode called while not in smask mode");
+              this.ctx._removeMirroring(), p(this.ctx, this.suspendedCtx), this.ctx = this.suspendedCtx, this.suspendedCtx = null;
+            }
+            compose(d) {
+              if (!this.current.activeSMask)
+                return;
+              d ? (d[0] = Math.floor(d[0]), d[1] = Math.floor(d[1]), d[2] = Math.ceil(d[2]), d[3] = Math.ceil(d[3])) : d = [0, 0, this.ctx.canvas.width, this.ctx.canvas.height];
+              const g = this.current.activeSMask, f = this.suspendedCtx;
+              D(f, g, this.ctx, d), this.ctx.save(), this.ctx.setTransform(1, 0, 0, 1, 0, 0), this.ctx.clearRect(0, 0, this.ctx.canvas.width, this.ctx.canvas.height), this.ctx.restore();
+            }
+            save() {
+              this.inSMaskMode ? (p(this.ctx, this.suspendedCtx), this.suspendedCtx.save()) : this.ctx.save();
+              const d = this.current;
+              this.stateStack.push(d), this.current = d.clone();
+            }
+            restore() {
+              this.stateStack.length === 0 && this.inSMaskMode && this.endSMaskMode(), this.stateStack.length !== 0 && (this.current = this.stateStack.pop(), this.inSMaskMode ? (this.suspendedCtx.restore(), p(this.suspendedCtx, this.ctx)) : this.ctx.restore(), this.checkSMaskState(), this.pendingClip = null, this._cachedScaleForStroking[0] = -1, this._cachedGetSinglePixelWidth = null);
+            }
+            transform(d, g, f, v, A, O) {
+              this.ctx.transform(d, g, f, v, A, O), this._cachedScaleForStroking[0] = -1, this._cachedGetSinglePixelWidth = null;
+            }
+            constructPath(d, g, f) {
+              const v = this.ctx, A = this.current;
+              let O = A.x, H = A.y, z, ae;
+              const Q = (0, s.getCurrentTransform)(v), ce = Q[0] === 0 && Q[3] === 0 || Q[1] === 0 && Q[2] === 0, ue = ce ? f.slice(0) : null;
+              for (let me = 0, fe = 0, Pe = d.length; me < Pe; me++)
+                switch (d[me] | 0) {
+                  case n.OPS.rectangle:
+                    O = g[fe++], H = g[fe++];
+                    const Fe = g[fe++], Ee = g[fe++], De = O + Fe, _e = H + Ee;
+                    v.moveTo(O, H), Fe === 0 || Ee === 0 ? v.lineTo(De, _e) : (v.lineTo(De, H), v.lineTo(De, _e), v.lineTo(O, _e)), ce || A.updateRectMinMax(Q, [O, H, De, _e]), v.closePath();
+                    break;
+                  case n.OPS.moveTo:
+                    O = g[fe++], H = g[fe++], v.moveTo(O, H), ce || A.updatePathMinMax(Q, O, H);
+                    break;
+                  case n.OPS.lineTo:
+                    O = g[fe++], H = g[fe++], v.lineTo(O, H), ce || A.updatePathMinMax(Q, O, H);
+                    break;
+                  case n.OPS.curveTo:
+                    z = O, ae = H, O = g[fe + 4], H = g[fe + 5], v.bezierCurveTo(g[fe], g[fe + 1], g[fe + 2], g[fe + 3], O, H), A.updateCurvePathMinMax(Q, z, ae, g[fe], g[fe + 1], g[fe + 2], g[fe + 3], O, H, ue), fe += 6;
+                    break;
+                  case n.OPS.curveTo2:
+                    z = O, ae = H, v.bezierCurveTo(O, H, g[fe], g[fe + 1], g[fe + 2], g[fe + 3]), A.updateCurvePathMinMax(Q, z, ae, O, H, g[fe], g[fe + 1], g[fe + 2], g[fe + 3], ue), O = g[fe + 2], H = g[fe + 3], fe += 4;
+                    break;
+                  case n.OPS.curveTo3:
+                    z = O, ae = H, O = g[fe + 2], H = g[fe + 3], v.bezierCurveTo(g[fe], g[fe + 1], O, H, O, H), A.updateCurvePathMinMax(Q, z, ae, g[fe], g[fe + 1], O, H, O, H, ue), fe += 4;
+                    break;
+                  case n.OPS.closePath:
+                    v.closePath();
+                    break;
+                }
+              ce && A.updateScalingPathMinMax(Q, ue), A.setCurrentPoint(O, H);
+            }
+            closePath() {
+              this.ctx.closePath();
+            }
+            stroke(d = !0) {
+              const g = this.ctx, f = this.current.strokeColor;
+              g.globalAlpha = this.current.strokeAlpha, this.contentVisible && (typeof f == "object" && (f != null && f.getPattern) ? (g.save(), g.strokeStyle = f.getPattern(g, this, (0, s.getCurrentTransformInverse)(g), l.PathType.STROKE), this.rescaleAndStroke(!1), g.restore()) : this.rescaleAndStroke(!0)), d && this.consumePath(this.current.getClippedPathBoundingBox()), g.globalAlpha = this.current.fillAlpha;
+            }
+            closeStroke() {
+              this.closePath(), this.stroke();
+            }
+            fill(d = !0) {
+              const g = this.ctx, f = this.current.fillColor, v = this.current.patternFill;
+              let A = !1;
+              v && (g.save(), g.fillStyle = f.getPattern(g, this, (0, s.getCurrentTransformInverse)(g), l.PathType.FILL), A = !0);
+              const O = this.current.getClippedPathBoundingBox();
+              this.contentVisible && O !== null && (this.pendingEOFill ? (g.fill("evenodd"), this.pendingEOFill = !1) : g.fill()), A && g.restore(), d && this.consumePath(O);
+            }
+            eoFill() {
+              this.pendingEOFill = !0, this.fill();
+            }
+            fillStroke() {
+              this.fill(!1), this.stroke(!1), this.consumePath();
+            }
+            eoFillStroke() {
+              this.pendingEOFill = !0, this.fillStroke();
+            }
+            closeFillStroke() {
+              this.closePath(), this.fillStroke();
+            }
+            closeEOFillStroke() {
+              this.pendingEOFill = !0, this.closePath(), this.fillStroke();
+            }
+            endPath() {
+              this.consumePath();
+            }
+            clip() {
+              this.pendingClip = B;
+            }
+            eoClip() {
+              this.pendingClip = ee;
+            }
+            beginText() {
+              this.current.textMatrix = n.IDENTITY_MATRIX, this.current.textMatrixScale = 1, this.current.x = this.current.lineX = 0, this.current.y = this.current.lineY = 0;
+            }
+            endText() {
+              const d = this.pendingTextPaths, g = this.ctx;
+              if (d === void 0) {
+                g.beginPath();
+                return;
+              }
+              g.save(), g.beginPath();
+              for (const f of d)
+                g.setTransform(...f.transform), g.translate(f.x, f.y), f.addToPath(g, f.fontSize);
+              g.restore(), g.clip(), g.beginPath(), delete this.pendingTextPaths;
+            }
+            setCharSpacing(d) {
+              this.current.charSpacing = d;
+            }
+            setWordSpacing(d) {
+              this.current.wordSpacing = d;
+            }
+            setHScale(d) {
+              this.current.textHScale = d / 100;
+            }
+            setLeading(d) {
+              this.current.leading = -d;
+            }
+            setFont(d, g) {
+              var Q;
+              const f = this.commonObjs.get(d), v = this.current;
+              if (!f)
+                throw new Error(`Can't find font for ${d}`);
+              if (v.fontMatrix = f.fontMatrix || n.FONT_IDENTITY_MATRIX, (v.fontMatrix[0] === 0 || v.fontMatrix[3] === 0) && (0, n.warn)("Invalid font matrix for font " + d), g < 0 ? (g = -g, v.fontDirection = -1) : v.fontDirection = 1, this.current.font = f, this.current.fontSize = g, f.isType3Font)
+                return;
+              const A = f.loadedName || "sans-serif", O = ((Q = f.systemFontInfo) == null ? void 0 : Q.css) || `"${A}", ${f.fallbackName}`;
+              let H = "normal";
+              f.black ? H = "900" : f.bold && (H = "bold");
+              const z = f.italic ? "italic" : "normal";
+              let ae = g;
+              g < _ ? ae = _ : g > c && (ae = c), this.current.fontSizeScale = g / ae, this.ctx.font = `${z} ${H} ${ae}px ${O}`;
+            }
+            setTextRenderingMode(d) {
+              this.current.textRenderingMode = d;
+            }
+            setTextRise(d) {
+              this.current.textRise = d;
+            }
+            moveText(d, g) {
+              this.current.x = this.current.lineX += d, this.current.y = this.current.lineY += g;
+            }
+            setLeadingMoveText(d, g) {
+              this.setLeading(-g), this.moveText(d, g);
+            }
+            setTextMatrix(d, g, f, v, A, O) {
+              this.current.textMatrix = [d, g, f, v, A, O], this.current.textMatrixScale = Math.hypot(d, g), this.current.x = this.current.lineX = 0, this.current.y = this.current.lineY = 0;
+            }
+            nextLine() {
+              this.moveText(0, this.current.leading);
+            }
+            paintChar(d, g, f, v) {
+              const A = this.ctx, O = this.current, H = O.font, z = O.textRenderingMode, ae = O.fontSize / O.fontSizeScale, Q = z & n.TextRenderingMode.FILL_STROKE_MASK, ce = !!(z & n.TextRenderingMode.ADD_TO_PATH_FLAG), ue = O.patternFill && !H.missingFile;
+              let me;
+              (H.disableFontFace || ce || ue) && (me = H.getPathGenerator(this.commonObjs, d)), H.disableFontFace || ue ? (A.save(), A.translate(g, f), A.beginPath(), me(A, ae), v && A.setTransform(...v), (Q === n.TextRenderingMode.FILL || Q === n.TextRenderingMode.FILL_STROKE) && A.fill(), (Q === n.TextRenderingMode.STROKE || Q === n.TextRenderingMode.FILL_STROKE) && A.stroke(), A.restore()) : ((Q === n.TextRenderingMode.FILL || Q === n.TextRenderingMode.FILL_STROKE) && A.fillText(d, g, f), (Q === n.TextRenderingMode.STROKE || Q === n.TextRenderingMode.FILL_STROKE) && A.strokeText(d, g, f)), ce && (this.pendingTextPaths || (this.pendingTextPaths = [])).push({
+                transform: (0, s.getCurrentTransform)(A),
+                x: g,
+                y: f,
+                fontSize: ae,
+                addToPath: me
+              });
+            }
+            get isFontSubpixelAAEnabled() {
+              const {
+                context: d
+              } = this.cachedCanvases.getCanvas("isFontSubpixelAAEnabled", 10, 10);
+              d.scale(1.5, 1), d.fillText("I", 0, 10);
+              const g = d.getImageData(0, 0, 10, 10).data;
+              let f = !1;
+              for (let v = 3; v < g.length; v += 4)
+                if (g[v] > 0 && g[v] < 255) {
+                  f = !0;
+                  break;
+                }
+              return (0, n.shadow)(this, "isFontSubpixelAAEnabled", f);
+            }
+            showText(d) {
+              const g = this.current, f = g.font;
+              if (f.isType3Font)
+                return this.showType3Text(d);
+              const v = g.fontSize;
+              if (v === 0)
+                return;
+              const A = this.ctx, O = g.fontSizeScale, H = g.charSpacing, z = g.wordSpacing, ae = g.fontDirection, Q = g.textHScale * ae, ce = d.length, ue = f.vertical, me = ue ? 1 : -1, fe = f.defaultVMetrics, Pe = v * g.fontMatrix[0], Fe = g.textRenderingMode === n.TextRenderingMode.FILL && !f.disableFontFace && !g.patternFill;
+              A.save(), A.transform(...g.textMatrix), A.translate(g.x, g.y + g.textRise), ae > 0 ? A.scale(Q, -1) : A.scale(Q, 1);
+              let Ee;
+              if (g.patternFill) {
+                A.save();
+                const ge = g.fillColor.getPattern(A, this, (0, s.getCurrentTransformInverse)(A), l.PathType.FILL);
+                Ee = (0, s.getCurrentTransform)(A), A.restore(), A.fillStyle = ge;
+              }
+              let De = g.lineWidth;
+              const _e = g.textMatrixScale;
+              if (_e === 0 || De === 0) {
+                const ge = g.textRenderingMode & n.TextRenderingMode.FILL_STROKE_MASK;
+                (ge === n.TextRenderingMode.STROKE || ge === n.TextRenderingMode.FILL_STROKE) && (De = this.getSinglePixelWidth());
+              } else
+                De /= _e;
+              if (O !== 1 && (A.scale(O, O), De /= O), A.lineWidth = De, f.isInvalidPDFjsFont) {
+                const ge = [];
+                let Ce = 0;
+                for (const xe of d)
+                  ge.push(xe.unicode), Ce += xe.width;
+                A.fillText(ge.join(""), 0, 0), g.x += Ce * Pe * Q, A.restore(), this.compose();
+                return;
+              }
+              let ie = 0, se;
+              for (se = 0; se < ce; ++se) {
+                const ge = d[se];
+                if (typeof ge == "number") {
+                  ie += me * ge * v / 1e3;
+                  continue;
+                }
+                let Ce = !1;
+                const xe = (ge.isSpace ? z : 0) + H, Ue = ge.fontChar, We = ge.accent;
+                let je, ze, Xe = ge.width;
+                if (ue) {
+                  const Ye = ge.vmetric || fe, de = -(ge.vmetric ? Ye[1] : Xe * 0.5) * Pe, ne = Ye[2] * Pe;
+                  Xe = Ye ? -Ye[0] : Xe, je = de / O, ze = (ie + ne) / O;
+                } else
+                  je = ie / O, ze = 0;
+                if (f.remeasure && Xe > 0) {
+                  const Ye = A.measureText(Ue).width * 1e3 / v * O;
+                  if (Xe < Ye && this.isFontSubpixelAAEnabled) {
+                    const de = Xe / Ye;
+                    Ce = !0, A.save(), A.scale(de, 1), je /= de;
+                  } else
+                    Xe !== Ye && (je += (Xe - Ye) / 2e3 * v / O);
+                }
+                if (this.contentVisible && (ge.isInFont || f.missingFile)) {
+                  if (Fe && !We)
+                    A.fillText(Ue, je, ze);
+                  else if (this.paintChar(Ue, je, ze, Ee), We) {
+                    const Ye = je + v * We.offset.x / O, de = ze - v * We.offset.y / O;
+                    this.paintChar(We.fontChar, Ye, de, Ee);
+                  }
+                }
+                const Ge = ue ? Xe * Pe - xe * ae : Xe * Pe + xe * ae;
+                ie += Ge, Ce && A.restore();
+              }
+              ue ? g.y -= ie : g.x += ie * Q, A.restore(), this.compose();
+            }
+            showType3Text(d) {
+              const g = this.ctx, f = this.current, v = f.font, A = f.fontSize, O = f.fontDirection, H = v.vertical ? 1 : -1, z = f.charSpacing, ae = f.wordSpacing, Q = f.textHScale * O, ce = f.fontMatrix || n.FONT_IDENTITY_MATRIX, ue = d.length, me = f.textRenderingMode === n.TextRenderingMode.INVISIBLE;
+              let fe, Pe, Fe, Ee;
+              if (!(me || A === 0)) {
+                for (this._cachedScaleForStroking[0] = -1, this._cachedGetSinglePixelWidth = null, g.save(), g.transform(...f.textMatrix), g.translate(f.x, f.y), g.scale(Q, O), fe = 0; fe < ue; ++fe) {
+                  if (Pe = d[fe], typeof Pe == "number") {
+                    Ee = H * Pe * A / 1e3, this.ctx.translate(Ee, 0), f.x += Ee * Q;
+                    continue;
+                  }
+                  const De = (Pe.isSpace ? ae : 0) + z, _e = v.charProcOperatorList[Pe.operatorListId];
+                  if (!_e) {
+                    (0, n.warn)(`Type3 character "${Pe.operatorListId}" is not available.`);
+                    continue;
+                  }
+                  this.contentVisible && (this.processingType3 = Pe, this.save(), g.scale(A, A), g.transform(...ce), this.executeOperatorList(_e), this.restore()), Fe = n.Util.applyTransform([Pe.width, 0], ce)[0] * A + De, g.translate(Fe, 0), f.x += Fe * Q;
+                }
+                g.restore(), this.processingType3 = null;
+              }
+            }
+            setCharWidth(d, g) {
+            }
+            setCharWidthAndBounds(d, g, f, v, A, O) {
+              this.ctx.rect(f, v, A - f, O - v), this.ctx.clip(), this.endPath();
+            }
+            getColorN_Pattern(d) {
+              let g;
+              if (d[0] === "TilingPattern") {
+                const f = d[1], v = this.baseTransform || (0, s.getCurrentTransform)(this.ctx), A = {
+                  createCanvasGraphics: (O) => new be(O, this.commonObjs, this.objs, this.canvasFactory, this.filterFactory, {
+                    optionalContentConfig: this.optionalContentConfig,
+                    markedContentStack: this.markedContentStack
+                  })
+                };
+                g = new l.TilingPattern(d, f, this.ctx, A, v);
+              } else
+                g = this._getPattern(d[1], d[2]);
+              return g;
+            }
+            setStrokeColorN() {
+              this.current.strokeColor = this.getColorN_Pattern(arguments);
+            }
+            setFillColorN() {
+              this.current.fillColor = this.getColorN_Pattern(arguments), this.current.patternFill = !0;
+            }
+            setStrokeRGBColor(d, g, f) {
+              const v = n.Util.makeHexColor(d, g, f);
+              this.ctx.strokeStyle = v, this.current.strokeColor = v;
+            }
+            setFillRGBColor(d, g, f) {
+              const v = n.Util.makeHexColor(d, g, f);
+              this.ctx.fillStyle = v, this.current.fillColor = v, this.current.patternFill = !1;
+            }
+            _getPattern(d, g = null) {
+              let f;
+              return this.cachedPatterns.has(d) ? f = this.cachedPatterns.get(d) : (f = (0, l.getShadingPattern)(this.getObject(d)), this.cachedPatterns.set(d, f)), g && (f.matrix = g), f;
+            }
+            shadingFill(d) {
+              if (!this.contentVisible)
+                return;
+              const g = this.ctx;
+              this.save();
+              const f = this._getPattern(d);
+              g.fillStyle = f.getPattern(g, this, (0, s.getCurrentTransformInverse)(g), l.PathType.SHADING);
+              const v = (0, s.getCurrentTransformInverse)(g);
+              if (v) {
+                const {
+                  width: A,
+                  height: O
+                } = g.canvas, [H, z, ae, Q] = n.Util.getAxialAlignedBoundingBox([0, 0, A, O], v);
+                this.ctx.fillRect(H, z, ae - H, Q - z);
+              } else
+                this.ctx.fillRect(-1e10, -1e10, 2e10, 2e10);
+              this.compose(this.current.getClippedPathBoundingBox()), this.restore();
+            }
+            beginInlineImage() {
+              (0, n.unreachable)("Should not call beginInlineImage");
+            }
+            beginImageData() {
+              (0, n.unreachable)("Should not call beginImageData");
+            }
+            paintFormXObjectBegin(d, g) {
+              if (this.contentVisible && (this.save(), this.baseTransformStack.push(this.baseTransform), Array.isArray(d) && d.length === 6 && this.transform(...d), this.baseTransform = (0, s.getCurrentTransform)(this.ctx), g)) {
+                const f = g[2] - g[0], v = g[3] - g[1];
+                this.ctx.rect(g[0], g[1], f, v), this.current.updateRectMinMax((0, s.getCurrentTransform)(this.ctx), g), this.clip(), this.endPath();
+              }
+            }
+            paintFormXObjectEnd() {
+              this.contentVisible && (this.restore(), this.baseTransform = this.baseTransformStack.pop());
+            }
+            beginGroup(d) {
+              if (!this.contentVisible)
+                return;
+              this.save(), this.inSMaskMode && (this.endSMaskMode(), this.current.activeSMask = null);
+              const g = this.ctx;
+              d.isolated || (0, n.info)("TODO: Support non-isolated groups."), d.knockout && (0, n.warn)("Knockout groups not supported.");
+              const f = (0, s.getCurrentTransform)(g);
+              if (d.matrix && g.transform(...d.matrix), !d.bbox)
+                throw new Error("Bounding box is required.");
+              let v = n.Util.getAxialAlignedBoundingBox(d.bbox, (0, s.getCurrentTransform)(g));
+              const A = [0, 0, g.canvas.width, g.canvas.height];
+              v = n.Util.intersect(v, A) || [0, 0, 0, 0];
+              const O = Math.floor(v[0]), H = Math.floor(v[1]);
+              let z = Math.max(Math.ceil(v[2]) - O, 1), ae = Math.max(Math.ceil(v[3]) - H, 1), Q = 1, ce = 1;
+              z > o && (Q = z / o, z = o), ae > o && (ce = ae / o, ae = o), this.current.startNewPathAndClipBox([0, 0, z, ae]);
+              let ue = "groupAt" + this.groupLevel;
+              d.smask && (ue += "_smask_" + this.smaskCounter++ % 2);
+              const me = this.cachedCanvases.getCanvas(ue, z, ae), fe = me.context;
+              fe.scale(1 / Q, 1 / ce), fe.translate(-O, -H), fe.transform(...f), d.smask ? this.smaskStack.push({
+                canvas: me.canvas,
+                context: fe,
+                offsetX: O,
+                offsetY: H,
+                scaleX: Q,
+                scaleY: ce,
+                subtype: d.smask.subtype,
+                backdrop: d.smask.backdrop,
+                transferMap: d.smask.transferMap || null,
+                startTransformInverse: null
+              }) : (g.setTransform(1, 0, 0, 1, 0, 0), g.translate(O, H), g.scale(Q, ce), g.save()), p(g, fe), this.ctx = fe, this.setGState([["BM", "source-over"], ["ca", 1], ["CA", 1]]), this.groupStack.push(g), this.groupLevel++;
+            }
+            endGroup(d) {
+              if (!this.contentVisible)
+                return;
+              this.groupLevel--;
+              const g = this.ctx, f = this.groupStack.pop();
+              if (this.ctx = f, this.ctx.imageSmoothingEnabled = !1, d.smask)
+                this.tempSMask = this.smaskStack.pop(), this.restore();
+              else {
+                this.ctx.restore();
+                const v = (0, s.getCurrentTransform)(this.ctx);
+                this.restore(), this.ctx.save(), this.ctx.setTransform(...v);
+                const A = n.Util.getAxialAlignedBoundingBox([0, 0, g.canvas.width, g.canvas.height], v);
+                this.ctx.drawImage(g.canvas, 0, 0), this.ctx.restore(), this.compose(A);
+              }
+            }
+            beginAnnotation(d, g, f, v, A) {
+              if (K(this, q, Zt).call(this), E(this.ctx), this.ctx.save(), this.save(), this.baseTransform && this.ctx.setTransform(...this.baseTransform), Array.isArray(g) && g.length === 4) {
+                const O = g[2] - g[0], H = g[3] - g[1];
+                if (A && this.annotationCanvasMap) {
+                  f = f.slice(), f[4] -= g[0], f[5] -= g[1], g = g.slice(), g[0] = g[1] = 0, g[2] = O, g[3] = H;
+                  const [z, ae] = n.Util.singularValueDecompose2dScale((0, s.getCurrentTransform)(this.ctx)), {
+                    viewportScale: Q
+                  } = this, ce = Math.ceil(O * this.outputScaleX * Q), ue = Math.ceil(H * this.outputScaleY * Q);
+                  this.annotationCanvas = this.canvasFactory.create(ce, ue);
+                  const {
+                    canvas: me,
+                    context: fe
+                  } = this.annotationCanvas;
+                  this.annotationCanvasMap.set(d, me), this.annotationCanvas.savedCtx = this.ctx, this.ctx = fe, this.ctx.save(), this.ctx.setTransform(z, 0, 0, -ae, 0, H * ae), E(this.ctx);
+                } else
+                  E(this.ctx), this.ctx.rect(g[0], g[1], O, H), this.ctx.clip(), this.endPath();
+              }
+              this.current = new F(this.ctx.canvas.width, this.ctx.canvas.height), this.transform(...f), this.transform(...v);
+            }
+            endAnnotation() {
+              this.annotationCanvas && (this.ctx.restore(), K(this, pe, en).call(this), this.ctx = this.annotationCanvas.savedCtx, delete this.annotationCanvas.savedCtx, delete this.annotationCanvas);
+            }
+            paintImageMaskXObject(d) {
+              if (!this.contentVisible)
+                return;
+              const g = d.count;
+              d = this.getObject(d.data, d), d.count = g;
+              const f = this.ctx, v = this.processingType3;
+              if (v && (v.compiled === void 0 && (v.compiled = k(d)), v.compiled)) {
+                v.compiled(f);
+                return;
+              }
+              const A = this._createMaskCanvas(d), O = A.canvas;
+              f.save(), f.setTransform(1, 0, 0, 1, 0, 0), f.drawImage(O, A.offsetX, A.offsetY), f.restore(), this.compose();
+            }
+            paintImageMaskXObjectRepeat(d, g, f = 0, v = 0, A, O) {
+              if (!this.contentVisible)
+                return;
+              d = this.getObject(d.data, d);
+              const H = this.ctx;
+              H.save();
+              const z = (0, s.getCurrentTransform)(H);
+              H.transform(g, f, v, A, 0, 0);
+              const ae = this._createMaskCanvas(d);
+              H.setTransform(1, 0, 0, 1, ae.offsetX - z[4], ae.offsetY - z[5]);
+              for (let Q = 0, ce = O.length; Q < ce; Q += 2) {
+                const ue = n.Util.transform(z, [g, f, v, A, O[Q], O[Q + 1]]), [me, fe] = n.Util.applyTransform([0, 0], ue);
+                H.drawImage(ae.canvas, me, fe);
+              }
+              H.restore(), this.compose();
+            }
+            paintImageMaskXObjectGroup(d) {
+              if (!this.contentVisible)
+                return;
+              const g = this.ctx, f = this.current.fillColor, v = this.current.patternFill;
+              for (const A of d) {
+                const {
+                  data: O,
+                  width: H,
+                  height: z,
+                  transform: ae
+                } = A, Q = this.cachedCanvases.getCanvas("maskCanvas", H, z), ce = Q.context;
+                ce.save();
+                const ue = this.getObject(O, A);
+                y(ce, ue), ce.globalCompositeOperation = "source-in", ce.fillStyle = v ? f.getPattern(ce, this, (0, s.getCurrentTransformInverse)(g), l.PathType.FILL) : f, ce.fillRect(0, 0, H, z), ce.restore(), g.save(), g.transform(...ae), g.scale(1, -1), b(g, Q.canvas, 0, 0, H, z, 0, -1, 1, 1), g.restore();
+              }
+              this.compose();
+            }
+            paintImageXObject(d) {
+              if (!this.contentVisible)
+                return;
+              const g = this.getObject(d);
+              if (!g) {
+                (0, n.warn)("Dependent image isn't ready yet");
+                return;
+              }
+              this.paintInlineImageXObject(g);
+            }
+            paintImageXObjectRepeat(d, g, f, v) {
+              if (!this.contentVisible)
+                return;
+              const A = this.getObject(d);
+              if (!A) {
+                (0, n.warn)("Dependent image isn't ready yet");
+                return;
+              }
+              const O = A.width, H = A.height, z = [];
+              for (let ae = 0, Q = v.length; ae < Q; ae += 2)
+                z.push({
+                  transform: [g, 0, 0, f, v[ae], v[ae + 1]],
+                  x: 0,
+                  y: 0,
+                  w: O,
+                  h: H
+                });
+              this.paintInlineImageXObjectGroup(A, z);
+            }
+            applyTransferMapsToCanvas(d) {
+              return this.current.transferMaps !== "none" && (d.filter = this.current.transferMaps, d.drawImage(d.canvas, 0, 0), d.filter = "none"), d.canvas;
+            }
+            applyTransferMapsToBitmap(d) {
+              if (this.current.transferMaps === "none")
+                return d.bitmap;
+              const {
+                bitmap: g,
+                width: f,
+                height: v
+              } = d, A = this.cachedCanvases.getCanvas("inlineImage", f, v), O = A.context;
+              return O.filter = this.current.transferMaps, O.drawImage(g, 0, 0), O.filter = "none", A.canvas;
+            }
+            paintInlineImageXObject(d) {
+              if (!this.contentVisible)
+                return;
+              const g = d.width, f = d.height, v = this.ctx;
+              if (this.save(), !n.isNodeJS) {
+                const {
+                  filter: H
+                } = v;
+                H !== "none" && H !== "" && (v.filter = "none");
+              }
+              v.scale(1 / g, -1 / f);
+              let A;
+              if (d.bitmap)
+                A = this.applyTransferMapsToBitmap(d);
+              else if (typeof HTMLElement == "function" && d instanceof HTMLElement || !d.data)
+                A = d;
+              else {
+                const z = this.cachedCanvases.getCanvas("inlineImage", g, f).context;
+                x(z, d), A = this.applyTransferMapsToCanvas(z);
+              }
+              const O = this._scaleImage(A, (0, s.getCurrentTransformInverse)(v));
+              v.imageSmoothingEnabled = X((0, s.getCurrentTransform)(v), d.interpolate), b(v, O.img, 0, 0, O.paintWidth, O.paintHeight, 0, -f, g, f), this.compose(), this.restore();
+            }
+            paintInlineImageXObjectGroup(d, g) {
+              if (!this.contentVisible)
+                return;
+              const f = this.ctx;
+              let v;
+              if (d.bitmap)
+                v = d.bitmap;
+              else {
+                const A = d.width, O = d.height, z = this.cachedCanvases.getCanvas("inlineImage", A, O).context;
+                x(z, d), v = this.applyTransferMapsToCanvas(z);
+              }
+              for (const A of g)
+                f.save(), f.transform(...A.transform), f.scale(1, -1), b(f, v, A.x, A.y, A.w, A.h, 0, -1, 1, 1), f.restore();
+              this.compose();
+            }
+            paintSolidColorImageMask() {
+              this.contentVisible && (this.ctx.fillRect(0, 0, 1, 1), this.compose());
+            }
+            markPoint(d) {
+            }
+            markPointProps(d, g) {
+            }
+            beginMarkedContent(d) {
+              this.markedContentStack.push({
+                visible: !0
+              });
+            }
+            beginMarkedContentProps(d, g) {
+              d === "OC" ? this.markedContentStack.push({
+                visible: this.optionalContentConfig.isVisible(g)
+              }) : this.markedContentStack.push({
+                visible: !0
+              }), this.contentVisible = this.isContentVisible();
+            }
+            endMarkedContent() {
+              this.markedContentStack.pop(), this.contentVisible = this.isContentVisible();
+            }
+            beginCompat() {
+            }
+            endCompat() {
+            }
+            consumePath(d) {
+              const g = this.current.isEmptyClip();
+              this.pendingClip && this.current.updateClipFromPath(), this.pendingClip || this.compose(d);
+              const f = this.ctx;
+              this.pendingClip && (g || (this.pendingClip === ee ? f.clip("evenodd") : f.clip()), this.pendingClip = null), this.current.startNewPathAndClipBox(this.current.clipBox), f.beginPath();
+            }
+            getSinglePixelWidth() {
+              if (!this._cachedGetSinglePixelWidth) {
+                const d = (0, s.getCurrentTransform)(this.ctx);
+                if (d[1] === 0 && d[2] === 0)
+                  this._cachedGetSinglePixelWidth = 1 / Math.min(Math.abs(d[0]), Math.abs(d[3]));
+                else {
+                  const g = Math.abs(d[0] * d[3] - d[2] * d[1]), f = Math.hypot(d[0], d[2]), v = Math.hypot(d[1], d[3]);
+                  this._cachedGetSinglePixelWidth = Math.max(f, v) / g;
+                }
+              }
+              return this._cachedGetSinglePixelWidth;
+            }
+            getScaleForStroking() {
+              if (this._cachedScaleForStroking[0] === -1) {
+                const {
+                  lineWidth: d
+                } = this.current, {
+                  a: g,
+                  b: f,
+                  c: v,
+                  d: A
+                } = this.ctx.getTransform();
+                let O, H;
+                if (f === 0 && v === 0) {
+                  const z = Math.abs(g), ae = Math.abs(A);
+                  if (z === ae)
+                    if (d === 0)
+                      O = H = 1 / z;
+                    else {
+                      const Q = z * d;
+                      O = H = Q < 1 ? 1 / Q : 1;
+                    }
+                  else if (d === 0)
+                    O = 1 / z, H = 1 / ae;
+                  else {
+                    const Q = z * d, ce = ae * d;
+                    O = Q < 1 ? 1 / Q : 1, H = ce < 1 ? 1 / ce : 1;
+                  }
+                } else {
+                  const z = Math.abs(g * A - f * v), ae = Math.hypot(g, f), Q = Math.hypot(v, A);
+                  if (d === 0)
+                    O = Q / z, H = ae / z;
+                  else {
+                    const ce = d * z;
+                    O = Q > ce ? Q / ce : 1, H = ae > ce ? ae / ce : 1;
+                  }
+                }
+                this._cachedScaleForStroking[0] = O, this._cachedScaleForStroking[1] = H;
+              }
+              return this._cachedScaleForStroking;
+            }
+            rescaleAndStroke(d) {
+              const {
+                ctx: g
+              } = this, {
+                lineWidth: f
+              } = this.current, [v, A] = this.getScaleForStroking();
+              if (g.lineWidth = f || 1, v === 1 && A === 1) {
+                g.stroke();
+                return;
+              }
+              const O = g.getLineDash();
+              if (d && g.save(), g.scale(v, A), O.length > 0) {
+                const H = Math.max(v, A);
+                g.setLineDash(O.map((z) => z / H)), g.lineDashOffset /= H;
+              }
+              g.stroke(), d && g.restore();
+            }
+            isContentVisible() {
+              for (let d = this.markedContentStack.length - 1; d >= 0; d--)
+                if (!this.markedContentStack[d].visible)
+                  return !1;
+              return !0;
+            }
+          };
+          q = new WeakSet(), Zt = function() {
+            for (; this.stateStack.length || this.inSMaskMode; )
+              this.restore();
+            this.ctx.restore(), this.transparentCanvas && (this.ctx = this.compositeCtx, this.ctx.save(), this.ctx.setTransform(1, 0, 0, 1, 0, 0), this.ctx.drawImage(this.transparentCanvas, 0, 0), this.ctx.restore(), this.transparentCanvas = null);
+          }, pe = new WeakSet(), en = function() {
+            if (this.pageColors) {
+              const d = this.filterFactory.addHCMFilter(this.pageColors.foreground, this.pageColors.background);
+              if (d !== "none") {
+                const g = this.ctx.filter;
+                this.ctx.filter = d, this.ctx.drawImage(this.ctx.canvas, 0, 0), this.ctx.filter = g;
+              }
+            }
+          };
+          let Y = be;
+          e.CanvasGraphics = Y;
+          for (const R in n.OPS)
+            Y.prototype[R] !== void 0 && (Y.prototype[n.OPS[R]] = Y.prototype[R]);
+        },
+        /* 12 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.TilingPattern = e.PathType = void 0, e.getShadingPattern = w;
+          var n = i(1), s = i(6);
+          const l = {
+            FILL: "Fill",
+            STROKE: "Stroke",
+            SHADING: "Shading"
+          };
+          e.PathType = l;
+          function h(k, F) {
+            if (!F)
+              return;
+            const x = F[2] - F[0], y = F[3] - F[1], p = new Path2D();
+            p.rect(F[0], F[1], x, y), k.clip(p);
+          }
+          class _ {
+            constructor() {
+              this.constructor === _ && (0, n.unreachable)("Cannot initialize BaseShadingPattern.");
+            }
+            getPattern() {
+              (0, n.unreachable)("Abstract method `getPattern` called.");
+            }
+          }
+          class c extends _ {
+            constructor(F) {
+              super(), this._type = F[1], this._bbox = F[2], this._colorStops = F[3], this._p0 = F[4], this._p1 = F[5], this._r0 = F[6], this._r1 = F[7], this.matrix = null;
+            }
+            _createGradient(F) {
+              let x;
+              this._type === "axial" ? x = F.createLinearGradient(this._p0[0], this._p0[1], this._p1[0], this._p1[1]) : this._type === "radial" && (x = F.createRadialGradient(this._p0[0], this._p0[1], this._r0, this._p1[0], this._p1[1], this._r1));
+              for (const y of this._colorStops)
+                x.addColorStop(y[0], y[1]);
+              return x;
+            }
+            getPattern(F, x, y, p) {
+              let E;
+              if (p === l.STROKE || p === l.FILL) {
+                const $ = x.current.getClippedPathBoundingBox(p, (0, s.getCurrentTransform)(F)) || [0, 0, 0, 0], M = Math.ceil($[2] - $[0]) || 1, m = Math.ceil($[3] - $[1]) || 1, N = x.cachedCanvases.getCanvas("pattern", M, m, !0), D = N.context;
+                D.clearRect(0, 0, D.canvas.width, D.canvas.height), D.beginPath(), D.rect(0, 0, D.canvas.width, D.canvas.height), D.translate(-$[0], -$[1]), y = n.Util.transform(y, [1, 0, 0, 1, $[0], $[1]]), D.transform(...x.baseTransform), this.matrix && D.transform(...this.matrix), h(D, this._bbox), D.fillStyle = this._createGradient(D), D.fill(), E = F.createPattern(N.canvas, "no-repeat");
+                const X = new DOMMatrix(y);
+                E.setTransform(X);
+              } else
+                h(F, this._bbox), E = this._createGradient(F);
+              return E;
+            }
+          }
+          function o(k, F, x, y, p, E, $, M) {
+            const m = F.coords, N = F.colors, D = k.data, X = k.width * 4;
+            let G;
+            m[x + 1] > m[y + 1] && (G = x, x = y, y = G, G = E, E = $, $ = G), m[y + 1] > m[p + 1] && (G = y, y = p, p = G, G = $, $ = M, M = G), m[x + 1] > m[y + 1] && (G = x, x = y, y = G, G = E, E = $, $ = G);
+            const I = (m[x] + F.offsetX) * F.scaleX, B = (m[x + 1] + F.offsetY) * F.scaleY, ee = (m[y] + F.offsetX) * F.scaleX, Y = (m[y + 1] + F.offsetY) * F.scaleY, q = (m[p] + F.offsetX) * F.scaleX, le = (m[p + 1] + F.offsetY) * F.scaleY;
+            if (B >= le)
+              return;
+            const pe = N[E], we = N[E + 1], be = N[E + 2], R = N[$], d = N[$ + 1], g = N[$ + 2], f = N[M], v = N[M + 1], A = N[M + 2], O = Math.round(B), H = Math.round(le);
+            let z, ae, Q, ce, ue, me, fe, Pe;
+            for (let Fe = O; Fe <= H; Fe++) {
+              if (Fe < Y) {
+                const se = Fe < B ? 0 : (B - Fe) / (B - Y);
+                z = I - (I - ee) * se, ae = pe - (pe - R) * se, Q = we - (we - d) * se, ce = be - (be - g) * se;
+              } else {
+                let se;
+                Fe > le ? se = 1 : Y === le ? se = 0 : se = (Y - Fe) / (Y - le), z = ee - (ee - q) * se, ae = R - (R - f) * se, Q = d - (d - v) * se, ce = g - (g - A) * se;
+              }
+              let Ee;
+              Fe < B ? Ee = 0 : Fe > le ? Ee = 1 : Ee = (B - Fe) / (B - le), ue = I - (I - q) * Ee, me = pe - (pe - f) * Ee, fe = we - (we - v) * Ee, Pe = be - (be - A) * Ee;
+              const De = Math.round(Math.min(z, ue)), _e = Math.round(Math.max(z, ue));
+              let ie = X * Fe + De * 4;
+              for (let se = De; se <= _e; se++)
+                Ee = (z - se) / (z - ue), Ee < 0 ? Ee = 0 : Ee > 1 && (Ee = 1), D[ie++] = ae - (ae - me) * Ee | 0, D[ie++] = Q - (Q - fe) * Ee | 0, D[ie++] = ce - (ce - Pe) * Ee | 0, D[ie++] = 255;
+            }
+          }
+          function r(k, F, x) {
+            const y = F.coords, p = F.colors;
+            let E, $;
+            switch (F.type) {
+              case "lattice":
+                const M = F.verticesPerRow, m = Math.floor(y.length / M) - 1, N = M - 1;
+                for (E = 0; E < m; E++) {
+                  let D = E * M;
+                  for (let X = 0; X < N; X++, D++)
+                    o(k, x, y[D], y[D + 1], y[D + M], p[D], p[D + 1], p[D + M]), o(k, x, y[D + M + 1], y[D + 1], y[D + M], p[D + M + 1], p[D + 1], p[D + M]);
+                }
+                break;
+              case "triangles":
+                for (E = 0, $ = y.length; E < $; E += 3)
+                  o(k, x, y[E], y[E + 1], y[E + 2], p[E], p[E + 1], p[E + 2]);
+                break;
+              default:
+                throw new Error("illegal figure");
+            }
+          }
+          class T extends _ {
+            constructor(F) {
+              super(), this._coords = F[2], this._colors = F[3], this._figures = F[4], this._bounds = F[5], this._bbox = F[7], this._background = F[8], this.matrix = null;
+            }
+            _createMeshCanvas(F, x, y) {
+              const M = Math.floor(this._bounds[0]), m = Math.floor(this._bounds[1]), N = Math.ceil(this._bounds[2]) - M, D = Math.ceil(this._bounds[3]) - m, X = Math.min(Math.ceil(Math.abs(N * F[0] * 1.1)), 3e3), G = Math.min(Math.ceil(Math.abs(D * F[1] * 1.1)), 3e3), I = N / X, B = D / G, ee = {
+                coords: this._coords,
+                colors: this._colors,
+                offsetX: -M,
+                offsetY: -m,
+                scaleX: 1 / I,
+                scaleY: 1 / B
+              }, Y = X + 2 * 2, q = G + 2 * 2, le = y.getCanvas("mesh", Y, q, !1), pe = le.context, we = pe.createImageData(X, G);
+              if (x) {
+                const R = we.data;
+                for (let d = 0, g = R.length; d < g; d += 4)
+                  R[d] = x[0], R[d + 1] = x[1], R[d + 2] = x[2], R[d + 3] = 255;
+              }
+              for (const R of this._figures)
+                r(we, R, ee);
+              return pe.putImageData(we, 2, 2), {
+                canvas: le.canvas,
+                offsetX: M - 2 * I,
+                offsetY: m - 2 * B,
+                scaleX: I,
+                scaleY: B
+              };
+            }
+            getPattern(F, x, y, p) {
+              h(F, this._bbox);
+              let E;
+              if (p === l.SHADING)
+                E = n.Util.singularValueDecompose2dScale((0, s.getCurrentTransform)(F));
+              else if (E = n.Util.singularValueDecompose2dScale(x.baseTransform), this.matrix) {
+                const M = n.Util.singularValueDecompose2dScale(this.matrix);
+                E = [E[0] * M[0], E[1] * M[1]];
+              }
+              const $ = this._createMeshCanvas(E, p === l.SHADING ? null : this._background, x.cachedCanvases);
+              return p !== l.SHADING && (F.setTransform(...x.baseTransform), this.matrix && F.transform(...this.matrix)), F.translate($.offsetX, $.offsetY), F.scale($.scaleX, $.scaleY), F.createPattern($.canvas, "no-repeat");
+            }
+          }
+          class S extends _ {
+            getPattern() {
+              return "hotpink";
+            }
+          }
+          function w(k) {
+            switch (k[0]) {
+              case "RadialAxial":
+                return new c(k);
+              case "Mesh":
+                return new T(k);
+              case "Dummy":
+                return new S();
+            }
+            throw new Error(`Unknown IR type: ${k[0]}`);
+          }
+          const C = {
+            COLORED: 1,
+            UNCOLORED: 2
+          }, b = class b {
+            constructor(F, x, y, p, E) {
+              this.operatorList = F[2], this.matrix = F[3] || [1, 0, 0, 1, 0, 0], this.bbox = F[4], this.xstep = F[5], this.ystep = F[6], this.paintType = F[7], this.tilingType = F[8], this.color = x, this.ctx = y, this.canvasGraphicsFactory = p, this.baseTransform = E;
+            }
+            createPatternCanvas(F) {
+              const x = this.operatorList, y = this.bbox, p = this.xstep, E = this.ystep, $ = this.paintType, M = this.tilingType, m = this.color, N = this.canvasGraphicsFactory;
+              (0, n.info)("TilingType: " + M);
+              const D = y[0], X = y[1], G = y[2], I = y[3], B = n.Util.singularValueDecompose2dScale(this.matrix), ee = n.Util.singularValueDecompose2dScale(this.baseTransform), Y = [B[0] * ee[0], B[1] * ee[1]], q = this.getSizeAndScale(p, this.ctx.canvas.width, Y[0]), le = this.getSizeAndScale(E, this.ctx.canvas.height, Y[1]), pe = F.cachedCanvases.getCanvas("pattern", q.size, le.size, !0), we = pe.context, be = N.createCanvasGraphics(we);
+              be.groupLevel = F.groupLevel, this.setFillAndStrokeStyleToContext(be, $, m);
+              let R = D, d = X, g = G, f = I;
+              return D < 0 && (R = 0, g += Math.abs(D)), X < 0 && (d = 0, f += Math.abs(X)), we.translate(-(q.scale * R), -(le.scale * d)), be.transform(q.scale, 0, 0, le.scale, 0, 0), we.save(), this.clipBbox(be, R, d, g, f), be.baseTransform = (0, s.getCurrentTransform)(be.ctx), be.executeOperatorList(x), be.endDrawing(), {
+                canvas: pe.canvas,
+                scaleX: q.scale,
+                scaleY: le.scale,
+                offsetX: R,
+                offsetY: d
+              };
+            }
+            getSizeAndScale(F, x, y) {
+              F = Math.abs(F);
+              const p = Math.max(b.MAX_PATTERN_SIZE, x);
+              let E = Math.ceil(F * y);
+              return E >= p ? E = p : y = E / F, {
+                scale: y,
+                size: E
+              };
+            }
+            clipBbox(F, x, y, p, E) {
+              const $ = p - x, M = E - y;
+              F.ctx.rect(x, y, $, M), F.current.updateRectMinMax((0, s.getCurrentTransform)(F.ctx), [x, y, p, E]), F.clip(), F.endPath();
+            }
+            setFillAndStrokeStyleToContext(F, x, y) {
+              const p = F.ctx, E = F.current;
+              switch (x) {
+                case C.COLORED:
+                  const $ = this.ctx;
+                  p.fillStyle = $.fillStyle, p.strokeStyle = $.strokeStyle, E.fillColor = $.fillStyle, E.strokeColor = $.strokeStyle;
+                  break;
+                case C.UNCOLORED:
+                  const M = n.Util.makeHexColor(y[0], y[1], y[2]);
+                  p.fillStyle = M, p.strokeStyle = M, E.fillColor = M, E.strokeColor = M;
+                  break;
+                default:
+                  throw new n.FormatError(`Unsupported paint type: ${x}`);
+              }
+            }
+            getPattern(F, x, y, p) {
+              let E = y;
+              p !== l.SHADING && (E = n.Util.transform(E, x.baseTransform), this.matrix && (E = n.Util.transform(E, this.matrix)));
+              const $ = this.createPatternCanvas(x);
+              let M = new DOMMatrix(E);
+              M = M.translate($.offsetX, $.offsetY), M = M.scale(1 / $.scaleX, 1 / $.scaleY);
+              const m = F.createPattern($.canvas, "repeat");
+              return m.setTransform(M), m;
+            }
+          };
+          nt(b, "MAX_PATTERN_SIZE", 3e3);
+          let P = b;
+          e.TilingPattern = P;
+        },
+        /* 13 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.convertBlackAndWhiteToRGBA = l, e.convertToRGBA = s, e.grayToRGBA = _;
+          var n = i(1);
+          function s(c) {
+            switch (c.kind) {
+              case n.ImageKind.GRAYSCALE_1BPP:
+                return l(c);
+              case n.ImageKind.RGB_24BPP:
+                return h(c);
+            }
+            return null;
+          }
+          function l({
+            src: c,
+            srcPos: o = 0,
+            dest: r,
+            width: T,
+            height: S,
+            nonBlackColor: w = 4294967295,
+            inverseDecode: C = !1
+          }) {
+            const P = n.FeatureTest.isLittleEndian ? 4278190080 : 255, [b, k] = C ? [w, P] : [P, w], F = T >> 3, x = T & 7, y = c.length;
+            r = new Uint32Array(r.buffer);
+            let p = 0;
+            for (let E = 0; E < S; E++) {
+              for (const M = o + F; o < M; o++) {
+                const m = o < y ? c[o] : 255;
+                r[p++] = m & 128 ? k : b, r[p++] = m & 64 ? k : b, r[p++] = m & 32 ? k : b, r[p++] = m & 16 ? k : b, r[p++] = m & 8 ? k : b, r[p++] = m & 4 ? k : b, r[p++] = m & 2 ? k : b, r[p++] = m & 1 ? k : b;
+              }
+              if (x === 0)
+                continue;
+              const $ = o < y ? c[o++] : 255;
+              for (let M = 0; M < x; M++)
+                r[p++] = $ & 1 << 7 - M ? k : b;
+            }
+            return {
+              srcPos: o,
+              destPos: p
+            };
+          }
+          function h({
+            src: c,
+            srcPos: o = 0,
+            dest: r,
+            destPos: T = 0,
+            width: S,
+            height: w
+          }) {
+            let C = 0;
+            const P = c.length >> 2, b = new Uint32Array(c.buffer, o, P);
+            if (n.FeatureTest.isLittleEndian) {
+              for (; C < P - 2; C += 3, T += 4) {
+                const k = b[C], F = b[C + 1], x = b[C + 2];
+                r[T] = k | 4278190080, r[T + 1] = k >>> 24 | F << 8 | 4278190080, r[T + 2] = F >>> 16 | x << 16 | 4278190080, r[T + 3] = x >>> 8 | 4278190080;
+              }
+              for (let k = C * 4, F = c.length; k < F; k += 3)
+                r[T++] = c[k] | c[k + 1] << 8 | c[k + 2] << 16 | 4278190080;
+            } else {
+              for (; C < P - 2; C += 3, T += 4) {
+                const k = b[C], F = b[C + 1], x = b[C + 2];
+                r[T] = k | 255, r[T + 1] = k << 24 | F >>> 8 | 255, r[T + 2] = F << 16 | x >>> 16 | 255, r[T + 3] = x << 8 | 255;
+              }
+              for (let k = C * 4, F = c.length; k < F; k += 3)
+                r[T++] = c[k] << 24 | c[k + 1] << 16 | c[k + 2] << 8 | 255;
+            }
+            return {
+              srcPos: o,
+              destPos: T
+            };
+          }
+          function _(c, o) {
+            if (n.FeatureTest.isLittleEndian)
+              for (let r = 0, T = c.length; r < T; r++)
+                o[r] = c[r] * 65793 | 4278190080;
+            else
+              for (let r = 0, T = c.length; r < T; r++)
+                o[r] = c[r] * 16843008 | 255;
+          }
+        },
+        /* 14 */
+        /***/
+        (t, e) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.GlobalWorkerOptions = void 0;
+          const i = /* @__PURE__ */ Object.create(null);
+          e.GlobalWorkerOptions = i, i.workerPort = null, i.workerSrc = "";
+        },
+        /* 15 */
+        /***/
+        (t, e, i) => {
+          var c, Mn, r, Fn, S, kt;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.MessageHandler = void 0;
+          var n = i(1);
+          const s = {
+            UNKNOWN: 0,
+            DATA: 1,
+            ERROR: 2
+          }, l = {
+            UNKNOWN: 0,
+            CANCEL: 1,
+            CANCEL_COMPLETE: 2,
+            CLOSE: 3,
+            ENQUEUE: 4,
+            ERROR: 5,
+            PULL: 6,
+            PULL_COMPLETE: 7,
+            START_COMPLETE: 8
+          };
+          function h(C) {
+            switch (C instanceof Error || typeof C == "object" && C !== null || (0, n.unreachable)('wrapReason: Expected "reason" to be a (possibly cloned) Error.'), C.name) {
+              case "AbortException":
+                return new n.AbortException(C.message);
+              case "MissingPDFException":
+                return new n.MissingPDFException(C.message);
+              case "PasswordException":
+                return new n.PasswordException(C.message, C.code);
+              case "UnexpectedResponseException":
+                return new n.UnexpectedResponseException(C.message, C.status);
+              case "UnknownErrorException":
+                return new n.UnknownErrorException(C.message, C.details);
+              default:
+                return new n.UnknownErrorException(C.message, C.toString());
+            }
+          }
+          class _ {
+            constructor(P, b, k) {
+              W(this, c);
+              W(this, r);
+              W(this, S);
+              this.sourceName = P, this.targetName = b, this.comObj = k, this.callbackId = 1, this.streamId = 1, this.streamSinks = /* @__PURE__ */ Object.create(null), this.streamControllers = /* @__PURE__ */ Object.create(null), this.callbackCapabilities = /* @__PURE__ */ Object.create(null), this.actionHandler = /* @__PURE__ */ Object.create(null), this._onComObjOnMessage = (F) => {
+                const x = F.data;
+                if (x.targetName !== this.sourceName)
+                  return;
+                if (x.stream) {
+                  K(this, r, Fn).call(this, x);
+                  return;
+                }
+                if (x.callback) {
+                  const p = x.callbackId, E = this.callbackCapabilities[p];
+                  if (!E)
+                    throw new Error(`Cannot resolve callback ${p}`);
+                  if (delete this.callbackCapabilities[p], x.callback === s.DATA)
+                    E.resolve(x.data);
+                  else if (x.callback === s.ERROR)
+                    E.reject(h(x.reason));
+                  else
+                    throw new Error("Unexpected callback case");
+                  return;
+                }
+                const y = this.actionHandler[x.action];
+                if (!y)
+                  throw new Error(`Unknown action from worker: ${x.action}`);
+                if (x.callbackId) {
+                  const p = this.sourceName, E = x.sourceName;
+                  new Promise(function($) {
+                    $(y(x.data));
+                  }).then(function($) {
+                    k.postMessage({
+                      sourceName: p,
+                      targetName: E,
+                      callback: s.DATA,
+                      callbackId: x.callbackId,
+                      data: $
+                    });
+                  }, function($) {
+                    k.postMessage({
+                      sourceName: p,
+                      targetName: E,
+                      callback: s.ERROR,
+                      callbackId: x.callbackId,
+                      reason: h($)
+                    });
+                  });
+                  return;
+                }
+                if (x.streamId) {
+                  K(this, c, Mn).call(this, x);
+                  return;
+                }
+                y(x.data);
+              }, k.addEventListener("message", this._onComObjOnMessage);
+            }
+            on(P, b) {
+              const k = this.actionHandler;
+              if (k[P])
+                throw new Error(`There is already an actionName called "${P}"`);
+              k[P] = b;
+            }
+            send(P, b, k) {
+              this.comObj.postMessage({
+                sourceName: this.sourceName,
+                targetName: this.targetName,
+                action: P,
+                data: b
+              }, k);
+            }
+            sendWithPromise(P, b, k) {
+              const F = this.callbackId++, x = new n.PromiseCapability();
+              this.callbackCapabilities[F] = x;
+              try {
+                this.comObj.postMessage({
+                  sourceName: this.sourceName,
+                  targetName: this.targetName,
+                  action: P,
+                  callbackId: F,
+                  data: b
+                }, k);
+              } catch (y) {
+                x.reject(y);
+              }
+              return x.promise;
+            }
+            sendWithStream(P, b, k, F) {
+              const x = this.streamId++, y = this.sourceName, p = this.targetName, E = this.comObj;
+              return new ReadableStream({
+                start: ($) => {
+                  const M = new n.PromiseCapability();
+                  return this.streamControllers[x] = {
+                    controller: $,
+                    startCall: M,
+                    pullCall: null,
+                    cancelCall: null,
+                    isClosed: !1
+                  }, E.postMessage({
+                    sourceName: y,
+                    targetName: p,
+                    action: P,
+                    streamId: x,
+                    data: b,
+                    desiredSize: $.desiredSize
+                  }, F), M.promise;
+                },
+                pull: ($) => {
+                  const M = new n.PromiseCapability();
+                  return this.streamControllers[x].pullCall = M, E.postMessage({
+                    sourceName: y,
+                    targetName: p,
+                    stream: l.PULL,
+                    streamId: x,
+                    desiredSize: $.desiredSize
+                  }), M.promise;
+                },
+                cancel: ($) => {
+                  (0, n.assert)($ instanceof Error, "cancel must have a valid reason");
+                  const M = new n.PromiseCapability();
+                  return this.streamControllers[x].cancelCall = M, this.streamControllers[x].isClosed = !0, E.postMessage({
+                    sourceName: y,
+                    targetName: p,
+                    stream: l.CANCEL,
+                    streamId: x,
+                    reason: h($)
+                  }), M.promise;
+                }
+              }, k);
+            }
+            destroy() {
+              this.comObj.removeEventListener("message", this._onComObjOnMessage);
+            }
+          }
+          c = new WeakSet(), Mn = function(P) {
+            const b = P.streamId, k = this.sourceName, F = P.sourceName, x = this.comObj, y = this, p = this.actionHandler[P.action], E = {
+              enqueue($, M = 1, m) {
+                if (this.isCancelled)
+                  return;
+                const N = this.desiredSize;
+                this.desiredSize -= M, N > 0 && this.desiredSize <= 0 && (this.sinkCapability = new n.PromiseCapability(), this.ready = this.sinkCapability.promise), x.postMessage({
+                  sourceName: k,
+                  targetName: F,
+                  stream: l.ENQUEUE,
+                  streamId: b,
+                  chunk: $
+                }, m);
+              },
+              close() {
+                this.isCancelled || (this.isCancelled = !0, x.postMessage({
+                  sourceName: k,
+                  targetName: F,
+                  stream: l.CLOSE,
+                  streamId: b
+                }), delete y.streamSinks[b]);
+              },
+              error($) {
+                (0, n.assert)($ instanceof Error, "error must have a valid reason"), !this.isCancelled && (this.isCancelled = !0, x.postMessage({
+                  sourceName: k,
+                  targetName: F,
+                  stream: l.ERROR,
+                  streamId: b,
+                  reason: h($)
+                }));
+              },
+              sinkCapability: new n.PromiseCapability(),
+              onPull: null,
+              onCancel: null,
+              isCancelled: !1,
+              desiredSize: P.desiredSize,
+              ready: null
+            };
+            E.sinkCapability.resolve(), E.ready = E.sinkCapability.promise, this.streamSinks[b] = E, new Promise(function($) {
+              $(p(P.data, E));
+            }).then(function() {
+              x.postMessage({
+                sourceName: k,
+                targetName: F,
+                stream: l.START_COMPLETE,
+                streamId: b,
+                success: !0
+              });
+            }, function($) {
+              x.postMessage({
+                sourceName: k,
+                targetName: F,
+                stream: l.START_COMPLETE,
+                streamId: b,
+                reason: h($)
+              });
+            });
+          }, r = new WeakSet(), Fn = function(P) {
+            const b = P.streamId, k = this.sourceName, F = P.sourceName, x = this.comObj, y = this.streamControllers[b], p = this.streamSinks[b];
+            switch (P.stream) {
+              case l.START_COMPLETE:
+                P.success ? y.startCall.resolve() : y.startCall.reject(h(P.reason));
+                break;
+              case l.PULL_COMPLETE:
+                P.success ? y.pullCall.resolve() : y.pullCall.reject(h(P.reason));
+                break;
+              case l.PULL:
+                if (!p) {
+                  x.postMessage({
+                    sourceName: k,
+                    targetName: F,
+                    stream: l.PULL_COMPLETE,
+                    streamId: b,
+                    success: !0
+                  });
+                  break;
+                }
+                p.desiredSize <= 0 && P.desiredSize > 0 && p.sinkCapability.resolve(), p.desiredSize = P.desiredSize, new Promise(function(E) {
+                  var $;
+                  E(($ = p.onPull) == null ? void 0 : $.call(p));
+                }).then(function() {
+                  x.postMessage({
+                    sourceName: k,
+                    targetName: F,
+                    stream: l.PULL_COMPLETE,
+                    streamId: b,
+                    success: !0
+                  });
+                }, function(E) {
+                  x.postMessage({
+                    sourceName: k,
+                    targetName: F,
+                    stream: l.PULL_COMPLETE,
+                    streamId: b,
+                    reason: h(E)
+                  });
+                });
+                break;
+              case l.ENQUEUE:
+                if ((0, n.assert)(y, "enqueue should have stream controller"), y.isClosed)
+                  break;
+                y.controller.enqueue(P.chunk);
+                break;
+              case l.CLOSE:
+                if ((0, n.assert)(y, "close should have stream controller"), y.isClosed)
+                  break;
+                y.isClosed = !0, y.controller.close(), K(this, S, kt).call(this, y, b);
+                break;
+              case l.ERROR:
+                (0, n.assert)(y, "error should have stream controller"), y.controller.error(h(P.reason)), K(this, S, kt).call(this, y, b);
+                break;
+              case l.CANCEL_COMPLETE:
+                P.success ? y.cancelCall.resolve() : y.cancelCall.reject(h(P.reason)), K(this, S, kt).call(this, y, b);
+                break;
+              case l.CANCEL:
+                if (!p)
+                  break;
+                new Promise(function(E) {
+                  var $;
+                  E(($ = p.onCancel) == null ? void 0 : $.call(p, h(P.reason)));
+                }).then(function() {
+                  x.postMessage({
+                    sourceName: k,
+                    targetName: F,
+                    stream: l.CANCEL_COMPLETE,
+                    streamId: b,
+                    success: !0
+                  });
+                }, function(E) {
+                  x.postMessage({
+                    sourceName: k,
+                    targetName: F,
+                    stream: l.CANCEL_COMPLETE,
+                    streamId: b,
+                    reason: h(E)
+                  });
+                }), p.sinkCapability.reject(h(P.reason)), p.isCancelled = !0, delete this.streamSinks[b];
+                break;
+              default:
+                throw new Error("Unexpected stream case");
+            }
+          }, S = new WeakSet(), kt = async function(P, b) {
+            var k, F, x;
+            await Promise.allSettled([(k = P.startCall) == null ? void 0 : k.promise, (F = P.pullCall) == null ? void 0 : F.promise, (x = P.cancelCall) == null ? void 0 : x.promise]), delete this.streamControllers[b];
+          }, e.MessageHandler = _;
+        },
+        /* 16 */
+        /***/
+        (t, e, i) => {
+          var l, h;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.Metadata = void 0;
+          var n = i(1);
+          class s {
+            constructor({
+              parsedData: c,
+              rawData: o
+            }) {
+              W(this, l, void 0);
+              W(this, h, void 0);
+              oe(this, l, c), oe(this, h, o);
+            }
+            getRaw() {
+              return a(this, h);
+            }
+            get(c) {
+              return a(this, l).get(c) ?? null;
+            }
+            getAll() {
+              return (0, n.objectFromMap)(a(this, l));
+            }
+            has(c) {
+              return a(this, l).has(c);
+            }
+          }
+          l = new WeakMap(), h = new WeakMap(), e.Metadata = s;
+        },
+        /* 17 */
+        /***/
+        (t, e, i) => {
+          var c, o, r, T, S, w, tn;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.OptionalContentConfig = void 0;
+          var n = i(1), s = i(8);
+          const l = Symbol("INTERNAL");
+          class h {
+            constructor(b, k) {
+              W(this, c, !0);
+              this.name = b, this.intent = k;
+            }
+            get visible() {
+              return a(this, c);
+            }
+            _setVisible(b, k) {
+              b !== l && (0, n.unreachable)("Internal method `_setVisible` called."), oe(this, c, k);
+            }
+          }
+          c = new WeakMap();
+          class _ {
+            constructor(b) {
+              W(this, w);
+              W(this, o, null);
+              W(this, r, /* @__PURE__ */ new Map());
+              W(this, T, null);
+              W(this, S, null);
+              if (this.name = null, this.creator = null, b !== null) {
+                this.name = b.name, this.creator = b.creator, oe(this, S, b.order);
+                for (const k of b.groups)
+                  a(this, r).set(k.id, new h(k.name, k.intent));
+                if (b.baseState === "OFF")
+                  for (const k of a(this, r).values())
+                    k._setVisible(l, !1);
+                for (const k of b.on)
+                  a(this, r).get(k)._setVisible(l, !0);
+                for (const k of b.off)
+                  a(this, r).get(k)._setVisible(l, !1);
+                oe(this, T, this.getHash());
+              }
+            }
+            isVisible(b) {
+              if (a(this, r).size === 0)
+                return !0;
+              if (!b)
+                return (0, n.warn)("Optional content group not defined."), !0;
+              if (b.type === "OCG")
+                return a(this, r).has(b.id) ? a(this, r).get(b.id).visible : ((0, n.warn)(`Optional content group not found: ${b.id}`), !0);
+              if (b.type === "OCMD") {
+                if (b.expression)
+                  return K(this, w, tn).call(this, b.expression);
+                if (!b.policy || b.policy === "AnyOn") {
+                  for (const k of b.ids) {
+                    if (!a(this, r).has(k))
+                      return (0, n.warn)(`Optional content group not found: ${k}`), !0;
+                    if (a(this, r).get(k).visible)
+                      return !0;
+                  }
+                  return !1;
+                } else if (b.policy === "AllOn") {
+                  for (const k of b.ids) {
+                    if (!a(this, r).has(k))
+                      return (0, n.warn)(`Optional content group not found: ${k}`), !0;
+                    if (!a(this, r).get(k).visible)
+                      return !1;
+                  }
+                  return !0;
+                } else if (b.policy === "AnyOff") {
+                  for (const k of b.ids) {
+                    if (!a(this, r).has(k))
+                      return (0, n.warn)(`Optional content group not found: ${k}`), !0;
+                    if (!a(this, r).get(k).visible)
+                      return !0;
+                  }
+                  return !1;
+                } else if (b.policy === "AllOff") {
+                  for (const k of b.ids) {
+                    if (!a(this, r).has(k))
+                      return (0, n.warn)(`Optional content group not found: ${k}`), !0;
+                    if (a(this, r).get(k).visible)
+                      return !1;
+                  }
+                  return !0;
+                }
+                return (0, n.warn)(`Unknown optional content policy ${b.policy}.`), !0;
+              }
+              return (0, n.warn)(`Unknown group type ${b.type}.`), !0;
+            }
+            setVisibility(b, k = !0) {
+              if (!a(this, r).has(b)) {
+                (0, n.warn)(`Optional content group not found: ${b}`);
+                return;
+              }
+              a(this, r).get(b)._setVisible(l, !!k), oe(this, o, null);
+            }
+            get hasInitialVisibility() {
+              return a(this, T) === null || this.getHash() === a(this, T);
+            }
+            getOrder() {
+              return a(this, r).size ? a(this, S) ? a(this, S).slice() : [...a(this, r).keys()] : null;
+            }
+            getGroups() {
+              return a(this, r).size > 0 ? (0, n.objectFromMap)(a(this, r)) : null;
+            }
+            getGroup(b) {
+              return a(this, r).get(b) || null;
+            }
+            getHash() {
+              if (a(this, o) !== null)
+                return a(this, o);
+              const b = new s.MurmurHash3_64();
+              for (const [k, F] of a(this, r))
+                b.update(`${k}:${F.visible}`);
+              return oe(this, o, b.hexdigest());
+            }
+          }
+          o = new WeakMap(), r = new WeakMap(), T = new WeakMap(), S = new WeakMap(), w = new WeakSet(), tn = function(b) {
+            const k = b.length;
+            if (k < 2)
+              return !0;
+            const F = b[0];
+            for (let x = 1; x < k; x++) {
+              const y = b[x];
+              let p;
+              if (Array.isArray(y))
+                p = K(this, w, tn).call(this, y);
+              else if (a(this, r).has(y))
+                p = a(this, r).get(y).visible;
+              else
+                return (0, n.warn)(`Optional content group not found: ${y}`), !0;
+              switch (F) {
+                case "And":
+                  if (!p)
+                    return !1;
+                  break;
+                case "Or":
+                  if (p)
+                    return !0;
+                  break;
+                case "Not":
+                  return !p;
+                default:
+                  return !0;
+              }
+            }
+            return F === "And";
+          }, e.OptionalContentConfig = _;
+        },
+        /* 18 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.PDFDataTransportStream = void 0;
+          var n = i(1), s = i(6);
+          class l {
+            constructor({
+              length: o,
+              initialData: r,
+              progressiveDone: T = !1,
+              contentDispositionFilename: S = null,
+              disableRange: w = !1,
+              disableStream: C = !1
+            }, P) {
+              if ((0, n.assert)(P, 'PDFDataTransportStream - missing required "pdfDataRangeTransport" argument.'), this._queuedChunks = [], this._progressiveDone = T, this._contentDispositionFilename = S, (r == null ? void 0 : r.length) > 0) {
+                const b = r instanceof Uint8Array && r.byteLength === r.buffer.byteLength ? r.buffer : new Uint8Array(r).buffer;
+                this._queuedChunks.push(b);
+              }
+              this._pdfDataRangeTransport = P, this._isStreamingSupported = !C, this._isRangeSupported = !w, this._contentLength = o, this._fullRequestReader = null, this._rangeReaders = [], this._pdfDataRangeTransport.addRangeListener((b, k) => {
+                this._onReceiveData({
+                  begin: b,
+                  chunk: k
+                });
+              }), this._pdfDataRangeTransport.addProgressListener((b, k) => {
+                this._onProgress({
+                  loaded: b,
+                  total: k
+                });
+              }), this._pdfDataRangeTransport.addProgressiveReadListener((b) => {
+                this._onReceiveData({
+                  chunk: b
+                });
+              }), this._pdfDataRangeTransport.addProgressiveDoneListener(() => {
+                this._onProgressiveDone();
+              }), this._pdfDataRangeTransport.transportReady();
+            }
+            _onReceiveData({
+              begin: o,
+              chunk: r
+            }) {
+              const T = r instanceof Uint8Array && r.byteLength === r.buffer.byteLength ? r.buffer : new Uint8Array(r).buffer;
+              if (o === void 0)
+                this._fullRequestReader ? this._fullRequestReader._enqueue(T) : this._queuedChunks.push(T);
+              else {
+                const S = this._rangeReaders.some(function(w) {
+                  return w._begin !== o ? !1 : (w._enqueue(T), !0);
+                });
+                (0, n.assert)(S, "_onReceiveData - no `PDFDataTransportStreamRangeReader` instance found.");
+              }
+            }
+            get _progressiveDataLength() {
+              var o;
+              return ((o = this._fullRequestReader) == null ? void 0 : o._loaded) ?? 0;
+            }
+            _onProgress(o) {
+              var r, T, S, w;
+              o.total === void 0 ? (T = (r = this._rangeReaders[0]) == null ? void 0 : r.onProgress) == null || T.call(r, {
+                loaded: o.loaded
+              }) : (w = (S = this._fullRequestReader) == null ? void 0 : S.onProgress) == null || w.call(S, {
+                loaded: o.loaded,
+                total: o.total
+              });
+            }
+            _onProgressiveDone() {
+              var o;
+              (o = this._fullRequestReader) == null || o.progressiveDone(), this._progressiveDone = !0;
+            }
+            _removeRangeReader(o) {
+              const r = this._rangeReaders.indexOf(o);
+              r >= 0 && this._rangeReaders.splice(r, 1);
+            }
+            getFullReader() {
+              (0, n.assert)(!this._fullRequestReader, "PDFDataTransportStream.getFullReader can only be called once.");
+              const o = this._queuedChunks;
+              return this._queuedChunks = null, new h(this, o, this._progressiveDone, this._contentDispositionFilename);
+            }
+            getRangeReader(o, r) {
+              if (r <= this._progressiveDataLength)
+                return null;
+              const T = new _(this, o, r);
+              return this._pdfDataRangeTransport.requestDataRange(o, r), this._rangeReaders.push(T), T;
+            }
+            cancelAllRequests(o) {
+              var r;
+              (r = this._fullRequestReader) == null || r.cancel(o);
+              for (const T of this._rangeReaders.slice(0))
+                T.cancel(o);
+              this._pdfDataRangeTransport.abort();
+            }
+          }
+          e.PDFDataTransportStream = l;
+          class h {
+            constructor(o, r, T = !1, S = null) {
+              this._stream = o, this._done = T || !1, this._filename = (0, s.isPdfFile)(S) ? S : null, this._queuedChunks = r || [], this._loaded = 0;
+              for (const w of this._queuedChunks)
+                this._loaded += w.byteLength;
+              this._requests = [], this._headersReady = Promise.resolve(), o._fullRequestReader = this, this.onProgress = null;
+            }
+            _enqueue(o) {
+              this._done || (this._requests.length > 0 ? this._requests.shift().resolve({
+                value: o,
+                done: !1
+              }) : this._queuedChunks.push(o), this._loaded += o.byteLength);
+            }
+            get headersReady() {
+              return this._headersReady;
+            }
+            get filename() {
+              return this._filename;
+            }
+            get isRangeSupported() {
+              return this._stream._isRangeSupported;
+            }
+            get isStreamingSupported() {
+              return this._stream._isStreamingSupported;
+            }
+            get contentLength() {
+              return this._stream._contentLength;
+            }
+            async read() {
+              if (this._queuedChunks.length > 0)
+                return {
+                  value: this._queuedChunks.shift(),
+                  done: !1
+                };
+              if (this._done)
+                return {
+                  value: void 0,
+                  done: !0
+                };
+              const o = new n.PromiseCapability();
+              return this._requests.push(o), o.promise;
+            }
+            cancel(o) {
+              this._done = !0;
+              for (const r of this._requests)
+                r.resolve({
+                  value: void 0,
+                  done: !0
+                });
+              this._requests.length = 0;
+            }
+            progressiveDone() {
+              this._done || (this._done = !0);
+            }
+          }
+          class _ {
+            constructor(o, r, T) {
+              this._stream = o, this._begin = r, this._end = T, this._queuedChunk = null, this._requests = [], this._done = !1, this.onProgress = null;
+            }
+            _enqueue(o) {
+              if (!this._done) {
+                if (this._requests.length === 0)
+                  this._queuedChunk = o;
+                else {
+                  this._requests.shift().resolve({
+                    value: o,
+                    done: !1
+                  });
+                  for (const T of this._requests)
+                    T.resolve({
+                      value: void 0,
+                      done: !0
+                    });
+                  this._requests.length = 0;
+                }
+                this._done = !0, this._stream._removeRangeReader(this);
+              }
+            }
+            get isStreamingSupported() {
+              return !1;
+            }
+            async read() {
+              if (this._queuedChunk) {
+                const r = this._queuedChunk;
+                return this._queuedChunk = null, {
+                  value: r,
+                  done: !1
+                };
+              }
+              if (this._done)
+                return {
+                  value: void 0,
+                  done: !0
+                };
+              const o = new n.PromiseCapability();
+              return this._requests.push(o), o.promise;
+            }
+            cancel(o) {
+              this._done = !0;
+              for (const r of this._requests)
+                r.resolve({
+                  value: void 0,
+                  done: !0
+                });
+              this._requests.length = 0, this._stream._removeRangeReader(this);
+            }
+          }
+        },
+        /* 19 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.PDFFetchStream = void 0;
+          var n = i(1), s = i(20);
+          function l(T, S, w) {
+            return {
+              method: "GET",
+              headers: T,
+              signal: w.signal,
+              mode: "cors",
+              credentials: S ? "include" : "same-origin",
+              redirect: "follow"
+            };
+          }
+          function h(T) {
+            const S = new Headers();
+            for (const w in T) {
+              const C = T[w];
+              C !== void 0 && S.append(w, C);
+            }
+            return S;
+          }
+          function _(T) {
+            return T instanceof Uint8Array ? T.buffer : T instanceof ArrayBuffer ? T : ((0, n.warn)(`getArrayBuffer - unexpected data format: ${T}`), new Uint8Array(T).buffer);
+          }
+          class c {
+            constructor(S) {
+              this.source = S, this.isHttp = /^https?:/i.test(S.url), this.httpHeaders = this.isHttp && S.httpHeaders || {}, this._fullRequestReader = null, this._rangeRequestReaders = [];
+            }
+            get _progressiveDataLength() {
+              var S;
+              return ((S = this._fullRequestReader) == null ? void 0 : S._loaded) ?? 0;
+            }
+            getFullReader() {
+              return (0, n.assert)(!this._fullRequestReader, "PDFFetchStream.getFullReader can only be called once."), this._fullRequestReader = new o(this), this._fullRequestReader;
+            }
+            getRangeReader(S, w) {
+              if (w <= this._progressiveDataLength)
+                return null;
+              const C = new r(this, S, w);
+              return this._rangeRequestReaders.push(C), C;
+            }
+            cancelAllRequests(S) {
+              var w;
+              (w = this._fullRequestReader) == null || w.cancel(S);
+              for (const C of this._rangeRequestReaders.slice(0))
+                C.cancel(S);
+            }
+          }
+          e.PDFFetchStream = c;
+          class o {
+            constructor(S) {
+              this._stream = S, this._reader = null, this._loaded = 0, this._filename = null;
+              const w = S.source;
+              this._withCredentials = w.withCredentials || !1, this._contentLength = w.length, this._headersCapability = new n.PromiseCapability(), this._disableRange = w.disableRange || !1, this._rangeChunkSize = w.rangeChunkSize, !this._rangeChunkSize && !this._disableRange && (this._disableRange = !0), this._abortController = new AbortController(), this._isStreamingSupported = !w.disableStream, this._isRangeSupported = !w.disableRange, this._headers = h(this._stream.httpHeaders);
+              const C = w.url;
+              fetch(C, l(this._headers, this._withCredentials, this._abortController)).then((P) => {
+                if (!(0, s.validateResponseStatus)(P.status))
+                  throw (0, s.createResponseStatusError)(P.status, C);
+                this._reader = P.body.getReader(), this._headersCapability.resolve();
+                const b = (x) => P.headers.get(x), {
+                  allowRangeRequests: k,
+                  suggestedLength: F
+                } = (0, s.validateRangeRequestCapabilities)({
+                  getResponseHeader: b,
+                  isHttp: this._stream.isHttp,
+                  rangeChunkSize: this._rangeChunkSize,
+                  disableRange: this._disableRange
+                });
+                this._isRangeSupported = k, this._contentLength = F || this._contentLength, this._filename = (0, s.extractFilenameFromHeader)(b), !this._isStreamingSupported && this._isRangeSupported && this.cancel(new n.AbortException("Streaming is disabled."));
+              }).catch(this._headersCapability.reject), this.onProgress = null;
+            }
+            get headersReady() {
+              return this._headersCapability.promise;
+            }
+            get filename() {
+              return this._filename;
+            }
+            get contentLength() {
+              return this._contentLength;
+            }
+            get isRangeSupported() {
+              return this._isRangeSupported;
+            }
+            get isStreamingSupported() {
+              return this._isStreamingSupported;
+            }
+            async read() {
+              var C;
+              await this._headersCapability.promise;
+              const {
+                value: S,
+                done: w
+              } = await this._reader.read();
+              return w ? {
+                value: S,
+                done: w
+              } : (this._loaded += S.byteLength, (C = this.onProgress) == null || C.call(this, {
+                loaded: this._loaded,
+                total: this._contentLength
+              }), {
+                value: _(S),
+                done: !1
+              });
+            }
+            cancel(S) {
+              var w;
+              (w = this._reader) == null || w.cancel(S), this._abortController.abort();
+            }
+          }
+          class r {
+            constructor(S, w, C) {
+              this._stream = S, this._reader = null, this._loaded = 0;
+              const P = S.source;
+              this._withCredentials = P.withCredentials || !1, this._readCapability = new n.PromiseCapability(), this._isStreamingSupported = !P.disableStream, this._abortController = new AbortController(), this._headers = h(this._stream.httpHeaders), this._headers.append("Range", `bytes=${w}-${C - 1}`);
+              const b = P.url;
+              fetch(b, l(this._headers, this._withCredentials, this._abortController)).then((k) => {
+                if (!(0, s.validateResponseStatus)(k.status))
+                  throw (0, s.createResponseStatusError)(k.status, b);
+                this._readCapability.resolve(), this._reader = k.body.getReader();
+              }).catch(this._readCapability.reject), this.onProgress = null;
+            }
+            get isStreamingSupported() {
+              return this._isStreamingSupported;
+            }
+            async read() {
+              var C;
+              await this._readCapability.promise;
+              const {
+                value: S,
+                done: w
+              } = await this._reader.read();
+              return w ? {
+                value: S,
+                done: w
+              } : (this._loaded += S.byteLength, (C = this.onProgress) == null || C.call(this, {
+                loaded: this._loaded
+              }), {
+                value: _(S),
+                done: !1
+              });
+            }
+            cancel(S) {
+              var w;
+              (w = this._reader) == null || w.cancel(S), this._abortController.abort();
+            }
+          }
+        },
+        /* 20 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.createResponseStatusError = c, e.extractFilenameFromHeader = _, e.validateRangeRequestCapabilities = h, e.validateResponseStatus = o;
+          var n = i(1), s = i(21), l = i(6);
+          function h({
+            getResponseHeader: r,
+            isHttp: T,
+            rangeChunkSize: S,
+            disableRange: w
+          }) {
+            const C = {
+              allowRangeRequests: !1,
+              suggestedLength: void 0
+            }, P = parseInt(r("Content-Length"), 10);
+            return !Number.isInteger(P) || (C.suggestedLength = P, P <= 2 * S) || w || !T || r("Accept-Ranges") !== "bytes" || (r("Content-Encoding") || "identity") !== "identity" || (C.allowRangeRequests = !0), C;
+          }
+          function _(r) {
+            const T = r("Content-Disposition");
+            if (T) {
+              let S = (0, s.getFilenameFromContentDispositionHeader)(T);
+              if (S.includes("%"))
+                try {
+                  S = decodeURIComponent(S);
+                } catch {
+                }
+              if ((0, l.isPdfFile)(S))
+                return S;
+            }
+            return null;
+          }
+          function c(r, T) {
+            return r === 404 || r === 0 && T.startsWith("file:") ? new n.MissingPDFException('Missing PDF "' + T + '".') : new n.UnexpectedResponseException(`Unexpected server response (${r}) while retrieving PDF "${T}".`, r);
+          }
+          function o(r) {
+            return r === 200 || r === 206;
+          }
+        },
+        /* 21 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.getFilenameFromContentDispositionHeader = s;
+          var n = i(1);
+          function s(l) {
+            let h = !0, _ = c("filename\\*", "i").exec(l);
+            if (_) {
+              _ = _[1];
+              let P = S(_);
+              return P = unescape(P), P = w(P), P = C(P), r(P);
+            }
+            if (_ = T(l), _) {
+              const P = C(_);
+              return r(P);
+            }
+            if (_ = c("filename", "i").exec(l), _) {
+              _ = _[1];
+              let P = S(_);
+              return P = C(P), r(P);
+            }
+            function c(P, b) {
+              return new RegExp("(?:^|;)\\s*" + P + '\\s*=\\s*([^";\\s][^;\\s]*|"(?:[^"\\\\]|\\\\"?)+"?)', b);
+            }
+            function o(P, b) {
+              if (P) {
+                if (!/^[\x00-\xFF]+$/.test(b))
+                  return b;
+                try {
+                  const k = new TextDecoder(P, {
+                    fatal: !0
+                  }), F = (0, n.stringToBytes)(b);
+                  b = k.decode(F), h = !1;
+                } catch {
+                }
+              }
+              return b;
+            }
+            function r(P) {
+              return h && /[\x80-\xff]/.test(P) && (P = o("utf-8", P), h && (P = o("iso-8859-1", P))), P;
+            }
+            function T(P) {
+              const b = [];
+              let k;
+              const F = c("filename\\*((?!0\\d)\\d+)(\\*?)", "ig");
+              for (; (k = F.exec(P)) !== null; ) {
+                let [, y, p, E] = k;
+                if (y = parseInt(y, 10), y in b) {
+                  if (y === 0)
+                    break;
+                  continue;
+                }
+                b[y] = [p, E];
+              }
+              const x = [];
+              for (let y = 0; y < b.length && y in b; ++y) {
+                let [p, E] = b[y];
+                E = S(E), p && (E = unescape(E), y === 0 && (E = w(E))), x.push(E);
+              }
+              return x.join("");
+            }
+            function S(P) {
+              if (P.startsWith('"')) {
+                const b = P.slice(1).split('\\"');
+                for (let k = 0; k < b.length; ++k) {
+                  const F = b[k].indexOf('"');
+                  F !== -1 && (b[k] = b[k].slice(0, F), b.length = k + 1), b[k] = b[k].replaceAll(/\\(.)/g, "$1");
+                }
+                P = b.join('"');
+              }
+              return P;
+            }
+            function w(P) {
+              const b = P.indexOf("'");
+              if (b === -1)
+                return P;
+              const k = P.slice(0, b), x = P.slice(b + 1).replace(/^[^']*'/, "");
+              return o(k, x);
+            }
+            function C(P) {
+              return !P.startsWith("=?") || /[\x00-\x19\x80-\xff]/.test(P) ? P : P.replaceAll(/=\?([\w-]*)\?([QqBb])\?((?:[^?]|\?(?!=))*)\?=/g, function(b, k, F, x) {
+                if (F === "q" || F === "Q")
+                  return x = x.replaceAll("_", " "), x = x.replaceAll(/=([0-9a-fA-F]{2})/g, function(y, p) {
+                    return String.fromCharCode(parseInt(p, 16));
+                  }), o(k, x);
+                try {
+                  x = atob(x);
+                } catch {
+                }
+                return o(k, x);
+              });
+            }
+            return "";
+          }
+        },
+        /* 22 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.PDFNetworkStream = void 0;
+          var n = i(1), s = i(20);
+          const l = 200, h = 206;
+          function _(S) {
+            const w = S.response;
+            return typeof w != "string" ? w : (0, n.stringToBytes)(w).buffer;
+          }
+          class c {
+            constructor(w, C = {}) {
+              this.url = w, this.isHttp = /^https?:/i.test(w), this.httpHeaders = this.isHttp && C.httpHeaders || /* @__PURE__ */ Object.create(null), this.withCredentials = C.withCredentials || !1, this.currXhrId = 0, this.pendingRequests = /* @__PURE__ */ Object.create(null);
+            }
+            requestRange(w, C, P) {
+              const b = {
+                begin: w,
+                end: C
+              };
+              for (const k in P)
+                b[k] = P[k];
+              return this.request(b);
+            }
+            requestFull(w) {
+              return this.request(w);
+            }
+            request(w) {
+              const C = new XMLHttpRequest(), P = this.currXhrId++, b = this.pendingRequests[P] = {
+                xhr: C
+              };
+              C.open("GET", this.url), C.withCredentials = this.withCredentials;
+              for (const k in this.httpHeaders) {
+                const F = this.httpHeaders[k];
+                F !== void 0 && C.setRequestHeader(k, F);
+              }
+              return this.isHttp && "begin" in w && "end" in w ? (C.setRequestHeader("Range", `bytes=${w.begin}-${w.end - 1}`), b.expectedStatus = h) : b.expectedStatus = l, C.responseType = "arraybuffer", w.onError && (C.onerror = function(k) {
+                w.onError(C.status);
+              }), C.onreadystatechange = this.onStateChange.bind(this, P), C.onprogress = this.onProgress.bind(this, P), b.onHeadersReceived = w.onHeadersReceived, b.onDone = w.onDone, b.onError = w.onError, b.onProgress = w.onProgress, C.send(null), P;
+            }
+            onProgress(w, C) {
+              var b;
+              const P = this.pendingRequests[w];
+              P && ((b = P.onProgress) == null || b.call(P, C));
+            }
+            onStateChange(w, C) {
+              var y, p, E;
+              const P = this.pendingRequests[w];
+              if (!P)
+                return;
+              const b = P.xhr;
+              if (b.readyState >= 2 && P.onHeadersReceived && (P.onHeadersReceived(), delete P.onHeadersReceived), b.readyState !== 4 || !(w in this.pendingRequests))
+                return;
+              if (delete this.pendingRequests[w], b.status === 0 && this.isHttp) {
+                (y = P.onError) == null || y.call(P, b.status);
+                return;
+              }
+              const k = b.status || l;
+              if (!(k === l && P.expectedStatus === h) && k !== P.expectedStatus) {
+                (p = P.onError) == null || p.call(P, b.status);
+                return;
+              }
+              const x = _(b);
+              if (k === h) {
+                const $ = b.getResponseHeader("Content-Range"), M = /bytes (\d+)-(\d+)\/(\d+)/.exec($);
+                P.onDone({
+                  begin: parseInt(M[1], 10),
+                  chunk: x
+                });
+              } else
+                x ? P.onDone({
+                  begin: 0,
+                  chunk: x
+                }) : (E = P.onError) == null || E.call(P, b.status);
+            }
+            getRequestXhr(w) {
+              return this.pendingRequests[w].xhr;
+            }
+            isPendingRequest(w) {
+              return w in this.pendingRequests;
+            }
+            abortRequest(w) {
+              const C = this.pendingRequests[w].xhr;
+              delete this.pendingRequests[w], C.abort();
+            }
+          }
+          class o {
+            constructor(w) {
+              this._source = w, this._manager = new c(w.url, {
+                httpHeaders: w.httpHeaders,
+                withCredentials: w.withCredentials
+              }), this._rangeChunkSize = w.rangeChunkSize, this._fullRequestReader = null, this._rangeRequestReaders = [];
+            }
+            _onRangeRequestReaderClosed(w) {
+              const C = this._rangeRequestReaders.indexOf(w);
+              C >= 0 && this._rangeRequestReaders.splice(C, 1);
+            }
+            getFullReader() {
+              return (0, n.assert)(!this._fullRequestReader, "PDFNetworkStream.getFullReader can only be called once."), this._fullRequestReader = new r(this._manager, this._source), this._fullRequestReader;
+            }
+            getRangeReader(w, C) {
+              const P = new T(this._manager, w, C);
+              return P.onClosed = this._onRangeRequestReaderClosed.bind(this), this._rangeRequestReaders.push(P), P;
+            }
+            cancelAllRequests(w) {
+              var C;
+              (C = this._fullRequestReader) == null || C.cancel(w);
+              for (const P of this._rangeRequestReaders.slice(0))
+                P.cancel(w);
+            }
+          }
+          e.PDFNetworkStream = o;
+          class r {
+            constructor(w, C) {
+              this._manager = w;
+              const P = {
+                onHeadersReceived: this._onHeadersReceived.bind(this),
+                onDone: this._onDone.bind(this),
+                onError: this._onError.bind(this),
+                onProgress: this._onProgress.bind(this)
+              };
+              this._url = C.url, this._fullRequestId = w.requestFull(P), this._headersReceivedCapability = new n.PromiseCapability(), this._disableRange = C.disableRange || !1, this._contentLength = C.length, this._rangeChunkSize = C.rangeChunkSize, !this._rangeChunkSize && !this._disableRange && (this._disableRange = !0), this._isStreamingSupported = !1, this._isRangeSupported = !1, this._cachedChunks = [], this._requests = [], this._done = !1, this._storedError = void 0, this._filename = null, this.onProgress = null;
+            }
+            _onHeadersReceived() {
+              const w = this._fullRequestId, C = this._manager.getRequestXhr(w), P = (F) => C.getResponseHeader(F), {
+                allowRangeRequests: b,
+                suggestedLength: k
+              } = (0, s.validateRangeRequestCapabilities)({
+                getResponseHeader: P,
+                isHttp: this._manager.isHttp,
+                rangeChunkSize: this._rangeChunkSize,
+                disableRange: this._disableRange
+              });
+              b && (this._isRangeSupported = !0), this._contentLength = k || this._contentLength, this._filename = (0, s.extractFilenameFromHeader)(P), this._isRangeSupported && this._manager.abortRequest(w), this._headersReceivedCapability.resolve();
+            }
+            _onDone(w) {
+              if (w && (this._requests.length > 0 ? this._requests.shift().resolve({
+                value: w.chunk,
+                done: !1
+              }) : this._cachedChunks.push(w.chunk)), this._done = !0, !(this._cachedChunks.length > 0)) {
+                for (const C of this._requests)
+                  C.resolve({
+                    value: void 0,
+                    done: !0
+                  });
+                this._requests.length = 0;
+              }
+            }
+            _onError(w) {
+              this._storedError = (0, s.createResponseStatusError)(w, this._url), this._headersReceivedCapability.reject(this._storedError);
+              for (const C of this._requests)
+                C.reject(this._storedError);
+              this._requests.length = 0, this._cachedChunks.length = 0;
+            }
+            _onProgress(w) {
+              var C;
+              (C = this.onProgress) == null || C.call(this, {
+                loaded: w.loaded,
+                total: w.lengthComputable ? w.total : this._contentLength
+              });
+            }
+            get filename() {
+              return this._filename;
+            }
+            get isRangeSupported() {
+              return this._isRangeSupported;
+            }
+            get isStreamingSupported() {
+              return this._isStreamingSupported;
+            }
+            get contentLength() {
+              return this._contentLength;
+            }
+            get headersReady() {
+              return this._headersReceivedCapability.promise;
+            }
+            async read() {
+              if (this._storedError)
+                throw this._storedError;
+              if (this._cachedChunks.length > 0)
+                return {
+                  value: this._cachedChunks.shift(),
+                  done: !1
+                };
+              if (this._done)
+                return {
+                  value: void 0,
+                  done: !0
+                };
+              const w = new n.PromiseCapability();
+              return this._requests.push(w), w.promise;
+            }
+            cancel(w) {
+              this._done = !0, this._headersReceivedCapability.reject(w);
+              for (const C of this._requests)
+                C.resolve({
+                  value: void 0,
+                  done: !0
+                });
+              this._requests.length = 0, this._manager.isPendingRequest(this._fullRequestId) && this._manager.abortRequest(this._fullRequestId), this._fullRequestReader = null;
+            }
+          }
+          class T {
+            constructor(w, C, P) {
+              this._manager = w;
+              const b = {
+                onDone: this._onDone.bind(this),
+                onError: this._onError.bind(this),
+                onProgress: this._onProgress.bind(this)
+              };
+              this._url = w.url, this._requestId = w.requestRange(C, P, b), this._requests = [], this._queuedChunk = null, this._done = !1, this._storedError = void 0, this.onProgress = null, this.onClosed = null;
+            }
+            _close() {
+              var w;
+              (w = this.onClosed) == null || w.call(this, this);
+            }
+            _onDone(w) {
+              const C = w.chunk;
+              this._requests.length > 0 ? this._requests.shift().resolve({
+                value: C,
+                done: !1
+              }) : this._queuedChunk = C, this._done = !0;
+              for (const P of this._requests)
+                P.resolve({
+                  value: void 0,
+                  done: !0
+                });
+              this._requests.length = 0, this._close();
+            }
+            _onError(w) {
+              this._storedError = (0, s.createResponseStatusError)(w, this._url);
+              for (const C of this._requests)
+                C.reject(this._storedError);
+              this._requests.length = 0, this._queuedChunk = null;
+            }
+            _onProgress(w) {
+              var C;
+              this.isStreamingSupported || (C = this.onProgress) == null || C.call(this, {
+                loaded: w.loaded
+              });
+            }
+            get isStreamingSupported() {
+              return !1;
+            }
+            async read() {
+              if (this._storedError)
+                throw this._storedError;
+              if (this._queuedChunk !== null) {
+                const C = this._queuedChunk;
+                return this._queuedChunk = null, {
+                  value: C,
+                  done: !1
+                };
+              }
+              if (this._done)
+                return {
+                  value: void 0,
+                  done: !0
+                };
+              const w = new n.PromiseCapability();
+              return this._requests.push(w), w.promise;
+            }
+            cancel(w) {
+              this._done = !0;
+              for (const C of this._requests)
+                C.resolve({
+                  value: void 0,
+                  done: !0
+                });
+              this._requests.length = 0, this._manager.isPendingRequest(this._requestId) && this._manager.abortRequest(this._requestId), this._close();
+            }
+          }
+        },
+        /* 23 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.PDFNodeStream = void 0;
+          var n = i(1), s = i(20);
+          const l = /^file:\/\/\/[a-zA-Z]:\//;
+          function h(P) {
+            const b = require$$5, k = b.parse(P);
+            return k.protocol === "file:" || k.host ? k : /^[a-z]:[/\\]/i.test(P) ? b.parse(`file:///${P}`) : (k.host || (k.protocol = "file:"), k);
+          }
+          class _ {
+            constructor(b) {
+              this.source = b, this.url = h(b.url), this.isHttp = this.url.protocol === "http:" || this.url.protocol === "https:", this.isFsUrl = this.url.protocol === "file:", this.httpHeaders = this.isHttp && b.httpHeaders || {}, this._fullRequestReader = null, this._rangeRequestReaders = [];
+            }
+            get _progressiveDataLength() {
+              var b;
+              return ((b = this._fullRequestReader) == null ? void 0 : b._loaded) ?? 0;
+            }
+            getFullReader() {
+              return (0, n.assert)(!this._fullRequestReader, "PDFNodeStream.getFullReader can only be called once."), this._fullRequestReader = this.isFsUrl ? new w(this) : new T(this), this._fullRequestReader;
+            }
+            getRangeReader(b, k) {
+              if (k <= this._progressiveDataLength)
+                return null;
+              const F = this.isFsUrl ? new C(this, b, k) : new S(this, b, k);
+              return this._rangeRequestReaders.push(F), F;
+            }
+            cancelAllRequests(b) {
+              var k;
+              (k = this._fullRequestReader) == null || k.cancel(b);
+              for (const F of this._rangeRequestReaders.slice(0))
+                F.cancel(b);
+            }
+          }
+          e.PDFNodeStream = _;
+          class c {
+            constructor(b) {
+              this._url = b.url, this._done = !1, this._storedError = null, this.onProgress = null;
+              const k = b.source;
+              this._contentLength = k.length, this._loaded = 0, this._filename = null, this._disableRange = k.disableRange || !1, this._rangeChunkSize = k.rangeChunkSize, !this._rangeChunkSize && !this._disableRange && (this._disableRange = !0), this._isStreamingSupported = !k.disableStream, this._isRangeSupported = !k.disableRange, this._readableStream = null, this._readCapability = new n.PromiseCapability(), this._headersCapability = new n.PromiseCapability();
+            }
+            get headersReady() {
+              return this._headersCapability.promise;
+            }
+            get filename() {
+              return this._filename;
+            }
+            get contentLength() {
+              return this._contentLength;
+            }
+            get isRangeSupported() {
+              return this._isRangeSupported;
+            }
+            get isStreamingSupported() {
+              return this._isStreamingSupported;
+            }
+            async read() {
+              var F;
+              if (await this._readCapability.promise, this._done)
+                return {
+                  value: void 0,
+                  done: !0
+                };
+              if (this._storedError)
+                throw this._storedError;
+              const b = this._readableStream.read();
+              return b === null ? (this._readCapability = new n.PromiseCapability(), this.read()) : (this._loaded += b.length, (F = this.onProgress) == null || F.call(this, {
+                loaded: this._loaded,
+                total: this._contentLength
+              }), {
+                value: new Uint8Array(b).buffer,
+                done: !1
+              });
+            }
+            cancel(b) {
+              if (!this._readableStream) {
+                this._error(b);
+                return;
+              }
+              this._readableStream.destroy(b);
+            }
+            _error(b) {
+              this._storedError = b, this._readCapability.resolve();
+            }
+            _setReadableStream(b) {
+              this._readableStream = b, b.on("readable", () => {
+                this._readCapability.resolve();
+              }), b.on("end", () => {
+                b.destroy(), this._done = !0, this._readCapability.resolve();
+              }), b.on("error", (k) => {
+                this._error(k);
+              }), !this._isStreamingSupported && this._isRangeSupported && this._error(new n.AbortException("streaming is disabled")), this._storedError && this._readableStream.destroy(this._storedError);
+            }
+          }
+          class o {
+            constructor(b) {
+              this._url = b.url, this._done = !1, this._storedError = null, this.onProgress = null, this._loaded = 0, this._readableStream = null, this._readCapability = new n.PromiseCapability();
+              const k = b.source;
+              this._isStreamingSupported = !k.disableStream;
+            }
+            get isStreamingSupported() {
+              return this._isStreamingSupported;
+            }
+            async read() {
+              var F;
+              if (await this._readCapability.promise, this._done)
+                return {
+                  value: void 0,
+                  done: !0
+                };
+              if (this._storedError)
+                throw this._storedError;
+              const b = this._readableStream.read();
+              return b === null ? (this._readCapability = new n.PromiseCapability(), this.read()) : (this._loaded += b.length, (F = this.onProgress) == null || F.call(this, {
+                loaded: this._loaded
+              }), {
+                value: new Uint8Array(b).buffer,
+                done: !1
+              });
+            }
+            cancel(b) {
+              if (!this._readableStream) {
+                this._error(b);
+                return;
+              }
+              this._readableStream.destroy(b);
+            }
+            _error(b) {
+              this._storedError = b, this._readCapability.resolve();
+            }
+            _setReadableStream(b) {
+              this._readableStream = b, b.on("readable", () => {
+                this._readCapability.resolve();
+              }), b.on("end", () => {
+                b.destroy(), this._done = !0, this._readCapability.resolve();
+              }), b.on("error", (k) => {
+                this._error(k);
+              }), this._storedError && this._readableStream.destroy(this._storedError);
+            }
+          }
+          function r(P, b) {
+            return {
+              protocol: P.protocol,
+              auth: P.auth,
+              host: P.hostname,
+              port: P.port,
+              path: P.path,
+              method: "GET",
+              headers: b
+            };
+          }
+          class T extends c {
+            constructor(b) {
+              super(b);
+              const k = (F) => {
+                if (F.statusCode === 404) {
+                  const E = new n.MissingPDFException(`Missing PDF "${this._url}".`);
+                  this._storedError = E, this._headersCapability.reject(E);
+                  return;
+                }
+                this._headersCapability.resolve(), this._setReadableStream(F);
+                const x = (E) => this._readableStream.headers[E.toLowerCase()], {
+                  allowRangeRequests: y,
+                  suggestedLength: p
+                } = (0, s.validateRangeRequestCapabilities)({
+                  getResponseHeader: x,
+                  isHttp: b.isHttp,
+                  rangeChunkSize: this._rangeChunkSize,
+                  disableRange: this._disableRange
+                });
+                this._isRangeSupported = y, this._contentLength = p || this._contentLength, this._filename = (0, s.extractFilenameFromHeader)(x);
+              };
+              if (this._request = null, this._url.protocol === "http:") {
+                const F = require$$5;
+                this._request = F.request(r(this._url, b.httpHeaders), k);
+              } else {
+                const F = require$$5;
+                this._request = F.request(r(this._url, b.httpHeaders), k);
+              }
+              this._request.on("error", (F) => {
+                this._storedError = F, this._headersCapability.reject(F);
+              }), this._request.end();
+            }
+          }
+          class S extends o {
+            constructor(b, k, F) {
+              super(b), this._httpHeaders = {};
+              for (const y in b.httpHeaders) {
+                const p = b.httpHeaders[y];
+                p !== void 0 && (this._httpHeaders[y] = p);
+              }
+              this._httpHeaders.Range = `bytes=${k}-${F - 1}`;
+              const x = (y) => {
+                if (y.statusCode === 404) {
+                  const p = new n.MissingPDFException(`Missing PDF "${this._url}".`);
+                  this._storedError = p;
+                  return;
+                }
+                this._setReadableStream(y);
+              };
+              if (this._request = null, this._url.protocol === "http:") {
+                const y = require$$5;
+                this._request = y.request(r(this._url, this._httpHeaders), x);
+              } else {
+                const y = require$$5;
+                this._request = y.request(r(this._url, this._httpHeaders), x);
+              }
+              this._request.on("error", (y) => {
+                this._storedError = y;
+              }), this._request.end();
+            }
+          }
+          class w extends c {
+            constructor(b) {
+              super(b);
+              let k = decodeURIComponent(this._url.path);
+              l.test(this._url.href) && (k = k.replace(/^\//, ""));
+              const F = require$$5;
+              F.lstat(k, (x, y) => {
+                if (x) {
+                  x.code === "ENOENT" && (x = new n.MissingPDFException(`Missing PDF "${k}".`)), this._storedError = x, this._headersCapability.reject(x);
+                  return;
+                }
+                this._contentLength = y.size, this._setReadableStream(F.createReadStream(k)), this._headersCapability.resolve();
+              });
+            }
+          }
+          class C extends o {
+            constructor(b, k, F) {
+              super(b);
+              let x = decodeURIComponent(this._url.path);
+              l.test(this._url.href) && (x = x.replace(/^\//, ""));
+              const y = require$$5;
+              this._setReadableStream(y.createReadStream(x, {
+                start: k,
+                end: F - 1
+              }));
+            }
+          }
+        },
+        /* 24 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.SVGGraphics = void 0;
+          var n = i(6), s = i(1);
+          const l = {
+            fontStyle: "normal",
+            fontWeight: "normal",
+            fillColor: "#000000"
+          }, h = "http://www.w3.org/XML/1998/namespace", _ = "http://www.w3.org/1999/xlink", c = ["butt", "round", "square"], o = ["miter", "round", "bevel"], r = function(y, p = "", E = !1) {
+            if (URL.createObjectURL && typeof Blob < "u" && !E)
+              return URL.createObjectURL(new Blob([y], {
+                type: p
+              }));
+            const $ = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
+            let M = `data:${p};base64,`;
+            for (let m = 0, N = y.length; m < N; m += 3) {
+              const D = y[m] & 255, X = y[m + 1] & 255, G = y[m + 2] & 255, I = D >> 2, B = (D & 3) << 4 | X >> 4, ee = m + 1 < N ? (X & 15) << 2 | G >> 6 : 64, Y = m + 2 < N ? G & 63 : 64;
+              M += $[I] + $[B] + $[ee] + $[Y];
+            }
+            return M;
+          }, T = function() {
+            const y = new Uint8Array([137, 80, 78, 71, 13, 10, 26, 10]), p = 12, E = new Int32Array(256);
+            for (let G = 0; G < 256; G++) {
+              let I = G;
+              for (let B = 0; B < 8; B++)
+                I = I & 1 ? 3988292384 ^ I >> 1 & 2147483647 : I >> 1 & 2147483647;
+              E[G] = I;
+            }
+            function $(G, I, B) {
+              let ee = -1;
+              for (let Y = I; Y < B; Y++) {
+                const q = (ee ^ G[Y]) & 255, le = E[q];
+                ee = ee >>> 8 ^ le;
+              }
+              return ee ^ -1;
+            }
+            function M(G, I, B, ee) {
+              let Y = ee;
+              const q = I.length;
+              B[Y] = q >> 24 & 255, B[Y + 1] = q >> 16 & 255, B[Y + 2] = q >> 8 & 255, B[Y + 3] = q & 255, Y += 4, B[Y] = G.charCodeAt(0) & 255, B[Y + 1] = G.charCodeAt(1) & 255, B[Y + 2] = G.charCodeAt(2) & 255, B[Y + 3] = G.charCodeAt(3) & 255, Y += 4, B.set(I, Y), Y += I.length;
+              const le = $(B, ee + 4, Y);
+              B[Y] = le >> 24 & 255, B[Y + 1] = le >> 16 & 255, B[Y + 2] = le >> 8 & 255, B[Y + 3] = le & 255;
+            }
+            function m(G, I, B) {
+              let ee = 1, Y = 0;
+              for (let q = I; q < B; ++q)
+                ee = (ee + (G[q] & 255)) % 65521, Y = (Y + ee) % 65521;
+              return Y << 16 | ee;
+            }
+            function N(G) {
+              if (!s.isNodeJS)
+                return D(G);
+              try {
+                const I = parseInt(process.versions.node) >= 8 ? G : Buffer.from(G), B = require$$5.deflateSync(I, {
+                  level: 9
+                });
+                return B instanceof Uint8Array ? B : new Uint8Array(B);
+              } catch (I) {
+                (0, s.warn)("Not compressing PNG because zlib.deflateSync is unavailable: " + I);
+              }
+              return D(G);
+            }
+            function D(G) {
+              let I = G.length;
+              const B = 65535, ee = Math.ceil(I / B), Y = new Uint8Array(2 + I + ee * 5 + 4);
+              let q = 0;
+              Y[q++] = 120, Y[q++] = 156;
+              let le = 0;
+              for (; I > B; )
+                Y[q++] = 0, Y[q++] = 255, Y[q++] = 255, Y[q++] = 0, Y[q++] = 0, Y.set(G.subarray(le, le + B), q), q += B, le += B, I -= B;
+              Y[q++] = 1, Y[q++] = I & 255, Y[q++] = I >> 8 & 255, Y[q++] = ~I & 65535 & 255, Y[q++] = (~I & 65535) >> 8 & 255, Y.set(G.subarray(le), q), q += G.length - le;
+              const pe = m(G, 0, G.length);
+              return Y[q++] = pe >> 24 & 255, Y[q++] = pe >> 16 & 255, Y[q++] = pe >> 8 & 255, Y[q++] = pe & 255, Y;
+            }
+            function X(G, I, B, ee) {
+              const Y = G.width, q = G.height;
+              let le, pe, we;
+              const be = G.data;
+              switch (I) {
+                case s.ImageKind.GRAYSCALE_1BPP:
+                  pe = 0, le = 1, we = Y + 7 >> 3;
+                  break;
+                case s.ImageKind.RGB_24BPP:
+                  pe = 2, le = 8, we = Y * 3;
+                  break;
+                case s.ImageKind.RGBA_32BPP:
+                  pe = 6, le = 8, we = Y * 4;
+                  break;
+                default:
+                  throw new Error("invalid format");
+              }
+              const R = new Uint8Array((1 + we) * q);
+              let d = 0, g = 0;
+              for (let z = 0; z < q; ++z)
+                R[d++] = 0, R.set(be.subarray(g, g + we), d), g += we, d += we;
+              if (I === s.ImageKind.GRAYSCALE_1BPP && ee) {
+                d = 0;
+                for (let z = 0; z < q; z++) {
+                  d++;
+                  for (let ae = 0; ae < we; ae++)
+                    R[d++] ^= 255;
+                }
+              }
+              const f = new Uint8Array([Y >> 24 & 255, Y >> 16 & 255, Y >> 8 & 255, Y & 255, q >> 24 & 255, q >> 16 & 255, q >> 8 & 255, q & 255, le, pe, 0, 0, 0]), v = N(R), A = y.length + p * 3 + f.length + v.length, O = new Uint8Array(A);
+              let H = 0;
+              return O.set(y, H), H += y.length, M("IHDR", f, O, H), H += p + f.length, M("IDATA", v, O, H), H += p + v.length, M("IEND", new Uint8Array(0), O, H), r(O, "image/png", B);
+            }
+            return function(I, B, ee) {
+              const Y = I.kind === void 0 ? s.ImageKind.GRAYSCALE_1BPP : I.kind;
+              return X(I, Y, B, ee);
+            };
+          }();
+          class S {
+            constructor() {
+              this.fontSizeScale = 1, this.fontWeight = l.fontWeight, this.fontSize = 0, this.textMatrix = s.IDENTITY_MATRIX, this.fontMatrix = s.FONT_IDENTITY_MATRIX, this.leading = 0, this.textRenderingMode = s.TextRenderingMode.FILL, this.textMatrixScale = 1, this.x = 0, this.y = 0, this.lineX = 0, this.lineY = 0, this.charSpacing = 0, this.wordSpacing = 0, this.textHScale = 1, this.textRise = 0, this.fillColor = l.fillColor, this.strokeColor = "#000000", this.fillAlpha = 1, this.strokeAlpha = 1, this.lineWidth = 1, this.lineJoin = "", this.lineCap = "", this.miterLimit = 0, this.dashArray = [], this.dashPhase = 0, this.dependencies = [], this.activeClipUrl = null, this.clipGroup = null, this.maskId = "";
+            }
+            clone() {
+              return Object.create(this);
+            }
+            setCurrentPoint(p, E) {
+              this.x = p, this.y = E;
+            }
+          }
+          function w(y) {
+            let p = [];
+            const E = [];
+            for (const $ of y) {
+              if ($.fn === "save") {
+                p.push({
+                  fnId: 92,
+                  fn: "group",
+                  items: []
+                }), E.push(p), p = p.at(-1).items;
+                continue;
+              }
+              $.fn === "restore" ? p = E.pop() : p.push($);
+            }
+            return p;
+          }
+          function C(y) {
+            if (Number.isInteger(y))
+              return y.toString();
+            const p = y.toFixed(10);
+            let E = p.length - 1;
+            if (p[E] !== "0")
+              return p;
+            do
+              E--;
+            while (p[E] === "0");
+            return p.substring(0, p[E] === "." ? E : E + 1);
+          }
+          function P(y) {
+            if (y[4] === 0 && y[5] === 0) {
+              if (y[1] === 0 && y[2] === 0)
+                return y[0] === 1 && y[3] === 1 ? "" : `scale(${C(y[0])} ${C(y[3])})`;
+              if (y[0] === y[3] && y[1] === -y[2]) {
+                const p = Math.acos(y[0]) * 180 / Math.PI;
+                return `rotate(${C(p)})`;
+              }
+            } else if (y[0] === 1 && y[1] === 0 && y[2] === 0 && y[3] === 1)
+              return `translate(${C(y[4])} ${C(y[5])})`;
+            return `matrix(${C(y[0])} ${C(y[1])} ${C(y[2])} ${C(y[3])} ${C(y[4])} ${C(y[5])})`;
+          }
+          let b = 0, k = 0, F = 0;
+          class x {
+            constructor(p, E, $ = !1) {
+              (0, n.deprecated)("The SVG back-end is no longer maintained and *may* be removed in the future."), this.svgFactory = new n.DOMSVGFactory(), this.current = new S(), this.transformMatrix = s.IDENTITY_MATRIX, this.transformStack = [], this.extraStack = [], this.commonObjs = p, this.objs = E, this.pendingClip = null, this.pendingEOFill = !1, this.embedFonts = !1, this.embeddedFonts = /* @__PURE__ */ Object.create(null), this.cssStyle = null, this.forceDataSchema = !!$, this._operatorIdMapping = [];
+              for (const M in s.OPS)
+                this._operatorIdMapping[s.OPS[M]] = M;
+            }
+            getObject(p, E = null) {
+              return typeof p == "string" ? p.startsWith("g_") ? this.commonObjs.get(p) : this.objs.get(p) : E;
+            }
+            save() {
+              this.transformStack.push(this.transformMatrix);
+              const p = this.current;
+              this.extraStack.push(p), this.current = p.clone();
+            }
+            restore() {
+              this.transformMatrix = this.transformStack.pop(), this.current = this.extraStack.pop(), this.pendingClip = null, this.tgrp = null;
+            }
+            group(p) {
+              this.save(), this.executeOpTree(p), this.restore();
+            }
+            loadDependencies(p) {
+              const E = p.fnArray, $ = p.argsArray;
+              for (let M = 0, m = E.length; M < m; M++)
+                if (E[M] === s.OPS.dependency)
+                  for (const N of $[M]) {
+                    const D = N.startsWith("g_") ? this.commonObjs : this.objs, X = new Promise((G) => {
+                      D.get(N, G);
+                    });
+                    this.current.dependencies.push(X);
+                  }
+              return Promise.all(this.current.dependencies);
+            }
+            transform(p, E, $, M, m, N) {
+              const D = [p, E, $, M, m, N];
+              this.transformMatrix = s.Util.transform(this.transformMatrix, D), this.tgrp = null;
+            }
+            getSVG(p, E) {
+              this.viewport = E;
+              const $ = this._initialize(E);
+              return this.loadDependencies(p).then(() => (this.transformMatrix = s.IDENTITY_MATRIX, this.executeOpTree(this.convertOpList(p)), $));
+            }
+            convertOpList(p) {
+              const E = this._operatorIdMapping, $ = p.argsArray, M = p.fnArray, m = [];
+              for (let N = 0, D = M.length; N < D; N++) {
+                const X = M[N];
+                m.push({
+                  fnId: X,
+                  fn: E[X],
+                  args: $[N]
+                });
+              }
+              return w(m);
+            }
+            executeOpTree(p) {
+              for (const E of p) {
+                const $ = E.fn, M = E.fnId, m = E.args;
+                switch (M | 0) {
+                  case s.OPS.beginText:
+                    this.beginText();
+                    break;
+                  case s.OPS.dependency:
+                    break;
+                  case s.OPS.setLeading:
+                    this.setLeading(m);
+                    break;
+                  case s.OPS.setLeadingMoveText:
+                    this.setLeadingMoveText(m[0], m[1]);
+                    break;
+                  case s.OPS.setFont:
+                    this.setFont(m);
+                    break;
+                  case s.OPS.showText:
+                    this.showText(m[0]);
+                    break;
+                  case s.OPS.showSpacedText:
+                    this.showText(m[0]);
+                    break;
+                  case s.OPS.endText:
+                    this.endText();
+                    break;
+                  case s.OPS.moveText:
+                    this.moveText(m[0], m[1]);
+                    break;
+                  case s.OPS.setCharSpacing:
+                    this.setCharSpacing(m[0]);
+                    break;
+                  case s.OPS.setWordSpacing:
+                    this.setWordSpacing(m[0]);
+                    break;
+                  case s.OPS.setHScale:
+                    this.setHScale(m[0]);
+                    break;
+                  case s.OPS.setTextMatrix:
+                    this.setTextMatrix(m[0], m[1], m[2], m[3], m[4], m[5]);
+                    break;
+                  case s.OPS.setTextRise:
+                    this.setTextRise(m[0]);
+                    break;
+                  case s.OPS.setTextRenderingMode:
+                    this.setTextRenderingMode(m[0]);
+                    break;
+                  case s.OPS.setLineWidth:
+                    this.setLineWidth(m[0]);
+                    break;
+                  case s.OPS.setLineJoin:
+                    this.setLineJoin(m[0]);
+                    break;
+                  case s.OPS.setLineCap:
+                    this.setLineCap(m[0]);
+                    break;
+                  case s.OPS.setMiterLimit:
+                    this.setMiterLimit(m[0]);
+                    break;
+                  case s.OPS.setFillRGBColor:
+                    this.setFillRGBColor(m[0], m[1], m[2]);
+                    break;
+                  case s.OPS.setStrokeRGBColor:
+                    this.setStrokeRGBColor(m[0], m[1], m[2]);
+                    break;
+                  case s.OPS.setStrokeColorN:
+                    this.setStrokeColorN(m);
+                    break;
+                  case s.OPS.setFillColorN:
+                    this.setFillColorN(m);
+                    break;
+                  case s.OPS.shadingFill:
+                    this.shadingFill(m[0]);
+                    break;
+                  case s.OPS.setDash:
+                    this.setDash(m[0], m[1]);
+                    break;
+                  case s.OPS.setRenderingIntent:
+                    this.setRenderingIntent(m[0]);
+                    break;
+                  case s.OPS.setFlatness:
+                    this.setFlatness(m[0]);
+                    break;
+                  case s.OPS.setGState:
+                    this.setGState(m[0]);
+                    break;
+                  case s.OPS.fill:
+                    this.fill();
+                    break;
+                  case s.OPS.eoFill:
+                    this.eoFill();
+                    break;
+                  case s.OPS.stroke:
+                    this.stroke();
+                    break;
+                  case s.OPS.fillStroke:
+                    this.fillStroke();
+                    break;
+                  case s.OPS.eoFillStroke:
+                    this.eoFillStroke();
+                    break;
+                  case s.OPS.clip:
+                    this.clip("nonzero");
+                    break;
+                  case s.OPS.eoClip:
+                    this.clip("evenodd");
+                    break;
+                  case s.OPS.paintSolidColorImageMask:
+                    this.paintSolidColorImageMask();
+                    break;
+                  case s.OPS.paintImageXObject:
+                    this.paintImageXObject(m[0]);
+                    break;
+                  case s.OPS.paintInlineImageXObject:
+                    this.paintInlineImageXObject(m[0]);
+                    break;
+                  case s.OPS.paintImageMaskXObject:
+                    this.paintImageMaskXObject(m[0]);
+                    break;
+                  case s.OPS.paintFormXObjectBegin:
+                    this.paintFormXObjectBegin(m[0], m[1]);
+                    break;
+                  case s.OPS.paintFormXObjectEnd:
+                    this.paintFormXObjectEnd();
+                    break;
+                  case s.OPS.closePath:
+                    this.closePath();
+                    break;
+                  case s.OPS.closeStroke:
+                    this.closeStroke();
+                    break;
+                  case s.OPS.closeFillStroke:
+                    this.closeFillStroke();
+                    break;
+                  case s.OPS.closeEOFillStroke:
+                    this.closeEOFillStroke();
+                    break;
+                  case s.OPS.nextLine:
+                    this.nextLine();
+                    break;
+                  case s.OPS.transform:
+                    this.transform(m[0], m[1], m[2], m[3], m[4], m[5]);
+                    break;
+                  case s.OPS.constructPath:
+                    this.constructPath(m[0], m[1]);
+                    break;
+                  case s.OPS.endPath:
+                    this.endPath();
+                    break;
+                  case 92:
+                    this.group(E.items);
+                    break;
+                  default:
+                    (0, s.warn)(`Unimplemented operator ${$}`);
+                    break;
+                }
+              }
+            }
+            setWordSpacing(p) {
+              this.current.wordSpacing = p;
+            }
+            setCharSpacing(p) {
+              this.current.charSpacing = p;
+            }
+            nextLine() {
+              this.moveText(0, this.current.leading);
+            }
+            setTextMatrix(p, E, $, M, m, N) {
+              const D = this.current;
+              D.textMatrix = D.lineMatrix = [p, E, $, M, m, N], D.textMatrixScale = Math.hypot(p, E), D.x = D.lineX = 0, D.y = D.lineY = 0, D.xcoords = [], D.ycoords = [], D.tspan = this.svgFactory.createElement("svg:tspan"), D.tspan.setAttributeNS(null, "font-family", D.fontFamily), D.tspan.setAttributeNS(null, "font-size", `${C(D.fontSize)}px`), D.tspan.setAttributeNS(null, "y", C(-D.y)), D.txtElement = this.svgFactory.createElement("svg:text"), D.txtElement.append(D.tspan);
+            }
+            beginText() {
+              const p = this.current;
+              p.x = p.lineX = 0, p.y = p.lineY = 0, p.textMatrix = s.IDENTITY_MATRIX, p.lineMatrix = s.IDENTITY_MATRIX, p.textMatrixScale = 1, p.tspan = this.svgFactory.createElement("svg:tspan"), p.txtElement = this.svgFactory.createElement("svg:text"), p.txtgrp = this.svgFactory.createElement("svg:g"), p.xcoords = [], p.ycoords = [];
+            }
+            moveText(p, E) {
+              const $ = this.current;
+              $.x = $.lineX += p, $.y = $.lineY += E, $.xcoords = [], $.ycoords = [], $.tspan = this.svgFactory.createElement("svg:tspan"), $.tspan.setAttributeNS(null, "font-family", $.fontFamily), $.tspan.setAttributeNS(null, "font-size", `${C($.fontSize)}px`), $.tspan.setAttributeNS(null, "y", C(-$.y));
+            }
+            showText(p) {
+              const E = this.current, $ = E.font, M = E.fontSize;
+              if (M === 0)
+                return;
+              const m = E.fontSizeScale, N = E.charSpacing, D = E.wordSpacing, X = E.fontDirection, G = E.textHScale * X, I = $.vertical, B = I ? 1 : -1, ee = $.defaultVMetrics, Y = M * E.fontMatrix[0];
+              let q = 0;
+              for (const we of p) {
+                if (we === null) {
+                  q += X * D;
+                  continue;
+                } else if (typeof we == "number") {
+                  q += B * we * M / 1e3;
+                  continue;
+                }
+                const be = (we.isSpace ? D : 0) + N, R = we.fontChar;
+                let d, g, f = we.width;
+                if (I) {
+                  let A;
+                  const O = we.vmetric || ee;
+                  A = we.vmetric ? O[1] : f * 0.5, A = -A * Y;
+                  const H = O[2] * Y;
+                  f = O ? -O[0] : f, d = A / m, g = (q + H) / m;
+                } else
+                  d = q / m, g = 0;
+                (we.isInFont || $.missingFile) && (E.xcoords.push(E.x + d), I && E.ycoords.push(-E.y + g), E.tspan.textContent += R);
+                const v = I ? f * Y - be * X : f * Y + be * X;
+                q += v;
+              }
+              E.tspan.setAttributeNS(null, "x", E.xcoords.map(C).join(" ")), I ? E.tspan.setAttributeNS(null, "y", E.ycoords.map(C).join(" ")) : E.tspan.setAttributeNS(null, "y", C(-E.y)), I ? E.y -= q : E.x += q * G, E.tspan.setAttributeNS(null, "font-family", E.fontFamily), E.tspan.setAttributeNS(null, "font-size", `${C(E.fontSize)}px`), E.fontStyle !== l.fontStyle && E.tspan.setAttributeNS(null, "font-style", E.fontStyle), E.fontWeight !== l.fontWeight && E.tspan.setAttributeNS(null, "font-weight", E.fontWeight);
+              const le = E.textRenderingMode & s.TextRenderingMode.FILL_STROKE_MASK;
+              if (le === s.TextRenderingMode.FILL || le === s.TextRenderingMode.FILL_STROKE ? (E.fillColor !== l.fillColor && E.tspan.setAttributeNS(null, "fill", E.fillColor), E.fillAlpha < 1 && E.tspan.setAttributeNS(null, "fill-opacity", E.fillAlpha)) : E.textRenderingMode === s.TextRenderingMode.ADD_TO_PATH ? E.tspan.setAttributeNS(null, "fill", "transparent") : E.tspan.setAttributeNS(null, "fill", "none"), le === s.TextRenderingMode.STROKE || le === s.TextRenderingMode.FILL_STROKE) {
+                const we = 1 / (E.textMatrixScale || 1);
+                this._setStrokeAttributes(E.tspan, we);
+              }
+              let pe = E.textMatrix;
+              E.textRise !== 0 && (pe = pe.slice(), pe[5] += E.textRise), E.txtElement.setAttributeNS(null, "transform", `${P(pe)} scale(${C(G)}, -1)`), E.txtElement.setAttributeNS(h, "xml:space", "preserve"), E.txtElement.append(E.tspan), E.txtgrp.append(E.txtElement), this._ensureTransformGroup().append(E.txtElement);
+            }
+            setLeadingMoveText(p, E) {
+              this.setLeading(-E), this.moveText(p, E);
+            }
+            addFontStyle(p) {
+              if (!p.data)
+                throw new Error('addFontStyle: No font data available, ensure that the "fontExtraProperties" API parameter is set.');
+              this.cssStyle || (this.cssStyle = this.svgFactory.createElement("svg:style"), this.cssStyle.setAttributeNS(null, "type", "text/css"), this.defs.append(this.cssStyle));
+              const E = r(p.data, p.mimetype, this.forceDataSchema);
+              this.cssStyle.textContent += `@font-face { font-family: "${p.loadedName}"; src: url(${E}); }
+`;
+            }
+            setFont(p) {
+              const E = this.current, $ = this.commonObjs.get(p[0]);
+              let M = p[1];
+              E.font = $, this.embedFonts && !$.missingFile && !this.embeddedFonts[$.loadedName] && (this.addFontStyle($), this.embeddedFonts[$.loadedName] = $), E.fontMatrix = $.fontMatrix || s.FONT_IDENTITY_MATRIX;
+              let m = "normal";
+              $.black ? m = "900" : $.bold && (m = "bold");
+              const N = $.italic ? "italic" : "normal";
+              M < 0 ? (M = -M, E.fontDirection = -1) : E.fontDirection = 1, E.fontSize = M, E.fontFamily = $.loadedName, E.fontWeight = m, E.fontStyle = N, E.tspan = this.svgFactory.createElement("svg:tspan"), E.tspan.setAttributeNS(null, "y", C(-E.y)), E.xcoords = [], E.ycoords = [];
+            }
+            endText() {
+              var E;
+              const p = this.current;
+              p.textRenderingMode & s.TextRenderingMode.ADD_TO_PATH_FLAG && ((E = p.txtElement) != null && E.hasChildNodes()) && (p.element = p.txtElement, this.clip("nonzero"), this.endPath());
+            }
+            setLineWidth(p) {
+              p > 0 && (this.current.lineWidth = p);
+            }
+            setLineCap(p) {
+              this.current.lineCap = c[p];
+            }
+            setLineJoin(p) {
+              this.current.lineJoin = o[p];
+            }
+            setMiterLimit(p) {
+              this.current.miterLimit = p;
+            }
+            setStrokeAlpha(p) {
+              this.current.strokeAlpha = p;
+            }
+            setStrokeRGBColor(p, E, $) {
+              this.current.strokeColor = s.Util.makeHexColor(p, E, $);
+            }
+            setFillAlpha(p) {
+              this.current.fillAlpha = p;
+            }
+            setFillRGBColor(p, E, $) {
+              this.current.fillColor = s.Util.makeHexColor(p, E, $), this.current.tspan = this.svgFactory.createElement("svg:tspan"), this.current.xcoords = [], this.current.ycoords = [];
+            }
+            setStrokeColorN(p) {
+              this.current.strokeColor = this._makeColorN_Pattern(p);
+            }
+            setFillColorN(p) {
+              this.current.fillColor = this._makeColorN_Pattern(p);
+            }
+            shadingFill(p) {
+              const {
+                width: E,
+                height: $
+              } = this.viewport, M = s.Util.inverseTransform(this.transformMatrix), [m, N, D, X] = s.Util.getAxialAlignedBoundingBox([0, 0, E, $], M), G = this.svgFactory.createElement("svg:rect");
+              G.setAttributeNS(null, "x", m), G.setAttributeNS(null, "y", N), G.setAttributeNS(null, "width", D - m), G.setAttributeNS(null, "height", X - N), G.setAttributeNS(null, "fill", this._makeShadingPattern(p)), this.current.fillAlpha < 1 && G.setAttributeNS(null, "fill-opacity", this.current.fillAlpha), this._ensureTransformGroup().append(G);
+            }
+            _makeColorN_Pattern(p) {
+              return p[0] === "TilingPattern" ? this._makeTilingPattern(p) : this._makeShadingPattern(p);
+            }
+            _makeTilingPattern(p) {
+              const E = p[1], $ = p[2], M = p[3] || s.IDENTITY_MATRIX, [m, N, D, X] = p[4], G = p[5], I = p[6], B = p[7], ee = `shading${F++}`, [Y, q, le, pe] = s.Util.normalizeRect([...s.Util.applyTransform([m, N], M), ...s.Util.applyTransform([D, X], M)]), [we, be] = s.Util.singularValueDecompose2dScale(M), R = G * we, d = I * be, g = this.svgFactory.createElement("svg:pattern");
+              g.setAttributeNS(null, "id", ee), g.setAttributeNS(null, "patternUnits", "userSpaceOnUse"), g.setAttributeNS(null, "width", R), g.setAttributeNS(null, "height", d), g.setAttributeNS(null, "x", `${Y}`), g.setAttributeNS(null, "y", `${q}`);
+              const f = this.svg, v = this.transformMatrix, A = this.current.fillColor, O = this.current.strokeColor, H = this.svgFactory.create(le - Y, pe - q);
+              if (this.svg = H, this.transformMatrix = M, B === 2) {
+                const z = s.Util.makeHexColor(...E);
+                this.current.fillColor = z, this.current.strokeColor = z;
+              }
+              return this.executeOpTree(this.convertOpList($)), this.svg = f, this.transformMatrix = v, this.current.fillColor = A, this.current.strokeColor = O, g.append(H.childNodes[0]), this.defs.append(g), `url(#${ee})`;
+            }
+            _makeShadingPattern(p) {
+              switch (typeof p == "string" && (p = this.objs.get(p)), p[0]) {
+                case "RadialAxial":
+                  const E = `shading${F++}`, $ = p[3];
+                  let M;
+                  switch (p[1]) {
+                    case "axial":
+                      const m = p[4], N = p[5];
+                      M = this.svgFactory.createElement("svg:linearGradient"), M.setAttributeNS(null, "id", E), M.setAttributeNS(null, "gradientUnits", "userSpaceOnUse"), M.setAttributeNS(null, "x1", m[0]), M.setAttributeNS(null, "y1", m[1]), M.setAttributeNS(null, "x2", N[0]), M.setAttributeNS(null, "y2", N[1]);
+                      break;
+                    case "radial":
+                      const D = p[4], X = p[5], G = p[6], I = p[7];
+                      M = this.svgFactory.createElement("svg:radialGradient"), M.setAttributeNS(null, "id", E), M.setAttributeNS(null, "gradientUnits", "userSpaceOnUse"), M.setAttributeNS(null, "cx", X[0]), M.setAttributeNS(null, "cy", X[1]), M.setAttributeNS(null, "r", I), M.setAttributeNS(null, "fx", D[0]), M.setAttributeNS(null, "fy", D[1]), M.setAttributeNS(null, "fr", G);
+                      break;
+                    default:
+                      throw new Error(`Unknown RadialAxial type: ${p[1]}`);
+                  }
+                  for (const m of $) {
+                    const N = this.svgFactory.createElement("svg:stop");
+                    N.setAttributeNS(null, "offset", m[0]), N.setAttributeNS(null, "stop-color", m[1]), M.append(N);
+                  }
+                  return this.defs.append(M), `url(#${E})`;
+                case "Mesh":
+                  return (0, s.warn)("Unimplemented pattern Mesh"), null;
+                case "Dummy":
+                  return "hotpink";
+                default:
+                  throw new Error(`Unknown IR type: ${p[0]}`);
+              }
+            }
+            setDash(p, E) {
+              this.current.dashArray = p, this.current.dashPhase = E;
+            }
+            constructPath(p, E) {
+              const $ = this.current;
+              let M = $.x, m = $.y, N = [], D = 0;
+              for (const X of p)
+                switch (X | 0) {
+                  case s.OPS.rectangle:
+                    M = E[D++], m = E[D++];
+                    const G = E[D++], I = E[D++], B = M + G, ee = m + I;
+                    N.push("M", C(M), C(m), "L", C(B), C(m), "L", C(B), C(ee), "L", C(M), C(ee), "Z");
+                    break;
+                  case s.OPS.moveTo:
+                    M = E[D++], m = E[D++], N.push("M", C(M), C(m));
+                    break;
+                  case s.OPS.lineTo:
+                    M = E[D++], m = E[D++], N.push("L", C(M), C(m));
+                    break;
+                  case s.OPS.curveTo:
+                    M = E[D + 4], m = E[D + 5], N.push("C", C(E[D]), C(E[D + 1]), C(E[D + 2]), C(E[D + 3]), C(M), C(m)), D += 6;
+                    break;
+                  case s.OPS.curveTo2:
+                    N.push("C", C(M), C(m), C(E[D]), C(E[D + 1]), C(E[D + 2]), C(E[D + 3])), M = E[D + 2], m = E[D + 3], D += 4;
+                    break;
+                  case s.OPS.curveTo3:
+                    M = E[D + 2], m = E[D + 3], N.push("C", C(E[D]), C(E[D + 1]), C(M), C(m), C(M), C(m)), D += 4;
+                    break;
+                  case s.OPS.closePath:
+                    N.push("Z");
+                    break;
+                }
+              N = N.join(" "), $.path && p.length > 0 && p[0] !== s.OPS.rectangle && p[0] !== s.OPS.moveTo ? N = $.path.getAttributeNS(null, "d") + N : ($.path = this.svgFactory.createElement("svg:path"), this._ensureTransformGroup().append($.path)), $.path.setAttributeNS(null, "d", N), $.path.setAttributeNS(null, "fill", "none"), $.element = $.path, $.setCurrentPoint(M, m);
+            }
+            endPath() {
+              const p = this.current;
+              if (p.path = null, !this.pendingClip)
+                return;
+              if (!p.element) {
+                this.pendingClip = null;
+                return;
+              }
+              const E = `clippath${b++}`, $ = this.svgFactory.createElement("svg:clipPath");
+              $.setAttributeNS(null, "id", E), $.setAttributeNS(null, "transform", P(this.transformMatrix));
+              const M = p.element.cloneNode(!0);
+              if (this.pendingClip === "evenodd" ? M.setAttributeNS(null, "clip-rule", "evenodd") : M.setAttributeNS(null, "clip-rule", "nonzero"), this.pendingClip = null, $.append(M), this.defs.append($), p.activeClipUrl) {
+                p.clipGroup = null;
+                for (const m of this.extraStack)
+                  m.clipGroup = null;
+                $.setAttributeNS(null, "clip-path", p.activeClipUrl);
+              }
+              p.activeClipUrl = `url(#${E})`, this.tgrp = null;
+            }
+            clip(p) {
+              this.pendingClip = p;
+            }
+            closePath() {
+              const p = this.current;
+              if (p.path) {
+                const E = `${p.path.getAttributeNS(null, "d")}Z`;
+                p.path.setAttributeNS(null, "d", E);
+              }
+            }
+            setLeading(p) {
+              this.current.leading = -p;
+            }
+            setTextRise(p) {
+              this.current.textRise = p;
+            }
+            setTextRenderingMode(p) {
+              this.current.textRenderingMode = p;
+            }
+            setHScale(p) {
+              this.current.textHScale = p / 100;
+            }
+            setRenderingIntent(p) {
+            }
+            setFlatness(p) {
+            }
+            setGState(p) {
+              for (const [E, $] of p)
+                switch (E) {
+                  case "LW":
+                    this.setLineWidth($);
+                    break;
+                  case "LC":
+                    this.setLineCap($);
+                    break;
+                  case "LJ":
+                    this.setLineJoin($);
+                    break;
+                  case "ML":
+                    this.setMiterLimit($);
+                    break;
+                  case "D":
+                    this.setDash($[0], $[1]);
+                    break;
+                  case "RI":
+                    this.setRenderingIntent($);
+                    break;
+                  case "FL":
+                    this.setFlatness($);
+                    break;
+                  case "Font":
+                    this.setFont($);
+                    break;
+                  case "CA":
+                    this.setStrokeAlpha($);
+                    break;
+                  case "ca":
+                    this.setFillAlpha($);
+                    break;
+                  default:
+                    (0, s.warn)(`Unimplemented graphic state operator ${E}`);
+                    break;
+                }
+            }
+            fill() {
+              const p = this.current;
+              p.element && (p.element.setAttributeNS(null, "fill", p.fillColor), p.element.setAttributeNS(null, "fill-opacity", p.fillAlpha), this.endPath());
+            }
+            stroke() {
+              const p = this.current;
+              p.element && (this._setStrokeAttributes(p.element), p.element.setAttributeNS(null, "fill", "none"), this.endPath());
+            }
+            _setStrokeAttributes(p, E = 1) {
+              const $ = this.current;
+              let M = $.dashArray;
+              E !== 1 && M.length > 0 && (M = M.map(function(m) {
+                return E * m;
+              })), p.setAttributeNS(null, "stroke", $.strokeColor), p.setAttributeNS(null, "stroke-opacity", $.strokeAlpha), p.setAttributeNS(null, "stroke-miterlimit", C($.miterLimit)), p.setAttributeNS(null, "stroke-linecap", $.lineCap), p.setAttributeNS(null, "stroke-linejoin", $.lineJoin), p.setAttributeNS(null, "stroke-width", C(E * $.lineWidth) + "px"), p.setAttributeNS(null, "stroke-dasharray", M.map(C).join(" ")), p.setAttributeNS(null, "stroke-dashoffset", C(E * $.dashPhase) + "px");
+            }
+            eoFill() {
+              var p;
+              (p = this.current.element) == null || p.setAttributeNS(null, "fill-rule", "evenodd"), this.fill();
+            }
+            fillStroke() {
+              this.stroke(), this.fill();
+            }
+            eoFillStroke() {
+              var p;
+              (p = this.current.element) == null || p.setAttributeNS(null, "fill-rule", "evenodd"), this.fillStroke();
+            }
+            closeStroke() {
+              this.closePath(), this.stroke();
+            }
+            closeFillStroke() {
+              this.closePath(), this.fillStroke();
+            }
+            closeEOFillStroke() {
+              this.closePath(), this.eoFillStroke();
+            }
+            paintSolidColorImageMask() {
+              const p = this.svgFactory.createElement("svg:rect");
+              p.setAttributeNS(null, "x", "0"), p.setAttributeNS(null, "y", "0"), p.setAttributeNS(null, "width", "1px"), p.setAttributeNS(null, "height", "1px"), p.setAttributeNS(null, "fill", this.current.fillColor), this._ensureTransformGroup().append(p);
+            }
+            paintImageXObject(p) {
+              const E = this.getObject(p);
+              if (!E) {
+                (0, s.warn)(`Dependent image with object ID ${p} is not ready yet`);
+                return;
+              }
+              this.paintInlineImageXObject(E);
+            }
+            paintInlineImageXObject(p, E) {
+              const $ = p.width, M = p.height, m = T(p, this.forceDataSchema, !!E), N = this.svgFactory.createElement("svg:rect");
+              N.setAttributeNS(null, "x", "0"), N.setAttributeNS(null, "y", "0"), N.setAttributeNS(null, "width", C($)), N.setAttributeNS(null, "height", C(M)), this.current.element = N, this.clip("nonzero");
+              const D = this.svgFactory.createElement("svg:image");
+              D.setAttributeNS(_, "xlink:href", m), D.setAttributeNS(null, "x", "0"), D.setAttributeNS(null, "y", C(-M)), D.setAttributeNS(null, "width", C($) + "px"), D.setAttributeNS(null, "height", C(M) + "px"), D.setAttributeNS(null, "transform", `scale(${C(1 / $)} ${C(-1 / M)})`), E ? E.append(D) : this._ensureTransformGroup().append(D);
+            }
+            paintImageMaskXObject(p) {
+              const E = this.getObject(p.data, p);
+              if (E.bitmap) {
+                (0, s.warn)("paintImageMaskXObject: ImageBitmap support is not implemented, ensure that the `isOffscreenCanvasSupported` API parameter is disabled.");
+                return;
+              }
+              const $ = this.current, M = E.width, m = E.height, N = $.fillColor;
+              $.maskId = `mask${k++}`;
+              const D = this.svgFactory.createElement("svg:mask");
+              D.setAttributeNS(null, "id", $.maskId);
+              const X = this.svgFactory.createElement("svg:rect");
+              X.setAttributeNS(null, "x", "0"), X.setAttributeNS(null, "y", "0"), X.setAttributeNS(null, "width", C(M)), X.setAttributeNS(null, "height", C(m)), X.setAttributeNS(null, "fill", N), X.setAttributeNS(null, "mask", `url(#${$.maskId})`), this.defs.append(D), this._ensureTransformGroup().append(X), this.paintInlineImageXObject(E, D);
+            }
+            paintFormXObjectBegin(p, E) {
+              if (Array.isArray(p) && p.length === 6 && this.transform(p[0], p[1], p[2], p[3], p[4], p[5]), E) {
+                const $ = E[2] - E[0], M = E[3] - E[1], m = this.svgFactory.createElement("svg:rect");
+                m.setAttributeNS(null, "x", E[0]), m.setAttributeNS(null, "y", E[1]), m.setAttributeNS(null, "width", C($)), m.setAttributeNS(null, "height", C(M)), this.current.element = m, this.clip("nonzero"), this.endPath();
+              }
+            }
+            paintFormXObjectEnd() {
+            }
+            _initialize(p) {
+              const E = this.svgFactory.create(p.width, p.height), $ = this.svgFactory.createElement("svg:defs");
+              E.append($), this.defs = $;
+              const M = this.svgFactory.createElement("svg:g");
+              return M.setAttributeNS(null, "transform", P(p.transform)), E.append(M), this.svg = M, E;
+            }
+            _ensureClipGroup() {
+              if (!this.current.clipGroup) {
+                const p = this.svgFactory.createElement("svg:g");
+                p.setAttributeNS(null, "clip-path", this.current.activeClipUrl), this.svg.append(p), this.current.clipGroup = p;
+              }
+              return this.current.clipGroup;
+            }
+            _ensureTransformGroup() {
+              return this.tgrp || (this.tgrp = this.svgFactory.createElement("svg:g"), this.tgrp.setAttributeNS(null, "transform", P(this.transformMatrix)), this.current.activeClipUrl ? this._ensureClipGroup().append(this.tgrp) : this.svg.append(this.tgrp)), this.tgrp;
+            }
+          }
+          e.SVGGraphics = x;
+        },
+        /* 25 */
+        /***/
+        (t, e) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.XfaText = void 0;
+          class i {
+            static textContent(s) {
+              const l = [], h = {
+                items: l,
+                styles: /* @__PURE__ */ Object.create(null)
+              };
+              function _(c) {
+                var T;
+                if (!c)
+                  return;
+                let o = null;
+                const r = c.name;
+                if (r === "#text")
+                  o = c.value;
+                else if (i.shouldBuildText(r))
+                  (T = c == null ? void 0 : c.attributes) != null && T.textContent ? o = c.attributes.textContent : c.value && (o = c.value);
+                else
+                  return;
+                if (o !== null && l.push({
+                  str: o
+                }), !!c.children)
+                  for (const S of c.children)
+                    _(S);
+              }
+              return _(s), h;
+            }
+            static shouldBuildText(s) {
+              return !(s === "textarea" || s === "input" || s === "option" || s === "select");
+            }
+          }
+          e.XfaText = i;
+        },
+        /* 26 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.TextLayerRenderTask = void 0, e.renderTextLayer = P, e.updateTextLayer = b;
+          var n = i(1), s = i(6);
+          const l = 1e5, h = 30, _ = 0.8, c = /* @__PURE__ */ new Map();
+          function o(k, F) {
+            let x;
+            if (F && n.FeatureTest.isOffscreenCanvasSupported)
+              x = new OffscreenCanvas(k, k).getContext("2d", {
+                alpha: !1
+              });
+            else {
+              const y = document.createElement("canvas");
+              y.width = y.height = k, x = y.getContext("2d", {
+                alpha: !1
+              });
+            }
+            return x;
+          }
+          function r(k, F) {
+            const x = c.get(k);
+            if (x)
+              return x;
+            const y = o(h, F);
+            y.font = `${h}px ${k}`;
+            const p = y.measureText("");
+            let E = p.fontBoundingBoxAscent, $ = Math.abs(p.fontBoundingBoxDescent);
+            if (E) {
+              const m = E / (E + $);
+              return c.set(k, m), y.canvas.width = y.canvas.height = 0, m;
+            }
+            y.strokeStyle = "red", y.clearRect(0, 0, h, h), y.strokeText("g", 0, 0);
+            let M = y.getImageData(0, 0, h, h).data;
+            $ = 0;
+            for (let m = M.length - 1 - 3; m >= 0; m -= 4)
+              if (M[m] > 0) {
+                $ = Math.ceil(m / 4 / h);
+                break;
+              }
+            y.clearRect(0, 0, h, h), y.strokeText("A", 0, h), M = y.getImageData(0, 0, h, h).data, E = 0;
+            for (let m = 0, N = M.length; m < N; m += 4)
+              if (M[m] > 0) {
+                E = h - Math.floor(m / 4 / h);
+                break;
+              }
+            if (y.canvas.width = y.canvas.height = 0, E) {
+              const m = E / (E + $);
+              return c.set(k, m), m;
+            }
+            return c.set(k, _), _;
+          }
+          function T(k, F, x) {
+            const y = document.createElement("span"), p = {
+              angle: 0,
+              canvasWidth: 0,
+              hasText: F.str !== "",
+              hasEOL: F.hasEOL,
+              fontSize: 0
+            };
+            k._textDivs.push(y);
+            const E = n.Util.transform(k._transform, F.transform);
+            let $ = Math.atan2(E[1], E[0]);
+            const M = x[F.fontName];
+            M.vertical && ($ += Math.PI / 2);
+            const m = Math.hypot(E[2], E[3]), N = m * r(M.fontFamily, k._isOffscreenCanvasSupported);
+            let D, X;
+            $ === 0 ? (D = E[4], X = E[5] - N) : (D = E[4] + N * Math.sin($), X = E[5] - N * Math.cos($));
+            const G = "calc(var(--scale-factor)*", I = y.style;
+            k._container === k._rootContainer ? (I.left = `${(100 * D / k._pageWidth).toFixed(2)}%`, I.top = `${(100 * X / k._pageHeight).toFixed(2)}%`) : (I.left = `${G}${D.toFixed(2)}px)`, I.top = `${G}${X.toFixed(2)}px)`), I.fontSize = `${G}${m.toFixed(2)}px)`, I.fontFamily = M.fontFamily, p.fontSize = m, y.setAttribute("role", "presentation"), y.textContent = F.str, y.dir = F.dir, k._fontInspectorEnabled && (y.dataset.fontName = F.fontName), $ !== 0 && (p.angle = $ * (180 / Math.PI));
+            let B = !1;
+            if (F.str.length > 1)
+              B = !0;
+            else if (F.str !== " " && F.transform[0] !== F.transform[3]) {
+              const ee = Math.abs(F.transform[0]), Y = Math.abs(F.transform[3]);
+              ee !== Y && Math.max(ee, Y) / Math.min(ee, Y) > 1.5 && (B = !0);
+            }
+            B && (p.canvasWidth = M.vertical ? F.height : F.width), k._textDivProperties.set(y, p), k._isReadableStream && k._layoutText(y);
+          }
+          function S(k) {
+            const {
+              div: F,
+              scale: x,
+              properties: y,
+              ctx: p,
+              prevFontSize: E,
+              prevFontFamily: $
+            } = k, {
+              style: M
+            } = F;
+            let m = "";
+            if (y.canvasWidth !== 0 && y.hasText) {
+              const {
+                fontFamily: N
+              } = M, {
+                canvasWidth: D,
+                fontSize: X
+              } = y;
+              (E !== X || $ !== N) && (p.font = `${X * x}px ${N}`, k.prevFontSize = X, k.prevFontFamily = N);
+              const {
+                width: G
+              } = p.measureText(F.textContent);
+              G > 0 && (m = `scaleX(${D * x / G})`);
+            }
+            y.angle !== 0 && (m = `rotate(${y.angle}deg) ${m}`), m.length > 0 && (M.transform = m);
+          }
+          function w(k) {
+            if (k._canceled)
+              return;
+            const F = k._textDivs, x = k._capability;
+            if (F.length > l) {
+              x.resolve();
+              return;
+            }
+            if (!k._isReadableStream)
+              for (const p of F)
+                k._layoutText(p);
+            x.resolve();
+          }
+          class C {
+            constructor({
+              textContentSource: F,
+              container: x,
+              viewport: y,
+              textDivs: p,
+              textDivProperties: E,
+              textContentItemsStr: $,
+              isOffscreenCanvasSupported: M
+            }) {
+              var G;
+              this._textContentSource = F, this._isReadableStream = F instanceof ReadableStream, this._container = this._rootContainer = x, this._textDivs = p || [], this._textContentItemsStr = $ || [], this._isOffscreenCanvasSupported = M, this._fontInspectorEnabled = !!((G = globalThis.FontInspector) != null && G.enabled), this._reader = null, this._textDivProperties = E || /* @__PURE__ */ new WeakMap(), this._canceled = !1, this._capability = new n.PromiseCapability(), this._layoutTextParams = {
+                prevFontSize: null,
+                prevFontFamily: null,
+                div: null,
+                scale: y.scale * (globalThis.devicePixelRatio || 1),
+                properties: null,
+                ctx: o(0, M)
+              };
+              const {
+                pageWidth: m,
+                pageHeight: N,
+                pageX: D,
+                pageY: X
+              } = y.rawDims;
+              this._transform = [1, 0, 0, -1, -D, X + N], this._pageWidth = m, this._pageHeight = N, (0, s.setLayerDimensions)(x, y), this._capability.promise.finally(() => {
+                this._layoutTextParams = null;
+              }).catch(() => {
+              });
+            }
+            get promise() {
+              return this._capability.promise;
+            }
+            cancel() {
+              this._canceled = !0, this._reader && (this._reader.cancel(new n.AbortException("TextLayer task cancelled.")).catch(() => {
+              }), this._reader = null), this._capability.reject(new n.AbortException("TextLayer task cancelled."));
+            }
+            _processItems(F, x) {
+              for (const y of F) {
+                if (y.str === void 0) {
+                  if (y.type === "beginMarkedContentProps" || y.type === "beginMarkedContent") {
+                    const p = this._container;
+                    this._container = document.createElement("span"), this._container.classList.add("markedContent"), y.id !== null && this._container.setAttribute("id", `${y.id}`), p.append(this._container);
+                  } else
+                    y.type === "endMarkedContent" && (this._container = this._container.parentNode);
+                  continue;
+                }
+                this._textContentItemsStr.push(y.str), T(this, y, x);
+              }
+            }
+            _layoutText(F) {
+              const x = this._layoutTextParams.properties = this._textDivProperties.get(F);
+              if (this._layoutTextParams.div = F, S(this._layoutTextParams), x.hasText && this._container.append(F), x.hasEOL) {
+                const y = document.createElement("br");
+                y.setAttribute("role", "presentation"), this._container.append(y);
+              }
+            }
+            _render() {
+              const F = new n.PromiseCapability();
+              let x = /* @__PURE__ */ Object.create(null);
+              if (this._isReadableStream) {
+                const y = () => {
+                  this._reader.read().then(({
+                    value: p,
+                    done: E
+                  }) => {
+                    if (E) {
+                      F.resolve();
+                      return;
+                    }
+                    Object.assign(x, p.styles), this._processItems(p.items, x), y();
+                  }, F.reject);
+                };
+                this._reader = this._textContentSource.getReader(), y();
+              } else if (this._textContentSource) {
+                const {
+                  items: y,
+                  styles: p
+                } = this._textContentSource;
+                this._processItems(y, p), F.resolve();
+              } else
+                throw new Error('No "textContentSource" parameter specified.');
+              F.promise.then(() => {
+                x = null, w(this);
+              }, this._capability.reject);
+            }
+          }
+          e.TextLayerRenderTask = C;
+          function P(k) {
+            !k.textContentSource && (k.textContent || k.textContentStream) && ((0, s.deprecated)("The TextLayerRender `textContent`/`textContentStream` parameters will be removed in the future, please use `textContentSource` instead."), k.textContentSource = k.textContent || k.textContentStream);
+            const {
+              container: F,
+              viewport: x
+            } = k, y = getComputedStyle(F), p = y.getPropertyValue("visibility"), E = parseFloat(y.getPropertyValue("--scale-factor"));
+            p === "visible" && (!E || Math.abs(E - x.scale) > 1e-5) && console.error("The `--scale-factor` CSS-variable must be set, to the same value as `viewport.scale`, either on the `container`-element itself or higher up in the DOM.");
+            const $ = new C(k);
+            return $._render(), $;
+          }
+          function b({
+            container: k,
+            viewport: F,
+            textDivs: x,
+            textDivProperties: y,
+            isOffscreenCanvasSupported: p,
+            mustRotate: E = !0,
+            mustRescale: $ = !0
+          }) {
+            if (E && (0, s.setLayerDimensions)(k, {
+              rotation: F.rotation
+            }), $) {
+              const M = o(0, p), N = {
+                prevFontSize: null,
+                prevFontFamily: null,
+                div: null,
+                scale: F.scale * (globalThis.devicePixelRatio || 1),
+                properties: null,
+                ctx: M
+              };
+              for (const D of x)
+                N.properties = y.get(D), N.div = D, S(N);
+            }
+          }
+        },
+        /* 27 */
+        /***/
+        (t, e, i) => {
+          var r, T, S, w, C, P, b, k, F, x, y, nn, E, Rt, M, sn, N, rn;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.AnnotationEditorLayer = void 0;
+          var n = i(1), s = i(4), l = i(28), h = i(33), _ = i(6), c = i(34);
+          const X = class X {
+            constructor({
+              uiManager: I,
+              pageIndex: B,
+              div: ee,
+              accessibilityManager: Y,
+              annotationLayer: q,
+              viewport: le,
+              l10n: pe
+            }) {
+              W(this, y);
+              W(this, E);
+              W(this, M);
+              W(this, N);
+              W(this, r, void 0);
+              W(this, T, !1);
+              W(this, S, null);
+              W(this, w, this.pointerup.bind(this));
+              W(this, C, this.pointerdown.bind(this));
+              W(this, P, /* @__PURE__ */ new Map());
+              W(this, b, !1);
+              W(this, k, !1);
+              W(this, F, !1);
+              W(this, x, void 0);
+              const we = [l.FreeTextEditor, h.InkEditor, c.StampEditor];
+              if (!X._initialized) {
+                X._initialized = !0;
+                for (const be of we)
+                  be.initialize(pe);
+              }
+              I.registerEditorTypes(we), oe(this, x, I), this.pageIndex = B, this.div = ee, oe(this, r, Y), oe(this, S, q), this.viewport = le, a(this, x).addLayer(this);
+            }
+            get isEmpty() {
+              return a(this, P).size === 0;
+            }
+            updateToolbar(I) {
+              a(this, x).updateToolbar(I);
+            }
+            updateMode(I = a(this, x).getMode()) {
+              K(this, N, rn).call(this), I === n.AnnotationEditorType.INK ? (this.addInkEditorIfNeeded(!1), this.disableClick()) : this.enableClick(), I !== n.AnnotationEditorType.NONE && (this.div.classList.toggle("freeTextEditing", I === n.AnnotationEditorType.FREETEXT), this.div.classList.toggle("inkEditing", I === n.AnnotationEditorType.INK), this.div.classList.toggle("stampEditing", I === n.AnnotationEditorType.STAMP), this.div.hidden = !1);
+            }
+            addInkEditorIfNeeded(I) {
+              if (!I && a(this, x).getMode() !== n.AnnotationEditorType.INK)
+                return;
+              if (!I) {
+                for (const ee of a(this, P).values())
+                  if (ee.isEmpty()) {
+                    ee.setInBackground();
+                    return;
+                  }
+              }
+              K(this, E, Rt).call(this, {
+                offsetX: 0,
+                offsetY: 0
+              }, !1).setInBackground();
+            }
+            setEditingState(I) {
+              a(this, x).setEditingState(I);
+            }
+            addCommands(I) {
+              a(this, x).addCommands(I);
+            }
+            enable() {
+              this.div.style.pointerEvents = "auto";
+              const I = /* @__PURE__ */ new Set();
+              for (const ee of a(this, P).values())
+                ee.enableEditing(), ee.annotationElementId && I.add(ee.annotationElementId);
+              if (!a(this, S))
+                return;
+              const B = a(this, S).getEditableAnnotations();
+              for (const ee of B) {
+                if (ee.hide(), a(this, x).isDeletedAnnotationElement(ee.data.id) || I.has(ee.data.id))
+                  continue;
+                const Y = this.deserialize(ee);
+                Y && (this.addOrRebuild(Y), Y.enableEditing());
+              }
+            }
+            disable() {
+              var B;
+              oe(this, F, !0), this.div.style.pointerEvents = "none";
+              const I = /* @__PURE__ */ new Set();
+              for (const ee of a(this, P).values()) {
+                if (ee.disableEditing(), !ee.annotationElementId || ee.serialize() !== null) {
+                  I.add(ee.annotationElementId);
+                  continue;
+                }
+                (B = this.getEditableAnnotation(ee.annotationElementId)) == null || B.show(), ee.remove();
+              }
+              if (a(this, S)) {
+                const ee = a(this, S).getEditableAnnotations();
+                for (const Y of ee) {
+                  const {
+                    id: q
+                  } = Y.data;
+                  I.has(q) || a(this, x).isDeletedAnnotationElement(q) || Y.show();
+                }
+              }
+              K(this, N, rn).call(this), this.isEmpty && (this.div.hidden = !0), oe(this, F, !1);
+            }
+            getEditableAnnotation(I) {
+              var B;
+              return ((B = a(this, S)) == null ? void 0 : B.getEditableAnnotation(I)) || null;
+            }
+            setActiveEditor(I) {
+              a(this, x).getActive() !== I && a(this, x).setActiveEditor(I);
+            }
+            enableClick() {
+              this.div.addEventListener("pointerdown", a(this, C)), this.div.addEventListener("pointerup", a(this, w));
+            }
+            disableClick() {
+              this.div.removeEventListener("pointerdown", a(this, C)), this.div.removeEventListener("pointerup", a(this, w));
+            }
+            attach(I) {
+              a(this, P).set(I.id, I);
+              const {
+                annotationElementId: B
+              } = I;
+              B && a(this, x).isDeletedAnnotationElement(B) && a(this, x).removeDeletedAnnotationElement(I);
+            }
+            detach(I) {
+              var B;
+              a(this, P).delete(I.id), (B = a(this, r)) == null || B.removePointerInTextLayer(I.contentDiv), !a(this, F) && I.annotationElementId && a(this, x).addDeletedAnnotationElement(I);
+            }
+            remove(I) {
+              this.detach(I), a(this, x).removeEditor(I), I.div.contains(document.activeElement) && setTimeout(() => {
+                a(this, x).focusMainContainer();
+              }, 0), I.div.remove(), I.isAttachedToDOM = !1, a(this, k) || this.addInkEditorIfNeeded(!1);
+            }
+            changeParent(I) {
+              var B;
+              I.parent !== this && (I.annotationElementId && (a(this, x).addDeletedAnnotationElement(I.annotationElementId), s.AnnotationEditor.deleteAnnotationElement(I), I.annotationElementId = null), this.attach(I), (B = I.parent) == null || B.detach(I), I.setParent(this), I.div && I.isAttachedToDOM && (I.div.remove(), this.div.append(I.div)));
+            }
+            add(I) {
+              if (this.changeParent(I), a(this, x).addEditor(I), this.attach(I), !I.isAttachedToDOM) {
+                const B = I.render();
+                this.div.append(B), I.isAttachedToDOM = !0;
+              }
+              I.fixAndSetPosition(), I.onceAdded(), a(this, x).addToAnnotationStorage(I);
+            }
+            moveEditorInDOM(I) {
+              var ee;
+              if (!I.isAttachedToDOM)
+                return;
+              const {
+                activeElement: B
+              } = document;
+              I.div.contains(B) && (I._focusEventsAllowed = !1, setTimeout(() => {
+                I.div.contains(document.activeElement) ? I._focusEventsAllowed = !0 : (I.div.addEventListener("focusin", () => {
+                  I._focusEventsAllowed = !0;
+                }, {
+                  once: !0
+                }), B.focus());
+              }, 0)), I._structTreeParentId = (ee = a(this, r)) == null ? void 0 : ee.moveElementInDOM(this.div, I.div, I.contentDiv, !0);
+            }
+            addOrRebuild(I) {
+              I.needsToBeRebuilt() ? I.rebuild() : this.add(I);
+            }
+            addUndoableEditor(I) {
+              const B = () => I._uiManager.rebuild(I), ee = () => {
+                I.remove();
+              };
+              this.addCommands({
+                cmd: B,
+                undo: ee,
+                mustExec: !1
+              });
+            }
+            getNextId() {
+              return a(this, x).getId();
+            }
+            pasteEditor(I, B) {
+              a(this, x).updateToolbar(I), a(this, x).updateMode(I);
+              const {
+                offsetX: ee,
+                offsetY: Y
+              } = K(this, M, sn).call(this), q = this.getNextId(), le = K(this, y, nn).call(this, {
+                parent: this,
+                id: q,
+                x: ee,
+                y: Y,
+                uiManager: a(this, x),
+                isCentered: !0,
+                ...B
+              });
+              le && this.add(le);
+            }
+            deserialize(I) {
+              switch (I.annotationType ?? I.annotationEditorType) {
+                case n.AnnotationEditorType.FREETEXT:
+                  return l.FreeTextEditor.deserialize(I, this, a(this, x));
+                case n.AnnotationEditorType.INK:
+                  return h.InkEditor.deserialize(I, this, a(this, x));
+                case n.AnnotationEditorType.STAMP:
+                  return c.StampEditor.deserialize(I, this, a(this, x));
+              }
+              return null;
+            }
+            addNewEditor() {
+              K(this, E, Rt).call(this, K(this, M, sn).call(this), !0);
+            }
+            setSelected(I) {
+              a(this, x).setSelected(I);
+            }
+            toggleSelected(I) {
+              a(this, x).toggleSelected(I);
+            }
+            isSelected(I) {
+              return a(this, x).isSelected(I);
+            }
+            unselect(I) {
+              a(this, x).unselect(I);
+            }
+            pointerup(I) {
+              const {
+                isMac: B
+              } = n.FeatureTest.platform;
+              if (!(I.button !== 0 || I.ctrlKey && B) && I.target === this.div && a(this, b)) {
+                if (oe(this, b, !1), !a(this, T)) {
+                  oe(this, T, !0);
+                  return;
+                }
+                if (a(this, x).getMode() === n.AnnotationEditorType.STAMP) {
+                  a(this, x).unselectAll();
+                  return;
+                }
+                K(this, E, Rt).call(this, I, !1);
+              }
+            }
+            pointerdown(I) {
+              if (a(this, b)) {
+                oe(this, b, !1);
+                return;
+              }
+              const {
+                isMac: B
+              } = n.FeatureTest.platform;
+              if (I.button !== 0 || I.ctrlKey && B || I.target !== this.div)
+                return;
+              oe(this, b, !0);
+              const ee = a(this, x).getActive();
+              oe(this, T, !ee || ee.isEmpty());
+            }
+            findNewParent(I, B, ee) {
+              const Y = a(this, x).findParent(B, ee);
+              return Y === null || Y === this ? !1 : (Y.changeParent(I), !0);
+            }
+            destroy() {
+              var I, B;
+              ((I = a(this, x).getActive()) == null ? void 0 : I.parent) === this && (a(this, x).commitOrRemove(), a(this, x).setActiveEditor(null));
+              for (const ee of a(this, P).values())
+                (B = a(this, r)) == null || B.removePointerInTextLayer(ee.contentDiv), ee.setParent(null), ee.isAttachedToDOM = !1, ee.div.remove();
+              this.div = null, a(this, P).clear(), a(this, x).removeLayer(this);
+            }
+            render({
+              viewport: I
+            }) {
+              this.viewport = I, (0, _.setLayerDimensions)(this.div, I);
+              for (const B of a(this, x).getEditors(this.pageIndex))
+                this.add(B);
+              this.updateMode();
+            }
+            update({
+              viewport: I
+            }) {
+              a(this, x).commitOrRemove(), this.viewport = I, (0, _.setLayerDimensions)(this.div, {
+                rotation: I.rotation
+              }), this.updateMode();
+            }
+            get pageDimensions() {
+              const {
+                pageWidth: I,
+                pageHeight: B
+              } = this.viewport.rawDims;
+              return [I, B];
+            }
+          };
+          r = new WeakMap(), T = new WeakMap(), S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakMap(), k = new WeakMap(), F = new WeakMap(), x = new WeakMap(), y = new WeakSet(), nn = function(I) {
+            switch (a(this, x).getMode()) {
+              case n.AnnotationEditorType.FREETEXT:
+                return new l.FreeTextEditor(I);
+              case n.AnnotationEditorType.INK:
+                return new h.InkEditor(I);
+              case n.AnnotationEditorType.STAMP:
+                return new c.StampEditor(I);
+            }
+            return null;
+          }, E = new WeakSet(), Rt = function(I, B) {
+            const ee = this.getNextId(), Y = K(this, y, nn).call(this, {
+              parent: this,
+              id: ee,
+              x: I.offsetX,
+              y: I.offsetY,
+              uiManager: a(this, x),
+              isCentered: B
+            });
+            return Y && this.add(Y), Y;
+          }, M = new WeakSet(), sn = function() {
+            const {
+              x: I,
+              y: B,
+              width: ee,
+              height: Y
+            } = this.div.getBoundingClientRect(), q = Math.max(0, I), le = Math.max(0, B), pe = Math.min(window.innerWidth, I + ee), we = Math.min(window.innerHeight, B + Y), be = (q + pe) / 2 - I, R = (le + we) / 2 - B, [d, g] = this.viewport.rotation % 180 === 0 ? [be, R] : [R, be];
+            return {
+              offsetX: d,
+              offsetY: g
+            };
+          }, N = new WeakSet(), rn = function() {
+            oe(this, k, !0);
+            for (const I of a(this, P).values())
+              I.isEmpty() && I.remove();
+            oe(this, k, !1);
+          }, nt(X, "_initialized", !1);
+          let o = X;
+          e.AnnotationEditorLayer = o;
+        },
+        /* 28 */
+        /***/
+        (t, e, i) => {
+          var c, o, r, T, S, w, C, P, b, k, In, x, Ln, p, Dn, $, At, m, an, D, On, G, on;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.FreeTextEditor = void 0;
+          var n = i(1), s = i(5), l = i(4), h = i(29);
+          const B = class B extends l.AnnotationEditor {
+            constructor(q) {
+              super({
+                ...q,
+                name: "freeTextEditor"
+              });
+              W(this, k);
+              W(this, x);
+              W(this, p);
+              W(this, $);
+              W(this, m);
+              W(this, D);
+              W(this, G);
+              W(this, c, this.editorDivBlur.bind(this));
+              W(this, o, this.editorDivFocus.bind(this));
+              W(this, r, this.editorDivInput.bind(this));
+              W(this, T, this.editorDivKeydown.bind(this));
+              W(this, S, void 0);
+              W(this, w, "");
+              W(this, C, `${this.id}-editor`);
+              W(this, P, void 0);
+              W(this, b, null);
+              oe(this, S, q.color || B._defaultColor || l.AnnotationEditor._defaultLineColor), oe(this, P, q.fontSize || B._defaultFontSize);
+            }
+            static get _keyboardManager() {
+              const q = B.prototype, le = (be) => be.isEmpty(), pe = s.AnnotationEditorUIManager.TRANSLATE_SMALL, we = s.AnnotationEditorUIManager.TRANSLATE_BIG;
+              return (0, n.shadow)(this, "_keyboardManager", new s.KeyboardManager([[["ctrl+s", "mac+meta+s", "ctrl+p", "mac+meta+p"], q.commitOrRemove, {
+                bubbles: !0
+              }], [["ctrl+Enter", "mac+meta+Enter", "Escape", "mac+Escape"], q.commitOrRemove], [["ArrowLeft", "mac+ArrowLeft"], q._translateEmpty, {
+                args: [-pe, 0],
+                checker: le
+              }], [["ctrl+ArrowLeft", "mac+shift+ArrowLeft"], q._translateEmpty, {
+                args: [-we, 0],
+                checker: le
+              }], [["ArrowRight", "mac+ArrowRight"], q._translateEmpty, {
+                args: [pe, 0],
+                checker: le
+              }], [["ctrl+ArrowRight", "mac+shift+ArrowRight"], q._translateEmpty, {
+                args: [we, 0],
+                checker: le
+              }], [["ArrowUp", "mac+ArrowUp"], q._translateEmpty, {
+                args: [0, -pe],
+                checker: le
+              }], [["ctrl+ArrowUp", "mac+shift+ArrowUp"], q._translateEmpty, {
+                args: [0, -we],
+                checker: le
+              }], [["ArrowDown", "mac+ArrowDown"], q._translateEmpty, {
+                args: [0, pe],
+                checker: le
+              }], [["ctrl+ArrowDown", "mac+shift+ArrowDown"], q._translateEmpty, {
+                args: [0, we],
+                checker: le
+              }]]));
+            }
+            static initialize(q) {
+              l.AnnotationEditor.initialize(q, {
+                strings: ["free_text2_default_content", "editor_free_text2_aria_label"]
+              });
+              const le = getComputedStyle(document.documentElement);
+              this._internalPadding = parseFloat(le.getPropertyValue("--freetext-padding"));
+            }
+            static updateDefaultParams(q, le) {
+              switch (q) {
+                case n.AnnotationEditorParamsType.FREETEXT_SIZE:
+                  B._defaultFontSize = le;
+                  break;
+                case n.AnnotationEditorParamsType.FREETEXT_COLOR:
+                  B._defaultColor = le;
+                  break;
+              }
+            }
+            updateParams(q, le) {
+              switch (q) {
+                case n.AnnotationEditorParamsType.FREETEXT_SIZE:
+                  K(this, k, In).call(this, le);
+                  break;
+                case n.AnnotationEditorParamsType.FREETEXT_COLOR:
+                  K(this, x, Ln).call(this, le);
+                  break;
+              }
+            }
+            static get defaultPropertiesToUpdate() {
+              return [[n.AnnotationEditorParamsType.FREETEXT_SIZE, B._defaultFontSize], [n.AnnotationEditorParamsType.FREETEXT_COLOR, B._defaultColor || l.AnnotationEditor._defaultLineColor]];
+            }
+            get propertiesToUpdate() {
+              return [[n.AnnotationEditorParamsType.FREETEXT_SIZE, a(this, P)], [n.AnnotationEditorParamsType.FREETEXT_COLOR, a(this, S)]];
+            }
+            _translateEmpty(q, le) {
+              this._uiManager.translateSelectedEditors(q, le, !0);
+            }
+            getInitialTranslation() {
+              const q = this.parentScale;
+              return [-B._internalPadding * q, -(B._internalPadding + a(this, P)) * q];
+            }
+            rebuild() {
+              this.parent && (super.rebuild(), this.div !== null && (this.isAttachedToDOM || this.parent.add(this)));
+            }
+            enableEditMode() {
+              this.isInEditMode() || (this.parent.setEditingState(!1), this.parent.updateToolbar(n.AnnotationEditorType.FREETEXT), super.enableEditMode(), this.overlayDiv.classList.remove("enabled"), this.editorDiv.contentEditable = !0, this._isDraggable = !1, this.div.removeAttribute("aria-activedescendant"), this.editorDiv.addEventListener("keydown", a(this, T)), this.editorDiv.addEventListener("focus", a(this, o)), this.editorDiv.addEventListener("blur", a(this, c)), this.editorDiv.addEventListener("input", a(this, r)));
+            }
+            disableEditMode() {
+              this.isInEditMode() && (this.parent.setEditingState(!0), super.disableEditMode(), this.overlayDiv.classList.add("enabled"), this.editorDiv.contentEditable = !1, this.div.setAttribute("aria-activedescendant", a(this, C)), this._isDraggable = !0, this.editorDiv.removeEventListener("keydown", a(this, T)), this.editorDiv.removeEventListener("focus", a(this, o)), this.editorDiv.removeEventListener("blur", a(this, c)), this.editorDiv.removeEventListener("input", a(this, r)), this.div.focus({
+                preventScroll: !0
+              }), this.isEditing = !1, this.parent.div.classList.add("freeTextEditing"));
+            }
+            focusin(q) {
+              this._focusEventsAllowed && (super.focusin(q), q.target !== this.editorDiv && this.editorDiv.focus());
+            }
+            onceAdded() {
+              var q;
+              if (this.width) {
+                K(this, G, on).call(this);
+                return;
+              }
+              this.enableEditMode(), this.editorDiv.focus(), (q = this._initialOptions) != null && q.isCentered && this.center(), this._initialOptions = null;
+            }
+            isEmpty() {
+              return !this.editorDiv || this.editorDiv.innerText.trim() === "";
+            }
+            remove() {
+              this.isEditing = !1, this.parent && (this.parent.setEditingState(!0), this.parent.div.classList.add("freeTextEditing")), super.remove();
+            }
+            commit() {
+              if (!this.isInEditMode())
+                return;
+              super.commit(), this.disableEditMode();
+              const q = a(this, w), le = oe(this, w, K(this, p, Dn).call(this).trimEnd());
+              if (q === le)
+                return;
+              const pe = (we) => {
+                if (oe(this, w, we), !we) {
+                  this.remove();
+                  return;
+                }
+                K(this, m, an).call(this), this._uiManager.rebuild(this), K(this, $, At).call(this);
+              };
+              this.addCommands({
+                cmd: () => {
+                  pe(le);
+                },
+                undo: () => {
+                  pe(q);
+                },
+                mustExec: !1
+              }), K(this, $, At).call(this);
+            }
+            shouldGetKeyboardEvents() {
+              return this.isInEditMode();
+            }
+            enterInEditMode() {
+              this.enableEditMode(), this.editorDiv.focus();
+            }
+            dblclick(q) {
+              this.enterInEditMode();
+            }
+            keydown(q) {
+              q.target === this.div && q.key === "Enter" && (this.enterInEditMode(), q.preventDefault());
+            }
+            editorDivKeydown(q) {
+              B._keyboardManager.exec(this, q);
+            }
+            editorDivFocus(q) {
+              this.isEditing = !0;
+            }
+            editorDivBlur(q) {
+              this.isEditing = !1;
+            }
+            editorDivInput(q) {
+              this.parent.div.classList.toggle("freeTextEditing", this.isEmpty());
+            }
+            disableEditing() {
+              this.editorDiv.setAttribute("role", "comment"), this.editorDiv.removeAttribute("aria-multiline");
+            }
+            enableEditing() {
+              this.editorDiv.setAttribute("role", "textbox"), this.editorDiv.setAttribute("aria-multiline", !0);
+            }
+            render() {
+              if (this.div)
+                return this.div;
+              let q, le;
+              this.width && (q = this.x, le = this.y), super.render(), this.editorDiv = document.createElement("div"), this.editorDiv.className = "internal", this.editorDiv.setAttribute("id", a(this, C)), this.enableEditing(), l.AnnotationEditor._l10nPromise.get("editor_free_text2_aria_label").then((we) => {
+                var be;
+                return (be = this.editorDiv) == null ? void 0 : be.setAttribute("aria-label", we);
+              }), l.AnnotationEditor._l10nPromise.get("free_text2_default_content").then((we) => {
+                var be;
+                return (be = this.editorDiv) == null ? void 0 : be.setAttribute("default-content", we);
+              }), this.editorDiv.contentEditable = !0;
+              const {
+                style: pe
+              } = this.editorDiv;
+              if (pe.fontSize = `calc(${a(this, P)}px * var(--scale-factor))`, pe.color = a(this, S), this.div.append(this.editorDiv), this.overlayDiv = document.createElement("div"), this.overlayDiv.classList.add("overlay", "enabled"), this.div.append(this.overlayDiv), (0, s.bindEvents)(this, this.div, ["dblclick", "keydown"]), this.width) {
+                const [we, be] = this.parentDimensions;
+                if (this.annotationElementId) {
+                  const {
+                    position: R
+                  } = a(this, b);
+                  let [d, g] = this.getInitialTranslation();
+                  [d, g] = this.pageTranslationToScreen(d, g);
+                  const [f, v] = this.pageDimensions, [A, O] = this.pageTranslation;
+                  let H, z;
+                  switch (this.rotation) {
+                    case 0:
+                      H = q + (R[0] - A) / f, z = le + this.height - (R[1] - O) / v;
+                      break;
+                    case 90:
+                      H = q + (R[0] - A) / f, z = le - (R[1] - O) / v, [d, g] = [g, -d];
+                      break;
+                    case 180:
+                      H = q - this.width + (R[0] - A) / f, z = le - (R[1] - O) / v, [d, g] = [-d, -g];
+                      break;
+                    case 270:
+                      H = q + (R[0] - A - this.height * v) / f, z = le + (R[1] - O - this.width * f) / v, [d, g] = [-g, d];
+                      break;
+                  }
+                  this.setAt(H * we, z * be, d, g);
+                } else
+                  this.setAt(q * we, le * be, this.width * we, this.height * be);
+                K(this, m, an).call(this), this._isDraggable = !0, this.editorDiv.contentEditable = !1;
+              } else
+                this._isDraggable = !1, this.editorDiv.contentEditable = !0;
+              return this.div;
+            }
+            get contentDiv() {
+              return this.editorDiv;
+            }
+            static deserialize(q, le, pe) {
+              let we = null;
+              if (q instanceof h.FreeTextAnnotationElement) {
+                const {
+                  data: {
+                    defaultAppearanceData: {
+                      fontSize: R,
+                      fontColor: d
+                    },
+                    rect: g,
+                    rotation: f,
+                    id: v
+                  },
+                  textContent: A,
+                  textPosition: O,
+                  parent: {
+                    page: {
+                      pageNumber: H
+                    }
+                  }
+                } = q;
+                if (!A || A.length === 0)
+                  return null;
+                we = q = {
+                  annotationType: n.AnnotationEditorType.FREETEXT,
+                  color: Array.from(d),
+                  fontSize: R,
+                  value: A.join(`
+`),
+                  position: O,
+                  pageIndex: H - 1,
+                  rect: g,
+                  rotation: f,
+                  id: v,
+                  deleted: !1
+                };
+              }
+              const be = super.deserialize(q, le, pe);
+              return oe(be, P, q.fontSize), oe(be, S, n.Util.makeHexColor(...q.color)), oe(be, w, q.value), be.annotationElementId = q.id || null, oe(be, b, we), be;
+            }
+            serialize(q = !1) {
+              if (this.isEmpty())
+                return null;
+              if (this.deleted)
+                return {
+                  pageIndex: this.pageIndex,
+                  id: this.annotationElementId,
+                  deleted: !0
+                };
+              const le = B._internalPadding * this.parentScale, pe = this.getRect(le, le), we = l.AnnotationEditor._colorManager.convert(this.isAttachedToDOM ? getComputedStyle(this.editorDiv).color : a(this, S)), be = {
+                annotationType: n.AnnotationEditorType.FREETEXT,
+                color: we,
+                fontSize: a(this, P),
+                value: a(this, w),
+                pageIndex: this.pageIndex,
+                rect: pe,
+                rotation: this.rotation,
+                structTreeParentId: this._structTreeParentId
+              };
+              return q ? be : this.annotationElementId && !K(this, D, On).call(this, be) ? null : (be.id = this.annotationElementId, be);
+            }
+          };
+          c = new WeakMap(), o = new WeakMap(), r = new WeakMap(), T = new WeakMap(), S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakMap(), k = new WeakSet(), In = function(q) {
+            const le = (we) => {
+              this.editorDiv.style.fontSize = `calc(${we}px * var(--scale-factor))`, this.translate(0, -(we - a(this, P)) * this.parentScale), oe(this, P, we), K(this, $, At).call(this);
+            }, pe = a(this, P);
+            this.addCommands({
+              cmd: () => {
+                le(q);
+              },
+              undo: () => {
+                le(pe);
+              },
+              mustExec: !0,
+              type: n.AnnotationEditorParamsType.FREETEXT_SIZE,
+              overwriteIfSameType: !0,
+              keepUndo: !0
+            });
+          }, x = new WeakSet(), Ln = function(q) {
+            const le = a(this, S);
+            this.addCommands({
+              cmd: () => {
+                oe(this, S, this.editorDiv.style.color = q);
+              },
+              undo: () => {
+                oe(this, S, this.editorDiv.style.color = le);
+              },
+              mustExec: !0,
+              type: n.AnnotationEditorParamsType.FREETEXT_COLOR,
+              overwriteIfSameType: !0,
+              keepUndo: !0
+            });
+          }, p = new WeakSet(), Dn = function() {
+            const q = this.editorDiv.getElementsByTagName("div");
+            if (q.length === 0)
+              return this.editorDiv.innerText;
+            const le = [];
+            for (const pe of q)
+              le.push(pe.innerText.replace(/\r\n?|\n/, ""));
+            return le.join(`
+`);
+          }, $ = new WeakSet(), At = function() {
+            const [q, le] = this.parentDimensions;
+            let pe;
+            if (this.isAttachedToDOM)
+              pe = this.div.getBoundingClientRect();
+            else {
+              const {
+                currentLayer: we,
+                div: be
+              } = this, R = be.style.display;
+              be.style.display = "hidden", we.div.append(this.div), pe = be.getBoundingClientRect(), be.remove(), be.style.display = R;
+            }
+            this.rotation % 180 === this.parentRotation % 180 ? (this.width = pe.width / q, this.height = pe.height / le) : (this.width = pe.height / q, this.height = pe.width / le), this.fixAndSetPosition();
+          }, m = new WeakSet(), an = function() {
+            if (this.editorDiv.replaceChildren(), !!a(this, w))
+              for (const q of a(this, w).split(`
+`)) {
+                const le = document.createElement("div");
+                le.append(q ? document.createTextNode(q) : document.createElement("br")), this.editorDiv.append(le);
+              }
+          }, D = new WeakSet(), On = function(q) {
+            const {
+              value: le,
+              fontSize: pe,
+              color: we,
+              rect: be,
+              pageIndex: R
+            } = a(this, b);
+            return q.value !== le || q.fontSize !== pe || q.rect.some((d, g) => Math.abs(d - be[g]) >= 1) || q.color.some((d, g) => d !== we[g]) || q.pageIndex !== R;
+          }, G = new WeakSet(), on = function(q = !1) {
+            if (!this.annotationElementId)
+              return;
+            if (K(this, $, At).call(this), !q && (this.width === 0 || this.height === 0)) {
+              setTimeout(() => K(this, G, on).call(this, !0), 0);
+              return;
+            }
+            const le = B._internalPadding * this.parentScale;
+            a(this, b).rect = this.getRect(le, le);
+          }, nt(B, "_freeTextDefaultContent", ""), nt(B, "_internalPadding", 0), nt(B, "_defaultColor", null), nt(B, "_defaultFontSize", 10), nt(B, "_type", "freetext");
+          let _ = B;
+          e.FreeTextEditor = _;
+        },
+        /* 29 */
+        /***/
+        (t, e, i) => {
+          var g, v, ht, O, Nn, z, ae, Q, ce, ue, me, fe, Pe, Fe, Ee, De, _e, ie, se, ge, Ce, xe, Ue, $n, je, Mt, Xe, ln, Ye, cn, ne, J, ve, Se, tt, et, te, hn, Ne, ke, $e, Be, Bn, Ae, un;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.StampAnnotationElement = e.InkAnnotationElement = e.FreeTextAnnotationElement = e.AnnotationLayer = void 0;
+          var n = i(1), s = i(6), l = i(3), h = i(30), _ = i(31), c = i(32);
+          const o = 1e3, r = 9, T = /* @__PURE__ */ new WeakSet();
+          function S(Oe) {
+            return {
+              width: Oe[2] - Oe[0],
+              height: Oe[3] - Oe[1]
+            };
+          }
+          class w {
+            static create(U) {
+              switch (U.data.annotationType) {
+                case n.AnnotationType.LINK:
+                  return new P(U);
+                case n.AnnotationType.TEXT:
+                  return new b(U);
+                case n.AnnotationType.WIDGET:
+                  switch (U.data.fieldType) {
+                    case "Tx":
+                      return new F(U);
+                    case "Btn":
+                      return U.data.radioButton ? new p(U) : U.data.checkBox ? new y(U) : new E(U);
+                    case "Ch":
+                      return new $(U);
+                    case "Sig":
+                      return new x(U);
+                  }
+                  return new k(U);
+                case n.AnnotationType.POPUP:
+                  return new M(U);
+                case n.AnnotationType.FREETEXT:
+                  return new N(U);
+                case n.AnnotationType.LINE:
+                  return new D(U);
+                case n.AnnotationType.SQUARE:
+                  return new X(U);
+                case n.AnnotationType.CIRCLE:
+                  return new G(U);
+                case n.AnnotationType.POLYLINE:
+                  return new I(U);
+                case n.AnnotationType.CARET:
+                  return new ee(U);
+                case n.AnnotationType.INK:
+                  return new Y(U);
+                case n.AnnotationType.POLYGON:
+                  return new B(U);
+                case n.AnnotationType.HIGHLIGHT:
+                  return new q(U);
+                case n.AnnotationType.UNDERLINE:
+                  return new le(U);
+                case n.AnnotationType.SQUIGGLY:
+                  return new pe(U);
+                case n.AnnotationType.STRIKEOUT:
+                  return new we(U);
+                case n.AnnotationType.STAMP:
+                  return new be(U);
+                case n.AnnotationType.FILEATTACHMENT:
+                  return new R(U);
+                default:
+                  return new C(U);
+              }
+            }
+          }
+          const f = class f {
+            constructor(U, {
+              isRenderable: u = !1,
+              ignoreBorder: L = !1,
+              createQuadrilaterals: j = !1
+            } = {}) {
+              W(this, g, !1);
+              this.isRenderable = u, this.data = U.data, this.layer = U.layer, this.linkService = U.linkService, this.downloadManager = U.downloadManager, this.imageResourcesPath = U.imageResourcesPath, this.renderForms = U.renderForms, this.svgFactory = U.svgFactory, this.annotationStorage = U.annotationStorage, this.enableScripting = U.enableScripting, this.hasJSActions = U.hasJSActions, this._fieldObjects = U.fieldObjects, this.parent = U.parent, u && (this.container = this._createContainer(L)), j && this._createQuadrilaterals();
+            }
+            static _hasPopupData({
+              titleObj: U,
+              contentsObj: u,
+              richText: L
+            }) {
+              return !!(U != null && U.str || u != null && u.str || L != null && L.str);
+            }
+            get hasPopupData() {
+              return f._hasPopupData(this.data);
+            }
+            _createContainer(U) {
+              const {
+                data: u,
+                parent: {
+                  page: L,
+                  viewport: j
+                }
+              } = this, V = document.createElement("section");
+              V.setAttribute("data-annotation-id", u.id), this instanceof k || (V.tabIndex = o), V.style.zIndex = this.parent.zIndex++, this.data.popupRef && V.setAttribute("aria-haspopup", "dialog"), u.noRotate && V.classList.add("norotate");
+              const {
+                pageWidth: Z,
+                pageHeight: he,
+                pageX: ye,
+                pageY: Me
+              } = j.rawDims;
+              if (!u.rect || this instanceof M) {
+                const {
+                  rotation: He
+                } = u;
+                return !u.hasOwnCanvas && He !== 0 && this.setRotation(He, V), V;
+              }
+              const {
+                width: Re,
+                height: qe
+              } = S(u.rect), Ie = n.Util.normalizeRect([u.rect[0], L.view[3] - u.rect[1] + L.view[1], u.rect[2], L.view[3] - u.rect[3] + L.view[1]]);
+              if (!U && u.borderStyle.width > 0) {
+                V.style.borderWidth = `${u.borderStyle.width}px`;
+                const He = u.borderStyle.horizontalCornerRadius, Ve = u.borderStyle.verticalCornerRadius;
+                if (He > 0 || Ve > 0) {
+                  const Ze = `calc(${He}px * var(--scale-factor)) / calc(${Ve}px * var(--scale-factor))`;
+                  V.style.borderRadius = Ze;
+                } else if (this instanceof p) {
+                  const Ze = `calc(${Re}px * var(--scale-factor)) / calc(${qe}px * var(--scale-factor))`;
+                  V.style.borderRadius = Ze;
+                }
+                switch (u.borderStyle.style) {
+                  case n.AnnotationBorderStyleType.SOLID:
+                    V.style.borderStyle = "solid";
+                    break;
+                  case n.AnnotationBorderStyleType.DASHED:
+                    V.style.borderStyle = "dashed";
+                    break;
+                  case n.AnnotationBorderStyleType.BEVELED:
+                    (0, n.warn)("Unimplemented border style: beveled");
+                    break;
+                  case n.AnnotationBorderStyleType.INSET:
+                    (0, n.warn)("Unimplemented border style: inset");
+                    break;
+                  case n.AnnotationBorderStyleType.UNDERLINE:
+                    V.style.borderBottomStyle = "solid";
+                    break;
+                }
+                const Je = u.borderColor || null;
+                Je ? (oe(this, g, !0), V.style.borderColor = n.Util.makeHexColor(Je[0] | 0, Je[1] | 0, Je[2] | 0)) : V.style.borderWidth = 0;
+              }
+              V.style.left = `${100 * (Ie[0] - ye) / Z}%`, V.style.top = `${100 * (Ie[1] - Me) / he}%`;
+              const {
+                rotation: Le
+              } = u;
+              return u.hasOwnCanvas || Le === 0 ? (V.style.width = `${100 * Re / Z}%`, V.style.height = `${100 * qe / he}%`) : this.setRotation(Le, V), V;
+            }
+            setRotation(U, u = this.container) {
+              if (!this.data.rect)
+                return;
+              const {
+                pageWidth: L,
+                pageHeight: j
+              } = this.parent.viewport.rawDims, {
+                width: V,
+                height: Z
+              } = S(this.data.rect);
+              let he, ye;
+              U % 180 === 0 ? (he = 100 * V / L, ye = 100 * Z / j) : (he = 100 * Z / L, ye = 100 * V / j), u.style.width = `${he}%`, u.style.height = `${ye}%`, u.setAttribute("data-main-rotation", (360 - U) % 360);
+            }
+            get _commonActions() {
+              const U = (u, L, j) => {
+                const V = j.detail[u], Z = V[0], he = V.slice(1);
+                j.target.style[L] = h.ColorConverters[`${Z}_HTML`](he), this.annotationStorage.setValue(this.data.id, {
+                  [L]: h.ColorConverters[`${Z}_rgb`](he)
+                });
+              };
+              return (0, n.shadow)(this, "_commonActions", {
+                display: (u) => {
+                  const {
+                    display: L
+                  } = u.detail, j = L % 2 === 1;
+                  this.container.style.visibility = j ? "hidden" : "visible", this.annotationStorage.setValue(this.data.id, {
+                    noView: j,
+                    noPrint: L === 1 || L === 2
+                  });
+                },
+                print: (u) => {
+                  this.annotationStorage.setValue(this.data.id, {
+                    noPrint: !u.detail.print
+                  });
+                },
+                hidden: (u) => {
+                  const {
+                    hidden: L
+                  } = u.detail;
+                  this.container.style.visibility = L ? "hidden" : "visible", this.annotationStorage.setValue(this.data.id, {
+                    noPrint: L,
+                    noView: L
+                  });
+                },
+                focus: (u) => {
+                  setTimeout(() => u.target.focus({
+                    preventScroll: !1
+                  }), 0);
+                },
+                userName: (u) => {
+                  u.target.title = u.detail.userName;
+                },
+                readonly: (u) => {
+                  u.target.disabled = u.detail.readonly;
+                },
+                required: (u) => {
+                  this._setRequired(u.target, u.detail.required);
+                },
+                bgColor: (u) => {
+                  U("bgColor", "backgroundColor", u);
+                },
+                fillColor: (u) => {
+                  U("fillColor", "backgroundColor", u);
+                },
+                fgColor: (u) => {
+                  U("fgColor", "color", u);
+                },
+                textColor: (u) => {
+                  U("textColor", "color", u);
+                },
+                borderColor: (u) => {
+                  U("borderColor", "borderColor", u);
+                },
+                strokeColor: (u) => {
+                  U("strokeColor", "borderColor", u);
+                },
+                rotation: (u) => {
+                  const L = u.detail.rotation;
+                  this.setRotation(L), this.annotationStorage.setValue(this.data.id, {
+                    rotation: L
+                  });
+                }
+              });
+            }
+            _dispatchEventFromSandbox(U, u) {
+              const L = this._commonActions;
+              for (const j of Object.keys(u.detail)) {
+                const V = U[j] || L[j];
+                V == null || V(u);
+              }
+            }
+            _setDefaultPropertiesFromJS(U) {
+              if (!this.enableScripting)
+                return;
+              const u = this.annotationStorage.getRawValue(this.data.id);
+              if (!u)
+                return;
+              const L = this._commonActions;
+              for (const [j, V] of Object.entries(u)) {
+                const Z = L[j];
+                if (Z) {
+                  const he = {
+                    detail: {
+                      [j]: V
+                    },
+                    target: U
+                  };
+                  Z(he), delete u[j];
+                }
+              }
+            }
+            _createQuadrilaterals() {
+              if (!this.container)
+                return;
+              const {
+                quadPoints: U
+              } = this.data;
+              if (!U)
+                return;
+              const [u, L, j, V] = this.data.rect;
+              if (U.length === 1) {
+                const [, {
+                  x: Ve,
+                  y: Je
+                }, {
+                  x: Ze,
+                  y: st
+                }] = U[0];
+                if (j === Ve && V === Je && u === Ze && L === st)
+                  return;
+              }
+              const {
+                style: Z
+              } = this.container;
+              let he;
+              if (a(this, g)) {
+                const {
+                  borderColor: Ve,
+                  borderWidth: Je
+                } = Z;
+                Z.borderWidth = 0, he = ["url('data:image/svg+xml;utf8,", '<svg xmlns="http://www.w3.org/2000/svg"', ' preserveAspectRatio="none" viewBox="0 0 1 1">', `<g fill="transparent" stroke="${Ve}" stroke-width="${Je}">`], this.container.classList.add("hasBorder");
+              }
+              const ye = j - u, Me = V - L, {
+                svgFactory: Re
+              } = this, qe = Re.createElement("svg");
+              qe.classList.add("quadrilateralsContainer"), qe.setAttribute("width", 0), qe.setAttribute("height", 0);
+              const Ie = Re.createElement("defs");
+              qe.append(Ie);
+              const Le = Re.createElement("clipPath"), He = `clippath_${this.data.id}`;
+              Le.setAttribute("id", He), Le.setAttribute("clipPathUnits", "objectBoundingBox"), Ie.append(Le);
+              for (const [, {
+                x: Ve,
+                y: Je
+              }, {
+                x: Ze,
+                y: st
+              }] of U) {
+                const it = Re.createElement("rect"), rt = (Ze - u) / ye, lt = (V - Je) / Me, ct = (Ve - Ze) / ye, An = (Je - st) / Me;
+                it.setAttribute("x", rt), it.setAttribute("y", lt), it.setAttribute("width", ct), it.setAttribute("height", An), Le.append(it), he == null || he.push(`<rect vector-effect="non-scaling-stroke" x="${rt}" y="${lt}" width="${ct}" height="${An}"/>`);
+              }
+              a(this, g) && (he.push("</g></svg>')"), Z.backgroundImage = he.join("")), this.container.append(qe), this.container.style.clipPath = `url(#${He})`;
+            }
+            _createPopup() {
+              const {
+                container: U,
+                data: u
+              } = this;
+              U.setAttribute("aria-haspopup", "dialog");
+              const L = new M({
+                data: {
+                  color: u.color,
+                  titleObj: u.titleObj,
+                  modificationDate: u.modificationDate,
+                  contentsObj: u.contentsObj,
+                  richText: u.richText,
+                  parentRect: u.rect,
+                  borderStyle: 0,
+                  id: `popup_${u.id}`,
+                  rotation: u.rotation
+                },
+                parent: this.parent,
+                elements: [this]
+              });
+              this.parent.div.append(L.render());
+            }
+            render() {
+              (0, n.unreachable)("Abstract method `AnnotationElement.render` called");
+            }
+            _getElementsByName(U, u = null) {
+              const L = [];
+              if (this._fieldObjects) {
+                const j = this._fieldObjects[U];
+                if (j)
+                  for (const {
+                    page: V,
+                    id: Z,
+                    exportValues: he
+                  } of j) {
+                    if (V === -1 || Z === u)
+                      continue;
+                    const ye = typeof he == "string" ? he : null, Me = document.querySelector(`[data-element-id="${Z}"]`);
+                    if (Me && !T.has(Me)) {
+                      (0, n.warn)(`_getElementsByName - element not allowed: ${Z}`);
+                      continue;
+                    }
+                    L.push({
+                      id: Z,
+                      exportValue: ye,
+                      domElement: Me
+                    });
+                  }
+                return L;
+              }
+              for (const j of document.getElementsByName(U)) {
+                const {
+                  exportValue: V
+                } = j, Z = j.getAttribute("data-element-id");
+                Z !== u && T.has(j) && L.push({
+                  id: Z,
+                  exportValue: V,
+                  domElement: j
+                });
+              }
+              return L;
+            }
+            show() {
+              var U;
+              this.container && (this.container.hidden = !1), (U = this.popup) == null || U.maybeShow();
+            }
+            hide() {
+              var U;
+              this.container && (this.container.hidden = !0), (U = this.popup) == null || U.forceHide();
+            }
+            getElementsToTriggerPopup() {
+              return this.container;
+            }
+            addHighlightArea() {
+              const U = this.getElementsToTriggerPopup();
+              if (Array.isArray(U))
+                for (const u of U)
+                  u.classList.add("highlightArea");
+              else
+                U.classList.add("highlightArea");
+            }
+            _editOnDoubleClick() {
+              const {
+                annotationEditorType: U,
+                data: {
+                  id: u
+                }
+              } = this;
+              this.container.addEventListener("dblclick", () => {
+                var L;
+                (L = this.linkService.eventBus) == null || L.dispatch("switchannotationeditormode", {
+                  source: this,
+                  mode: U,
+                  editId: u
+                });
+              });
+            }
+          };
+          g = new WeakMap();
+          let C = f;
+          class P extends C {
+            constructor(u, L = null) {
+              super(u, {
+                isRenderable: !0,
+                ignoreBorder: !!(L != null && L.ignoreBorder),
+                createQuadrilaterals: !0
+              });
+              W(this, v);
+              W(this, O);
+              this.isTooltipOnly = u.data.isTooltipOnly;
+            }
+            render() {
+              const {
+                data: u,
+                linkService: L
+              } = this, j = document.createElement("a");
+              j.setAttribute("data-element-id", u.id);
+              let V = !1;
+              return u.url ? (L.addLinkAttributes(j, u.url, u.newWindow), V = !0) : u.action ? (this._bindNamedAction(j, u.action), V = !0) : u.attachment ? (this._bindAttachment(j, u.attachment), V = !0) : u.setOCGState ? (K(this, O, Nn).call(this, j, u.setOCGState), V = !0) : u.dest ? (this._bindLink(j, u.dest), V = !0) : (u.actions && (u.actions.Action || u.actions["Mouse Up"] || u.actions["Mouse Down"]) && this.enableScripting && this.hasJSActions && (this._bindJSAction(j, u), V = !0), u.resetForm ? (this._bindResetFormAction(j, u.resetForm), V = !0) : this.isTooltipOnly && !V && (this._bindLink(j, ""), V = !0)), this.container.classList.add("linkAnnotation"), V && this.container.append(j), this.container;
+            }
+            _bindLink(u, L) {
+              u.href = this.linkService.getDestinationHash(L), u.onclick = () => (L && this.linkService.goToDestination(L), !1), (L || L === "") && K(this, v, ht).call(this);
+            }
+            _bindNamedAction(u, L) {
+              u.href = this.linkService.getAnchorUrl(""), u.onclick = () => (this.linkService.executeNamedAction(L), !1), K(this, v, ht).call(this);
+            }
+            _bindAttachment(u, L) {
+              u.href = this.linkService.getAnchorUrl(""), u.onclick = () => {
+                var j;
+                return (j = this.downloadManager) == null || j.openOrDownloadData(this.container, L.content, L.filename), !1;
+              }, K(this, v, ht).call(this);
+            }
+            _bindJSAction(u, L) {
+              u.href = this.linkService.getAnchorUrl("");
+              const j = /* @__PURE__ */ new Map([["Action", "onclick"], ["Mouse Up", "onmouseup"], ["Mouse Down", "onmousedown"]]);
+              for (const V of Object.keys(L.actions)) {
+                const Z = j.get(V);
+                Z && (u[Z] = () => {
+                  var he;
+                  return (he = this.linkService.eventBus) == null || he.dispatch("dispatcheventinsandbox", {
+                    source: this,
+                    detail: {
+                      id: L.id,
+                      name: V
+                    }
+                  }), !1;
+                });
+              }
+              u.onclick || (u.onclick = () => !1), K(this, v, ht).call(this);
+            }
+            _bindResetFormAction(u, L) {
+              const j = u.onclick;
+              if (j || (u.href = this.linkService.getAnchorUrl("")), K(this, v, ht).call(this), !this._fieldObjects) {
+                (0, n.warn)('_bindResetFormAction - "resetForm" action not supported, ensure that the `fieldObjects` parameter is provided.'), j || (u.onclick = () => !1);
+                return;
+              }
+              u.onclick = () => {
+                var qe;
+                j == null || j();
+                const {
+                  fields: V,
+                  refs: Z,
+                  include: he
+                } = L, ye = [];
+                if (V.length !== 0 || Z.length !== 0) {
+                  const Ie = new Set(Z);
+                  for (const Le of V) {
+                    const He = this._fieldObjects[Le] || [];
+                    for (const {
+                      id: Ve
+                    } of He)
+                      Ie.add(Ve);
+                  }
+                  for (const Le of Object.values(this._fieldObjects))
+                    for (const He of Le)
+                      Ie.has(He.id) === he && ye.push(He);
+                } else
+                  for (const Ie of Object.values(this._fieldObjects))
+                    ye.push(...Ie);
+                const Me = this.annotationStorage, Re = [];
+                for (const Ie of ye) {
+                  const {
+                    id: Le
+                  } = Ie;
+                  switch (Re.push(Le), Ie.type) {
+                    case "text": {
+                      const Ve = Ie.defaultValue || "";
+                      Me.setValue(Le, {
+                        value: Ve
+                      });
+                      break;
+                    }
+                    case "checkbox":
+                    case "radiobutton": {
+                      const Ve = Ie.defaultValue === Ie.exportValues;
+                      Me.setValue(Le, {
+                        value: Ve
+                      });
+                      break;
+                    }
+                    case "combobox":
+                    case "listbox": {
+                      const Ve = Ie.defaultValue || "";
+                      Me.setValue(Le, {
+                        value: Ve
+                      });
+                      break;
+                    }
+                    default:
+                      continue;
+                  }
+                  const He = document.querySelector(`[data-element-id="${Le}"]`);
+                  if (He) {
+                    if (!T.has(He)) {
+                      (0, n.warn)(`_bindResetFormAction - element not allowed: ${Le}`);
+                      continue;
+                    }
+                  } else
+                    continue;
+                  He.dispatchEvent(new Event("resetform"));
+                }
+                return this.enableScripting && ((qe = this.linkService.eventBus) == null || qe.dispatch("dispatcheventinsandbox", {
+                  source: this,
+                  detail: {
+                    id: "app",
+                    ids: Re,
+                    name: "ResetForm"
+                  }
+                })), !1;
+              };
+            }
+          }
+          v = new WeakSet(), ht = function() {
+            this.container.setAttribute("data-internal-link", "");
+          }, O = new WeakSet(), Nn = function(u, L) {
+            u.href = this.linkService.getAnchorUrl(""), u.onclick = () => (this.linkService.executeSetOCGState(L), !1), K(this, v, ht).call(this);
+          };
+          class b extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0
+              });
+            }
+            render() {
+              this.container.classList.add("textAnnotation");
+              const U = document.createElement("img");
+              return U.src = this.imageResourcesPath + "annotation-" + this.data.name.toLowerCase() + ".svg", U.alt = "[{{type}} Annotation]", U.dataset.l10nId = "text_annotation_type", U.dataset.l10nArgs = JSON.stringify({
+                type: this.data.name
+              }), !this.data.popupRef && this.hasPopupData && this._createPopup(), this.container.append(U), this.container;
+            }
+          }
+          class k extends C {
+            render() {
+              return this.data.alternativeText && (this.container.title = this.data.alternativeText), this.container;
+            }
+            showElementAndHideCanvas(U) {
+              var u;
+              this.data.hasOwnCanvas && (((u = U.previousSibling) == null ? void 0 : u.nodeName) === "CANVAS" && (U.previousSibling.hidden = !0), U.hidden = !1);
+            }
+            _getKeyModifier(U) {
+              const {
+                isWin: u,
+                isMac: L
+              } = n.FeatureTest.platform;
+              return u && U.ctrlKey || L && U.metaKey;
+            }
+            _setEventListener(U, u, L, j, V) {
+              L.includes("mouse") ? U.addEventListener(L, (Z) => {
+                var he;
+                (he = this.linkService.eventBus) == null || he.dispatch("dispatcheventinsandbox", {
+                  source: this,
+                  detail: {
+                    id: this.data.id,
+                    name: j,
+                    value: V(Z),
+                    shift: Z.shiftKey,
+                    modifier: this._getKeyModifier(Z)
+                  }
+                });
+              }) : U.addEventListener(L, (Z) => {
+                var he;
+                if (L === "blur") {
+                  if (!u.focused || !Z.relatedTarget)
+                    return;
+                  u.focused = !1;
+                } else if (L === "focus") {
+                  if (u.focused)
+                    return;
+                  u.focused = !0;
+                }
+                V && ((he = this.linkService.eventBus) == null || he.dispatch("dispatcheventinsandbox", {
+                  source: this,
+                  detail: {
+                    id: this.data.id,
+                    name: j,
+                    value: V(Z)
+                  }
+                }));
+              });
+            }
+            _setEventListeners(U, u, L, j) {
+              var V, Z, he;
+              for (const [ye, Me] of L)
+                (Me === "Action" || (V = this.data.actions) != null && V[Me]) && ((Me === "Focus" || Me === "Blur") && (u || (u = {
+                  focused: !1
+                })), this._setEventListener(U, u, ye, Me, j), Me === "Focus" && !((Z = this.data.actions) != null && Z.Blur) ? this._setEventListener(U, u, "blur", "Blur", null) : Me === "Blur" && !((he = this.data.actions) != null && he.Focus) && this._setEventListener(U, u, "focus", "Focus", null));
+            }
+            _setBackgroundColor(U) {
+              const u = this.data.backgroundColor || null;
+              U.style.backgroundColor = u === null ? "transparent" : n.Util.makeHexColor(u[0], u[1], u[2]);
+            }
+            _setTextStyle(U) {
+              const u = ["left", "center", "right"], {
+                fontColor: L
+              } = this.data.defaultAppearanceData, j = this.data.defaultAppearanceData.fontSize || r, V = U.style;
+              let Z;
+              const he = 2, ye = (Me) => Math.round(10 * Me) / 10;
+              if (this.data.multiLine) {
+                const Me = Math.abs(this.data.rect[3] - this.data.rect[1] - he), Re = Math.round(Me / (n.LINE_FACTOR * j)) || 1, qe = Me / Re;
+                Z = Math.min(j, ye(qe / n.LINE_FACTOR));
+              } else {
+                const Me = Math.abs(this.data.rect[3] - this.data.rect[1] - he);
+                Z = Math.min(j, ye(Me / n.LINE_FACTOR));
+              }
+              V.fontSize = `calc(${Z}px * var(--scale-factor))`, V.color = n.Util.makeHexColor(L[0], L[1], L[2]), this.data.textAlignment !== null && (V.textAlign = u[this.data.textAlignment]);
+            }
+            _setRequired(U, u) {
+              u ? U.setAttribute("required", !0) : U.removeAttribute("required"), U.setAttribute("aria-required", u);
+            }
+          }
+          class F extends k {
+            constructor(U) {
+              const u = U.renderForms || !U.data.hasAppearance && !!U.data.fieldValue;
+              super(U, {
+                isRenderable: u
+              });
+            }
+            setPropertyOnSiblings(U, u, L, j) {
+              const V = this.annotationStorage;
+              for (const Z of this._getElementsByName(U.name, U.id))
+                Z.domElement && (Z.domElement[u] = L), V.setValue(Z.id, {
+                  [j]: L
+                });
+            }
+            render() {
+              var j, V;
+              const U = this.annotationStorage, u = this.data.id;
+              this.container.classList.add("textWidgetAnnotation");
+              let L = null;
+              if (this.renderForms) {
+                const Z = U.getValue(u, {
+                  value: this.data.fieldValue
+                });
+                let he = Z.value || "";
+                const ye = U.getValue(u, {
+                  charLimit: this.data.maxLen
+                }).charLimit;
+                ye && he.length > ye && (he = he.slice(0, ye));
+                let Me = Z.formattedValue || ((j = this.data.textContent) == null ? void 0 : j.join(`
+`)) || null;
+                Me && this.data.comb && (Me = Me.replaceAll(/\s+/g, ""));
+                const Re = {
+                  userValue: he,
+                  formattedValue: Me,
+                  lastCommittedValue: null,
+                  commitKey: 1,
+                  focused: !1
+                };
+                this.data.multiLine ? (L = document.createElement("textarea"), L.textContent = Me ?? he, this.data.doNotScroll && (L.style.overflowY = "hidden")) : (L = document.createElement("input"), L.type = "text", L.setAttribute("value", Me ?? he), this.data.doNotScroll && (L.style.overflowX = "hidden")), this.data.hasOwnCanvas && (L.hidden = !0), T.add(L), L.setAttribute("data-element-id", u), L.disabled = this.data.readOnly, L.name = this.data.fieldName, L.tabIndex = o, this._setRequired(L, this.data.required), ye && (L.maxLength = ye), L.addEventListener("input", (Ie) => {
+                  U.setValue(u, {
+                    value: Ie.target.value
+                  }), this.setPropertyOnSiblings(L, "value", Ie.target.value, "value"), Re.formattedValue = null;
+                }), L.addEventListener("resetform", (Ie) => {
+                  const Le = this.data.defaultFieldValue ?? "";
+                  L.value = Re.userValue = Le, Re.formattedValue = null;
+                });
+                let qe = (Ie) => {
+                  const {
+                    formattedValue: Le
+                  } = Re;
+                  Le != null && (Ie.target.value = Le), Ie.target.scrollLeft = 0;
+                };
+                if (this.enableScripting && this.hasJSActions) {
+                  L.addEventListener("focus", (Le) => {
+                    if (Re.focused)
+                      return;
+                    const {
+                      target: He
+                    } = Le;
+                    Re.userValue && (He.value = Re.userValue), Re.lastCommittedValue = He.value, Re.commitKey = 1, Re.focused = !0;
+                  }), L.addEventListener("updatefromsandbox", (Le) => {
+                    this.showElementAndHideCanvas(Le.target);
+                    const He = {
+                      value(Ve) {
+                        Re.userValue = Ve.detail.value ?? "", U.setValue(u, {
+                          value: Re.userValue.toString()
+                        }), Ve.target.value = Re.userValue;
+                      },
+                      formattedValue(Ve) {
+                        const {
+                          formattedValue: Je
+                        } = Ve.detail;
+                        Re.formattedValue = Je, Je != null && Ve.target !== document.activeElement && (Ve.target.value = Je), U.setValue(u, {
+                          formattedValue: Je
+                        });
+                      },
+                      selRange(Ve) {
+                        Ve.target.setSelectionRange(...Ve.detail.selRange);
+                      },
+                      charLimit: (Ve) => {
+                        var it;
+                        const {
+                          charLimit: Je
+                        } = Ve.detail, {
+                          target: Ze
+                        } = Ve;
+                        if (Je === 0) {
+                          Ze.removeAttribute("maxLength");
+                          return;
+                        }
+                        Ze.setAttribute("maxLength", Je);
+                        let st = Re.userValue;
+                        !st || st.length <= Je || (st = st.slice(0, Je), Ze.value = Re.userValue = st, U.setValue(u, {
+                          value: st
+                        }), (it = this.linkService.eventBus) == null || it.dispatch("dispatcheventinsandbox", {
+                          source: this,
+                          detail: {
+                            id: u,
+                            name: "Keystroke",
+                            value: st,
+                            willCommit: !0,
+                            commitKey: 1,
+                            selStart: Ze.selectionStart,
+                            selEnd: Ze.selectionEnd
+                          }
+                        }));
+                      }
+                    };
+                    this._dispatchEventFromSandbox(He, Le);
+                  }), L.addEventListener("keydown", (Le) => {
+                    var Je;
+                    Re.commitKey = 1;
+                    let He = -1;
+                    if (Le.key === "Escape" ? He = 0 : Le.key === "Enter" && !this.data.multiLine ? He = 2 : Le.key === "Tab" && (Re.commitKey = 3), He === -1)
+                      return;
+                    const {
+                      value: Ve
+                    } = Le.target;
+                    Re.lastCommittedValue !== Ve && (Re.lastCommittedValue = Ve, Re.userValue = Ve, (Je = this.linkService.eventBus) == null || Je.dispatch("dispatcheventinsandbox", {
+                      source: this,
+                      detail: {
+                        id: u,
+                        name: "Keystroke",
+                        value: Ve,
+                        willCommit: !0,
+                        commitKey: He,
+                        selStart: Le.target.selectionStart,
+                        selEnd: Le.target.selectionEnd
+                      }
+                    }));
+                  });
+                  const Ie = qe;
+                  qe = null, L.addEventListener("blur", (Le) => {
+                    var Ve;
+                    if (!Re.focused || !Le.relatedTarget)
+                      return;
+                    Re.focused = !1;
+                    const {
+                      value: He
+                    } = Le.target;
+                    Re.userValue = He, Re.lastCommittedValue !== He && ((Ve = this.linkService.eventBus) == null || Ve.dispatch("dispatcheventinsandbox", {
+                      source: this,
+                      detail: {
+                        id: u,
+                        name: "Keystroke",
+                        value: He,
+                        willCommit: !0,
+                        commitKey: Re.commitKey,
+                        selStart: Le.target.selectionStart,
+                        selEnd: Le.target.selectionEnd
+                      }
+                    })), Ie(Le);
+                  }), (V = this.data.actions) != null && V.Keystroke && L.addEventListener("beforeinput", (Le) => {
+                    var lt;
+                    Re.lastCommittedValue = null;
+                    const {
+                      data: He,
+                      target: Ve
+                    } = Le, {
+                      value: Je,
+                      selectionStart: Ze,
+                      selectionEnd: st
+                    } = Ve;
+                    let it = Ze, rt = st;
+                    switch (Le.inputType) {
+                      case "deleteWordBackward": {
+                        const ct = Je.substring(0, Ze).match(/\w*[^\w]*$/);
+                        ct && (it -= ct[0].length);
+                        break;
+                      }
+                      case "deleteWordForward": {
+                        const ct = Je.substring(Ze).match(/^[^\w]*\w*/);
+                        ct && (rt += ct[0].length);
+                        break;
+                      }
+                      case "deleteContentBackward":
+                        Ze === st && (it -= 1);
+                        break;
+                      case "deleteContentForward":
+                        Ze === st && (rt += 1);
+                        break;
+                    }
+                    Le.preventDefault(), (lt = this.linkService.eventBus) == null || lt.dispatch("dispatcheventinsandbox", {
+                      source: this,
+                      detail: {
+                        id: u,
+                        name: "Keystroke",
+                        value: Je,
+                        change: He || "",
+                        willCommit: !1,
+                        selStart: it,
+                        selEnd: rt
+                      }
+                    });
+                  }), this._setEventListeners(L, Re, [["focus", "Focus"], ["blur", "Blur"], ["mousedown", "Mouse Down"], ["mouseenter", "Mouse Enter"], ["mouseleave", "Mouse Exit"], ["mouseup", "Mouse Up"]], (Le) => Le.target.value);
+                }
+                if (qe && L.addEventListener("blur", qe), this.data.comb) {
+                  const Le = (this.data.rect[2] - this.data.rect[0]) / ye;
+                  L.classList.add("comb"), L.style.letterSpacing = `calc(${Le}px * var(--scale-factor) - 1ch)`;
+                }
+              } else
+                L = document.createElement("div"), L.textContent = this.data.fieldValue, L.style.verticalAlign = "middle", L.style.display = "table-cell";
+              return this._setTextStyle(L), this._setBackgroundColor(L), this._setDefaultPropertiesFromJS(L), this.container.append(L), this.container;
+            }
+          }
+          class x extends k {
+            constructor(U) {
+              super(U, {
+                isRenderable: !!U.data.hasOwnCanvas
+              });
+            }
+          }
+          class y extends k {
+            constructor(U) {
+              super(U, {
+                isRenderable: U.renderForms
+              });
+            }
+            render() {
+              const U = this.annotationStorage, u = this.data, L = u.id;
+              let j = U.getValue(L, {
+                value: u.exportValue === u.fieldValue
+              }).value;
+              typeof j == "string" && (j = j !== "Off", U.setValue(L, {
+                value: j
+              })), this.container.classList.add("buttonWidgetAnnotation", "checkBox");
+              const V = document.createElement("input");
+              return T.add(V), V.setAttribute("data-element-id", L), V.disabled = u.readOnly, this._setRequired(V, this.data.required), V.type = "checkbox", V.name = u.fieldName, j && V.setAttribute("checked", !0), V.setAttribute("exportValue", u.exportValue), V.tabIndex = o, V.addEventListener("change", (Z) => {
+                const {
+                  name: he,
+                  checked: ye
+                } = Z.target;
+                for (const Me of this._getElementsByName(he, L)) {
+                  const Re = ye && Me.exportValue === u.exportValue;
+                  Me.domElement && (Me.domElement.checked = Re), U.setValue(Me.id, {
+                    value: Re
+                  });
+                }
+                U.setValue(L, {
+                  value: ye
+                });
+              }), V.addEventListener("resetform", (Z) => {
+                const he = u.defaultFieldValue || "Off";
+                Z.target.checked = he === u.exportValue;
+              }), this.enableScripting && this.hasJSActions && (V.addEventListener("updatefromsandbox", (Z) => {
+                const he = {
+                  value(ye) {
+                    ye.target.checked = ye.detail.value !== "Off", U.setValue(L, {
+                      value: ye.target.checked
+                    });
+                  }
+                };
+                this._dispatchEventFromSandbox(he, Z);
+              }), this._setEventListeners(V, null, [["change", "Validate"], ["change", "Action"], ["focus", "Focus"], ["blur", "Blur"], ["mousedown", "Mouse Down"], ["mouseenter", "Mouse Enter"], ["mouseleave", "Mouse Exit"], ["mouseup", "Mouse Up"]], (Z) => Z.target.checked)), this._setBackgroundColor(V), this._setDefaultPropertiesFromJS(V), this.container.append(V), this.container;
+            }
+          }
+          class p extends k {
+            constructor(U) {
+              super(U, {
+                isRenderable: U.renderForms
+              });
+            }
+            render() {
+              this.container.classList.add("buttonWidgetAnnotation", "radioButton");
+              const U = this.annotationStorage, u = this.data, L = u.id;
+              let j = U.getValue(L, {
+                value: u.fieldValue === u.buttonValue
+              }).value;
+              typeof j == "string" && (j = j !== u.buttonValue, U.setValue(L, {
+                value: j
+              }));
+              const V = document.createElement("input");
+              if (T.add(V), V.setAttribute("data-element-id", L), V.disabled = u.readOnly, this._setRequired(V, this.data.required), V.type = "radio", V.name = u.fieldName, j && V.setAttribute("checked", !0), V.tabIndex = o, V.addEventListener("change", (Z) => {
+                const {
+                  name: he,
+                  checked: ye
+                } = Z.target;
+                for (const Me of this._getElementsByName(he, L))
+                  U.setValue(Me.id, {
+                    value: !1
+                  });
+                U.setValue(L, {
+                  value: ye
+                });
+              }), V.addEventListener("resetform", (Z) => {
+                const he = u.defaultFieldValue;
+                Z.target.checked = he != null && he === u.buttonValue;
+              }), this.enableScripting && this.hasJSActions) {
+                const Z = u.buttonValue;
+                V.addEventListener("updatefromsandbox", (he) => {
+                  const ye = {
+                    value: (Me) => {
+                      const Re = Z === Me.detail.value;
+                      for (const qe of this._getElementsByName(Me.target.name)) {
+                        const Ie = Re && qe.id === L;
+                        qe.domElement && (qe.domElement.checked = Ie), U.setValue(qe.id, {
+                          value: Ie
+                        });
+                      }
+                    }
+                  };
+                  this._dispatchEventFromSandbox(ye, he);
+                }), this._setEventListeners(V, null, [["change", "Validate"], ["change", "Action"], ["focus", "Focus"], ["blur", "Blur"], ["mousedown", "Mouse Down"], ["mouseenter", "Mouse Enter"], ["mouseleave", "Mouse Exit"], ["mouseup", "Mouse Up"]], (he) => he.target.checked);
+              }
+              return this._setBackgroundColor(V), this._setDefaultPropertiesFromJS(V), this.container.append(V), this.container;
+            }
+          }
+          class E extends P {
+            constructor(U) {
+              super(U, {
+                ignoreBorder: U.data.hasAppearance
+              });
+            }
+            render() {
+              const U = super.render();
+              U.classList.add("buttonWidgetAnnotation", "pushButton"), this.data.alternativeText && (U.title = this.data.alternativeText);
+              const u = U.lastChild;
+              return this.enableScripting && this.hasJSActions && u && (this._setDefaultPropertiesFromJS(u), u.addEventListener("updatefromsandbox", (L) => {
+                this._dispatchEventFromSandbox({}, L);
+              })), U;
+            }
+          }
+          class $ extends k {
+            constructor(U) {
+              super(U, {
+                isRenderable: U.renderForms
+              });
+            }
+            render() {
+              this.container.classList.add("choiceWidgetAnnotation");
+              const U = this.annotationStorage, u = this.data.id, L = U.getValue(u, {
+                value: this.data.fieldValue
+              }), j = document.createElement("select");
+              T.add(j), j.setAttribute("data-element-id", u), j.disabled = this.data.readOnly, this._setRequired(j, this.data.required), j.name = this.data.fieldName, j.tabIndex = o;
+              let V = this.data.combo && this.data.options.length > 0;
+              this.data.combo || (j.size = this.data.options.length, this.data.multiSelect && (j.multiple = !0)), j.addEventListener("resetform", (Re) => {
+                const qe = this.data.defaultFieldValue;
+                for (const Ie of j.options)
+                  Ie.selected = Ie.value === qe;
+              });
+              for (const Re of this.data.options) {
+                const qe = document.createElement("option");
+                qe.textContent = Re.displayValue, qe.value = Re.exportValue, L.value.includes(Re.exportValue) && (qe.setAttribute("selected", !0), V = !1), j.append(qe);
+              }
+              let Z = null;
+              if (V) {
+                const Re = document.createElement("option");
+                Re.value = " ", Re.setAttribute("hidden", !0), Re.setAttribute("selected", !0), j.prepend(Re), Z = () => {
+                  Re.remove(), j.removeEventListener("input", Z), Z = null;
+                }, j.addEventListener("input", Z);
+              }
+              const he = (Re) => {
+                const qe = Re ? "value" : "textContent", {
+                  options: Ie,
+                  multiple: Le
+                } = j;
+                return Le ? Array.prototype.filter.call(Ie, (He) => He.selected).map((He) => He[qe]) : Ie.selectedIndex === -1 ? null : Ie[Ie.selectedIndex][qe];
+              };
+              let ye = he(!1);
+              const Me = (Re) => {
+                const qe = Re.target.options;
+                return Array.prototype.map.call(qe, (Ie) => ({
+                  displayValue: Ie.textContent,
+                  exportValue: Ie.value
+                }));
+              };
+              return this.enableScripting && this.hasJSActions ? (j.addEventListener("updatefromsandbox", (Re) => {
+                const qe = {
+                  value(Ie) {
+                    Z == null || Z();
+                    const Le = Ie.detail.value, He = new Set(Array.isArray(Le) ? Le : [Le]);
+                    for (const Ve of j.options)
+                      Ve.selected = He.has(Ve.value);
+                    U.setValue(u, {
+                      value: he(!0)
+                    }), ye = he(!1);
+                  },
+                  multipleSelection(Ie) {
+                    j.multiple = !0;
+                  },
+                  remove(Ie) {
+                    const Le = j.options, He = Ie.detail.remove;
+                    Le[He].selected = !1, j.remove(He), Le.length > 0 && Array.prototype.findIndex.call(Le, (Je) => Je.selected) === -1 && (Le[0].selected = !0), U.setValue(u, {
+                      value: he(!0),
+                      items: Me(Ie)
+                    }), ye = he(!1);
+                  },
+                  clear(Ie) {
+                    for (; j.length !== 0; )
+                      j.remove(0);
+                    U.setValue(u, {
+                      value: null,
+                      items: []
+                    }), ye = he(!1);
+                  },
+                  insert(Ie) {
+                    const {
+                      index: Le,
+                      displayValue: He,
+                      exportValue: Ve
+                    } = Ie.detail.insert, Je = j.children[Le], Ze = document.createElement("option");
+                    Ze.textContent = He, Ze.value = Ve, Je ? Je.before(Ze) : j.append(Ze), U.setValue(u, {
+                      value: he(!0),
+                      items: Me(Ie)
+                    }), ye = he(!1);
+                  },
+                  items(Ie) {
+                    const {
+                      items: Le
+                    } = Ie.detail;
+                    for (; j.length !== 0; )
+                      j.remove(0);
+                    for (const He of Le) {
+                      const {
+                        displayValue: Ve,
+                        exportValue: Je
+                      } = He, Ze = document.createElement("option");
+                      Ze.textContent = Ve, Ze.value = Je, j.append(Ze);
+                    }
+                    j.options.length > 0 && (j.options[0].selected = !0), U.setValue(u, {
+                      value: he(!0),
+                      items: Me(Ie)
+                    }), ye = he(!1);
+                  },
+                  indices(Ie) {
+                    const Le = new Set(Ie.detail.indices);
+                    for (const He of Ie.target.options)
+                      He.selected = Le.has(He.index);
+                    U.setValue(u, {
+                      value: he(!0)
+                    }), ye = he(!1);
+                  },
+                  editable(Ie) {
+                    Ie.target.disabled = !Ie.detail.editable;
+                  }
+                };
+                this._dispatchEventFromSandbox(qe, Re);
+              }), j.addEventListener("input", (Re) => {
+                var Ie;
+                const qe = he(!0);
+                U.setValue(u, {
+                  value: qe
+                }), Re.preventDefault(), (Ie = this.linkService.eventBus) == null || Ie.dispatch("dispatcheventinsandbox", {
+                  source: this,
+                  detail: {
+                    id: u,
+                    name: "Keystroke",
+                    value: ye,
+                    changeEx: qe,
+                    willCommit: !1,
+                    commitKey: 1,
+                    keyDown: !1
+                  }
+                });
+              }), this._setEventListeners(j, null, [["focus", "Focus"], ["blur", "Blur"], ["mousedown", "Mouse Down"], ["mouseenter", "Mouse Enter"], ["mouseleave", "Mouse Exit"], ["mouseup", "Mouse Up"], ["input", "Action"], ["input", "Validate"]], (Re) => Re.target.value)) : j.addEventListener("input", function(Re) {
+                U.setValue(u, {
+                  value: he(!0)
+                });
+              }), this.data.combo && this._setTextStyle(j), this._setBackgroundColor(j), this._setDefaultPropertiesFromJS(j), this.container.append(j), this.container;
+            }
+          }
+          class M extends C {
+            constructor(U) {
+              const {
+                data: u,
+                elements: L
+              } = U;
+              super(U, {
+                isRenderable: C._hasPopupData(u)
+              }), this.elements = L;
+            }
+            render() {
+              this.container.classList.add("popupAnnotation");
+              const U = new m({
+                container: this.container,
+                color: this.data.color,
+                titleObj: this.data.titleObj,
+                modificationDate: this.data.modificationDate,
+                contentsObj: this.data.contentsObj,
+                richText: this.data.richText,
+                rect: this.data.rect,
+                parentRect: this.data.parentRect || null,
+                parent: this.parent,
+                elements: this.elements,
+                open: this.data.open
+              }), u = [];
+              for (const L of this.elements)
+                L.popup = U, u.push(L.data.id), L.addHighlightArea();
+              return this.container.setAttribute("aria-controls", u.map((L) => `${n.AnnotationPrefix}${L}`).join(",")), this.container;
+            }
+          }
+          class m {
+            constructor({
+              container: U,
+              color: u,
+              elements: L,
+              titleObj: j,
+              modificationDate: V,
+              contentsObj: Z,
+              richText: he,
+              parent: ye,
+              rect: Me,
+              parentRect: Re,
+              open: qe
+            }) {
+              W(this, Ue);
+              W(this, je);
+              W(this, Xe);
+              W(this, Ye);
+              W(this, z, null);
+              W(this, ae, K(this, Ue, $n).bind(this));
+              W(this, Q, K(this, Ye, cn).bind(this));
+              W(this, ce, K(this, Xe, ln).bind(this));
+              W(this, ue, K(this, je, Mt).bind(this));
+              W(this, me, null);
+              W(this, fe, null);
+              W(this, Pe, null);
+              W(this, Fe, null);
+              W(this, Ee, null);
+              W(this, De, null);
+              W(this, _e, !1);
+              W(this, ie, null);
+              W(this, se, null);
+              W(this, ge, null);
+              W(this, Ce, null);
+              W(this, xe, !1);
+              var Le;
+              oe(this, fe, U), oe(this, Ce, j), oe(this, Pe, Z), oe(this, ge, he), oe(this, Ee, ye), oe(this, me, u), oe(this, se, Me), oe(this, De, Re), oe(this, Fe, L);
+              const Ie = s.PDFDateString.toDateObject(V);
+              Ie && oe(this, z, ye.l10n.get("annotation_date_string", {
+                date: Ie.toLocaleDateString(),
+                time: Ie.toLocaleTimeString()
+              })), this.trigger = L.flatMap((He) => He.getElementsToTriggerPopup());
+              for (const He of this.trigger)
+                He.addEventListener("click", a(this, ue)), He.addEventListener("mouseenter", a(this, ce)), He.addEventListener("mouseleave", a(this, Q)), He.classList.add("popupTriggerArea");
+              for (const He of L)
+                (Le = He.container) == null || Le.addEventListener("keydown", a(this, ae));
+              a(this, fe).hidden = !0, qe && K(this, je, Mt).call(this);
+            }
+            render() {
+              if (a(this, ie))
+                return;
+              const {
+                page: {
+                  view: U
+                },
+                viewport: {
+                  rawDims: {
+                    pageWidth: u,
+                    pageHeight: L,
+                    pageX: j,
+                    pageY: V
+                  }
+                }
+              } = a(this, Ee), Z = oe(this, ie, document.createElement("div"));
+              if (Z.className = "popup", a(this, me)) {
+                const it = Z.style.outlineColor = n.Util.makeHexColor(...a(this, me));
+                CSS.supports("background-color", "color-mix(in srgb, red 30%, white)") ? Z.style.backgroundColor = `color-mix(in srgb, ${it} 30%, white)` : Z.style.backgroundColor = n.Util.makeHexColor(...a(this, me).map((lt) => Math.floor(0.7 * (255 - lt) + lt)));
+              }
+              const he = document.createElement("span");
+              he.className = "header";
+              const ye = document.createElement("h1");
+              if (he.append(ye), {
+                dir: ye.dir,
+                str: ye.textContent
+              } = a(this, Ce), Z.append(he), a(this, z)) {
+                const it = document.createElement("span");
+                it.classList.add("popupDate"), a(this, z).then((rt) => {
+                  it.textContent = rt;
+                }), he.append(it);
+              }
+              const Me = a(this, Pe), Re = a(this, ge);
+              if (Re != null && Re.str && (!(Me != null && Me.str) || Me.str === Re.str))
+                c.XfaLayer.render({
+                  xfaHtml: Re.html,
+                  intent: "richText",
+                  div: Z
+                }), Z.lastChild.classList.add("richText", "popupContent");
+              else {
+                const it = this._formatContents(Me);
+                Z.append(it);
+              }
+              let qe = !!a(this, De), Ie = qe ? a(this, De) : a(this, se);
+              for (const it of a(this, Fe))
+                if (!Ie || n.Util.intersect(it.data.rect, Ie) !== null) {
+                  Ie = it.data.rect, qe = !0;
+                  break;
+                }
+              const Le = n.Util.normalizeRect([Ie[0], U[3] - Ie[1] + U[1], Ie[2], U[3] - Ie[3] + U[1]]), He = 5, Ve = qe ? Ie[2] - Ie[0] + He : 0, Je = Le[0] + Ve, Ze = Le[1], {
+                style: st
+              } = a(this, fe);
+              st.left = `${100 * (Je - j) / u}%`, st.top = `${100 * (Ze - V) / L}%`, a(this, fe).append(Z);
+            }
+            _formatContents({
+              str: U,
+              dir: u
+            }) {
+              const L = document.createElement("p");
+              L.classList.add("popupContent"), L.dir = u;
+              const j = U.split(/(?:\r\n?|\n)/);
+              for (let V = 0, Z = j.length; V < Z; ++V) {
+                const he = j[V];
+                L.append(document.createTextNode(he)), V < Z - 1 && L.append(document.createElement("br"));
+              }
+              return L;
+            }
+            forceHide() {
+              oe(this, xe, this.isVisible), a(this, xe) && (a(this, fe).hidden = !0);
+            }
+            maybeShow() {
+              a(this, xe) && (oe(this, xe, !1), a(this, fe).hidden = !1);
+            }
+            get isVisible() {
+              return a(this, fe).hidden === !1;
+            }
+          }
+          z = new WeakMap(), ae = new WeakMap(), Q = new WeakMap(), ce = new WeakMap(), ue = new WeakMap(), me = new WeakMap(), fe = new WeakMap(), Pe = new WeakMap(), Fe = new WeakMap(), Ee = new WeakMap(), De = new WeakMap(), _e = new WeakMap(), ie = new WeakMap(), se = new WeakMap(), ge = new WeakMap(), Ce = new WeakMap(), xe = new WeakMap(), Ue = new WeakSet(), $n = function(U) {
+            U.altKey || U.shiftKey || U.ctrlKey || U.metaKey || (U.key === "Enter" || U.key === "Escape" && a(this, _e)) && K(this, je, Mt).call(this);
+          }, je = new WeakSet(), Mt = function() {
+            oe(this, _e, !a(this, _e)), a(this, _e) ? (K(this, Xe, ln).call(this), a(this, fe).addEventListener("click", a(this, ue)), a(this, fe).addEventListener("keydown", a(this, ae))) : (K(this, Ye, cn).call(this), a(this, fe).removeEventListener("click", a(this, ue)), a(this, fe).removeEventListener("keydown", a(this, ae)));
+          }, Xe = new WeakSet(), ln = function() {
+            a(this, ie) || this.render(), this.isVisible ? a(this, _e) && a(this, fe).classList.add("focused") : (a(this, fe).hidden = !1, a(this, fe).style.zIndex = parseInt(a(this, fe).style.zIndex) + 1e3);
+          }, Ye = new WeakSet(), cn = function() {
+            a(this, fe).classList.remove("focused"), !(a(this, _e) || !this.isVisible) && (a(this, fe).hidden = !0, a(this, fe).style.zIndex = parseInt(a(this, fe).style.zIndex) - 1e3);
+          };
+          class N extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              }), this.textContent = U.data.textContent, this.textPosition = U.data.textPosition, this.annotationEditorType = n.AnnotationEditorType.FREETEXT;
+            }
+            render() {
+              if (this.container.classList.add("freeTextAnnotation"), this.textContent) {
+                const U = document.createElement("div");
+                U.classList.add("annotationTextContent"), U.setAttribute("role", "comment");
+                for (const u of this.textContent) {
+                  const L = document.createElement("span");
+                  L.textContent = u, U.append(L);
+                }
+                this.container.append(U);
+              }
+              return !this.data.popupRef && this.hasPopupData && this._createPopup(), this._editOnDoubleClick(), this.container;
+            }
+          }
+          e.FreeTextAnnotationElement = N;
+          class D extends C {
+            constructor(u) {
+              super(u, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              });
+              W(this, ne, null);
+            }
+            render() {
+              this.container.classList.add("lineAnnotation");
+              const u = this.data, {
+                width: L,
+                height: j
+              } = S(u.rect), V = this.svgFactory.create(L, j, !0), Z = oe(this, ne, this.svgFactory.createElement("svg:line"));
+              return Z.setAttribute("x1", u.rect[2] - u.lineCoordinates[0]), Z.setAttribute("y1", u.rect[3] - u.lineCoordinates[1]), Z.setAttribute("x2", u.rect[2] - u.lineCoordinates[2]), Z.setAttribute("y2", u.rect[3] - u.lineCoordinates[3]), Z.setAttribute("stroke-width", u.borderStyle.width || 1), Z.setAttribute("stroke", "transparent"), Z.setAttribute("fill", "transparent"), V.append(Z), this.container.append(V), !u.popupRef && this.hasPopupData && this._createPopup(), this.container;
+            }
+            getElementsToTriggerPopup() {
+              return a(this, ne);
+            }
+            addHighlightArea() {
+              this.container.classList.add("highlightArea");
+            }
+          }
+          ne = new WeakMap();
+          class X extends C {
+            constructor(u) {
+              super(u, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              });
+              W(this, J, null);
+            }
+            render() {
+              this.container.classList.add("squareAnnotation");
+              const u = this.data, {
+                width: L,
+                height: j
+              } = S(u.rect), V = this.svgFactory.create(L, j, !0), Z = u.borderStyle.width, he = oe(this, J, this.svgFactory.createElement("svg:rect"));
+              return he.setAttribute("x", Z / 2), he.setAttribute("y", Z / 2), he.setAttribute("width", L - Z), he.setAttribute("height", j - Z), he.setAttribute("stroke-width", Z || 1), he.setAttribute("stroke", "transparent"), he.setAttribute("fill", "transparent"), V.append(he), this.container.append(V), !u.popupRef && this.hasPopupData && this._createPopup(), this.container;
+            }
+            getElementsToTriggerPopup() {
+              return a(this, J);
+            }
+            addHighlightArea() {
+              this.container.classList.add("highlightArea");
+            }
+          }
+          J = new WeakMap();
+          class G extends C {
+            constructor(u) {
+              super(u, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              });
+              W(this, ve, null);
+            }
+            render() {
+              this.container.classList.add("circleAnnotation");
+              const u = this.data, {
+                width: L,
+                height: j
+              } = S(u.rect), V = this.svgFactory.create(L, j, !0), Z = u.borderStyle.width, he = oe(this, ve, this.svgFactory.createElement("svg:ellipse"));
+              return he.setAttribute("cx", L / 2), he.setAttribute("cy", j / 2), he.setAttribute("rx", L / 2 - Z / 2), he.setAttribute("ry", j / 2 - Z / 2), he.setAttribute("stroke-width", Z || 1), he.setAttribute("stroke", "transparent"), he.setAttribute("fill", "transparent"), V.append(he), this.container.append(V), !u.popupRef && this.hasPopupData && this._createPopup(), this.container;
+            }
+            getElementsToTriggerPopup() {
+              return a(this, ve);
+            }
+            addHighlightArea() {
+              this.container.classList.add("highlightArea");
+            }
+          }
+          ve = new WeakMap();
+          class I extends C {
+            constructor(u) {
+              super(u, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              });
+              W(this, Se, null);
+              this.containerClassName = "polylineAnnotation", this.svgElementName = "svg:polyline";
+            }
+            render() {
+              this.container.classList.add(this.containerClassName);
+              const u = this.data, {
+                width: L,
+                height: j
+              } = S(u.rect), V = this.svgFactory.create(L, j, !0);
+              let Z = [];
+              for (const ye of u.vertices) {
+                const Me = ye.x - u.rect[0], Re = u.rect[3] - ye.y;
+                Z.push(Me + "," + Re);
+              }
+              Z = Z.join(" ");
+              const he = oe(this, Se, this.svgFactory.createElement(this.svgElementName));
+              return he.setAttribute("points", Z), he.setAttribute("stroke-width", u.borderStyle.width || 1), he.setAttribute("stroke", "transparent"), he.setAttribute("fill", "transparent"), V.append(he), this.container.append(V), !u.popupRef && this.hasPopupData && this._createPopup(), this.container;
+            }
+            getElementsToTriggerPopup() {
+              return a(this, Se);
+            }
+            addHighlightArea() {
+              this.container.classList.add("highlightArea");
+            }
+          }
+          Se = new WeakMap();
+          class B extends I {
+            constructor(U) {
+              super(U), this.containerClassName = "polygonAnnotation", this.svgElementName = "svg:polygon";
+            }
+          }
+          class ee extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              });
+            }
+            render() {
+              return this.container.classList.add("caretAnnotation"), !this.data.popupRef && this.hasPopupData && this._createPopup(), this.container;
+            }
+          }
+          class Y extends C {
+            constructor(u) {
+              super(u, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              });
+              W(this, tt, []);
+              this.containerClassName = "inkAnnotation", this.svgElementName = "svg:polyline", this.annotationEditorType = n.AnnotationEditorType.INK;
+            }
+            render() {
+              this.container.classList.add(this.containerClassName);
+              const u = this.data, {
+                width: L,
+                height: j
+              } = S(u.rect), V = this.svgFactory.create(L, j, !0);
+              for (const Z of u.inkLists) {
+                let he = [];
+                for (const Me of Z) {
+                  const Re = Me.x - u.rect[0], qe = u.rect[3] - Me.y;
+                  he.push(`${Re},${qe}`);
+                }
+                he = he.join(" ");
+                const ye = this.svgFactory.createElement(this.svgElementName);
+                a(this, tt).push(ye), ye.setAttribute("points", he), ye.setAttribute("stroke-width", u.borderStyle.width || 1), ye.setAttribute("stroke", "transparent"), ye.setAttribute("fill", "transparent"), !u.popupRef && this.hasPopupData && this._createPopup(), V.append(ye);
+              }
+              return this.container.append(V), this.container;
+            }
+            getElementsToTriggerPopup() {
+              return a(this, tt);
+            }
+            addHighlightArea() {
+              this.container.classList.add("highlightArea");
+            }
+          }
+          tt = new WeakMap(), e.InkAnnotationElement = Y;
+          class q extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0,
+                ignoreBorder: !0,
+                createQuadrilaterals: !0
+              });
+            }
+            render() {
+              return !this.data.popupRef && this.hasPopupData && this._createPopup(), this.container.classList.add("highlightAnnotation"), this.container;
+            }
+          }
+          class le extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0,
+                ignoreBorder: !0,
+                createQuadrilaterals: !0
+              });
+            }
+            render() {
+              return !this.data.popupRef && this.hasPopupData && this._createPopup(), this.container.classList.add("underlineAnnotation"), this.container;
+            }
+          }
+          class pe extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0,
+                ignoreBorder: !0,
+                createQuadrilaterals: !0
+              });
+            }
+            render() {
+              return !this.data.popupRef && this.hasPopupData && this._createPopup(), this.container.classList.add("squigglyAnnotation"), this.container;
+            }
+          }
+          class we extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0,
+                ignoreBorder: !0,
+                createQuadrilaterals: !0
+              });
+            }
+            render() {
+              return !this.data.popupRef && this.hasPopupData && this._createPopup(), this.container.classList.add("strikeoutAnnotation"), this.container;
+            }
+          }
+          class be extends C {
+            constructor(U) {
+              super(U, {
+                isRenderable: !0,
+                ignoreBorder: !0
+              });
+            }
+            render() {
+              return this.container.classList.add("stampAnnotation"), !this.data.popupRef && this.hasPopupData && this._createPopup(), this.container;
+            }
+          }
+          e.StampAnnotationElement = be;
+          class R extends C {
+            constructor(u) {
+              var V;
+              super(u, {
+                isRenderable: !0
+              });
+              W(this, te);
+              W(this, et, null);
+              const {
+                filename: L,
+                content: j
+              } = this.data.file;
+              this.filename = (0, s.getFilenameFromUrl)(L, !0), this.content = j, (V = this.linkService.eventBus) == null || V.dispatch("fileattachmentannotation", {
+                source: this,
+                filename: L,
+                content: j
+              });
+            }
+            render() {
+              this.container.classList.add("fileAttachmentAnnotation");
+              const {
+                container: u,
+                data: L
+              } = this;
+              let j;
+              L.hasAppearance || L.fillAlpha === 0 ? j = document.createElement("div") : (j = document.createElement("img"), j.src = `${this.imageResourcesPath}annotation-${/paperclip/i.test(L.name) ? "paperclip" : "pushpin"}.svg`, L.fillAlpha && L.fillAlpha < 1 && (j.style = `filter: opacity(${Math.round(L.fillAlpha * 100)}%);`)), j.addEventListener("dblclick", K(this, te, hn).bind(this)), oe(this, et, j);
+              const {
+                isMac: V
+              } = n.FeatureTest.platform;
+              return u.addEventListener("keydown", (Z) => {
+                Z.key === "Enter" && (V ? Z.metaKey : Z.ctrlKey) && K(this, te, hn).call(this);
+              }), !L.popupRef && this.hasPopupData ? this._createPopup() : j.classList.add("popupTriggerArea"), u.append(j), u;
+            }
+            getElementsToTriggerPopup() {
+              return a(this, et);
+            }
+            addHighlightArea() {
+              this.container.classList.add("highlightArea");
+            }
+          }
+          et = new WeakMap(), te = new WeakSet(), hn = function() {
+            var u;
+            (u = this.downloadManager) == null || u.openOrDownloadData(this.container, this.content, this.filename);
+          };
+          class d {
+            constructor({
+              div: U,
+              accessibilityManager: u,
+              annotationCanvasMap: L,
+              l10n: j,
+              page: V,
+              viewport: Z
+            }) {
+              W(this, Be);
+              W(this, Ae);
+              W(this, Ne, null);
+              W(this, ke, null);
+              W(this, $e, /* @__PURE__ */ new Map());
+              this.div = U, oe(this, Ne, u), oe(this, ke, L), this.l10n = j, this.page = V, this.viewport = Z, this.zIndex = 0, this.l10n || (this.l10n = _.NullL10n);
+            }
+            async render(U) {
+              const {
+                annotations: u
+              } = U, L = this.div;
+              (0, s.setLayerDimensions)(L, this.viewport);
+              const j = /* @__PURE__ */ new Map(), V = {
+                data: null,
+                layer: L,
+                linkService: U.linkService,
+                downloadManager: U.downloadManager,
+                imageResourcesPath: U.imageResourcesPath || "",
+                renderForms: U.renderForms !== !1,
+                svgFactory: new s.DOMSVGFactory(),
+                annotationStorage: U.annotationStorage || new l.AnnotationStorage(),
+                enableScripting: U.enableScripting === !0,
+                hasJSActions: U.hasJSActions,
+                fieldObjects: U.fieldObjects,
+                parent: this,
+                elements: null
+              };
+              for (const Z of u) {
+                if (Z.noHTML)
+                  continue;
+                const he = Z.annotationType === n.AnnotationType.POPUP;
+                if (he) {
+                  const Re = j.get(Z.id);
+                  if (!Re)
+                    continue;
+                  V.elements = Re;
+                } else {
+                  const {
+                    width: Re,
+                    height: qe
+                  } = S(Z.rect);
+                  if (Re <= 0 || qe <= 0)
+                    continue;
+                }
+                V.data = Z;
+                const ye = w.create(V);
+                if (!ye.isRenderable)
+                  continue;
+                if (!he && Z.popupRef) {
+                  const Re = j.get(Z.popupRef);
+                  Re ? Re.push(ye) : j.set(Z.popupRef, [ye]);
+                }
+                ye.annotationEditorType > 0 && a(this, $e).set(ye.data.id, ye);
+                const Me = ye.render();
+                Z.hidden && (Me.style.visibility = "hidden"), K(this, Be, Bn).call(this, Me, Z.id);
+              }
+              K(this, Ae, un).call(this), await this.l10n.translate(L);
+            }
+            update({
+              viewport: U
+            }) {
+              const u = this.div;
+              this.viewport = U, (0, s.setLayerDimensions)(u, {
+                rotation: U.rotation
+              }), K(this, Ae, un).call(this), u.hidden = !1;
+            }
+            getEditableAnnotations() {
+              return Array.from(a(this, $e).values());
+            }
+            getEditableAnnotation(U) {
+              return a(this, $e).get(U);
+            }
+          }
+          Ne = new WeakMap(), ke = new WeakMap(), $e = new WeakMap(), Be = new WeakSet(), Bn = function(U, u) {
+            var j;
+            const L = U.firstChild || U;
+            L.id = `${n.AnnotationPrefix}${u}`, this.div.append(U), (j = a(this, Ne)) == null || j.moveElementInDOM(this.div, U, L, !1);
+          }, Ae = new WeakSet(), un = function() {
+            if (!a(this, ke))
+              return;
+            const U = this.div;
+            for (const [u, L] of a(this, ke)) {
+              const j = U.querySelector(`[data-annotation-id="${u}"]`);
+              if (!j)
+                continue;
+              const {
+                firstChild: V
+              } = j;
+              V ? V.nodeName === "CANVAS" ? V.replaceWith(L) : V.before(L) : j.append(L);
+            }
+            a(this, ke).clear();
+          }, e.AnnotationLayer = d;
+        },
+        /* 30 */
+        /***/
+        (t, e) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.ColorConverters = void 0;
+          function i(l) {
+            return Math.floor(Math.max(0, Math.min(1, l)) * 255).toString(16).padStart(2, "0");
+          }
+          function n(l) {
+            return Math.max(0, Math.min(255, 255 * l));
+          }
+          class s {
+            static CMYK_G([h, _, c, o]) {
+              return ["G", 1 - Math.min(1, 0.3 * h + 0.59 * c + 0.11 * _ + o)];
+            }
+            static G_CMYK([h]) {
+              return ["CMYK", 0, 0, 0, 1 - h];
+            }
+            static G_RGB([h]) {
+              return ["RGB", h, h, h];
+            }
+            static G_rgb([h]) {
+              return h = n(h), [h, h, h];
+            }
+            static G_HTML([h]) {
+              const _ = i(h);
+              return `#${_}${_}${_}`;
+            }
+            static RGB_G([h, _, c]) {
+              return ["G", 0.3 * h + 0.59 * _ + 0.11 * c];
+            }
+            static RGB_rgb(h) {
+              return h.map(n);
+            }
+            static RGB_HTML(h) {
+              return `#${h.map(i).join("")}`;
+            }
+            static T_HTML() {
+              return "#00000000";
+            }
+            static T_rgb() {
+              return [null];
+            }
+            static CMYK_RGB([h, _, c, o]) {
+              return ["RGB", 1 - Math.min(1, h + o), 1 - Math.min(1, c + o), 1 - Math.min(1, _ + o)];
+            }
+            static CMYK_rgb([h, _, c, o]) {
+              return [n(1 - Math.min(1, h + o)), n(1 - Math.min(1, c + o)), n(1 - Math.min(1, _ + o))];
+            }
+            static CMYK_HTML(h) {
+              const _ = this.CMYK_RGB(h).slice(1);
+              return this.RGB_HTML(_);
+            }
+            static RGB_CMYK([h, _, c]) {
+              const o = 1 - h, r = 1 - _, T = 1 - c, S = Math.min(o, r, T);
+              return ["CMYK", o, r, T, S];
+            }
+          }
+          e.ColorConverters = s;
+        },
+        /* 31 */
+        /***/
+        (t, e) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.NullL10n = void 0, e.getL10nFallback = n;
+          const i = {
+            of_pages: "of {{pagesCount}}",
+            page_of_pages: "({{pageNumber}} of {{pagesCount}})",
+            document_properties_kb: "{{size_kb}} KB ({{size_b}} bytes)",
+            document_properties_mb: "{{size_mb}} MB ({{size_b}} bytes)",
+            document_properties_date_string: "{{date}}, {{time}}",
+            document_properties_page_size_unit_inches: "in",
+            document_properties_page_size_unit_millimeters: "mm",
+            document_properties_page_size_orientation_portrait: "portrait",
+            document_properties_page_size_orientation_landscape: "landscape",
+            document_properties_page_size_name_a3: "A3",
+            document_properties_page_size_name_a4: "A4",
+            document_properties_page_size_name_letter: "Letter",
+            document_properties_page_size_name_legal: "Legal",
+            document_properties_page_size_dimension_string: "{{width}} × {{height}} {{unit}} ({{orientation}})",
+            document_properties_page_size_dimension_name_string: "{{width}} × {{height}} {{unit}} ({{name}}, {{orientation}})",
+            document_properties_linearized_yes: "Yes",
+            document_properties_linearized_no: "No",
+            additional_layers: "Additional Layers",
+            page_landmark: "Page {{page}}",
+            thumb_page_title: "Page {{page}}",
+            thumb_page_canvas: "Thumbnail of Page {{page}}",
+            find_reached_top: "Reached top of document, continued from bottom",
+            find_reached_bottom: "Reached end of document, continued from top",
+            "find_match_count[one]": "{{current}} of {{total}} match",
+            "find_match_count[other]": "{{current}} of {{total}} matches",
+            "find_match_count_limit[one]": "More than {{limit}} match",
+            "find_match_count_limit[other]": "More than {{limit}} matches",
+            find_not_found: "Phrase not found",
+            page_scale_width: "Page Width",
+            page_scale_fit: "Page Fit",
+            page_scale_auto: "Automatic Zoom",
+            page_scale_actual: "Actual Size",
+            page_scale_percent: "{{scale}}%",
+            loading_error: "An error occurred while loading the PDF.",
+            invalid_file_error: "Invalid or corrupted PDF file.",
+            missing_file_error: "Missing PDF file.",
+            unexpected_response_error: "Unexpected server response.",
+            rendering_error: "An error occurred while rendering the page.",
+            annotation_date_string: "{{date}}, {{time}}",
+            printing_not_supported: "Warning: Printing is not fully supported by this browser.",
+            printing_not_ready: "Warning: The PDF is not fully loaded for printing.",
+            web_fonts_disabled: "Web fonts are disabled: unable to use embedded PDF fonts.",
+            free_text2_default_content: "Start typing…",
+            editor_free_text2_aria_label: "Text Editor",
+            editor_ink2_aria_label: "Draw Editor",
+            editor_ink_canvas_aria_label: "User-created image",
+            editor_alt_text_button_label: "Alt text",
+            editor_alt_text_edit_button_label: "Edit alt text",
+            editor_alt_text_decorative_tooltip: "Marked as decorative"
+          };
+          i.print_progress_percent = "{{progress}}%";
+          function n(h, _) {
+            switch (h) {
+              case "find_match_count":
+                h = `find_match_count[${_.total === 1 ? "one" : "other"}]`;
+                break;
+              case "find_match_count_limit":
+                h = `find_match_count_limit[${_.limit === 1 ? "one" : "other"}]`;
+                break;
+            }
+            return i[h] || "";
+          }
+          function s(h, _) {
+            return _ ? h.replaceAll(/\{\{\s*(\w+)\s*\}\}/g, (c, o) => o in _ ? _[o] : "{{" + o + "}}") : h;
+          }
+          const l = {
+            async getLanguage() {
+              return "en-us";
+            },
+            async getDirection() {
+              return "ltr";
+            },
+            async get(h, _ = null, c = n(h, _)) {
+              return s(c, _);
+            },
+            async translate(h) {
+            }
+          };
+          e.NullL10n = l;
+        },
+        /* 32 */
+        /***/
+        (t, e, i) => {
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.XfaLayer = void 0;
+          var n = i(25);
+          class s {
+            static setupStorage(h, _, c, o, r) {
+              const T = o.getValue(_, {
+                value: null
+              });
+              switch (c.name) {
+                case "textarea":
+                  if (T.value !== null && (h.textContent = T.value), r === "print")
+                    break;
+                  h.addEventListener("input", (S) => {
+                    o.setValue(_, {
+                      value: S.target.value
+                    });
+                  });
+                  break;
+                case "input":
+                  if (c.attributes.type === "radio" || c.attributes.type === "checkbox") {
+                    if (T.value === c.attributes.xfaOn ? h.setAttribute("checked", !0) : T.value === c.attributes.xfaOff && h.removeAttribute("checked"), r === "print")
+                      break;
+                    h.addEventListener("change", (S) => {
+                      o.setValue(_, {
+                        value: S.target.checked ? S.target.getAttribute("xfaOn") : S.target.getAttribute("xfaOff")
+                      });
+                    });
+                  } else {
+                    if (T.value !== null && h.setAttribute("value", T.value), r === "print")
+                      break;
+                    h.addEventListener("input", (S) => {
+                      o.setValue(_, {
+                        value: S.target.value
+                      });
+                    });
+                  }
+                  break;
+                case "select":
+                  if (T.value !== null) {
+                    h.setAttribute("value", T.value);
+                    for (const S of c.children)
+                      S.attributes.value === T.value ? S.attributes.selected = !0 : S.attributes.hasOwnProperty("selected") && delete S.attributes.selected;
+                  }
+                  h.addEventListener("input", (S) => {
+                    const w = S.target.options, C = w.selectedIndex === -1 ? "" : w[w.selectedIndex].value;
+                    o.setValue(_, {
+                      value: C
+                    });
+                  });
+                  break;
+              }
+            }
+            static setAttributes({
+              html: h,
+              element: _,
+              storage: c = null,
+              intent: o,
+              linkService: r
+            }) {
+              const {
+                attributes: T
+              } = _, S = h instanceof HTMLAnchorElement;
+              T.type === "radio" && (T.name = `${T.name}-${o}`);
+              for (const [w, C] of Object.entries(T))
+                if (C != null)
+                  switch (w) {
+                    case "class":
+                      C.length && h.setAttribute(w, C.join(" "));
+                      break;
+                    case "dataId":
+                      break;
+                    case "id":
+                      h.setAttribute("data-element-id", C);
+                      break;
+                    case "style":
+                      Object.assign(h.style, C);
+                      break;
+                    case "textContent":
+                      h.textContent = C;
+                      break;
+                    default:
+                      (!S || w !== "href" && w !== "newWindow") && h.setAttribute(w, C);
+                  }
+              S && r.addLinkAttributes(h, T.href, T.newWindow), c && T.dataId && this.setupStorage(h, T.dataId, _, c);
+            }
+            static render(h) {
+              var P;
+              const _ = h.annotationStorage, c = h.linkService, o = h.xfaHtml, r = h.intent || "display", T = document.createElement(o.name);
+              o.attributes && this.setAttributes({
+                html: T,
+                element: o,
+                intent: r,
+                linkService: c
+              });
+              const S = [[o, -1, T]], w = h.div;
+              if (w.append(T), h.viewport) {
+                const b = `matrix(${h.viewport.transform.join(",")})`;
+                w.style.transform = b;
+              }
+              r !== "richText" && w.setAttribute("class", "xfaLayer xfaFont");
+              const C = [];
+              for (; S.length > 0; ) {
+                const [b, k, F] = S.at(-1);
+                if (k + 1 === b.children.length) {
+                  S.pop();
+                  continue;
+                }
+                const x = b.children[++S.at(-1)[1]];
+                if (x === null)
+                  continue;
+                const {
+                  name: y
+                } = x;
+                if (y === "#text") {
+                  const E = document.createTextNode(x.value);
+                  C.push(E), F.append(E);
+                  continue;
+                }
+                const p = (P = x == null ? void 0 : x.attributes) != null && P.xmlns ? document.createElementNS(x.attributes.xmlns, y) : document.createElement(y);
+                if (F.append(p), x.attributes && this.setAttributes({
+                  html: p,
+                  element: x,
+                  storage: _,
+                  intent: r,
+                  linkService: c
+                }), x.children && x.children.length > 0)
+                  S.push([x, -1, p]);
+                else if (x.value) {
+                  const E = document.createTextNode(x.value);
+                  n.XfaText.shouldBuildText(y) && C.push(E), p.append(E);
+                }
+              }
+              for (const b of w.querySelectorAll(".xfaNonInteractive input, .xfaNonInteractive textarea"))
+                b.setAttribute("readOnly", !0);
+              return {
+                textDivs: C
+              };
+            }
+            static update(h) {
+              const _ = `matrix(${h.viewport.transform.join(",")})`;
+              h.div.style.transform = _, h.div.hidden = !1;
+            }
+          }
+          e.XfaLayer = s;
+        },
+        /* 33 */
+        /***/
+        (t, e, i) => {
+          var o, r, T, S, w, C, P, b, k, F, x, y, p, E, $, Hn, m, Un, D, jn, G, Gn, B, dn, Y, Wn, le, pn, we, qn, R, zn, g, Xn, v, Vn, O, Yn, z, ot, Q, gn, ue, Ft, fe, It, Fe, pt, De, _n, ie, Lt, ge, Kn, xe, mn, We, Jn, ze, Qn, Ge, bn, de, Dt, J, gt;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.InkEditor = void 0;
+          var n = i(1), s = i(4), l = i(29), h = i(6), _ = i(5);
+          const Se = class Se extends s.AnnotationEditor {
+            constructor(te) {
+              super({
+                ...te,
+                name: "inkEditor"
+              });
+              W(this, $);
+              W(this, m);
+              W(this, D);
+              W(this, G);
+              W(this, B);
+              W(this, Y);
+              W(this, le);
+              W(this, we);
+              W(this, R);
+              W(this, g);
+              W(this, v);
+              W(this, O);
+              W(this, z);
+              W(this, Q);
+              W(this, ue);
+              W(this, fe);
+              W(this, Fe);
+              W(this, De);
+              W(this, ie);
+              W(this, ze);
+              W(this, Ge);
+              W(this, de);
+              W(this, J);
+              W(this, o, 0);
+              W(this, r, 0);
+              W(this, T, this.canvasPointermove.bind(this));
+              W(this, S, this.canvasPointerleave.bind(this));
+              W(this, w, this.canvasPointerup.bind(this));
+              W(this, C, this.canvasPointerdown.bind(this));
+              W(this, P, new Path2D());
+              W(this, b, !1);
+              W(this, k, !1);
+              W(this, F, !1);
+              W(this, x, null);
+              W(this, y, 0);
+              W(this, p, 0);
+              W(this, E, null);
+              this.color = te.color || null, this.thickness = te.thickness || null, this.opacity = te.opacity || null, this.paths = [], this.bezierPath2D = [], this.allRawPaths = [], this.currentPath = [], this.scaleFactor = 1, this.translationX = this.translationY = 0, this.x = 0, this.y = 0, this._willKeepAspectRatio = !0;
+            }
+            static initialize(te) {
+              s.AnnotationEditor.initialize(te, {
+                strings: ["editor_ink_canvas_aria_label", "editor_ink2_aria_label"]
+              });
+            }
+            static updateDefaultParams(te, Te) {
+              switch (te) {
+                case n.AnnotationEditorParamsType.INK_THICKNESS:
+                  Se._defaultThickness = Te;
+                  break;
+                case n.AnnotationEditorParamsType.INK_COLOR:
+                  Se._defaultColor = Te;
+                  break;
+                case n.AnnotationEditorParamsType.INK_OPACITY:
+                  Se._defaultOpacity = Te / 100;
+                  break;
+              }
+            }
+            updateParams(te, Te) {
+              switch (te) {
+                case n.AnnotationEditorParamsType.INK_THICKNESS:
+                  K(this, $, Hn).call(this, Te);
+                  break;
+                case n.AnnotationEditorParamsType.INK_COLOR:
+                  K(this, m, Un).call(this, Te);
+                  break;
+                case n.AnnotationEditorParamsType.INK_OPACITY:
+                  K(this, D, jn).call(this, Te);
+                  break;
+              }
+            }
+            static get defaultPropertiesToUpdate() {
+              return [[n.AnnotationEditorParamsType.INK_THICKNESS, Se._defaultThickness], [n.AnnotationEditorParamsType.INK_COLOR, Se._defaultColor || s.AnnotationEditor._defaultLineColor], [n.AnnotationEditorParamsType.INK_OPACITY, Math.round(Se._defaultOpacity * 100)]];
+            }
+            get propertiesToUpdate() {
+              return [[n.AnnotationEditorParamsType.INK_THICKNESS, this.thickness || Se._defaultThickness], [n.AnnotationEditorParamsType.INK_COLOR, this.color || Se._defaultColor || s.AnnotationEditor._defaultLineColor], [n.AnnotationEditorParamsType.INK_OPACITY, Math.round(100 * (this.opacity ?? Se._defaultOpacity))]];
+            }
+            rebuild() {
+              this.parent && (super.rebuild(), this.div !== null && (this.canvas || (K(this, ue, Ft).call(this), K(this, fe, It).call(this)), this.isAttachedToDOM || (this.parent.add(this), K(this, Fe, pt).call(this)), K(this, J, gt).call(this)));
+            }
+            remove() {
+              this.canvas !== null && (this.isEmpty() || this.commit(), this.canvas.width = this.canvas.height = 0, this.canvas.remove(), this.canvas = null, a(this, x).disconnect(), oe(this, x, null), super.remove());
+            }
+            setParent(te) {
+              !this.parent && te ? this._uiManager.removeShouldRescale(this) : this.parent && te === null && this._uiManager.addShouldRescale(this), super.setParent(te);
+            }
+            onScaleChanging() {
+              const [te, Te] = this.parentDimensions, Ne = this.width * te, ke = this.height * Te;
+              this.setDimensions(Ne, ke);
+            }
+            enableEditMode() {
+              a(this, b) || this.canvas === null || (super.enableEditMode(), this._isDraggable = !1, this.canvas.addEventListener("pointerdown", a(this, C)));
+            }
+            disableEditMode() {
+              !this.isInEditMode() || this.canvas === null || (super.disableEditMode(), this._isDraggable = !this.isEmpty(), this.div.classList.remove("editing"), this.canvas.removeEventListener("pointerdown", a(this, C)));
+            }
+            onceAdded() {
+              this._isDraggable = !this.isEmpty();
+            }
+            isEmpty() {
+              return this.paths.length === 0 || this.paths.length === 1 && this.paths[0].length === 0;
+            }
+            commit() {
+              a(this, b) || (super.commit(), this.isEditing = !1, this.disableEditMode(), this.setInForeground(), oe(this, b, !0), this.div.classList.add("disabled"), K(this, J, gt).call(this, !0), this.makeResizable(), this.parent.addInkEditorIfNeeded(!0), this.moveInDOM(), this.div.focus({
+                preventScroll: !0
+              }));
+            }
+            focusin(te) {
+              this._focusEventsAllowed && (super.focusin(te), this.enableEditMode());
+            }
+            canvasPointerdown(te) {
+              te.button !== 0 || !this.isInEditMode() || a(this, b) || (this.setInForeground(), te.preventDefault(), te.type !== "mouse" && this.div.focus(), K(this, Y, Wn).call(this, te.offsetX, te.offsetY));
+            }
+            canvasPointermove(te) {
+              te.preventDefault(), K(this, le, pn).call(this, te.offsetX, te.offsetY);
+            }
+            canvasPointerup(te) {
+              te.preventDefault(), K(this, Q, gn).call(this, te);
+            }
+            canvasPointerleave(te) {
+              K(this, Q, gn).call(this, te);
+            }
+            get isResizable() {
+              return !this.isEmpty() && a(this, b);
+            }
+            render() {
+              if (this.div)
+                return this.div;
+              let te, Te;
+              this.width && (te = this.x, Te = this.y), super.render(), s.AnnotationEditor._l10nPromise.get("editor_ink2_aria_label").then((Qe) => {
+                var Ae;
+                return (Ae = this.div) == null ? void 0 : Ae.setAttribute("aria-label", Qe);
+              });
+              const [Ne, ke, $e, Be] = K(this, G, Gn).call(this);
+              if (this.setAt(Ne, ke, 0, 0), this.setDims($e, Be), K(this, ue, Ft).call(this), this.width) {
+                const [Qe, Ae] = this.parentDimensions;
+                this.setAspectRatio(this.width * Qe, this.height * Ae), this.setAt(te * Qe, Te * Ae, this.width * Qe, this.height * Ae), oe(this, F, !0), K(this, Fe, pt).call(this), this.setDims(this.width * Qe, this.height * Ae), K(this, z, ot).call(this), this.div.classList.add("disabled");
+              } else
+                this.div.classList.add("editing"), this.enableEditMode();
+              return K(this, fe, It).call(this), this.div;
+            }
+            setDimensions(te, Te) {
+              const Ne = Math.round(te), ke = Math.round(Te);
+              if (a(this, y) === Ne && a(this, p) === ke)
+                return;
+              oe(this, y, Ne), oe(this, p, ke), this.canvas.style.visibility = "hidden";
+              const [$e, Be] = this.parentDimensions;
+              this.width = te / $e, this.height = Te / Be, this.fixAndSetPosition(), a(this, b) && K(this, De, _n).call(this, te, Te), K(this, Fe, pt).call(this), K(this, z, ot).call(this), this.canvas.style.visibility = "visible", this.fixDims();
+            }
+            static deserialize(te, Te, Ne) {
+              var V, Z, he;
+              if (te instanceof l.InkAnnotationElement)
+                return null;
+              const ke = super.deserialize(te, Te, Ne);
+              ke.thickness = te.thickness, ke.color = n.Util.makeHexColor(...te.color), ke.opacity = te.opacity;
+              const [$e, Be] = ke.pageDimensions, Qe = ke.width * $e, Ae = ke.height * Be, Ke = ke.parentScale, Oe = te.thickness / 2;
+              oe(ke, b, !0), oe(ke, y, Math.round(Qe)), oe(ke, p, Math.round(Ae));
+              const {
+                paths: U,
+                rect: u,
+                rotation: L
+              } = te;
+              for (let {
+                bezier: ye
+              } of U) {
+                ye = K(V = Se, We, Jn).call(V, ye, u, L);
+                const Me = [];
+                ke.paths.push(Me);
+                let Re = Ke * (ye[0] - Oe), qe = Ke * (ye[1] - Oe);
+                for (let Le = 2, He = ye.length; Le < He; Le += 6) {
+                  const Ve = Ke * (ye[Le] - Oe), Je = Ke * (ye[Le + 1] - Oe), Ze = Ke * (ye[Le + 2] - Oe), st = Ke * (ye[Le + 3] - Oe), it = Ke * (ye[Le + 4] - Oe), rt = Ke * (ye[Le + 5] - Oe);
+                  Me.push([[Re, qe], [Ve, Je], [Ze, st], [it, rt]]), Re = it, qe = rt;
+                }
+                const Ie = K(this, ge, Kn).call(this, Me);
+                ke.bezierPath2D.push(Ie);
+              }
+              const j = K(Z = ke, Ge, bn).call(Z);
+              return oe(ke, r, Math.max(s.AnnotationEditor.MIN_SIZE, j[2] - j[0])), oe(ke, o, Math.max(s.AnnotationEditor.MIN_SIZE, j[3] - j[1])), K(he = ke, De, _n).call(he, Qe, Ae), ke;
+            }
+            serialize() {
+              if (this.isEmpty())
+                return null;
+              const te = this.getRect(0, 0), Te = s.AnnotationEditor._colorManager.convert(this.ctx.strokeStyle);
+              return {
+                annotationType: n.AnnotationEditorType.INK,
+                color: Te,
+                thickness: this.thickness,
+                opacity: this.opacity,
+                paths: K(this, ze, Qn).call(this, this.scaleFactor / this.parentScale, this.translationX, this.translationY, te),
+                pageIndex: this.pageIndex,
+                rect: te,
+                rotation: this.rotation,
+                structTreeParentId: this._structTreeParentId
+              };
+            }
+          };
+          o = new WeakMap(), r = new WeakMap(), T = new WeakMap(), S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakMap(), k = new WeakMap(), F = new WeakMap(), x = new WeakMap(), y = new WeakMap(), p = new WeakMap(), E = new WeakMap(), $ = new WeakSet(), Hn = function(te) {
+            const Te = this.thickness;
+            this.addCommands({
+              cmd: () => {
+                this.thickness = te, K(this, J, gt).call(this);
+              },
+              undo: () => {
+                this.thickness = Te, K(this, J, gt).call(this);
+              },
+              mustExec: !0,
+              type: n.AnnotationEditorParamsType.INK_THICKNESS,
+              overwriteIfSameType: !0,
+              keepUndo: !0
+            });
+          }, m = new WeakSet(), Un = function(te) {
+            const Te = this.color;
+            this.addCommands({
+              cmd: () => {
+                this.color = te, K(this, z, ot).call(this);
+              },
+              undo: () => {
+                this.color = Te, K(this, z, ot).call(this);
+              },
+              mustExec: !0,
+              type: n.AnnotationEditorParamsType.INK_COLOR,
+              overwriteIfSameType: !0,
+              keepUndo: !0
+            });
+          }, D = new WeakSet(), jn = function(te) {
+            te /= 100;
+            const Te = this.opacity;
+            this.addCommands({
+              cmd: () => {
+                this.opacity = te, K(this, z, ot).call(this);
+              },
+              undo: () => {
+                this.opacity = Te, K(this, z, ot).call(this);
+              },
+              mustExec: !0,
+              type: n.AnnotationEditorParamsType.INK_OPACITY,
+              overwriteIfSameType: !0,
+              keepUndo: !0
+            });
+          }, G = new WeakSet(), Gn = function() {
+            const {
+              parentRotation: te,
+              parentDimensions: [Te, Ne]
+            } = this;
+            switch (te) {
+              case 90:
+                return [0, Ne, Ne, Te];
+              case 180:
+                return [Te, Ne, Te, Ne];
+              case 270:
+                return [Te, 0, Ne, Te];
+              default:
+                return [0, 0, Te, Ne];
+            }
+          }, B = new WeakSet(), dn = function() {
+            const {
+              ctx: te,
+              color: Te,
+              opacity: Ne,
+              thickness: ke,
+              parentScale: $e,
+              scaleFactor: Be
+            } = this;
+            te.lineWidth = ke * $e / Be, te.lineCap = "round", te.lineJoin = "round", te.miterLimit = 10, te.strokeStyle = `${Te}${(0, _.opacityToHex)(Ne)}`;
+          }, Y = new WeakSet(), Wn = function(te, Te) {
+            this.canvas.addEventListener("contextmenu", h.noContextMenu), this.canvas.addEventListener("pointerleave", a(this, S)), this.canvas.addEventListener("pointermove", a(this, T)), this.canvas.addEventListener("pointerup", a(this, w)), this.canvas.removeEventListener("pointerdown", a(this, C)), this.isEditing = !0, a(this, F) || (oe(this, F, !0), K(this, Fe, pt).call(this), this.thickness || (this.thickness = Se._defaultThickness), this.color || (this.color = Se._defaultColor || s.AnnotationEditor._defaultLineColor), this.opacity ?? (this.opacity = Se._defaultOpacity)), this.currentPath.push([te, Te]), oe(this, k, !1), K(this, B, dn).call(this), oe(this, E, () => {
+              K(this, g, Xn).call(this), a(this, E) && window.requestAnimationFrame(a(this, E));
+            }), window.requestAnimationFrame(a(this, E));
+          }, le = new WeakSet(), pn = function(te, Te) {
+            const [Ne, ke] = this.currentPath.at(-1);
+            if (this.currentPath.length > 1 && te === Ne && Te === ke)
+              return;
+            const $e = this.currentPath;
+            let Be = a(this, P);
+            if ($e.push([te, Te]), oe(this, k, !0), $e.length <= 2) {
+              Be.moveTo(...$e[0]), Be.lineTo(te, Te);
+              return;
+            }
+            $e.length === 3 && (oe(this, P, Be = new Path2D()), Be.moveTo(...$e[0])), K(this, v, Vn).call(this, Be, ...$e.at(-3), ...$e.at(-2), te, Te);
+          }, we = new WeakSet(), qn = function() {
+            if (this.currentPath.length === 0)
+              return;
+            const te = this.currentPath.at(-1);
+            a(this, P).lineTo(...te);
+          }, R = new WeakSet(), zn = function(te, Te) {
+            oe(this, E, null), te = Math.min(Math.max(te, 0), this.canvas.width), Te = Math.min(Math.max(Te, 0), this.canvas.height), K(this, le, pn).call(this, te, Te), K(this, we, qn).call(this);
+            let Ne;
+            if (this.currentPath.length !== 1)
+              Ne = K(this, O, Yn).call(this);
+            else {
+              const Ae = [te, Te];
+              Ne = [[Ae, Ae.slice(), Ae.slice(), Ae]];
+            }
+            const ke = a(this, P), $e = this.currentPath;
+            this.currentPath = [], oe(this, P, new Path2D());
+            const Be = () => {
+              this.allRawPaths.push($e), this.paths.push(Ne), this.bezierPath2D.push(ke), this.rebuild();
+            }, Qe = () => {
+              this.allRawPaths.pop(), this.paths.pop(), this.bezierPath2D.pop(), this.paths.length === 0 ? this.remove() : (this.canvas || (K(this, ue, Ft).call(this), K(this, fe, It).call(this)), K(this, J, gt).call(this));
+            };
+            this.addCommands({
+              cmd: Be,
+              undo: Qe,
+              mustExec: !0
+            });
+          }, g = new WeakSet(), Xn = function() {
+            if (!a(this, k))
+              return;
+            oe(this, k, !1);
+            const te = Math.ceil(this.thickness * this.parentScale), Te = this.currentPath.slice(-3), Ne = Te.map((Be) => Be[0]), ke = Te.map((Be) => Be[1]);
+            Math.min(...Ne) - te, Math.max(...Ne) + te, Math.min(...ke) - te, Math.max(...ke) + te;
+            const {
+              ctx: $e
+            } = this;
+            $e.save(), $e.clearRect(0, 0, this.canvas.width, this.canvas.height);
+            for (const Be of this.bezierPath2D)
+              $e.stroke(Be);
+            $e.stroke(a(this, P)), $e.restore();
+          }, v = new WeakSet(), Vn = function(te, Te, Ne, ke, $e, Be, Qe) {
+            const Ae = (Te + ke) / 2, Ke = (Ne + $e) / 2, Oe = (ke + Be) / 2, U = ($e + Qe) / 2;
+            te.bezierCurveTo(Ae + 2 * (ke - Ae) / 3, Ke + 2 * ($e - Ke) / 3, Oe + 2 * (ke - Oe) / 3, U + 2 * ($e - U) / 3, Oe, U);
+          }, O = new WeakSet(), Yn = function() {
+            const te = this.currentPath;
+            if (te.length <= 2)
+              return [[te[0], te[0], te.at(-1), te.at(-1)]];
+            const Te = [];
+            let Ne, [ke, $e] = te[0];
+            for (Ne = 1; Ne < te.length - 2; Ne++) {
+              const [u, L] = te[Ne], [j, V] = te[Ne + 1], Z = (u + j) / 2, he = (L + V) / 2, ye = [ke + 2 * (u - ke) / 3, $e + 2 * (L - $e) / 3], Me = [Z + 2 * (u - Z) / 3, he + 2 * (L - he) / 3];
+              Te.push([[ke, $e], ye, Me, [Z, he]]), [ke, $e] = [Z, he];
+            }
+            const [Be, Qe] = te[Ne], [Ae, Ke] = te[Ne + 1], Oe = [ke + 2 * (Be - ke) / 3, $e + 2 * (Qe - $e) / 3], U = [Ae + 2 * (Be - Ae) / 3, Ke + 2 * (Qe - Ke) / 3];
+            return Te.push([[ke, $e], Oe, U, [Ae, Ke]]), Te;
+          }, z = new WeakSet(), ot = function() {
+            if (this.isEmpty()) {
+              K(this, ie, Lt).call(this);
+              return;
+            }
+            K(this, B, dn).call(this);
+            const {
+              canvas: te,
+              ctx: Te
+            } = this;
+            Te.setTransform(1, 0, 0, 1, 0, 0), Te.clearRect(0, 0, te.width, te.height), K(this, ie, Lt).call(this);
+            for (const Ne of this.bezierPath2D)
+              Te.stroke(Ne);
+          }, Q = new WeakSet(), gn = function(te) {
+            this.canvas.removeEventListener("pointerleave", a(this, S)), this.canvas.removeEventListener("pointermove", a(this, T)), this.canvas.removeEventListener("pointerup", a(this, w)), this.canvas.addEventListener("pointerdown", a(this, C)), setTimeout(() => {
+              this.canvas.removeEventListener("contextmenu", h.noContextMenu);
+            }, 10), K(this, R, zn).call(this, te.offsetX, te.offsetY), this.addToAnnotationStorage(), this.setInBackground();
+          }, ue = new WeakSet(), Ft = function() {
+            this.canvas = document.createElement("canvas"), this.canvas.width = this.canvas.height = 0, this.canvas.className = "inkEditorCanvas", s.AnnotationEditor._l10nPromise.get("editor_ink_canvas_aria_label").then((te) => {
+              var Te;
+              return (Te = this.canvas) == null ? void 0 : Te.setAttribute("aria-label", te);
+            }), this.div.append(this.canvas), this.ctx = this.canvas.getContext("2d");
+          }, fe = new WeakSet(), It = function() {
+            oe(this, x, new ResizeObserver((te) => {
+              const Te = te[0].contentRect;
+              Te.width && Te.height && this.setDimensions(Te.width, Te.height);
+            })), a(this, x).observe(this.div);
+          }, Fe = new WeakSet(), pt = function() {
+            if (!a(this, F))
+              return;
+            const [te, Te] = this.parentDimensions;
+            this.canvas.width = Math.ceil(this.width * te), this.canvas.height = Math.ceil(this.height * Te), K(this, ie, Lt).call(this);
+          }, De = new WeakSet(), _n = function(te, Te) {
+            const Ne = K(this, de, Dt).call(this), ke = (te - Ne) / a(this, r), $e = (Te - Ne) / a(this, o);
+            this.scaleFactor = Math.min(ke, $e);
+          }, ie = new WeakSet(), Lt = function() {
+            const te = K(this, de, Dt).call(this) / 2;
+            this.ctx.setTransform(this.scaleFactor, 0, 0, this.scaleFactor, this.translationX * this.scaleFactor + te, this.translationY * this.scaleFactor + te);
+          }, ge = new WeakSet(), Kn = function(te) {
+            const Te = new Path2D();
+            for (let Ne = 0, ke = te.length; Ne < ke; Ne++) {
+              const [$e, Be, Qe, Ae] = te[Ne];
+              Ne === 0 && Te.moveTo(...$e), Te.bezierCurveTo(Be[0], Be[1], Qe[0], Qe[1], Ae[0], Ae[1]);
+            }
+            return Te;
+          }, xe = new WeakSet(), mn = function(te, Te, Ne) {
+            const [ke, $e, Be, Qe] = Te;
+            switch (Ne) {
+              case 0:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2)
+                  te[Ae] += ke, te[Ae + 1] = Qe - te[Ae + 1];
+                break;
+              case 90:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2) {
+                  const Oe = te[Ae];
+                  te[Ae] = te[Ae + 1] + ke, te[Ae + 1] = Oe + $e;
+                }
+                break;
+              case 180:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2)
+                  te[Ae] = Be - te[Ae], te[Ae + 1] += $e;
+                break;
+              case 270:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2) {
+                  const Oe = te[Ae];
+                  te[Ae] = Be - te[Ae + 1], te[Ae + 1] = Qe - Oe;
+                }
+                break;
+              default:
+                throw new Error("Invalid rotation");
+            }
+            return te;
+          }, We = new WeakSet(), Jn = function(te, Te, Ne) {
+            const [ke, $e, Be, Qe] = Te;
+            switch (Ne) {
+              case 0:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2)
+                  te[Ae] -= ke, te[Ae + 1] = Qe - te[Ae + 1];
+                break;
+              case 90:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2) {
+                  const Oe = te[Ae];
+                  te[Ae] = te[Ae + 1] - $e, te[Ae + 1] = Oe - ke;
+                }
+                break;
+              case 180:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2)
+                  te[Ae] = Be - te[Ae], te[Ae + 1] -= $e;
+                break;
+              case 270:
+                for (let Ae = 0, Ke = te.length; Ae < Ke; Ae += 2) {
+                  const Oe = te[Ae];
+                  te[Ae] = Qe - te[Ae + 1], te[Ae + 1] = Be - Oe;
+                }
+                break;
+              default:
+                throw new Error("Invalid rotation");
+            }
+            return te;
+          }, ze = new WeakSet(), Qn = function(te, Te, Ne, ke) {
+            var Ke, Oe;
+            const $e = [], Be = this.thickness / 2, Qe = te * Te + Be, Ae = te * Ne + Be;
+            for (const U of this.paths) {
+              const u = [], L = [];
+              for (let j = 0, V = U.length; j < V; j++) {
+                const [Z, he, ye, Me] = U[j], Re = te * Z[0] + Qe, qe = te * Z[1] + Ae, Ie = te * he[0] + Qe, Le = te * he[1] + Ae, He = te * ye[0] + Qe, Ve = te * ye[1] + Ae, Je = te * Me[0] + Qe, Ze = te * Me[1] + Ae;
+                j === 0 && (u.push(Re, qe), L.push(Re, qe)), u.push(Ie, Le, He, Ve, Je, Ze), L.push(Ie, Le), j === V - 1 && L.push(Je, Ze);
+              }
+              $e.push({
+                bezier: K(Ke = Se, xe, mn).call(Ke, u, ke, this.rotation),
+                points: K(Oe = Se, xe, mn).call(Oe, L, ke, this.rotation)
+              });
+            }
+            return $e;
+          }, Ge = new WeakSet(), bn = function() {
+            let te = 1 / 0, Te = -1 / 0, Ne = 1 / 0, ke = -1 / 0;
+            for (const $e of this.paths)
+              for (const [Be, Qe, Ae, Ke] of $e) {
+                const Oe = n.Util.bezierBoundingBox(...Be, ...Qe, ...Ae, ...Ke);
+                te = Math.min(te, Oe[0]), Ne = Math.min(Ne, Oe[1]), Te = Math.max(Te, Oe[2]), ke = Math.max(ke, Oe[3]);
+              }
+            return [te, Ne, Te, ke];
+          }, de = new WeakSet(), Dt = function() {
+            return a(this, b) ? Math.ceil(this.thickness * this.parentScale) : 0;
+          }, J = new WeakSet(), gt = function(te = !1) {
+            if (this.isEmpty())
+              return;
+            if (!a(this, b)) {
+              K(this, z, ot).call(this);
+              return;
+            }
+            const Te = K(this, Ge, bn).call(this), Ne = K(this, de, Dt).call(this);
+            oe(this, r, Math.max(s.AnnotationEditor.MIN_SIZE, Te[2] - Te[0])), oe(this, o, Math.max(s.AnnotationEditor.MIN_SIZE, Te[3] - Te[1]));
+            const ke = Math.ceil(Ne + a(this, r) * this.scaleFactor), $e = Math.ceil(Ne + a(this, o) * this.scaleFactor), [Be, Qe] = this.parentDimensions;
+            this.width = ke / Be, this.height = $e / Qe, this.setAspectRatio(ke, $e);
+            const Ae = this.translationX, Ke = this.translationY;
+            this.translationX = -Te[0], this.translationY = -Te[1], K(this, Fe, pt).call(this), K(this, z, ot).call(this), oe(this, y, ke), oe(this, p, $e), this.setDims(ke, $e);
+            const Oe = te ? Ne / this.scaleFactor / 2 : 0;
+            this.translate(Ae - this.translationX - Oe, Ke - this.translationY - Oe);
+          }, W(Se, ge), W(Se, xe), W(Se, We), nt(Se, "_defaultColor", null), nt(Se, "_defaultOpacity", 1), nt(Se, "_defaultThickness", 1), nt(Se, "_type", "ink");
+          let c = Se;
+          e.InkEditor = c;
+        },
+        /* 34 */
+        /***/
+        (t, e, i) => {
+          var c, o, r, T, S, w, C, P, b, k, F, Et, y, St, E, Ot, M, yn, N, Zn, X, ei, I, vn, ee, Nt, q, ti;
+          Object.defineProperty(e, "__esModule", {
+            value: !0
+          }), e.StampEditor = void 0;
+          var n = i(1), s = i(4), l = i(6), h = i(29);
+          const pe = class pe extends s.AnnotationEditor {
+            constructor(R) {
+              super({
+                ...R,
+                name: "stampEditor"
+              });
+              W(this, F);
+              W(this, y);
+              W(this, E);
+              W(this, M);
+              W(this, N);
+              W(this, X);
+              W(this, I);
+              W(this, ee);
+              W(this, q);
+              W(this, c, null);
+              W(this, o, null);
+              W(this, r, null);
+              W(this, T, null);
+              W(this, S, null);
+              W(this, w, null);
+              W(this, C, null);
+              W(this, P, null);
+              W(this, b, !1);
+              W(this, k, !1);
+              oe(this, T, R.bitmapUrl), oe(this, S, R.bitmapFile);
+            }
+            static initialize(R) {
+              s.AnnotationEditor.initialize(R);
+            }
+            static get supportedTypes() {
+              const R = ["apng", "avif", "bmp", "gif", "jpeg", "png", "svg+xml", "webp", "x-icon"];
+              return (0, n.shadow)(this, "supportedTypes", R.map((d) => `image/${d}`));
+            }
+            static get supportedTypesStr() {
+              return (0, n.shadow)(this, "supportedTypesStr", this.supportedTypes.join(","));
+            }
+            static isHandlingMimeForPasting(R) {
+              return this.supportedTypes.includes(R);
+            }
+            static paste(R, d) {
+              d.pasteEditor(n.AnnotationEditorType.STAMP, {
+                bitmapFile: R.getAsFile()
+              });
+            }
+            remove() {
+              var R, d;
+              a(this, o) && (oe(this, c, null), this._uiManager.imageManager.deleteId(a(this, o)), (R = a(this, w)) == null || R.remove(), oe(this, w, null), (d = a(this, C)) == null || d.disconnect(), oe(this, C, null)), super.remove();
+            }
+            rebuild() {
+              if (!this.parent) {
+                a(this, o) && K(this, E, Ot).call(this);
+                return;
+              }
+              super.rebuild(), this.div !== null && (a(this, o) && K(this, E, Ot).call(this), this.isAttachedToDOM || this.parent.add(this));
+            }
+            onceAdded() {
+              this._isDraggable = !0, this.div.focus();
+            }
+            isEmpty() {
+              return !(a(this, r) || a(this, c) || a(this, T) || a(this, S));
+            }
+            get isResizable() {
+              return !0;
+            }
+            render() {
+              if (this.div)
+                return this.div;
+              let R, d;
+              if (this.width && (R = this.x, d = this.y), super.render(), this.div.hidden = !0, a(this, c) ? K(this, M, yn).call(this) : K(this, E, Ot).call(this), this.width) {
+                const [g, f] = this.parentDimensions;
+                this.setAt(R * g, d * f, this.width * g, this.height * f);
+              }
+              return this.div;
+            }
+            static deserialize(R, d, g) {
+              if (R instanceof h.StampAnnotationElement)
+                return null;
+              const f = super.deserialize(R, d, g), {
+                rect: v,
+                bitmapUrl: A,
+                bitmapId: O,
+                isSvg: H,
+                accessibilityData: z
+              } = R;
+              O && g.imageManager.isValidId(O) ? oe(f, o, O) : oe(f, T, A), oe(f, b, H);
+              const [ae, Q] = f.pageDimensions;
+              return f.width = (v[2] - v[0]) / ae, f.height = (v[3] - v[1]) / Q, z && (f.altTextData = z), f;
+            }
+            serialize(R = !1, d = null) {
+              if (this.isEmpty())
+                return null;
+              const g = {
+                annotationType: n.AnnotationEditorType.STAMP,
+                bitmapId: a(this, o),
+                pageIndex: this.pageIndex,
+                rect: this.getRect(0, 0),
+                rotation: this.rotation,
+                isSvg: a(this, b),
+                structTreeParentId: this._structTreeParentId
+              };
+              if (R)
+                return g.bitmapUrl = K(this, ee, Nt).call(this, !0), g.accessibilityData = this.altTextData, g;
+              const {
+                decorative: f,
+                altText: v
+              } = this.altTextData;
+              if (!f && v && (g.accessibilityData = {
+                type: "Figure",
+                alt: v
+              }), d === null)
+                return g;
+              d.stamps || (d.stamps = /* @__PURE__ */ new Map());
+              const A = a(this, b) ? (g.rect[2] - g.rect[0]) * (g.rect[3] - g.rect[1]) : null;
+              if (!d.stamps.has(a(this, o)))
+                d.stamps.set(a(this, o), {
+                  area: A,
+                  serialized: g
+                }), g.bitmap = K(this, ee, Nt).call(this, !1);
+              else if (a(this, b)) {
+                const O = d.stamps.get(a(this, o));
+                A > O.area && (O.area = A, O.serialized.bitmap.close(), O.serialized.bitmap = K(this, ee, Nt).call(this, !1));
+              }
+              return g;
+            }
+          };
+          c = new WeakMap(), o = new WeakMap(), r = new WeakMap(), T = new WeakMap(), S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakMap(), k = new WeakMap(), F = new WeakSet(), Et = function(R, d = !1) {
+            if (!R) {
+              this.remove();
+              return;
+            }
+            oe(this, c, R.bitmap), d || (oe(this, o, R.id), oe(this, b, R.isSvg)), K(this, M, yn).call(this);
+          }, y = new WeakSet(), St = function() {
+            oe(this, r, null), this._uiManager.enableWaiting(!1), a(this, w) && this.div.focus();
+          }, E = new WeakSet(), Ot = function() {
+            if (a(this, o)) {
+              this._uiManager.enableWaiting(!0), this._uiManager.imageManager.getFromId(a(this, o)).then((d) => K(this, F, Et).call(this, d, !0)).finally(() => K(this, y, St).call(this));
+              return;
+            }
+            if (a(this, T)) {
+              const d = a(this, T);
+              oe(this, T, null), this._uiManager.enableWaiting(!0), oe(this, r, this._uiManager.imageManager.getFromUrl(d).then((g) => K(this, F, Et).call(this, g)).finally(() => K(this, y, St).call(this)));
+              return;
+            }
+            if (a(this, S)) {
+              const d = a(this, S);
+              oe(this, S, null), this._uiManager.enableWaiting(!0), oe(this, r, this._uiManager.imageManager.getFromFile(d).then((g) => K(this, F, Et).call(this, g)).finally(() => K(this, y, St).call(this)));
+              return;
+            }
+            const R = document.createElement("input");
+            R.type = "file", R.accept = pe.supportedTypesStr, oe(this, r, new Promise((d) => {
+              R.addEventListener("change", async () => {
+                if (!R.files || R.files.length === 0)
+                  this.remove();
+                else {
+                  this._uiManager.enableWaiting(!0);
+                  const g = await this._uiManager.imageManager.getFromFile(R.files[0]);
+                  K(this, F, Et).call(this, g);
+                }
+                d();
+              }), R.addEventListener("cancel", () => {
+                this.remove(), d();
+              });
+            }).finally(() => K(this, y, St).call(this))), R.click();
+          }, M = new WeakSet(), yn = function() {
+            const {
+              div: R
+            } = this;
+            let {
+              width: d,
+              height: g
+            } = a(this, c);
+            const [f, v] = this.pageDimensions, A = 0.75;
+            if (this.width)
+              d = this.width * f, g = this.height * v;
+            else if (d > A * f || g > A * v) {
+              const ae = Math.min(A * f / d, A * v / g);
+              d *= ae, g *= ae;
+            }
+            const [O, H] = this.parentDimensions;
+            this.setDims(d * O / f, g * H / v), this._uiManager.enableWaiting(!1);
+            const z = oe(this, w, document.createElement("canvas"));
+            R.append(z), R.hidden = !1, K(this, I, vn).call(this, d, g), K(this, q, ti).call(this), a(this, k) || (this.parent.addUndoableEditor(this), oe(this, k, !0)), this._uiManager._eventBus.dispatch("reporttelemetry", {
+              source: this,
+              details: {
+                type: "editing",
+                subtype: this.editorType,
+                data: {
+                  action: "inserted_image"
+                }
+              }
+            }), this.addAltTextButton();
+          }, N = new WeakSet(), Zn = function(R, d) {
+            var A;
+            const [g, f] = this.parentDimensions;
+            this.width = R / g, this.height = d / f, this.setDims(R, d), (A = this._initialOptions) != null && A.isCentered ? this.center() : this.fixAndSetPosition(), this._initialOptions = null, a(this, P) !== null && clearTimeout(a(this, P)), oe(this, P, setTimeout(() => {
+              oe(this, P, null), K(this, I, vn).call(this, R, d);
+            }, 200));
+          }, X = new WeakSet(), ei = function(R, d) {
+            const {
+              width: g,
+              height: f
+            } = a(this, c);
+            let v = g, A = f, O = a(this, c);
+            for (; v > 2 * R || A > 2 * d; ) {
+              const H = v, z = A;
+              v > 2 * R && (v = v >= 16384 ? Math.floor(v / 2) - 1 : Math.ceil(v / 2)), A > 2 * d && (A = A >= 16384 ? Math.floor(A / 2) - 1 : Math.ceil(A / 2));
+              const ae = new OffscreenCanvas(v, A);
+              ae.getContext("2d").drawImage(O, 0, 0, H, z, 0, 0, v, A), O = ae.transferToImageBitmap();
+            }
+            return O;
+          }, I = new WeakSet(), vn = function(R, d) {
+            R = Math.ceil(R), d = Math.ceil(d);
+            const g = a(this, w);
+            if (!g || g.width === R && g.height === d)
+              return;
+            g.width = R, g.height = d;
+            const f = a(this, b) ? a(this, c) : K(this, X, ei).call(this, R, d), v = g.getContext("2d");
+            v.filter = this._uiManager.hcmFilter, v.drawImage(f, 0, 0, f.width, f.height, 0, 0, R, d);
+          }, ee = new WeakSet(), Nt = function(R) {
+            if (R) {
+              if (a(this, b)) {
+                const f = this._uiManager.imageManager.getSvgUrl(a(this, o));
+                if (f)
+                  return f;
+              }
+              const d = document.createElement("canvas");
+              return {
+                width: d.width,
+                height: d.height
+              } = a(this, c), d.getContext("2d").drawImage(a(this, c), 0, 0), d.toDataURL();
+            }
+            if (a(this, b)) {
+              const [d, g] = this.pageDimensions, f = Math.round(this.width * d * l.PixelsPerInch.PDF_TO_CSS_UNITS), v = Math.round(this.height * g * l.PixelsPerInch.PDF_TO_CSS_UNITS), A = new OffscreenCanvas(f, v);
+              return A.getContext("2d").drawImage(a(this, c), 0, 0, a(this, c).width, a(this, c).height, 0, 0, f, v), A.transferToImageBitmap();
+            }
+            return structuredClone(a(this, c));
+          }, q = new WeakSet(), ti = function() {
+            oe(this, C, new ResizeObserver((R) => {
+              const d = R[0].contentRect;
+              d.width && d.height && K(this, N, Zn).call(this, d.width, d.height);
+            })), a(this, C).observe(this.div);
+          }, nt(pe, "_type", "stamp");
+          let _ = pe;
+          e.StampEditor = _;
+        }
+        /******/
+      ], __webpack_module_cache__ = {};
+      function __w_pdfjs_require__(t) {
+        var e = __webpack_module_cache__[t];
+        if (e !== void 0)
+          return e.exports;
+        var i = __webpack_module_cache__[t] = {
+          /******/
+          // no module.id needed
+          /******/
+          // no module.loaded needed
+          /******/
+          exports: {}
+          /******/
+        };
+        return __webpack_modules__[t](i, i.exports, __w_pdfjs_require__), i.exports;
+      }
+      var __webpack_exports__ = {};
+      return (() => {
+        var t = __webpack_exports__;
+        Object.defineProperty(t, "__esModule", {
+          value: !0
+        }), Object.defineProperty(t, "AbortException", {
+          enumerable: !0,
+          get: function() {
+            return e.AbortException;
+          }
+        }), Object.defineProperty(t, "AnnotationEditorLayer", {
+          enumerable: !0,
+          get: function() {
+            return l.AnnotationEditorLayer;
+          }
+        }), Object.defineProperty(t, "AnnotationEditorParamsType", {
+          enumerable: !0,
+          get: function() {
+            return e.AnnotationEditorParamsType;
+          }
+        }), Object.defineProperty(t, "AnnotationEditorType", {
+          enumerable: !0,
+          get: function() {
+            return e.AnnotationEditorType;
+          }
+        }), Object.defineProperty(t, "AnnotationEditorUIManager", {
+          enumerable: !0,
+          get: function() {
+            return h.AnnotationEditorUIManager;
+          }
+        }), Object.defineProperty(t, "AnnotationLayer", {
+          enumerable: !0,
+          get: function() {
+            return _.AnnotationLayer;
+          }
+        }), Object.defineProperty(t, "AnnotationMode", {
+          enumerable: !0,
+          get: function() {
+            return e.AnnotationMode;
+          }
+        }), Object.defineProperty(t, "CMapCompressionType", {
+          enumerable: !0,
+          get: function() {
+            return e.CMapCompressionType;
+          }
+        }), Object.defineProperty(t, "DOMSVGFactory", {
+          enumerable: !0,
+          get: function() {
+            return n.DOMSVGFactory;
+          }
+        }), Object.defineProperty(t, "FeatureTest", {
+          enumerable: !0,
+          get: function() {
+            return e.FeatureTest;
+          }
+        }), Object.defineProperty(t, "GlobalWorkerOptions", {
+          enumerable: !0,
+          get: function() {
+            return c.GlobalWorkerOptions;
+          }
+        }), Object.defineProperty(t, "ImageKind", {
+          enumerable: !0,
+          get: function() {
+            return e.ImageKind;
+          }
+        }), Object.defineProperty(t, "InvalidPDFException", {
+          enumerable: !0,
+          get: function() {
+            return e.InvalidPDFException;
+          }
+        }), Object.defineProperty(t, "MissingPDFException", {
+          enumerable: !0,
+          get: function() {
+            return e.MissingPDFException;
+          }
+        }), Object.defineProperty(t, "OPS", {
+          enumerable: !0,
+          get: function() {
+            return e.OPS;
+          }
+        }), Object.defineProperty(t, "PDFDataRangeTransport", {
+          enumerable: !0,
+          get: function() {
+            return i.PDFDataRangeTransport;
+          }
+        }), Object.defineProperty(t, "PDFDateString", {
+          enumerable: !0,
+          get: function() {
+            return n.PDFDateString;
+          }
+        }), Object.defineProperty(t, "PDFWorker", {
+          enumerable: !0,
+          get: function() {
+            return i.PDFWorker;
+          }
+        }), Object.defineProperty(t, "PasswordResponses", {
+          enumerable: !0,
+          get: function() {
+            return e.PasswordResponses;
+          }
+        }), Object.defineProperty(t, "PermissionFlag", {
+          enumerable: !0,
+          get: function() {
+            return e.PermissionFlag;
+          }
+        }), Object.defineProperty(t, "PixelsPerInch", {
+          enumerable: !0,
+          get: function() {
+            return n.PixelsPerInch;
+          }
+        }), Object.defineProperty(t, "PromiseCapability", {
+          enumerable: !0,
+          get: function() {
+            return e.PromiseCapability;
+          }
+        }), Object.defineProperty(t, "RenderingCancelledException", {
+          enumerable: !0,
+          get: function() {
+            return n.RenderingCancelledException;
+          }
+        }), Object.defineProperty(t, "SVGGraphics", {
+          enumerable: !0,
+          get: function() {
+            return i.SVGGraphics;
+          }
+        }), Object.defineProperty(t, "UnexpectedResponseException", {
+          enumerable: !0,
+          get: function() {
+            return e.UnexpectedResponseException;
+          }
+        }), Object.defineProperty(t, "Util", {
+          enumerable: !0,
+          get: function() {
+            return e.Util;
+          }
+        }), Object.defineProperty(t, "VerbosityLevel", {
+          enumerable: !0,
+          get: function() {
+            return e.VerbosityLevel;
+          }
+        }), Object.defineProperty(t, "XfaLayer", {
+          enumerable: !0,
+          get: function() {
+            return o.XfaLayer;
+          }
+        }), Object.defineProperty(t, "build", {
+          enumerable: !0,
+          get: function() {
+            return i.build;
+          }
+        }), Object.defineProperty(t, "createValidAbsoluteUrl", {
+          enumerable: !0,
+          get: function() {
+            return e.createValidAbsoluteUrl;
+          }
+        }), Object.defineProperty(t, "getDocument", {
+          enumerable: !0,
+          get: function() {
+            return i.getDocument;
+          }
+        }), Object.defineProperty(t, "getFilenameFromUrl", {
+          enumerable: !0,
+          get: function() {
+            return n.getFilenameFromUrl;
+          }
+        }), Object.defineProperty(t, "getPdfFilenameFromUrl", {
+          enumerable: !0,
+          get: function() {
+            return n.getPdfFilenameFromUrl;
+          }
+        }), Object.defineProperty(t, "getXfaPageViewport", {
+          enumerable: !0,
+          get: function() {
+            return n.getXfaPageViewport;
+          }
+        }), Object.defineProperty(t, "isDataScheme", {
+          enumerable: !0,
+          get: function() {
+            return n.isDataScheme;
+          }
+        }), Object.defineProperty(t, "isPdfFile", {
+          enumerable: !0,
+          get: function() {
+            return n.isPdfFile;
+          }
+        }), Object.defineProperty(t, "loadScript", {
+          enumerable: !0,
+          get: function() {
+            return n.loadScript;
+          }
+        }), Object.defineProperty(t, "noContextMenu", {
+          enumerable: !0,
+          get: function() {
+            return n.noContextMenu;
+          }
+        }), Object.defineProperty(t, "normalizeUnicode", {
+          enumerable: !0,
+          get: function() {
+            return e.normalizeUnicode;
+          }
+        }), Object.defineProperty(t, "renderTextLayer", {
+          enumerable: !0,
+          get: function() {
+            return s.renderTextLayer;
+          }
+        }), Object.defineProperty(t, "setLayerDimensions", {
+          enumerable: !0,
+          get: function() {
+            return n.setLayerDimensions;
+          }
+        }), Object.defineProperty(t, "shadow", {
+          enumerable: !0,
+          get: function() {
+            return e.shadow;
+          }
+        }), Object.defineProperty(t, "updateTextLayer", {
+          enumerable: !0,
+          get: function() {
+            return s.updateTextLayer;
+          }
+        }), Object.defineProperty(t, "version", {
+          enumerable: !0,
+          get: function() {
+            return i.version;
+          }
+        });
+        var e = __w_pdfjs_require__(1), i = __w_pdfjs_require__(2), n = __w_pdfjs_require__(6), s = __w_pdfjs_require__(26), l = __w_pdfjs_require__(27), h = __w_pdfjs_require__(5), _ = __w_pdfjs_require__(29), c = __w_pdfjs_require__(14), o = __w_pdfjs_require__(32);
+      })(), __webpack_exports__;
+    })()
+  ));
+})(pdf);
+var pdfExports = pdf.exports;
+const pdfjsLib = /* @__PURE__ */ getDefaultExportFromCjs(pdfExports), Index_svelte_svelte_type_style_lang = "", {
+  SvelteComponent,
+  append,
+  assign,
+  attr,
+  binding_callbacks,
+  check_outros,
+  create_component,
+  destroy_component,
+  detach,
+  element,
+  empty,
+  get_spread_object,
+  get_spread_update,
+  group_outros,
+  init,
+  insert,
+  mount_component,
+  safe_not_equal,
+  set_data,
+  set_style,
+  space,
+  text,
+  transition_in,
+  transition_out
+} = window.__gradio__svelte__internal, { tick } = window.__gradio__svelte__internal;
+function create_if_block_1(t) {
+  let e, i;
+  const n = [
+    {
+      autoscroll: (
+        /*gradio*/
+        t[11].autoscroll
+      )
+    },
+    { i18n: (
+      /*gradio*/
+      t[11].i18n
+    ) },
+    /*loading_status*/
+    t[10]
+  ];
+  let s = {};
+  for (let l = 0; l < n.length; l += 1)
+    s = assign(s, n[l]);
+  return e = new Static({ props: s }), {
+    c() {
+      create_component(e.$$.fragment);
+    },
+    m(l, h) {
+      mount_component(e, l, h), i = !0;
+    },
+    p(l, h) {
+      const _ = h & /*gradio, loading_status*/
+      3072 ? get_spread_update(n, [
+        h & /*gradio*/
+        2048 && {
+          autoscroll: (
+            /*gradio*/
+            l[11].autoscroll
+          )
+        },
+        h & /*gradio*/
+        2048 && { i18n: (
+          /*gradio*/
+          l[11].i18n
+        ) },
+        h & /*loading_status*/
+        1024 && get_spread_object(
+          /*loading_status*/
+          l[10]
+        )
+      ]) : {};
+      e.$set(_);
+    },
+    i(l) {
+      i || (transition_in(e.$$.fragment, l), i = !0);
+    },
+    o(l) {
+      transition_out(e.$$.fragment, l), i = !1;
+    },
+    d(l) {
+      destroy_component(e, l);
+    }
+  };
+}
+function create_else_block(t) {
+  let e, i;
+  return e = new Upload({
+    props: {
+      filetype: "application/pdf",
+      file_count: "single",
+      root: (
+        /*root*/
+        t[7]
+      ),
+      $$slots: { default: [create_default_slot_3] },
+      $$scope: { ctx: t }
+    }
+  }), e.$on(
+    "load",
+    /*handle_upload*/
+    t[17]
+  ), {
+    c() {
+      create_component(e.$$.fragment);
+    },
+    m(n, s) {
+      mount_component(e, n, s), i = !0;
+    },
+    p(n, s) {
+      const l = {};
+      s & /*root*/
+      128 && (l.root = /*root*/
+      n[7]), s & /*$$scope*/
+      134217728 && (l.$$scope = { dirty: s, ctx: n }), e.$set(l);
+    },
+    i(n) {
+      i || (transition_in(e.$$.fragment, n), i = !0);
+    },
+    o(n) {
+      transition_out(e.$$.fragment, n), i = !1;
+    },
+    d(n) {
+      destroy_component(e, n);
+    }
+  };
+}
+function create_if_block(t) {
+  let e, i, n, s, l, h, _, c, o, r, T, S, w, C, P;
+  return e = new ModifyUpload({
+    props: {
+      i18n: (
+        /*gradio*/
+        t[11].i18n
+      ),
+      absolute: !0
+    }
+  }), e.$on(
+    "clear",
+    /*handle_clear*/
+    t[16]
+  ), _ = new Button({
+    props: {
+      $$slots: { default: [create_default_slot_2] },
+      $$scope: { ctx: t }
+    }
+  }), _.$on(
+    "click",
+    /*prev_page*/
+    t[19]
+  ), C = new Button({
+    props: {
+      $$slots: { default: [create_default_slot_1] },
+      $$scope: { ctx: t }
+    }
+  }), C.$on(
+    "click",
+    /*next_page*/
+    t[18]
+  ), {
+    c() {
+      create_component(e.$$.fragment), i = space(), n = element("div"), s = element("canvas"), l = space(), h = element("div"), create_component(_.$$.fragment), c = space(), o = element("span"), r = text(
+        /*currentPage*/
+        t[14]
+      ), T = text(" / "), S = text(
+        /*numPages*/
+        t[13]
+      ), w = space(), create_component(C.$$.fragment), attr(n, "class", "pdf-canvas svelte-qxsbof"), set_style(
+        n,
+        "height",
+        /*height*/
+        t[1] + "px"
+      ), attr(o, "class", "page-count svelte-qxsbof"), attr(h, "class", "button-row svelte-qxsbof");
+    },
+    m(b, k) {
+      mount_component(e, b, k), insert(b, i, k), insert(b, n, k), append(n, s), t[22](s), insert(b, l, k), insert(b, h, k), mount_component(_, h, null), append(h, c), append(h, o), append(o, r), append(o, T), append(o, S), append(h, w), mount_component(C, h, null), P = !0;
+    },
+    p(b, k) {
+      const F = {};
+      k & /*gradio*/
+      2048 && (F.i18n = /*gradio*/
+      b[11].i18n), e.$set(F), (!P || k & /*height*/
+      2) && set_style(
+        n,
+        "height",
+        /*height*/
+        b[1] + "px"
+      );
+      const x = {};
+      k & /*$$scope*/
+      134217728 && (x.$$scope = { dirty: k, ctx: b }), _.$set(x), (!P || k & /*currentPage*/
+      16384) && set_data(
+        r,
+        /*currentPage*/
+        b[14]
+      ), (!P || k & /*numPages*/
+      8192) && set_data(
+        S,
+        /*numPages*/
+        b[13]
+      );
+      const y = {};
+      k & /*$$scope*/
+      134217728 && (y.$$scope = { dirty: k, ctx: b }), C.$set(y);
+    },
+    i(b) {
+      P || (transition_in(e.$$.fragment, b), transition_in(_.$$.fragment, b), transition_in(C.$$.fragment, b), P = !0);
+    },
+    o(b) {
+      transition_out(e.$$.fragment, b), transition_out(_.$$.fragment, b), transition_out(C.$$.fragment, b), P = !1;
+    },
+    d(b) {
+      b && (detach(i), detach(n), detach(l), detach(h)), destroy_component(e, b), t[22](null), destroy_component(_), destroy_component(C);
+    }
+  };
+}
+function create_default_slot_3(t) {
+  let e, i;
+  return e = new PdfUploadText({}), {
+    c() {
+      create_component(e.$$.fragment);
+    },
+    m(n, s) {
+      mount_component(e, n, s), i = !0;
+    },
+    i(n) {
+      i || (transition_in(e.$$.fragment, n), i = !0);
+    },
+    o(n) {
+      transition_out(e.$$.fragment, n), i = !1;
+    },
+    d(n) {
+      destroy_component(e, n);
+    }
+  };
+}
+function create_default_slot_2(t) {
+  let e;
+  return {
+    c() {
+      e = text("⬅️");
+    },
+    m(i, n) {
+      insert(i, e, n);
+    },
+    d(i) {
+      i && detach(e);
+    }
+  };
+}
+function create_default_slot_1(t) {
+  let e;
+  return {
+    c() {
+      e = text("➡️");
+    },
+    m(i, n) {
+      insert(i, e, n);
+    },
+    d(i) {
+      i && detach(e);
+    }
+  };
+}
+function create_default_slot(t) {
+  let e, i, n, s, l, h, _, c = (
+    /*loading_status*/
+    t[10] && create_if_block_1(t)
+  );
+  i = new BlockLabel({
+    props: {
+      show_label: (
+        /*label*/
+        t[8] !== null
+      ),
+      Icon: File$1,
+      float: (
+        /*value*/
+        t[0] === null
+      ),
+      label: (
+        /*label*/
+        t[8] || "File"
+      )
+    }
+  });
+  const o = [create_if_block, create_else_block], r = [];
+  function T(S, w) {
+    return (
+      /*_value*/
+      S[12] ? 0 : 1
+    );
+  }
+  return s = T(t), l = r[s] = o[s](t), {
+    c() {
+      c && c.c(), e = space(), create_component(i.$$.fragment), n = space(), l.c(), h = empty();
+    },
+    m(S, w) {
+      c && c.m(S, w), insert(S, e, w), mount_component(i, S, w), insert(S, n, w), r[s].m(S, w), insert(S, h, w), _ = !0;
+    },
+    p(S, w) {
+      /*loading_status*/
+      S[10] ? c ? (c.p(S, w), w & /*loading_status*/
+      1024 && transition_in(c, 1)) : (c = create_if_block_1(S), c.c(), transition_in(c, 1), c.m(e.parentNode, e)) : c && (group_outros(), transition_out(c, 1, 1, () => {
+        c = null;
+      }), check_outros());
+      const C = {};
+      w & /*label*/
+      256 && (C.show_label = /*label*/
+      S[8] !== null), w & /*value*/
+      1 && (C.float = /*value*/
+      S[0] === null), w & /*label*/
+      256 && (C.label = /*label*/
+      S[8] || "File"), i.$set(C);
+      let P = s;
+      s = T(S), s === P ? r[s].p(S, w) : (group_outros(), transition_out(r[P], 1, 1, () => {
+        r[P] = null;
+      }), check_outros(), l = r[s], l ? l.p(S, w) : (l = r[s] = o[s](S), l.c()), transition_in(l, 1), l.m(h.parentNode, h));
+    },
+    i(S) {
+      _ || (transition_in(c), transition_in(i.$$.fragment, S), transition_in(l), _ = !0);
+    },
+    o(S) {
+      transition_out(c), transition_out(i.$$.fragment, S), transition_out(l), _ = !1;
+    },
+    d(S) {
+      S && (detach(e), detach(n), detach(h)), c && c.d(S), destroy_component(i, S), r[s].d(S);
+    }
+  };
+}
+function create_fragment(t) {
+  let e, i;
+  return e = new Block({
+    props: {
+      visible: (
+        /*visible*/
+        t[4]
+      ),
+      elem_id: (
+        /*elem_id*/
+        t[2]
+      ),
+      elem_classes: (
+        /*elem_classes*/
+        t[3]
+      ),
+      container: (
+        /*container*/
+        t[5]
+      ),
+      scale: (
+        /*scale*/
+        t[6]
+      ),
+      min_width: (
+        /*min_width*/
+        t[9]
+      ),
+      $$slots: { default: [create_default_slot] },
+      $$scope: { ctx: t }
+    }
+  }), {
+    c() {
+      create_component(e.$$.fragment);
+    },
+    m(n, s) {
+      mount_component(e, n, s), i = !0;
+    },
+    p(n, [s]) {
+      const l = {};
+      s & /*visible*/
+      16 && (l.visible = /*visible*/
+      n[4]), s & /*elem_id*/
+      4 && (l.elem_id = /*elem_id*/
+      n[2]), s & /*elem_classes*/
+      8 && (l.elem_classes = /*elem_classes*/
+      n[3]), s & /*container*/
+      32 && (l.container = /*container*/
+      n[5]), s & /*scale*/
+      64 && (l.scale = /*scale*/
+      n[6]), s & /*min_width*/
+      512 && (l.min_width = /*min_width*/
+      n[9]), s & /*$$scope, numPages, currentPage, height, canvasRef, gradio, _value, root, label, value, loading_status*/
+      134282627 && (l.$$scope = { dirty: s, ctx: n }), e.$set(l);
+    },
+    i(n) {
+      i || (transition_in(e.$$.fragment, n), i = !0);
+    },
+    o(n) {
+      transition_out(e.$$.fragment, n), i = !1;
+    },
+    d(n) {
+      destroy_component(e, n);
+    }
+  };
+}
+function instance(t, e, i) {
+  let { elem_id: n = "" } = e, { elem_classes: s = [] } = e, { visible: l = !0 } = e, { value: h = null } = e, { container: _ = !0 } = e, { scale: c = null } = e, { root: o } = e, { height: r = 500 } = e, { label: T } = e, { proxy_url: S } = e, { min_width: w = void 0 } = e, { loading_status: C } = e, { gradio: P } = e;
+  pdfjsLib.GlobalWorkerOptions.workerSrc = "https://cdn.bootcss.com/pdf.js/3.11.174/pdf.worker.js";
+  let b = h, k = b, F, x = 1, y = 1, p;
+  async function E() {
+    i(12, b = null), await tick(), P.dispatch("change");
+  }
+  async function $({ detail: G }) {
+    i(0, h = G), await tick(), P.dispatch("change"), P.dispatch("upload");
+  }
+  async function M(G) {
+    F = await pdfjsLib.getDocument(G.url).promise, i(13, x = F.numPages), m();
+  }
+  function m() {
+    F.getPage(y).then((G) => {
+      const I = p.getContext("2d");
+      I.clearRect(0, 0, p.width, p.height);
+      let B = G.getViewport({ scale: 1 }), ee = r / B.height;
+      B = G.getViewport({ scale: ee });
+      const Y = { canvasContext: I, viewport: B };
+      i(15, p.width = B.width, p), i(15, p.height = B.height, p), G.render(Y);
+    });
+  }
+  function N() {
+    y >= x || (i(14, y++, y), m());
+  }
+  function D() {
+    y != 1 && (i(14, y--, y), m());
+  }
+  function X(G) {
+    binding_callbacks[G ? "unshift" : "push"](() => {
+      p = G, i(15, p);
+    });
+  }
+  return t.$$set = (G) => {
+    "elem_id" in G && i(2, n = G.elem_id), "elem_classes" in G && i(3, s = G.elem_classes), "visible" in G && i(4, l = G.visible), "value" in G && i(0, h = G.value), "container" in G && i(5, _ = G.container), "scale" in G && i(6, c = G.scale), "root" in G && i(7, o = G.root), "height" in G && i(1, r = G.height), "label" in G && i(8, T = G.label), "proxy_url" in G && i(20, S = G.proxy_url), "min_width" in G && i(9, w = G.min_width), "loading_status" in G && i(10, C = G.loading_status), "gradio" in G && i(11, P = G.gradio);
+  }, t.$$.update = () => {
+    t.$$.dirty & /*height*/
+    2 && i(1, r = r || 500), t.$$.dirty & /*value, root, proxy_url*/
+    1048705 && i(12, b = normalise_file(h, o, S)), t.$$.dirty & /*old_value, _value, gradio*/
+    2103296 && JSON.stringify(k) != JSON.stringify(b) && (b && M(b), i(21, k = b), P.dispatch("change"));
+  }, [
+    h,
+    r,
+    n,
+    s,
+    l,
+    _,
+    c,
+    o,
+    T,
+    w,
+    C,
+    P,
+    b,
+    x,
+    y,
+    p,
+    E,
+    $,
+    N,
+    D,
+    S,
+    k,
+    X
+  ];
+}
+class Index extends SvelteComponent {
+  constructor(e) {
+    super(), init(this, e, instance, create_fragment, safe_not_equal, {
+      elem_id: 2,
+      elem_classes: 3,
+      visible: 4,
+      value: 0,
+      container: 5,
+      scale: 6,
+      root: 7,
+      height: 1,
+      label: 8,
+      proxy_url: 20,
+      min_width: 9,
+      loading_status: 10,
+      gradio: 11
+    });
+  }
+}
+export {
+  Index as I,
+  require$$5$1 as r
+};