diff --git "a/src/backend/gradio_pdf/templates/component/Index-9e3f581a.js" "b/src/backend/gradio_pdf/templates/component/Index-9e3f581a.js"
new file mode 100644--- /dev/null
+++ "b/src/backend/gradio_pdf/templates/component/Index-9e3f581a.js"
@@ -0,0 +1,19929 @@
+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-15fa1cb3.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() {
+ if (this instanceof n) {
+ var s = [null];
+ s.push.apply(s, arguments);
+ var l = Function.bind.apply(e, s);
+ return new l();
+ }
+ return 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,', 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,", '')"), 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
+};