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: onMount$1 } = 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$1(() => (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-9201c0de.js");
NodeBlob = (await Promise.resolve().then(() => __viteBrowserExternal)).Blob, global.WebSocket = I.WebSocket;
}
const { ws_protocol: C, http_protocol: P, host: b, space_id: k } = await process_endpoint(h, r), F = Math.random().toString(36).substring(2), x = {};
let y, p = {}, E = !1;
r && k && (E = await get_jwt(k, r));
async function $(I) {
if (y = I, p = map_names_to_ids((I == null ? void 0 : I.dependencies) || []), y.auth_required)
return {
config: y,
...S
};
try {
M = await G(y);
} catch (B) {
console.error(`Could not get api details: ${B.message}`);
}
return {
config: y,
...S
};
}
let M;
async function m(I) {
if (o && o(I), I.status === "running")
try {
y = await resolve_config(
t,
`${P}//${b}`,
r
);
const B = await $(y);
c(B);
} catch (B) {
console.error(B), o && o({
status: "error",
message: "Could not load this space.",
load_status: "error",
detail: "NOT_FOUND"
});
}
}
try {
y = await resolve_config(
t,
`${P}//${b}`,
r
);
const I = await $(y);
c(I);
} catch (I) {
console.error(I), k ? check_space_status(
k,
RE_SPACE_NAME.test(k) ? "space_name" : "subdomain",
m
) : o && o({
status: "error",
message: "Could not load this space.",
load_status: "error",
detail: "NOT_FOUND"
});
}
function N(I, B, ee) {
let Y = !1, q = !1, le;
if (typeof I == "number")
le = y.dependencies[I];
else {
const pe = I.replace(/^\//, "");
le = y.dependencies[p[pe]];
}
if (le.types.continuous)
throw new Error(
"Cannot call predict on this function as it may run forever. Use submit instead"
);
return new Promise((pe, we) => {
const be = D(I, B, ee);
let R;
be.on("data", (d) => {
q && (be.destroy(), pe(d)), Y = !0, R = d;
}).on("status", (d) => {
d.stage === "error" && we(d), d.stage === "complete" && (q = !0, Y && (be.destroy(), pe(R)));
});
});
}
function D(I, B, ee) {
let Y, q;
if (typeof I == "number")
Y = I, q = M.unnamed_endpoints[Y];
else {
const Q = I.replace(/^\//, "");
Y = p[Q], q = M.named_endpoints[I.trim()];
}
if (typeof Y != "number")
throw new Error(
"There is no endpoint matching that name of fn_index matching that number."
);
let le, pe, we = y.protocol ?? "sse";
const be = typeof I == "number" ? "/predict" : I;
let R, d = null, g = !1;
const f = {};
let v = "";
typeof window < "u" && (v = new URLSearchParams(window.location.search).toString()), l(
`${P}//${resolve_root(b, y.path, !0)}`,
B,
q,
r
).then((Q) => {
if (R = { data: Q || [], event_data: ee, fn_index: Y }, skip_queue(Y, y))
A({
type: "status",
endpoint: be,
stage: "pending",
queue: !1,
fn_index: Y,
time: /* @__PURE__ */ new Date()
}), i(
`${P}//${resolve_root(b, y.path, !0)}/run${be.startsWith("/") ? be : `/${be}`}${v ? "?" + v : ""}`,
{
...R,
session_hash: F
},
r
).then(([ue, me]) => {
const fe = w ? transform_output(
ue.data,
q,
y.root,
y.root_url
) : ue.data;
me == 200 ? (A({
type: "data",
endpoint: be,
fn_index: Y,
data: fe,
time: /* @__PURE__ */ new Date()
}), A({
type: "status",
endpoint: be,
fn_index: Y,
stage: "complete",
eta: ue.average_duration,
queue: !1,
time: /* @__PURE__ */ new Date()
})) : A({
type: "status",
stage: "error",
endpoint: be,
fn_index: Y,
message: ue.error,
queue: !1,
time: /* @__PURE__ */ new Date()
});
}).catch((ue) => {
A({
type: "status",
stage: "error",
message: ue.message,
endpoint: be,
fn_index: Y,
queue: !1,
time: /* @__PURE__ */ new Date()
});
});
else if (we == "ws") {
A({
type: "status",
stage: "pending",
queue: !0,
endpoint: be,
fn_index: Y,
time: /* @__PURE__ */ new Date()
});
let ue = new URL(`${C}://${resolve_root(
b,
y.path,
!0
)}
/queue/join${v ? "?" + v : ""}`);
E && ue.searchParams.set("__sign", E), le = e(ue), le.onclose = (me) => {
me.wasClean || A({
type: "status",
stage: "error",
broken: !0,
message: BROKEN_CONNECTION_MSG,
queue: !0,
endpoint: be,
fn_index: Y,
time: /* @__PURE__ */ new Date()
});
}, le.onmessage = function(me) {
const fe = JSON.parse(me.data), { type: Pe, status: Fe, data: Ee } = handle_message(
fe,
x[Y]
);
if (Pe === "update" && Fe && !g)
A({
type: "status",
endpoint: be,
fn_index: Y,
time: /* @__PURE__ */ new Date(),
...Fe
}), Fe.stage === "error" && le.close();
else if (Pe === "hash") {
le.send(JSON.stringify({ fn_index: Y, session_hash: F }));
return;
} else
Pe === "data" ? le.send(JSON.stringify({ ...R, session_hash: F })) : Pe === "complete" ? g = Fe : Pe === "log" ? A({
type: "log",
log: Ee.log,
level: Ee.level,
endpoint: be,
fn_index: Y
}) : Pe === "generating" && A({
type: "status",
time: /* @__PURE__ */ new Date(),
...Fe,
stage: Fe == null ? void 0 : Fe.stage,
queue: !0,
endpoint: be,
fn_index: Y
});
Ee && (A({
type: "data",
time: /* @__PURE__ */ new Date(),
data: w ? transform_output(
Ee.data,
q,
y.root,
y.root_url
) : Ee.data,
endpoint: be,
fn_index: Y
}), g && (A({
type: "status",
time: /* @__PURE__ */ new Date(),
...g,
stage: Fe == null ? void 0 : Fe.stage,
queue: !0,
endpoint: be,
fn_index: Y
}), le.close()));
}, semiver(y.version || "2.0.0", "3.6") < 0 && addEventListener(
"open",
() => le.send(JSON.stringify({ hash: F }))
);
} else {
A({
type: "status",
stage: "pending",
queue: !0,
endpoint: be,
fn_index: Y,
time: /* @__PURE__ */ new Date()
});
var ce = new URLSearchParams({
fn_index: Y.toString(),
session_hash: F
}).toString();
let ue = new URL(
`${P}//${resolve_root(
b,
y.path,
!0
)}/queue/join?${ce}`
);
pe = new EventSource(ue), pe.onmessage = async function(me) {
const fe = JSON.parse(me.data), { type: Pe, status: Fe, data: Ee } = handle_message(
fe,
x[Y]
);
if (Pe === "update" && Fe && !g)
A({
type: "status",
endpoint: be,
fn_index: Y,
time: /* @__PURE__ */ new Date(),
...Fe
}), Fe.stage === "error" && pe.close();
else if (Pe === "data") {
d = fe.event_id;
let [De, _e] = await i(
`${P}//${resolve_root(
b,
y.path,
!0
)}/queue/data`,
{
...R,
session_hash: F,
event_id: d
},
r
);
_e !== 200 && (A({
type: "status",
stage: "error",
message: BROKEN_CONNECTION_MSG,
queue: !0,
endpoint: be,
fn_index: Y,
time: /* @__PURE__ */ new Date()
}), pe.close());
} else
Pe === "complete" ? g = Fe : Pe === "log" ? A({
type: "log",
log: Ee.log,
level: Ee.level,
endpoint: be,
fn_index: Y
}) : Pe === "generating" && A({
type: "status",
time: /* @__PURE__ */ new Date(),
...Fe,
stage: Fe == null ? void 0 : Fe.stage,
queue: !0,
endpoint: be,
fn_index: Y
});
Ee && (A({
type: "data",
time: /* @__PURE__ */ new Date(),
data: w ? transform_output(
Ee.data,
q,
y.root,
y.root_url
) : Ee.data,
endpoint: be,
fn_index: Y
}), g && (A({
type: "status",
time: /* @__PURE__ */ new Date(),
...g,
stage: Fe == null ? void 0 : Fe.stage,
queue: !0,
endpoint: be,
fn_index: Y
}), pe.close()));
};
}
});
function A(Q) {
const ue = f[Q.type] || [];
ue == null || ue.forEach((me) => me(Q));
}
function O(Q, ce) {
const ue = f, me = ue[Q] || [];
return ue[Q] = me, me == null || me.push(ce), { on: O, off: H, cancel: z, destroy: ae };
}
function H(Q, ce) {
const ue = f;
let me = ue[Q] || [];
return me = me == null ? void 0 : me.filter((fe) => fe !== ce), ue[Q] = me, { on: O, off: H, cancel: z, destroy: ae };
}
async function z() {
const Q = {
stage: "complete",
queue: !1,
time: /* @__PURE__ */ new Date()
};
g = Q, A({
...Q,
type: "status",
endpoint: be,
fn_index: Y
});
let ce = {};
we === "ws" ? (le && le.readyState === 0 ? le.addEventListener("open", () => {
le.close();
}) : le.close(), ce = { fn_index: Y, session_hash: F }) : (pe.close(), ce = { event_id: d });
try {
await t(
`${P}//${resolve_root(
b,
y.path,
!0
)}/reset`,
{
headers: { "Content-Type": "application/json" },
method: "POST",
body: JSON.stringify(ce)
}
);
} catch {
console.warn(
"The `/reset` endpoint could not be called. Subsequent endpoint results may be unreliable."
);
}
}
function ae() {
for (const Q in f)
f[Q].forEach((ce) => {
H(Q, ce);
});
}
return {
on: O,
off: H,
cancel: z,
destroy: ae
};
}
async function X(I, B, ee) {
var Y;
const q = { "Content-Type": "application/json" };
r && (q.Authorization = `Bearer ${r}`);
let le, pe = y.components.find(
(R) => R.id === I
);
(Y = pe == null ? void 0 : pe.props) != null && Y.root_url ? le = pe.props.root_url : le = `${P}//${resolve_root(
b,
y.path,
!0
)}/`;
const we = await t(
`${le}component_server/`,
{
method: "POST",
body: JSON.stringify({
data: ee,
component_id: I,
fn_name: B,
session_hash: F
}),
headers: q
}
);
if (!we.ok)
throw new Error(
"Could not connect to component server: " + we.statusText
);
return await we.json();
}
async function G(I) {
if (M)
return M;
const B = { "Content-Type": "application/json" };
r && (B.Authorization = `Bearer ${r}`);
let ee;
if (semiver(I.version || "2.0.0", "3.30") < 0 ? ee = await t(
"https://gradio-space-api-fetcher-v2.hf.space/api",
{
method: "POST",
body: JSON.stringify({
serialize: !1,
config: JSON.stringify(I)
}),
headers: B
}
) : ee = await t(`${I.root}/info`, {
headers: B
}), !ee.ok)
throw new Error(BROKEN_CONNECTION_MSG);
let Y = await ee.json();
return "api" in Y && (Y = Y.api), Y.named_endpoints["/predict"] && !Y.unnamed_endpoints[0] && (Y.unnamed_endpoints[0] = Y.named_endpoints["/predict"]), transform_api_info(Y, I, p);
}
});
}
async function l(h, _, c, o) {
const r = await walk_and_store_blobs(
_,
void 0,
[],
!0,
c
);
return Promise.all(
r.map(async ({ path: T, blob: S, type: w }) => {
if (S) {
const C = (await n(h, [S], o)).files[0];
return { path: T, file_url: C, type: w, name: S == null ? void 0 : S.name };
}
return { path: T, type: w };
})
).then((T) => (T.forEach(({ path: S, file_url: w, type: C, name: P }) => {
if (C === "Gallery")
update_object(_, w, S);
else if (w) {
const b = new FileData({ path: w, orig_name: P });
update_object(_, b, S);
}
}), _));
}
}
const { post_data, upload_files, client, handle_blob } = api_factory(
fetch,
(...t) => new WebSocket(...t)
);
function transform_output(t, e, i, n) {
return t.map((s, l) => {
var h, _, c, o;
return ((_ = (h = e == null ? void 0 : e.returns) == null ? void 0 : h[l]) == null ? void 0 : _.component) === "File" ? normalise_file(s, i, n) : ((o = (c = e == null ? void 0 : e.returns) == null ? void 0 : c[l]) == null ? void 0 : o.component) === "Gallery" ? s.map((r) => Array.isArray(r) ? [normalise_file(r[0], i, n), r[1]] : [normalise_file(r, i, n), null]) : typeof s == "object" && s.path ? normalise_file(s, i, n) : s;
});
}
function get_type(t, e, i, n) {
switch (t.type) {
case "string":
return "string";
case "boolean":
return "boolean";
case "number":
return "number";
}
if (i === "JSONSerializable" || i === "StringSerializable")
return "any";
if (i === "ListStringSerializable")
return "string[]";
if (e === "Image")
return n === "parameter" ? "Blob | File | Buffer" : "string";
if (i === "FileSerializable")
return (t == null ? void 0 : t.type) === "array" ? n === "parameter" ? "(Blob | File | Buffer)[]" : "{ name: string; data: string; size?: number; is_file?: boolean; orig_name?: string}[]" : n === "parameter" ? "Blob | File | Buffer" : "{ name: string; data: string; size?: number; is_file?: boolean; orig_name?: string}";
if (i === "GallerySerializable")
return n === "parameter" ? "[(Blob | File | Buffer), (string | null)][]" : "[{ name: string; data: string; size?: number; is_file?: boolean; orig_name?: string}, (string | null))][]";
}
function get_description(t, e) {
return e === "GallerySerializable" ? "array of [file, label] tuples" : e === "ListStringSerializable" ? "array of strings" : e === "FileSerializable" ? "array of files or single file" : t.description;
}
function transform_api_info(t, e, i) {
const n = {
named_endpoints: {},
unnamed_endpoints: {}
};
for (const s in t) {
const l = t[s];
for (const h in l) {
const _ = e.dependencies[h] ? h : i[h.replace("/", "")], c = l[h];
n[s][h] = {}, n[s][h].parameters = {}, n[s][h].returns = {}, n[s][h].type = e.dependencies[_].types, n[s][h].parameters = c.parameters.map(
({ label: o, component: r, type: T, serializer: S }) => ({
label: o,
component: r,
type: get_type(T, r, S, "parameter"),
description: get_description(T, S)
})
), n[s][h].returns = c.returns.map(
({ label: o, component: r, type: T, serializer: S }) => ({
label: o,
component: r,
type: get_type(T, r, S, "return"),
description: get_description(T, S)
})
);
}
}
return n;
}
async function get_jwt(t, e) {
try {
return (await (await fetch(`https://huggingface.co/api/spaces/${t}/jwt`, {
headers: {
Authorization: `Bearer ${e}`
}
})).json()).token || !1;
} catch (i) {
return console.error(i), !1;
}
}
function update_object(t, e, i) {
for (; i.length > 1; )
t = t[i.shift()];
t[i.shift()] = e;
}
async function walk_and_store_blobs(t, e = void 0, i = [], n = !1, s = void 0) {
if (Array.isArray(t)) {
let l = [];
return await Promise.all(
t.map(async (h, _) => {
var c;
let o = i.slice();
o.push(_);
const r = await walk_and_store_blobs(
t[_],
n ? ((c = s == null ? void 0 : s.parameters[_]) == null ? void 0 : c.component) || void 0 : e,
o,
!1,
s
);
l = l.concat(r);
})
), l;
} else {
if (globalThis.Buffer && t instanceof globalThis.Buffer)
return [
{
path: i,
blob: e === "Image" ? !1 : new NodeBlob([t]),
type: e
}
];
if (typeof t == "object") {
let l = [];
for (let h in t)
if (t.hasOwnProperty(h)) {
let _ = i.slice();
_.push(h), l = l.concat(
await walk_and_store_blobs(
t[h],
void 0,
_,
!1,
s
)
);
}
return l;
}
}
return [];
}
function skip_queue(t, e) {
var i, n, s, l;
return !(((n = (i = e == null ? void 0 : e.dependencies) == null ? void 0 : i[t]) == null ? void 0 : n.queue) === null ? e.enable_queue : (l = (s = e == null ? void 0 : e.dependencies) == null ? void 0 : s[t]) != null && l.queue) || !1;
}
async function resolve_config(t, e, i) {
const n = {};
if (i && (n.Authorization = `Bearer ${i}`), typeof window < "u" && window.gradio_config && location.origin !== "http://localhost:9876" && !window.gradio_config.dev_mode) {
const s = window.gradio_config.root, l = window.gradio_config;
return l.root = resolve_root(e, l.root, !1), { ...l, path: s };
} else if (e) {
let s = await t(`${e}/config`, {
headers: n
});
if (s.status === 200) {
const l = await s.json();
return l.path = l.path ?? "", l.root = e, l;
}
throw new Error("Could not get config.");
}
throw new Error("No config or app endpoint found");
}
async function check_space_status(t, e, i) {
let n = e === "subdomain" ? `https://huggingface.co/api/spaces/by-subdomain/${t}` : `https://huggingface.co/api/spaces/${t}`, s, l;
try {
if (s = await fetch(n), l = s.status, l !== 200)
throw new Error();
s = await s.json();
} catch {
i({
status: "error",
load_status: "error",
message: "Could not get space status",
detail: "NOT_FOUND"
});
return;
}
if (!s || l !== 200)
return;
const {
runtime: { stage: h },
id: _
} = s;
switch (h) {
case "STOPPED":
case "SLEEPING":
i({
status: "sleeping",
load_status: "pending",
message: "Space is asleep. Waking it up...",
detail: h
}), setTimeout(() => {
check_space_status(t, e, i);
}, 1e3);
break;
case "PAUSED":
i({
status: "paused",
load_status: "error",
message: "This space has been paused by the author. If you would like to try this demo, consider duplicating the space.",
detail: h,
discussions_enabled: await discussions_enabled(_)
});
break;
case "RUNNING":
case "RUNNING_BUILDING":
i({
status: "running",
load_status: "complete",
message: "",
detail: h
});
break;
case "BUILDING":
i({
status: "building",
load_status: "pending",
message: "Space is building...",
detail: h
}), setTimeout(() => {
check_space_status(t, e, i);
}, 1e3);
break;
default:
i({
status: "space_error",
load_status: "error",
message: "This space is experiencing an issue.",
detail: h,
discussions_enabled: await discussions_enabled(_)
});
break;
}
}
function handle_message(t, e) {
switch (t.msg) {
case "send_data":
return { type: "data" };
case "send_hash":
return { type: "hash" };
case "queue_full":
return {
type: "update",
status: {
queue: !0,
message: QUEUE_FULL_MSG,
stage: "error",
code: t.code,
success: t.success
}
};
case "estimation":
return {
type: "update",
status: {
queue: !0,
stage: e || "pending",
code: t.code,
size: t.queue_size,
position: t.rank,
eta: t.rank_eta,
success: t.success
}
};
case "progress":
return {
type: "update",
status: {
queue: !0,
stage: "pending",
code: t.code,
progress_data: t.progress_data,
success: t.success
}
};
case "log":
return { type: "log", data: t };
case "process_generating":
return {
type: "generating",
status: {
queue: !0,
message: t.success ? null : t.output.error,
stage: t.success ? "generating" : "error",
code: t.code,
progress_data: t.progress_data,
eta: t.average_duration
},
data: t.success ? t.output : null
};
case "process_completed":
return "error" in t.output ? {
type: "update",
status: {
queue: !0,
message: t.output.error,
stage: "error",
code: t.code,
success: t.success
}
} : {
type: "complete",
status: {
queue: !0,
message: t.success ? void 0 : t.output.error,
stage: t.success ? "complete" : "error",
code: t.code,
progress_data: t.progress_data,
eta: t.output.average_duration
},
data: t.success ? t.output : null
};
case "process_starts":
return {
type: "update",
status: {
queue: !0,
stage: "pending",
code: t.code,
size: t.rank,
position: 0,
success: t.success
}
};
}
return { type: "none", status: { stage: "error", queue: !0 } };
}
function getDefaultExportFromCjs(t) {
return t && t.__esModule && Object.prototype.hasOwnProperty.call(t, "default") ? t.default : t;
}
function getAugmentedNamespace(t) {
if (t.__esModule)
return t;
var e = t.default;
if (typeof e == "function") {
var i = function n() {
return this instanceof n ? Reflect.construct(e, arguments, this.constructor) : e.apply(this, arguments);
};
i.prototype = e.prototype;
} else
i = {};
return Object.defineProperty(i, "__esModule", { value: !0 }), Object.keys(t).forEach(function(n) {
var s = Object.getOwnPropertyDescriptor(t, n);
Object.defineProperty(i, n, s.get ? s : {
enumerable: !0,
get: function() {
return t[n];
}
});
}), i;
}
var isMergeableObject = function(e) {
return isNonNullObject(e) && !isSpecial(e);
};
function isNonNullObject(t) {
return !!t && typeof t == "object";
}
function isSpecial(t) {
var e = Object.prototype.toString.call(t);
return e === "[object RegExp]" || e === "[object Date]" || isReactElement(t);
}
var canUseSymbol = typeof Symbol == "function" && Symbol.for, REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for("react.element") : 60103;
function isReactElement(t) {
return t.$$typeof === REACT_ELEMENT_TYPE;
}
function emptyTarget(t) {
return Array.isArray(t) ? [] : {};
}
function cloneUnlessOtherwiseSpecified(t, e) {
return e.clone !== !1 && e.isMergeableObject(t) ? deepmerge(emptyTarget(t), t, e) : t;
}
function defaultArrayMerge(t, e, i) {
return t.concat(e).map(function(n) {
return cloneUnlessOtherwiseSpecified(n, i);
});
}
function getMergeFunction(t, e) {
if (!e.customMerge)
return deepmerge;
var i = e.customMerge(t);
return typeof i == "function" ? i : deepmerge;
}
function getEnumerableOwnPropertySymbols(t) {
return Object.getOwnPropertySymbols ? Object.getOwnPropertySymbols(t).filter(function(e) {
return Object.propertyIsEnumerable.call(t, e);
}) : [];
}
function getKeys(t) {
return Object.keys(t).concat(getEnumerableOwnPropertySymbols(t));
}
function propertyIsOnObject(t, e) {
try {
return e in t;
} catch {
return !1;
}
}
function propertyIsUnsafe(t, e) {
return propertyIsOnObject(t, e) && !(Object.hasOwnProperty.call(t, e) && Object.propertyIsEnumerable.call(t, e));
}
function mergeObject(t, e, i) {
var n = {};
return i.isMergeableObject(t) && getKeys(t).forEach(function(s) {
n[s] = cloneUnlessOtherwiseSpecified(t[s], i);
}), getKeys(e).forEach(function(s) {
propertyIsUnsafe(t, s) || (propertyIsOnObject(t, s) && i.isMergeableObject(e[s]) ? n[s] = getMergeFunction(s, i)(t[s], e[s], i) : n[s] = cloneUnlessOtherwiseSpecified(e[s], i));
}), n;
}
function deepmerge(t, e, i) {
i = i || {}, i.arrayMerge = i.arrayMerge || defaultArrayMerge, i.isMergeableObject = i.isMergeableObject || isMergeableObject, i.cloneUnlessOtherwiseSpecified = cloneUnlessOtherwiseSpecified;
var n = Array.isArray(e), s = Array.isArray(t), l = n === s;
return l ? n ? i.arrayMerge(t, e, i) : mergeObject(t, e, i) : cloneUnlessOtherwiseSpecified(e, i);
}
deepmerge.all = function(e, i) {
if (!Array.isArray(e))
throw new Error("first argument should be an array");
return e.reduce(function(n, s) {
return deepmerge(n, s, i);
}, {});
};
var deepmerge_1 = deepmerge, cjs = deepmerge_1;
const deepmerge$1 = /* @__PURE__ */ getDefaultExportFromCjs(cjs);
var extendStatics = function(t, e) {
return extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(i, n) {
i.__proto__ = n;
} || function(i, n) {
for (var s in n)
Object.prototype.hasOwnProperty.call(n, s) && (i[s] = n[s]);
}, extendStatics(t, e);
};
function __extends(t, e) {
if (typeof e != "function" && e !== null)
throw new TypeError("Class extends value " + String(e) + " is not a constructor or null");
extendStatics(t, e);
function i() {
this.constructor = t;
}
t.prototype = e === null ? Object.create(e) : (i.prototype = e.prototype, new i());
}
var __assign = function() {
return __assign = Object.assign || function(e) {
for (var i, n = 1, s = arguments.length; n < s; n++) {
i = arguments[n];
for (var l in i)
Object.prototype.hasOwnProperty.call(i, l) && (e[l] = i[l]);
}
return e;
}, __assign.apply(this, arguments);
};
function __spreadArray(t, e, i) {
if (i || arguments.length === 2)
for (var n = 0, s = e.length, l; n < s; n++)
(l || !(n in e)) && (l || (l = Array.prototype.slice.call(e, 0, n)), l[n] = e[n]);
return t.concat(l || Array.prototype.slice.call(e));
}
typeof SuppressedError == "function" && SuppressedError;
var ErrorKind;
(function(t) {
t[t.EXPECT_ARGUMENT_CLOSING_BRACE = 1] = "EXPECT_ARGUMENT_CLOSING_BRACE", t[t.EMPTY_ARGUMENT = 2] = "EMPTY_ARGUMENT", t[t.MALFORMED_ARGUMENT = 3] = "MALFORMED_ARGUMENT", t[t.EXPECT_ARGUMENT_TYPE = 4] = "EXPECT_ARGUMENT_TYPE", t[t.INVALID_ARGUMENT_TYPE = 5] = "INVALID_ARGUMENT_TYPE", t[t.EXPECT_ARGUMENT_STYLE = 6] = "EXPECT_ARGUMENT_STYLE", t[t.INVALID_NUMBER_SKELETON = 7] = "INVALID_NUMBER_SKELETON", t[t.INVALID_DATE_TIME_SKELETON = 8] = "INVALID_DATE_TIME_SKELETON", t[t.EXPECT_NUMBER_SKELETON = 9] = "EXPECT_NUMBER_SKELETON", t[t.EXPECT_DATE_TIME_SKELETON = 10] = "EXPECT_DATE_TIME_SKELETON", t[t.UNCLOSED_QUOTE_IN_ARGUMENT_STYLE = 11] = "UNCLOSED_QUOTE_IN_ARGUMENT_STYLE", t[t.EXPECT_SELECT_ARGUMENT_OPTIONS = 12] = "EXPECT_SELECT_ARGUMENT_OPTIONS", t[t.EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE = 13] = "EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE", t[t.INVALID_PLURAL_ARGUMENT_OFFSET_VALUE = 14] = "INVALID_PLURAL_ARGUMENT_OFFSET_VALUE", t[t.EXPECT_SELECT_ARGUMENT_SELECTOR = 15] = "EXPECT_SELECT_ARGUMENT_SELECTOR", t[t.EXPECT_PLURAL_ARGUMENT_SELECTOR = 16] = "EXPECT_PLURAL_ARGUMENT_SELECTOR", t[t.EXPECT_SELECT_ARGUMENT_SELECTOR_FRAGMENT = 17] = "EXPECT_SELECT_ARGUMENT_SELECTOR_FRAGMENT", t[t.EXPECT_PLURAL_ARGUMENT_SELECTOR_FRAGMENT = 18] = "EXPECT_PLURAL_ARGUMENT_SELECTOR_FRAGMENT", t[t.INVALID_PLURAL_ARGUMENT_SELECTOR = 19] = "INVALID_PLURAL_ARGUMENT_SELECTOR", t[t.DUPLICATE_PLURAL_ARGUMENT_SELECTOR = 20] = "DUPLICATE_PLURAL_ARGUMENT_SELECTOR", t[t.DUPLICATE_SELECT_ARGUMENT_SELECTOR = 21] = "DUPLICATE_SELECT_ARGUMENT_SELECTOR", t[t.MISSING_OTHER_CLAUSE = 22] = "MISSING_OTHER_CLAUSE", t[t.INVALID_TAG = 23] = "INVALID_TAG", t[t.INVALID_TAG_NAME = 25] = "INVALID_TAG_NAME", t[t.UNMATCHED_CLOSING_TAG = 26] = "UNMATCHED_CLOSING_TAG", t[t.UNCLOSED_TAG = 27] = "UNCLOSED_TAG";
})(ErrorKind || (ErrorKind = {}));
var TYPE;
(function(t) {
t[t.literal = 0] = "literal", t[t.argument = 1] = "argument", t[t.number = 2] = "number", t[t.date = 3] = "date", t[t.time = 4] = "time", t[t.select = 5] = "select", t[t.plural = 6] = "plural", t[t.pound = 7] = "pound", t[t.tag = 8] = "tag";
})(TYPE || (TYPE = {}));
var SKELETON_TYPE;
(function(t) {
t[t.number = 0] = "number", t[t.dateTime = 1] = "dateTime";
})(SKELETON_TYPE || (SKELETON_TYPE = {}));
function isLiteralElement(t) {
return t.type === TYPE.literal;
}
function isArgumentElement(t) {
return t.type === TYPE.argument;
}
function isNumberElement(t) {
return t.type === TYPE.number;
}
function isDateElement(t) {
return t.type === TYPE.date;
}
function isTimeElement(t) {
return t.type === TYPE.time;
}
function isSelectElement(t) {
return t.type === TYPE.select;
}
function isPluralElement(t) {
return t.type === TYPE.plural;
}
function isPoundElement(t) {
return t.type === TYPE.pound;
}
function isTagElement(t) {
return t.type === TYPE.tag;
}
function isNumberSkeleton(t) {
return !!(t && typeof t == "object" && t.type === SKELETON_TYPE.number);
}
function isDateTimeSkeleton(t) {
return !!(t && typeof t == "object" && t.type === SKELETON_TYPE.dateTime);
}
var SPACE_SEPARATOR_REGEX = /[ \xA0\u1680\u2000-\u200A\u202F\u205F\u3000]/, DATE_TIME_REGEX = /(?:[Eec]{1,6}|G{1,5}|[Qq]{1,5}|(?:[yYur]+|U{1,5})|[ML]{1,5}|d{1,2}|D{1,3}|F{1}|[abB]{1,5}|[hkHK]{1,2}|w{1,2}|W{1}|m{1,2}|s{1,2}|[zZOvVxX]{1,4})(?=([^']*'[^']*')*[^']*$)/g;
function parseDateTimeSkeleton(t) {
var e = {};
return t.replace(DATE_TIME_REGEX, function(i) {
var n = i.length;
switch (i[0]) {
case "G":
e.era = n === 4 ? "long" : n === 5 ? "narrow" : "short";
break;
case "y":
e.year = n === 2 ? "2-digit" : "numeric";
break;
case "Y":
case "u":
case "U":
case "r":
throw new RangeError("`Y/u/U/r` (year) patterns are not supported, use `y` instead");
case "q":
case "Q":
throw new RangeError("`q/Q` (quarter) patterns are not supported");
case "M":
case "L":
e.month = ["numeric", "2-digit", "short", "long", "narrow"][n - 1];
break;
case "w":
case "W":
throw new RangeError("`w/W` (week) patterns are not supported");
case "d":
e.day = ["numeric", "2-digit"][n - 1];
break;
case "D":
case "F":
case "g":
throw new RangeError("`D/F/g` (day) patterns are not supported, use `d` instead");
case "E":
e.weekday = n === 4 ? "short" : n === 5 ? "narrow" : "short";
break;
case "e":
if (n < 4)
throw new RangeError("`e..eee` (weekday) patterns are not supported");
e.weekday = ["short", "long", "narrow", "short"][n - 4];
break;
case "c":
if (n < 4)
throw new RangeError("`c..ccc` (weekday) patterns are not supported");
e.weekday = ["short", "long", "narrow", "short"][n - 4];
break;
case "a":
e.hour12 = !0;
break;
case "b":
case "B":
throw new RangeError("`b/B` (period) patterns are not supported, use `a` instead");
case "h":
e.hourCycle = "h12", e.hour = ["numeric", "2-digit"][n - 1];
break;
case "H":
e.hourCycle = "h23", e.hour = ["numeric", "2-digit"][n - 1];
break;
case "K":
e.hourCycle = "h11", e.hour = ["numeric", "2-digit"][n - 1];
break;
case "k":
e.hourCycle = "h24", e.hour = ["numeric", "2-digit"][n - 1];
break;
case "j":
case "J":
case "C":
throw new RangeError("`j/J/C` (hour) patterns are not supported, use `h/H/K/k` instead");
case "m":
e.minute = ["numeric", "2-digit"][n - 1];
break;
case "s":
e.second = ["numeric", "2-digit"][n - 1];
break;
case "S":
case "A":
throw new RangeError("`S/A` (second) patterns are not supported, use `s` instead");
case "z":
e.timeZoneName = n < 4 ? "short" : "long";
break;
case "Z":
case "O":
case "v":
case "V":
case "X":
case "x":
throw new RangeError("`Z/O/v/V/X/x` (timeZone) patterns are not supported, use `z` instead");
}
return "";
}), e;
}
var WHITE_SPACE_REGEX = /[\t-\r \x85\u200E\u200F\u2028\u2029]/i;
function parseNumberSkeletonFromString(t) {
if (t.length === 0)
throw new Error("Number skeleton cannot be empty");
for (var e = t.split(WHITE_SPACE_REGEX).filter(function(S) {
return S.length > 0;
}), i = [], n = 0, s = e; n < s.length; n++) {
var l = s[n], h = l.split("/");
if (h.length === 0)
throw new Error("Invalid number skeleton");
for (var _ = h[0], c = h.slice(1), o = 0, r = c; o < r.length; o++) {
var T = r[o];
if (T.length === 0)
throw new Error("Invalid number skeleton");
}
i.push({ stem: _, options: c });
}
return i;
}
function icuUnitToEcma(t) {
return t.replace(/^(.*?)-/, "");
}
var FRACTION_PRECISION_REGEX = /^\.(?:(0+)(\*)?|(#+)|(0+)(#+))$/g, SIGNIFICANT_PRECISION_REGEX = /^(@+)?(\+|#+)?[rs]?$/g, INTEGER_WIDTH_REGEX = /(\*)(0+)|(#+)(0+)|(0+)/g, CONCISE_INTEGER_WIDTH_REGEX = /^(0+)$/;
function parseSignificantPrecision(t) {
var e = {};
return t[t.length - 1] === "r" ? e.roundingPriority = "morePrecision" : t[t.length - 1] === "s" && (e.roundingPriority = "lessPrecision"), t.replace(SIGNIFICANT_PRECISION_REGEX, function(i, n, s) {
return typeof s != "string" ? (e.minimumSignificantDigits = n.length, e.maximumSignificantDigits = n.length) : s === "+" ? e.minimumSignificantDigits = n.length : n[0] === "#" ? e.maximumSignificantDigits = n.length : (e.minimumSignificantDigits = n.length, e.maximumSignificantDigits = n.length + (typeof s == "string" ? s.length : 0)), "";
}), e;
}
function parseSign(t) {
switch (t) {
case "sign-auto":
return {
signDisplay: "auto"
};
case "sign-accounting":
case "()":
return {
currencySign: "accounting"
};
case "sign-always":
case "+!":
return {
signDisplay: "always"
};
case "sign-accounting-always":
case "()!":
return {
signDisplay: "always",
currencySign: "accounting"
};
case "sign-except-zero":
case "+?":
return {
signDisplay: "exceptZero"
};
case "sign-accounting-except-zero":
case "()?":
return {
signDisplay: "exceptZero",
currencySign: "accounting"
};
case "sign-never":
case "+_":
return {
signDisplay: "never"
};
}
}
function parseConciseScientificAndEngineeringStem(t) {
var e;
if (t[0] === "E" && t[1] === "E" ? (e = {
notation: "engineering"
}, t = t.slice(2)) : t[0] === "E" && (e = {
notation: "scientific"
}, t = t.slice(1)), e) {
var i = t.slice(0, 2);
if (i === "+!" ? (e.signDisplay = "always", t = t.slice(2)) : i === "+?" && (e.signDisplay = "exceptZero", t = t.slice(2)), !CONCISE_INTEGER_WIDTH_REGEX.test(t))
throw new Error("Malformed concise eng/scientific notation");
e.minimumIntegerDigits = t.length;
}
return e;
}
function parseNotationOptions(t) {
var e = {}, i = parseSign(t);
return i || e;
}
function parseNumberSkeleton(t) {
for (var e = {}, i = 0, n = t; i < n.length; i++) {
var s = n[i];
switch (s.stem) {
case "percent":
case "%":
e.style = "percent";
continue;
case "%x100":
e.style = "percent", e.scale = 100;
continue;
case "currency":
e.style = "currency", e.currency = s.options[0];
continue;
case "group-off":
case ",_":
e.useGrouping = !1;
continue;
case "precision-integer":
case ".":
e.maximumFractionDigits = 0;
continue;
case "measure-unit":
case "unit":
e.style = "unit", e.unit = icuUnitToEcma(s.options[0]);
continue;
case "compact-short":
case "K":
e.notation = "compact", e.compactDisplay = "short";
continue;
case "compact-long":
case "KK":
e.notation = "compact", e.compactDisplay = "long";
continue;
case "scientific":
e = __assign(__assign(__assign({}, e), { notation: "scientific" }), s.options.reduce(function(c, o) {
return __assign(__assign({}, c), parseNotationOptions(o));
}, {}));
continue;
case "engineering":
e = __assign(__assign(__assign({}, e), { notation: "engineering" }), s.options.reduce(function(c, o) {
return __assign(__assign({}, c), parseNotationOptions(o));
}, {}));
continue;
case "notation-simple":
e.notation = "standard";
continue;
case "unit-width-narrow":
e.currencyDisplay = "narrowSymbol", e.unitDisplay = "narrow";
continue;
case "unit-width-short":
e.currencyDisplay = "code", e.unitDisplay = "short";
continue;
case "unit-width-full-name":
e.currencyDisplay = "name", e.unitDisplay = "long";
continue;
case "unit-width-iso-code":
e.currencyDisplay = "symbol";
continue;
case "scale":
e.scale = parseFloat(s.options[0]);
continue;
case "integer-width":
if (s.options.length > 1)
throw new RangeError("integer-width stems only accept a single optional option");
s.options[0].replace(INTEGER_WIDTH_REGEX, function(c, o, r, T, S, w) {
if (o)
e.minimumIntegerDigits = r.length;
else {
if (T && S)
throw new Error("We currently do not support maximum integer digits");
if (w)
throw new Error("We currently do not support exact integer digits");
}
return "";
});
continue;
}
if (CONCISE_INTEGER_WIDTH_REGEX.test(s.stem)) {
e.minimumIntegerDigits = s.stem.length;
continue;
}
if (FRACTION_PRECISION_REGEX.test(s.stem)) {
if (s.options.length > 1)
throw new RangeError("Fraction-precision stems only accept a single optional option");
s.stem.replace(FRACTION_PRECISION_REGEX, function(c, o, r, T, S, w) {
return r === "*" ? e.minimumFractionDigits = o.length : T && T[0] === "#" ? e.maximumFractionDigits = T.length : S && w ? (e.minimumFractionDigits = S.length, e.maximumFractionDigits = S.length + w.length) : (e.minimumFractionDigits = o.length, e.maximumFractionDigits = o.length), "";
});
var l = s.options[0];
l === "w" ? e = __assign(__assign({}, e), { trailingZeroDisplay: "stripIfInteger" }) : l && (e = __assign(__assign({}, e), parseSignificantPrecision(l)));
continue;
}
if (SIGNIFICANT_PRECISION_REGEX.test(s.stem)) {
e = __assign(__assign({}, e), parseSignificantPrecision(s.stem));
continue;
}
var h = parseSign(s.stem);
h && (e = __assign(__assign({}, e), h));
var _ = parseConciseScientificAndEngineeringStem(s.stem);
_ && (e = __assign(__assign({}, e), _));
}
return e;
}
var timeData = {
AX: [
"H"
],
BQ: [
"H"
],
CP: [
"H"
],
CZ: [
"H"
],
DK: [
"H"
],
FI: [
"H"
],
ID: [
"H"
],
IS: [
"H"
],
ML: [
"H"
],
NE: [
"H"
],
RU: [
"H"
],
SE: [
"H"
],
SJ: [
"H"
],
SK: [
"H"
],
AS: [
"h",
"H"
],
BT: [
"h",
"H"
],
DJ: [
"h",
"H"
],
ER: [
"h",
"H"
],
GH: [
"h",
"H"
],
IN: [
"h",
"H"
],
LS: [
"h",
"H"
],
PG: [
"h",
"H"
],
PW: [
"h",
"H"
],
SO: [
"h",
"H"
],
TO: [
"h",
"H"
],
VU: [
"h",
"H"
],
WS: [
"h",
"H"
],
"001": [
"H",
"h"
],
AL: [
"h",
"H",
"hB"
],
TD: [
"h",
"H",
"hB"
],
"ca-ES": [
"H",
"h",
"hB"
],
CF: [
"H",
"h",
"hB"
],
CM: [
"H",
"h",
"hB"
],
"fr-CA": [
"H",
"h",
"hB"
],
"gl-ES": [
"H",
"h",
"hB"
],
"it-CH": [
"H",
"h",
"hB"
],
"it-IT": [
"H",
"h",
"hB"
],
LU: [
"H",
"h",
"hB"
],
NP: [
"H",
"h",
"hB"
],
PF: [
"H",
"h",
"hB"
],
SC: [
"H",
"h",
"hB"
],
SM: [
"H",
"h",
"hB"
],
SN: [
"H",
"h",
"hB"
],
TF: [
"H",
"h",
"hB"
],
VA: [
"H",
"h",
"hB"
],
CY: [
"h",
"H",
"hb",
"hB"
],
GR: [
"h",
"H",
"hb",
"hB"
],
CO: [
"h",
"H",
"hB",
"hb"
],
DO: [
"h",
"H",
"hB",
"hb"
],
KP: [
"h",
"H",
"hB",
"hb"
],
KR: [
"h",
"H",
"hB",
"hb"
],
NA: [
"h",
"H",
"hB",
"hb"
],
PA: [
"h",
"H",
"hB",
"hb"
],
PR: [
"h",
"H",
"hB",
"hb"
],
VE: [
"h",
"H",
"hB",
"hb"
],
AC: [
"H",
"h",
"hb",
"hB"
],
AI: [
"H",
"h",
"hb",
"hB"
],
BW: [
"H",
"h",
"hb",
"hB"
],
BZ: [
"H",
"h",
"hb",
"hB"
],
CC: [
"H",
"h",
"hb",
"hB"
],
CK: [
"H",
"h",
"hb",
"hB"
],
CX: [
"H",
"h",
"hb",
"hB"
],
DG: [
"H",
"h",
"hb",
"hB"
],
FK: [
"H",
"h",
"hb",
"hB"
],
GB: [
"H",
"h",
"hb",
"hB"
],
GG: [
"H",
"h",
"hb",
"hB"
],
GI: [
"H",
"h",
"hb",
"hB"
],
IE: [
"H",
"h",
"hb",
"hB"
],
IM: [
"H",
"h",
"hb",
"hB"
],
IO: [
"H",
"h",
"hb",
"hB"
],
JE: [
"H",
"h",
"hb",
"hB"
],
LT: [
"H",
"h",
"hb",
"hB"
],
MK: [
"H",
"h",
"hb",
"hB"
],
MN: [
"H",
"h",
"hb",
"hB"
],
MS: [
"H",
"h",
"hb",
"hB"
],
NF: [
"H",
"h",
"hb",
"hB"
],
NG: [
"H",
"h",
"hb",
"hB"
],
NR: [
"H",
"h",
"hb",
"hB"
],
NU: [
"H",
"h",
"hb",
"hB"
],
PN: [
"H",
"h",
"hb",
"hB"
],
SH: [
"H",
"h",
"hb",
"hB"
],
SX: [
"H",
"h",
"hb",
"hB"
],
TA: [
"H",
"h",
"hb",
"hB"
],
ZA: [
"H",
"h",
"hb",
"hB"
],
"af-ZA": [
"H",
"h",
"hB",
"hb"
],
AR: [
"H",
"h",
"hB",
"hb"
],
CL: [
"H",
"h",
"hB",
"hb"
],
CR: [
"H",
"h",
"hB",
"hb"
],
CU: [
"H",
"h",
"hB",
"hb"
],
EA: [
"H",
"h",
"hB",
"hb"
],
"es-BO": [
"H",
"h",
"hB",
"hb"
],
"es-BR": [
"H",
"h",
"hB",
"hb"
],
"es-EC": [
"H",
"h",
"hB",
"hb"
],
"es-ES": [
"H",
"h",
"hB",
"hb"
],
"es-GQ": [
"H",
"h",
"hB",
"hb"
],
"es-PE": [
"H",
"h",
"hB",
"hb"
],
GT: [
"H",
"h",
"hB",
"hb"
],
HN: [
"H",
"h",
"hB",
"hb"
],
IC: [
"H",
"h",
"hB",
"hb"
],
KG: [
"H",
"h",
"hB",
"hb"
],
KM: [
"H",
"h",
"hB",
"hb"
],
LK: [
"H",
"h",
"hB",
"hb"
],
MA: [
"H",
"h",
"hB",
"hb"
],
MX: [
"H",
"h",
"hB",
"hb"
],
NI: [
"H",
"h",
"hB",
"hb"
],
PY: [
"H",
"h",
"hB",
"hb"
],
SV: [
"H",
"h",
"hB",
"hb"
],
UY: [
"H",
"h",
"hB",
"hb"
],
JP: [
"H",
"h",
"K"
],
AD: [
"H",
"hB"
],
AM: [
"H",
"hB"
],
AO: [
"H",
"hB"
],
AT: [
"H",
"hB"
],
AW: [
"H",
"hB"
],
BE: [
"H",
"hB"
],
BF: [
"H",
"hB"
],
BJ: [
"H",
"hB"
],
BL: [
"H",
"hB"
],
BR: [
"H",
"hB"
],
CG: [
"H",
"hB"
],
CI: [
"H",
"hB"
],
CV: [
"H",
"hB"
],
DE: [
"H",
"hB"
],
EE: [
"H",
"hB"
],
FR: [
"H",
"hB"
],
GA: [
"H",
"hB"
],
GF: [
"H",
"hB"
],
GN: [
"H",
"hB"
],
GP: [
"H",
"hB"
],
GW: [
"H",
"hB"
],
HR: [
"H",
"hB"
],
IL: [
"H",
"hB"
],
IT: [
"H",
"hB"
],
KZ: [
"H",
"hB"
],
MC: [
"H",
"hB"
],
MD: [
"H",
"hB"
],
MF: [
"H",
"hB"
],
MQ: [
"H",
"hB"
],
MZ: [
"H",
"hB"
],
NC: [
"H",
"hB"
],
NL: [
"H",
"hB"
],
PM: [
"H",
"hB"
],
PT: [
"H",
"hB"
],
RE: [
"H",
"hB"
],
RO: [
"H",
"hB"
],
SI: [
"H",
"hB"
],
SR: [
"H",
"hB"
],
ST: [
"H",
"hB"
],
TG: [
"H",
"hB"
],
TR: [
"H",
"hB"
],
WF: [
"H",
"hB"
],
YT: [
"H",
"hB"
],
BD: [
"h",
"hB",
"H"
],
PK: [
"h",
"hB",
"H"
],
AZ: [
"H",
"hB",
"h"
],
BA: [
"H",
"hB",
"h"
],
BG: [
"H",
"hB",
"h"
],
CH: [
"H",
"hB",
"h"
],
GE: [
"H",
"hB",
"h"
],
LI: [
"H",
"hB",
"h"
],
ME: [
"H",
"hB",
"h"
],
RS: [
"H",
"hB",
"h"
],
UA: [
"H",
"hB",
"h"
],
UZ: [
"H",
"hB",
"h"
],
XK: [
"H",
"hB",
"h"
],
AG: [
"h",
"hb",
"H",
"hB"
],
AU: [
"h",
"hb",
"H",
"hB"
],
BB: [
"h",
"hb",
"H",
"hB"
],
BM: [
"h",
"hb",
"H",
"hB"
],
BS: [
"h",
"hb",
"H",
"hB"
],
CA: [
"h",
"hb",
"H",
"hB"
],
DM: [
"h",
"hb",
"H",
"hB"
],
"en-001": [
"h",
"hb",
"H",
"hB"
],
FJ: [
"h",
"hb",
"H",
"hB"
],
FM: [
"h",
"hb",
"H",
"hB"
],
GD: [
"h",
"hb",
"H",
"hB"
],
GM: [
"h",
"hb",
"H",
"hB"
],
GU: [
"h",
"hb",
"H",
"hB"
],
GY: [
"h",
"hb",
"H",
"hB"
],
JM: [
"h",
"hb",
"H",
"hB"
],
KI: [
"h",
"hb",
"H",
"hB"
],
KN: [
"h",
"hb",
"H",
"hB"
],
KY: [
"h",
"hb",
"H",
"hB"
],
LC: [
"h",
"hb",
"H",
"hB"
],
LR: [
"h",
"hb",
"H",
"hB"
],
MH: [
"h",
"hb",
"H",
"hB"
],
MP: [
"h",
"hb",
"H",
"hB"
],
MW: [
"h",
"hb",
"H",
"hB"
],
NZ: [
"h",
"hb",
"H",
"hB"
],
SB: [
"h",
"hb",
"H",
"hB"
],
SG: [
"h",
"hb",
"H",
"hB"
],
SL: [
"h",
"hb",
"H",
"hB"
],
SS: [
"h",
"hb",
"H",
"hB"
],
SZ: [
"h",
"hb",
"H",
"hB"
],
TC: [
"h",
"hb",
"H",
"hB"
],
TT: [
"h",
"hb",
"H",
"hB"
],
UM: [
"h",
"hb",
"H",
"hB"
],
US: [
"h",
"hb",
"H",
"hB"
],
VC: [
"h",
"hb",
"H",
"hB"
],
VG: [
"h",
"hb",
"H",
"hB"
],
VI: [
"h",
"hb",
"H",
"hB"
],
ZM: [
"h",
"hb",
"H",
"hB"
],
BO: [
"H",
"hB",
"h",
"hb"
],
EC: [
"H",
"hB",
"h",
"hb"
],
ES: [
"H",
"hB",
"h",
"hb"
],
GQ: [
"H",
"hB",
"h",
"hb"
],
PE: [
"H",
"hB",
"h",
"hb"
],
AE: [
"h",
"hB",
"hb",
"H"
],
"ar-001": [
"h",
"hB",
"hb",
"H"
],
BH: [
"h",
"hB",
"hb",
"H"
],
DZ: [
"h",
"hB",
"hb",
"H"
],
EG: [
"h",
"hB",
"hb",
"H"
],
EH: [
"h",
"hB",
"hb",
"H"
],
HK: [
"h",
"hB",
"hb",
"H"
],
IQ: [
"h",
"hB",
"hb",
"H"
],
JO: [
"h",
"hB",
"hb",
"H"
],
KW: [
"h",
"hB",
"hb",
"H"
],
LB: [
"h",
"hB",
"hb",
"H"
],
LY: [
"h",
"hB",
"hb",
"H"
],
MO: [
"h",
"hB",
"hb",
"H"
],
MR: [
"h",
"hB",
"hb",
"H"
],
OM: [
"h",
"hB",
"hb",
"H"
],
PH: [
"h",
"hB",
"hb",
"H"
],
PS: [
"h",
"hB",
"hb",
"H"
],
QA: [
"h",
"hB",
"hb",
"H"
],
SA: [
"h",
"hB",
"hb",
"H"
],
SD: [
"h",
"hB",
"hb",
"H"
],
SY: [
"h",
"hB",
"hb",
"H"
],
TN: [
"h",
"hB",
"hb",
"H"
],
YE: [
"h",
"hB",
"hb",
"H"
],
AF: [
"H",
"hb",
"hB",
"h"
],
LA: [
"H",
"hb",
"hB",
"h"
],
CN: [
"H",
"hB",
"hb",
"h"
],
LV: [
"H",
"hB",
"hb",
"h"
],
TL: [
"H",
"hB",
"hb",
"h"
],
"zu-ZA": [
"H",
"hB",
"hb",
"h"
],
CD: [
"hB",
"H"
],
IR: [
"hB",
"H"
],
"hi-IN": [
"hB",
"h",
"H"
],
"kn-IN": [
"hB",
"h",
"H"
],
"ml-IN": [
"hB",
"h",
"H"
],
"te-IN": [
"hB",
"h",
"H"
],
KH: [
"hB",
"h",
"H",
"hb"
],
"ta-IN": [
"hB",
"h",
"hb",
"H"
],
BN: [
"hb",
"hB",
"h",
"H"
],
MY: [
"hb",
"hB",
"h",
"H"
],
ET: [
"hB",
"hb",
"h",
"H"
],
"gu-IN": [
"hB",
"hb",
"h",
"H"
],
"mr-IN": [
"hB",
"hb",
"h",
"H"
],
"pa-IN": [
"hB",
"hb",
"h",
"H"
],
TW: [
"hB",
"hb",
"h",
"H"
],
KE: [
"hB",
"hb",
"H",
"h"
],
MM: [
"hB",
"hb",
"H",
"h"
],
TZ: [
"hB",
"hb",
"H",
"h"
],
UG: [
"hB",
"hb",
"H",
"h"
]
};
function getBestPattern(t, e) {
for (var i = "", n = 0; n < t.length; n++) {
var s = t.charAt(n);
if (s === "j") {
for (var l = 0; n + 1 < t.length && t.charAt(n + 1) === s; )
l++, n++;
var h = 1 + (l & 1), _ = l < 2 ? 1 : 3 + (l >> 1), c = "a", o = getDefaultHourSymbolFromLocale(e);
for ((o == "H" || o == "k") && (_ = 0); _-- > 0; )
i += c;
for (; h-- > 0; )
i = o + i;
} else
s === "J" ? i += "H" : i += s;
}
return i;
}
function getDefaultHourSymbolFromLocale(t) {
var e = t.hourCycle;
if (e === void 0 && // @ts-ignore hourCycle(s) is not identified yet
t.hourCycles && // @ts-ignore
t.hourCycles.length && (e = t.hourCycles[0]), e)
switch (e) {
case "h24":
return "k";
case "h23":
return "H";
case "h12":
return "h";
case "h11":
return "K";
default:
throw new Error("Invalid hourCycle");
}
var i = t.language, n;
i !== "root" && (n = t.maximize().region);
var s = timeData[n || ""] || timeData[i || ""] || timeData["".concat(i, "-001")] || timeData["001"];
return s[0];
}
var _a, SPACE_SEPARATOR_START_REGEX = new RegExp("^".concat(SPACE_SEPARATOR_REGEX.source, "*")), SPACE_SEPARATOR_END_REGEX = new RegExp("".concat(SPACE_SEPARATOR_REGEX.source, "*$"));
function createLocation(t, e) {
return { start: t, end: e };
}
var hasNativeStartsWith = !!String.prototype.startsWith, hasNativeFromCodePoint = !!String.fromCodePoint, hasNativeFromEntries = !!Object.fromEntries, hasNativeCodePointAt = !!String.prototype.codePointAt, hasTrimStart = !!String.prototype.trimStart, hasTrimEnd = !!String.prototype.trimEnd, hasNativeIsSafeInteger = !!Number.isSafeInteger, isSafeInteger = hasNativeIsSafeInteger ? Number.isSafeInteger : function(t) {
return typeof t == "number" && isFinite(t) && Math.floor(t) === t && Math.abs(t) <= 9007199254740991;
}, REGEX_SUPPORTS_U_AND_Y = !0;
try {
var re = RE("([^\\p{White_Space}\\p{Pattern_Syntax}]*)", "yu");
REGEX_SUPPORTS_U_AND_Y = ((_a = re.exec("a")) === null || _a === void 0 ? void 0 : _a[0]) === "a";
} catch {
REGEX_SUPPORTS_U_AND_Y = !1;
}
var startsWith = hasNativeStartsWith ? (
// Native
function(e, i, n) {
return e.startsWith(i, n);
}
) : (
// For IE11
function(e, i, n) {
return e.slice(n, n + i.length) === i;
}
), fromCodePoint = hasNativeFromCodePoint ? String.fromCodePoint : (
// IE11
function() {
for (var e = [], i = 0; i < arguments.length; i++)
e[i] = arguments[i];
for (var n = "", s = e.length, l = 0, h; s > l; ) {
if (h = e[l++], h > 1114111)
throw RangeError(h + " is not a valid code point");
n += h < 65536 ? String.fromCharCode(h) : String.fromCharCode(((h -= 65536) >> 10) + 55296, h % 1024 + 56320);
}
return n;
}
), fromEntries = (
// native
hasNativeFromEntries ? Object.fromEntries : (
// Ponyfill
function(e) {
for (var i = {}, n = 0, s = e; n < s.length; n++) {
var l = s[n], h = l[0], _ = l[1];
i[h] = _;
}
return i;
}
)
), codePointAt = hasNativeCodePointAt ? (
// Native
function(e, i) {
return e.codePointAt(i);
}
) : (
// IE 11
function(e, i) {
var n = e.length;
if (!(i < 0 || i >= n)) {
var s = e.charCodeAt(i), l;
return s < 55296 || s > 56319 || i + 1 === n || (l = e.charCodeAt(i + 1)) < 56320 || l > 57343 ? s : (s - 55296 << 10) + (l - 56320) + 65536;
}
}
), trimStart = hasTrimStart ? (
// Native
function(e) {
return e.trimStart();
}
) : (
// Ponyfill
function(e) {
return e.replace(SPACE_SEPARATOR_START_REGEX, "");
}
), trimEnd = hasTrimEnd ? (
// Native
function(e) {
return e.trimEnd();
}
) : (
// Ponyfill
function(e) {
return e.replace(SPACE_SEPARATOR_END_REGEX, "");
}
);
function RE(t, e) {
return new RegExp(t, e);
}
var matchIdentifierAtIndex;
if (REGEX_SUPPORTS_U_AND_Y) {
var IDENTIFIER_PREFIX_RE_1 = RE("([^\\p{White_Space}\\p{Pattern_Syntax}]*)", "yu");
matchIdentifierAtIndex = function(e, i) {
var n;
IDENTIFIER_PREFIX_RE_1.lastIndex = i;
var s = IDENTIFIER_PREFIX_RE_1.exec(e);
return (n = s[1]) !== null && n !== void 0 ? n : "";
};
} else
matchIdentifierAtIndex = function(e, i) {
for (var n = []; ; ) {
var s = codePointAt(e, i);
if (s === void 0 || _isWhiteSpace(s) || _isPatternSyntax(s))
break;
n.push(s), i += s >= 65536 ? 2 : 1;
}
return fromCodePoint.apply(void 0, n);
};
var Parser = (
/** @class */
function() {
function t(e, i) {
i === void 0 && (i = {}), this.message = e, this.position = { offset: 0, line: 1, column: 1 }, this.ignoreTag = !!i.ignoreTag, this.locale = i.locale, this.requiresOtherClause = !!i.requiresOtherClause, this.shouldParseSkeletons = !!i.shouldParseSkeletons;
}
return t.prototype.parse = function() {
if (this.offset() !== 0)
throw Error("parser can only be used once");
return this.parseMessage(0, "", !1);
}, t.prototype.parseMessage = function(e, i, n) {
for (var s = []; !this.isEOF(); ) {
var l = this.char();
if (l === 123) {
var h = this.parseArgument(e, n);
if (h.err)
return h;
s.push(h.val);
} else {
if (l === 125 && e > 0)
break;
if (l === 35 && (i === "plural" || i === "selectordinal")) {
var _ = this.clonePosition();
this.bump(), s.push({
type: TYPE.pound,
location: createLocation(_, this.clonePosition())
});
} else if (l === 60 && !this.ignoreTag && this.peek() === 47) {
if (n)
break;
return this.error(ErrorKind.UNMATCHED_CLOSING_TAG, createLocation(this.clonePosition(), this.clonePosition()));
} else if (l === 60 && !this.ignoreTag && _isAlpha(this.peek() || 0)) {
var h = this.parseTag(e, i);
if (h.err)
return h;
s.push(h.val);
} else {
var h = this.parseLiteral(e, i);
if (h.err)
return h;
s.push(h.val);
}
}
}
return { val: s, err: null };
}, t.prototype.parseTag = function(e, i) {
var n = this.clonePosition();
this.bump();
var s = this.parseTagName();
if (this.bumpSpace(), this.bumpIf("/>"))
return {
val: {
type: TYPE.literal,
value: "<".concat(s, "/>"),
location: createLocation(n, this.clonePosition())
},
err: null
};
if (this.bumpIf(">")) {
var l = this.parseMessage(e + 1, i, !0);
if (l.err)
return l;
var h = l.val, _ = this.clonePosition();
if (this.bumpIf("")) {
if (this.isEOF() || !_isAlpha(this.char()))
return this.error(ErrorKind.INVALID_TAG, createLocation(_, this.clonePosition()));
var c = this.clonePosition(), o = this.parseTagName();
return s !== o ? this.error(ErrorKind.UNMATCHED_CLOSING_TAG, createLocation(c, this.clonePosition())) : (this.bumpSpace(), this.bumpIf(">") ? {
val: {
type: TYPE.tag,
value: s,
children: h,
location: createLocation(n, this.clonePosition())
},
err: null
} : this.error(ErrorKind.INVALID_TAG, createLocation(_, this.clonePosition())));
} else
return this.error(ErrorKind.UNCLOSED_TAG, createLocation(n, this.clonePosition()));
} else
return this.error(ErrorKind.INVALID_TAG, createLocation(n, this.clonePosition()));
}, t.prototype.parseTagName = function() {
var e = this.offset();
for (this.bump(); !this.isEOF() && _isPotentialElementNameChar(this.char()); )
this.bump();
return this.message.slice(e, this.offset());
}, t.prototype.parseLiteral = function(e, i) {
for (var n = this.clonePosition(), s = ""; ; ) {
var l = this.tryParseQuote(i);
if (l) {
s += l;
continue;
}
var h = this.tryParseUnquoted(e, i);
if (h) {
s += h;
continue;
}
var _ = this.tryParseLeftAngleBracket();
if (_) {
s += _;
continue;
}
break;
}
var c = createLocation(n, this.clonePosition());
return {
val: { type: TYPE.literal, value: s, location: c },
err: null
};
}, t.prototype.tryParseLeftAngleBracket = function() {
return !this.isEOF() && this.char() === 60 && (this.ignoreTag || // If at the opening tag or closing tag position, bail.
!_isAlphaOrSlash(this.peek() || 0)) ? (this.bump(), "<") : null;
}, t.prototype.tryParseQuote = function(e) {
if (this.isEOF() || this.char() !== 39)
return null;
switch (this.peek()) {
case 39:
return this.bump(), this.bump(), "'";
case 123:
case 60:
case 62:
case 125:
break;
case 35:
if (e === "plural" || e === "selectordinal")
break;
return null;
default:
return null;
}
this.bump();
var i = [this.char()];
for (this.bump(); !this.isEOF(); ) {
var n = this.char();
if (n === 39)
if (this.peek() === 39)
i.push(39), this.bump();
else {
this.bump();
break;
}
else
i.push(n);
this.bump();
}
return fromCodePoint.apply(void 0, i);
}, t.prototype.tryParseUnquoted = function(e, i) {
if (this.isEOF())
return null;
var n = this.char();
return n === 60 || n === 123 || n === 35 && (i === "plural" || i === "selectordinal") || n === 125 && e > 0 ? null : (this.bump(), fromCodePoint(n));
}, t.prototype.parseArgument = function(e, i) {
var n = this.clonePosition();
if (this.bump(), this.bumpSpace(), this.isEOF())
return this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(n, this.clonePosition()));
if (this.char() === 125)
return this.bump(), this.error(ErrorKind.EMPTY_ARGUMENT, createLocation(n, this.clonePosition()));
var s = this.parseIdentifierIfPossible().value;
if (!s)
return this.error(ErrorKind.MALFORMED_ARGUMENT, createLocation(n, this.clonePosition()));
if (this.bumpSpace(), this.isEOF())
return this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(n, this.clonePosition()));
switch (this.char()) {
case 125:
return this.bump(), {
val: {
type: TYPE.argument,
// value does not include the opening and closing braces.
value: s,
location: createLocation(n, this.clonePosition())
},
err: null
};
case 44:
return this.bump(), this.bumpSpace(), this.isEOF() ? this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(n, this.clonePosition())) : this.parseArgumentOptions(e, i, s, n);
default:
return this.error(ErrorKind.MALFORMED_ARGUMENT, createLocation(n, this.clonePosition()));
}
}, t.prototype.parseIdentifierIfPossible = function() {
var e = this.clonePosition(), i = this.offset(), n = matchIdentifierAtIndex(this.message, i), s = i + n.length;
this.bumpTo(s);
var l = this.clonePosition(), h = createLocation(e, l);
return { value: n, location: h };
}, t.prototype.parseArgumentOptions = function(e, i, n, s) {
var l, h = this.clonePosition(), _ = this.parseIdentifierIfPossible().value, c = this.clonePosition();
switch (_) {
case "":
return this.error(ErrorKind.EXPECT_ARGUMENT_TYPE, createLocation(h, c));
case "number":
case "date":
case "time": {
this.bumpSpace();
var o = null;
if (this.bumpIf(",")) {
this.bumpSpace();
var r = this.clonePosition(), T = this.parseSimpleArgStyleIfPossible();
if (T.err)
return T;
var S = trimEnd(T.val);
if (S.length === 0)
return this.error(ErrorKind.EXPECT_ARGUMENT_STYLE, createLocation(this.clonePosition(), this.clonePosition()));
var w = createLocation(r, this.clonePosition());
o = { style: S, styleLocation: w };
}
var C = this.tryParseArgumentClose(s);
if (C.err)
return C;
var P = createLocation(s, this.clonePosition());
if (o && startsWith(o == null ? void 0 : o.style, "::", 0)) {
var b = trimStart(o.style.slice(2));
if (_ === "number") {
var T = this.parseNumberSkeletonFromString(b, o.styleLocation);
return T.err ? T : {
val: { type: TYPE.number, value: n, location: P, style: T.val },
err: null
};
} else {
if (b.length === 0)
return this.error(ErrorKind.EXPECT_DATE_TIME_SKELETON, P);
var k = b;
this.locale && (k = getBestPattern(b, this.locale));
var S = {
type: SKELETON_TYPE.dateTime,
pattern: k,
location: o.styleLocation,
parsedOptions: this.shouldParseSkeletons ? parseDateTimeSkeleton(k) : {}
}, F = _ === "date" ? TYPE.date : TYPE.time;
return {
val: { type: F, value: n, location: P, style: S },
err: null
};
}
}
return {
val: {
type: _ === "number" ? TYPE.number : _ === "date" ? TYPE.date : TYPE.time,
value: n,
location: P,
style: (l = o == null ? void 0 : o.style) !== null && l !== void 0 ? l : null
},
err: null
};
}
case "plural":
case "selectordinal":
case "select": {
var x = this.clonePosition();
if (this.bumpSpace(), !this.bumpIf(","))
return this.error(ErrorKind.EXPECT_SELECT_ARGUMENT_OPTIONS, createLocation(x, __assign({}, x)));
this.bumpSpace();
var y = this.parseIdentifierIfPossible(), p = 0;
if (_ !== "select" && y.value === "offset") {
if (!this.bumpIf(":"))
return this.error(ErrorKind.EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE, createLocation(this.clonePosition(), this.clonePosition()));
this.bumpSpace();
var T = this.tryParseDecimalInteger(ErrorKind.EXPECT_PLURAL_ARGUMENT_OFFSET_VALUE, ErrorKind.INVALID_PLURAL_ARGUMENT_OFFSET_VALUE);
if (T.err)
return T;
this.bumpSpace(), y = this.parseIdentifierIfPossible(), p = T.val;
}
var E = this.tryParsePluralOrSelectOptions(e, _, i, y);
if (E.err)
return E;
var C = this.tryParseArgumentClose(s);
if (C.err)
return C;
var $ = createLocation(s, this.clonePosition());
return _ === "select" ? {
val: {
type: TYPE.select,
value: n,
options: fromEntries(E.val),
location: $
},
err: null
} : {
val: {
type: TYPE.plural,
value: n,
options: fromEntries(E.val),
offset: p,
pluralType: _ === "plural" ? "cardinal" : "ordinal",
location: $
},
err: null
};
}
default:
return this.error(ErrorKind.INVALID_ARGUMENT_TYPE, createLocation(h, c));
}
}, t.prototype.tryParseArgumentClose = function(e) {
return this.isEOF() || this.char() !== 125 ? this.error(ErrorKind.EXPECT_ARGUMENT_CLOSING_BRACE, createLocation(e, this.clonePosition())) : (this.bump(), { val: !0, err: null });
}, t.prototype.parseSimpleArgStyleIfPossible = function() {
for (var e = 0, i = this.clonePosition(); !this.isEOF(); ) {
var n = this.char();
switch (n) {
case 39: {
this.bump();
var s = this.clonePosition();
if (!this.bumpUntil("'"))
return this.error(ErrorKind.UNCLOSED_QUOTE_IN_ARGUMENT_STYLE, createLocation(s, this.clonePosition()));
this.bump();
break;
}
case 123: {
e += 1, this.bump();
break;
}
case 125: {
if (e > 0)
e -= 1;
else
return {
val: this.message.slice(i.offset, this.offset()),
err: null
};
break;
}
default:
this.bump();
break;
}
}
return {
val: this.message.slice(i.offset, this.offset()),
err: null
};
}, t.prototype.parseNumberSkeletonFromString = function(e, i) {
var n = [];
try {
n = parseNumberSkeletonFromString(e);
} catch {
return this.error(ErrorKind.INVALID_NUMBER_SKELETON, i);
}
return {
val: {
type: SKELETON_TYPE.number,
tokens: n,
location: i,
parsedOptions: this.shouldParseSkeletons ? parseNumberSkeleton(n) : {}
},
err: null
};
}, t.prototype.tryParsePluralOrSelectOptions = function(e, i, n, s) {
for (var l, h = !1, _ = [], c = /* @__PURE__ */ new Set(), o = s.value, r = s.location; ; ) {
if (o.length === 0) {
var T = this.clonePosition();
if (i !== "select" && this.bumpIf("=")) {
var S = this.tryParseDecimalInteger(ErrorKind.EXPECT_PLURAL_ARGUMENT_SELECTOR, ErrorKind.INVALID_PLURAL_ARGUMENT_SELECTOR);
if (S.err)
return S;
r = createLocation(T, this.clonePosition()), o = this.message.slice(T.offset, this.offset());
} else
break;
}
if (c.has(o))
return this.error(i === "select" ? ErrorKind.DUPLICATE_SELECT_ARGUMENT_SELECTOR : ErrorKind.DUPLICATE_PLURAL_ARGUMENT_SELECTOR, r);
o === "other" && (h = !0), this.bumpSpace();
var w = this.clonePosition();
if (!this.bumpIf("{"))
return this.error(i === "select" ? ErrorKind.EXPECT_SELECT_ARGUMENT_SELECTOR_FRAGMENT : ErrorKind.EXPECT_PLURAL_ARGUMENT_SELECTOR_FRAGMENT, createLocation(this.clonePosition(), this.clonePosition()));
var C = this.parseMessage(e + 1, i, n);
if (C.err)
return C;
var P = this.tryParseArgumentClose(w);
if (P.err)
return P;
_.push([
o,
{
value: C.val,
location: createLocation(w, this.clonePosition())
}
]), c.add(o), this.bumpSpace(), l = this.parseIdentifierIfPossible(), o = l.value, r = l.location;
}
return _.length === 0 ? this.error(i === "select" ? ErrorKind.EXPECT_SELECT_ARGUMENT_SELECTOR : ErrorKind.EXPECT_PLURAL_ARGUMENT_SELECTOR, createLocation(this.clonePosition(), this.clonePosition())) : this.requiresOtherClause && !h ? this.error(ErrorKind.MISSING_OTHER_CLAUSE, createLocation(this.clonePosition(), this.clonePosition())) : { val: _, err: null };
}, t.prototype.tryParseDecimalInteger = function(e, i) {
var n = 1, s = this.clonePosition();
this.bumpIf("+") || this.bumpIf("-") && (n = -1);
for (var l = !1, h = 0; !this.isEOF(); ) {
var _ = this.char();
if (_ >= 48 && _ <= 57)
l = !0, h = h * 10 + (_ - 48), this.bump();
else
break;
}
var c = createLocation(s, this.clonePosition());
return l ? (h *= n, isSafeInteger(h) ? { val: h, err: null } : this.error(i, c)) : this.error(e, c);
}, t.prototype.offset = function() {
return this.position.offset;
}, t.prototype.isEOF = function() {
return this.offset() === this.message.length;
}, t.prototype.clonePosition = function() {
return {
offset: this.position.offset,
line: this.position.line,
column: this.position.column
};
}, t.prototype.char = function() {
var e = this.position.offset;
if (e >= this.message.length)
throw Error("out of bound");
var i = codePointAt(this.message, e);
if (i === void 0)
throw Error("Offset ".concat(e, " is at invalid UTF-16 code unit boundary"));
return i;
}, t.prototype.error = function(e, i) {
return {
val: null,
err: {
kind: e,
message: this.message,
location: i
}
};
}, t.prototype.bump = function() {
if (!this.isEOF()) {
var e = this.char();
e === 10 ? (this.position.line += 1, this.position.column = 1, this.position.offset += 1) : (this.position.column += 1, this.position.offset += e < 65536 ? 1 : 2);
}
}, t.prototype.bumpIf = function(e) {
if (startsWith(this.message, e, this.offset())) {
for (var i = 0; i < e.length; i++)
this.bump();
return !0;
}
return !1;
}, t.prototype.bumpUntil = function(e) {
var i = this.offset(), n = this.message.indexOf(e, i);
return n >= 0 ? (this.bumpTo(n), !0) : (this.bumpTo(this.message.length), !1);
}, t.prototype.bumpTo = function(e) {
if (this.offset() > e)
throw Error("targetOffset ".concat(e, " must be greater than or equal to the current offset ").concat(this.offset()));
for (e = Math.min(e, this.message.length); ; ) {
var i = this.offset();
if (i === e)
break;
if (i > e)
throw Error("targetOffset ".concat(e, " is at invalid UTF-16 code unit boundary"));
if (this.bump(), this.isEOF())
break;
}
}, t.prototype.bumpSpace = function() {
for (; !this.isEOF() && _isWhiteSpace(this.char()); )
this.bump();
}, t.prototype.peek = function() {
if (this.isEOF())
return null;
var e = this.char(), i = this.offset(), n = this.message.charCodeAt(i + (e >= 65536 ? 2 : 1));
return n ?? null;
}, t;
}()
);
function _isAlpha(t) {
return t >= 97 && t <= 122 || t >= 65 && t <= 90;
}
function _isAlphaOrSlash(t) {
return _isAlpha(t) || t === 47;
}
function _isPotentialElementNameChar(t) {
return t === 45 || t === 46 || t >= 48 && t <= 57 || t === 95 || t >= 97 && t <= 122 || t >= 65 && t <= 90 || t == 183 || t >= 192 && t <= 214 || t >= 216 && t <= 246 || t >= 248 && t <= 893 || t >= 895 && t <= 8191 || t >= 8204 && t <= 8205 || t >= 8255 && t <= 8256 || t >= 8304 && t <= 8591 || t >= 11264 && t <= 12271 || t >= 12289 && t <= 55295 || t >= 63744 && t <= 64975 || t >= 65008 && t <= 65533 || t >= 65536 && t <= 983039;
}
function _isWhiteSpace(t) {
return t >= 9 && t <= 13 || t === 32 || t === 133 || t >= 8206 && t <= 8207 || t === 8232 || t === 8233;
}
function _isPatternSyntax(t) {
return t >= 33 && t <= 35 || t === 36 || t >= 37 && t <= 39 || t === 40 || t === 41 || t === 42 || t === 43 || t === 44 || t === 45 || t >= 46 && t <= 47 || t >= 58 && t <= 59 || t >= 60 && t <= 62 || t >= 63 && t <= 64 || t === 91 || t === 92 || t === 93 || t === 94 || t === 96 || t === 123 || t === 124 || t === 125 || t === 126 || t === 161 || t >= 162 && t <= 165 || t === 166 || t === 167 || t === 169 || t === 171 || t === 172 || t === 174 || t === 176 || t === 177 || t === 182 || t === 187 || t === 191 || t === 215 || t === 247 || t >= 8208 && t <= 8213 || t >= 8214 && t <= 8215 || t === 8216 || t === 8217 || t === 8218 || t >= 8219 && t <= 8220 || t === 8221 || t === 8222 || t === 8223 || t >= 8224 && t <= 8231 || t >= 8240 && t <= 8248 || t === 8249 || t === 8250 || t >= 8251 && t <= 8254 || t >= 8257 && t <= 8259 || t === 8260 || t === 8261 || t === 8262 || t >= 8263 && t <= 8273 || t === 8274 || t === 8275 || t >= 8277 && t <= 8286 || t >= 8592 && t <= 8596 || t >= 8597 && t <= 8601 || t >= 8602 && t <= 8603 || t >= 8604 && t <= 8607 || t === 8608 || t >= 8609 && t <= 8610 || t === 8611 || t >= 8612 && t <= 8613 || t === 8614 || t >= 8615 && t <= 8621 || t === 8622 || t >= 8623 && t <= 8653 || t >= 8654 && t <= 8655 || t >= 8656 && t <= 8657 || t === 8658 || t === 8659 || t === 8660 || t >= 8661 && t <= 8691 || t >= 8692 && t <= 8959 || t >= 8960 && t <= 8967 || t === 8968 || t === 8969 || t === 8970 || t === 8971 || t >= 8972 && t <= 8991 || t >= 8992 && t <= 8993 || t >= 8994 && t <= 9e3 || t === 9001 || t === 9002 || t >= 9003 && t <= 9083 || t === 9084 || t >= 9085 && t <= 9114 || t >= 9115 && t <= 9139 || t >= 9140 && t <= 9179 || t >= 9180 && t <= 9185 || t >= 9186 && t <= 9254 || t >= 9255 && t <= 9279 || t >= 9280 && t <= 9290 || t >= 9291 && t <= 9311 || t >= 9472 && t <= 9654 || t === 9655 || t >= 9656 && t <= 9664 || t === 9665 || t >= 9666 && t <= 9719 || t >= 9720 && t <= 9727 || t >= 9728 && t <= 9838 || t === 9839 || t >= 9840 && t <= 10087 || t === 10088 || t === 10089 || t === 10090 || t === 10091 || t === 10092 || t === 10093 || t === 10094 || t === 10095 || t === 10096 || t === 10097 || t === 10098 || t === 10099 || t === 10100 || t === 10101 || t >= 10132 && t <= 10175 || t >= 10176 && t <= 10180 || t === 10181 || t === 10182 || t >= 10183 && t <= 10213 || t === 10214 || t === 10215 || t === 10216 || t === 10217 || t === 10218 || t === 10219 || t === 10220 || t === 10221 || t === 10222 || t === 10223 || t >= 10224 && t <= 10239 || t >= 10240 && t <= 10495 || t >= 10496 && t <= 10626 || t === 10627 || t === 10628 || t === 10629 || t === 10630 || t === 10631 || t === 10632 || t === 10633 || t === 10634 || t === 10635 || t === 10636 || t === 10637 || t === 10638 || t === 10639 || t === 10640 || t === 10641 || t === 10642 || t === 10643 || t === 10644 || t === 10645 || t === 10646 || t === 10647 || t === 10648 || t >= 10649 && t <= 10711 || t === 10712 || t === 10713 || t === 10714 || t === 10715 || t >= 10716 && t <= 10747 || t === 10748 || t === 10749 || t >= 10750 && t <= 11007 || t >= 11008 && t <= 11055 || t >= 11056 && t <= 11076 || t >= 11077 && t <= 11078 || t >= 11079 && t <= 11084 || t >= 11085 && t <= 11123 || t >= 11124 && t <= 11125 || t >= 11126 && t <= 11157 || t === 11158 || t >= 11159 && t <= 11263 || t >= 11776 && t <= 11777 || t === 11778 || t === 11779 || t === 11780 || t === 11781 || t >= 11782 && t <= 11784 || t === 11785 || t === 11786 || t === 11787 || t === 11788 || t === 11789 || t >= 11790 && t <= 11798 || t === 11799 || t >= 11800 && t <= 11801 || t === 11802 || t === 11803 || t === 11804 || t === 11805 || t >= 11806 && t <= 11807 || t === 11808 || t === 11809 || t === 11810 || t === 11811 || t === 11812 || t === 11813 || t === 11814 || t === 11815 || t === 11816 || t === 11817 || t >= 11818 && t <= 11822 || t === 11823 || t >= 11824 && t <= 11833 || t >= 11834 && t <= 11835 || t >= 11836 && t <= 11839 || t === 11840 || t === 11841 || t === 11842 || t >= 11843 && t <= 11855 || t >= 11856 && t <= 11857 || t === 11858 || t >= 11859 && t <= 11903 || t >= 12289 && t <= 12291 || t === 12296 || t === 12297 || t === 12298 || t === 12299 || t === 12300 || t === 12301 || t === 12302 || t === 12303 || t === 12304 || t === 12305 || t >= 12306 && t <= 12307 || t === 12308 || t === 12309 || t === 12310 || t === 12311 || t === 12312 || t === 12313 || t === 12314 || t === 12315 || t === 12316 || t === 12317 || t >= 12318 && t <= 12319 || t === 12320 || t === 12336 || t === 64830 || t === 64831 || t >= 65093 && t <= 65094;
}
function pruneLocation(t) {
t.forEach(function(e) {
if (delete e.location, isSelectElement(e) || isPluralElement(e))
for (var i in e.options)
delete e.options[i].location, pruneLocation(e.options[i].value);
else
isNumberElement(e) && isNumberSkeleton(e.style) || (isDateElement(e) || isTimeElement(e)) && isDateTimeSkeleton(e.style) ? delete e.style.location : isTagElement(e) && pruneLocation(e.children);
});
}
function parse(t, e) {
e === void 0 && (e = {}), e = __assign({ shouldParseSkeletons: !0, requiresOtherClause: !0 }, e);
var i = new Parser(t, e).parse();
if (i.err) {
var n = SyntaxError(ErrorKind[i.err.kind]);
throw n.location = i.err.location, n.originalMessage = i.err.message, n;
}
return e != null && e.captureLocation || pruneLocation(i.val), i.val;
}
function memoize(t, e) {
var i = e && e.cache ? e.cache : cacheDefault, n = e && e.serializer ? e.serializer : serializerDefault, s = e && e.strategy ? e.strategy : strategyDefault;
return s(t, {
cache: i,
serializer: n
});
}
function isPrimitive(t) {
return t == null || typeof t == "number" || typeof t == "boolean";
}
function monadic(t, e, i, n) {
var s = isPrimitive(n) ? n : i(n), l = e.get(s);
return typeof l > "u" && (l = t.call(this, n), e.set(s, l)), l;
}
function variadic(t, e, i) {
var n = Array.prototype.slice.call(arguments, 3), s = i(n), l = e.get(s);
return typeof l > "u" && (l = t.apply(this, n), e.set(s, l)), l;
}
function assemble(t, e, i, n, s) {
return i.bind(e, t, n, s);
}
function strategyDefault(t, e) {
var i = t.length === 1 ? monadic : variadic;
return assemble(t, this, i, e.cache.create(), e.serializer);
}
function strategyVariadic(t, e) {
return assemble(t, this, variadic, e.cache.create(), e.serializer);
}
function strategyMonadic(t, e) {
return assemble(t, this, monadic, e.cache.create(), e.serializer);
}
var serializerDefault = function() {
return JSON.stringify(arguments);
};
function ObjectWithoutPrototypeCache() {
this.cache = /* @__PURE__ */ Object.create(null);
}
ObjectWithoutPrototypeCache.prototype.get = function(t) {
return this.cache[t];
};
ObjectWithoutPrototypeCache.prototype.set = function(t, e) {
this.cache[t] = e;
};
var cacheDefault = {
create: function() {
return new ObjectWithoutPrototypeCache();
}
}, strategies = {
variadic: strategyVariadic,
monadic: strategyMonadic
}, ErrorCode;
(function(t) {
t.MISSING_VALUE = "MISSING_VALUE", t.INVALID_VALUE = "INVALID_VALUE", t.MISSING_INTL_API = "MISSING_INTL_API";
})(ErrorCode || (ErrorCode = {}));
var FormatError = (
/** @class */
function(t) {
__extends(e, t);
function e(i, n, s) {
var l = t.call(this, i) || this;
return l.code = n, l.originalMessage = s, l;
}
return e.prototype.toString = function() {
return "[formatjs Error: ".concat(this.code, "] ").concat(this.message);
}, e;
}(Error)
), InvalidValueError = (
/** @class */
function(t) {
__extends(e, t);
function e(i, n, s, l) {
return t.call(this, 'Invalid values for "'.concat(i, '": "').concat(n, '". Options are "').concat(Object.keys(s).join('", "'), '"'), ErrorCode.INVALID_VALUE, l) || this;
}
return e;
}(FormatError)
), InvalidValueTypeError = (
/** @class */
function(t) {
__extends(e, t);
function e(i, n, s) {
return t.call(this, 'Value for "'.concat(i, '" must be of type ').concat(n), ErrorCode.INVALID_VALUE, s) || this;
}
return e;
}(FormatError)
), MissingValueError = (
/** @class */
function(t) {
__extends(e, t);
function e(i, n) {
return t.call(this, 'The intl string context variable "'.concat(i, '" was not provided to the string "').concat(n, '"'), ErrorCode.MISSING_VALUE, n) || this;
}
return e;
}(FormatError)
), PART_TYPE;
(function(t) {
t[t.literal = 0] = "literal", t[t.object = 1] = "object";
})(PART_TYPE || (PART_TYPE = {}));
function mergeLiteral(t) {
return t.length < 2 ? t : t.reduce(function(e, i) {
var n = e[e.length - 1];
return !n || n.type !== PART_TYPE.literal || i.type !== PART_TYPE.literal ? e.push(i) : n.value += i.value, e;
}, []);
}
function isFormatXMLElementFn(t) {
return typeof t == "function";
}
function formatToParts(t, e, i, n, s, l, h) {
if (t.length === 1 && isLiteralElement(t[0]))
return [
{
type: PART_TYPE.literal,
value: t[0].value
}
];
for (var _ = [], c = 0, o = t; c < o.length; c++) {
var r = o[c];
if (isLiteralElement(r)) {
_.push({
type: PART_TYPE.literal,
value: r.value
});
continue;
}
if (isPoundElement(r)) {
typeof l == "number" && _.push({
type: PART_TYPE.literal,
value: i.getNumberFormat(e).format(l)
});
continue;
}
var T = r.value;
if (!(s && T in s))
throw new MissingValueError(T, h);
var S = s[T];
if (isArgumentElement(r)) {
(!S || typeof S == "string" || typeof S == "number") && (S = typeof S == "string" || typeof S == "number" ? String(S) : ""), _.push({
type: typeof S == "string" ? PART_TYPE.literal : PART_TYPE.object,
value: S
});
continue;
}
if (isDateElement(r)) {
var w = typeof r.style == "string" ? n.date[r.style] : isDateTimeSkeleton(r.style) ? r.style.parsedOptions : void 0;
_.push({
type: PART_TYPE.literal,
value: i.getDateTimeFormat(e, w).format(S)
});
continue;
}
if (isTimeElement(r)) {
var w = typeof r.style == "string" ? n.time[r.style] : isDateTimeSkeleton(r.style) ? r.style.parsedOptions : n.time.medium;
_.push({
type: PART_TYPE.literal,
value: i.getDateTimeFormat(e, w).format(S)
});
continue;
}
if (isNumberElement(r)) {
var w = typeof r.style == "string" ? n.number[r.style] : isNumberSkeleton(r.style) ? r.style.parsedOptions : void 0;
w && w.scale && (S = S * (w.scale || 1)), _.push({
type: PART_TYPE.literal,
value: i.getNumberFormat(e, w).format(S)
});
continue;
}
if (isTagElement(r)) {
var C = r.children, P = r.value, b = s[P];
if (!isFormatXMLElementFn(b))
throw new InvalidValueTypeError(P, "function", h);
var k = formatToParts(C, e, i, n, s, l), F = b(k.map(function(p) {
return p.value;
}));
Array.isArray(F) || (F = [F]), _.push.apply(_, F.map(function(p) {
return {
type: typeof p == "string" ? PART_TYPE.literal : PART_TYPE.object,
value: p
};
}));
}
if (isSelectElement(r)) {
var x = r.options[S] || r.options.other;
if (!x)
throw new InvalidValueError(r.value, S, Object.keys(r.options), h);
_.push.apply(_, formatToParts(x.value, e, i, n, s));
continue;
}
if (isPluralElement(r)) {
var x = r.options["=".concat(S)];
if (!x) {
if (!Intl.PluralRules)
throw new FormatError(`Intl.PluralRules is not available in this environment.
Try polyfilling it using "@formatjs/intl-pluralrules"
`, ErrorCode.MISSING_INTL_API, h);
var y = i.getPluralRules(e, { type: r.pluralType }).select(S - (r.offset || 0));
x = r.options[y] || r.options.other;
}
if (!x)
throw new InvalidValueError(r.value, S, Object.keys(r.options), h);
_.push.apply(_, formatToParts(x.value, e, i, n, s, S - (r.offset || 0)));
continue;
}
}
return mergeLiteral(_);
}
function mergeConfig(t, e) {
return e ? __assign(__assign(__assign({}, t || {}), e || {}), Object.keys(t).reduce(function(i, n) {
return i[n] = __assign(__assign({}, t[n]), e[n] || {}), i;
}, {})) : t;
}
function mergeConfigs(t, e) {
return e ? Object.keys(t).reduce(function(i, n) {
return i[n] = mergeConfig(t[n], e[n]), i;
}, __assign({}, t)) : t;
}
function createFastMemoizeCache(t) {
return {
create: function() {
return {
get: function(e) {
return t[e];
},
set: function(e, i) {
t[e] = i;
}
};
}
};
}
function createDefaultFormatters(t) {
return t === void 0 && (t = {
number: {},
dateTime: {},
pluralRules: {}
}), {
getNumberFormat: memoize(function() {
for (var e, i = [], n = 0; n < arguments.length; n++)
i[n] = arguments[n];
return new ((e = Intl.NumberFormat).bind.apply(e, __spreadArray([void 0], i, !1)))();
}, {
cache: createFastMemoizeCache(t.number),
strategy: strategies.variadic
}),
getDateTimeFormat: memoize(function() {
for (var e, i = [], n = 0; n < arguments.length; n++)
i[n] = arguments[n];
return new ((e = Intl.DateTimeFormat).bind.apply(e, __spreadArray([void 0], i, !1)))();
}, {
cache: createFastMemoizeCache(t.dateTime),
strategy: strategies.variadic
}),
getPluralRules: memoize(function() {
for (var e, i = [], n = 0; n < arguments.length; n++)
i[n] = arguments[n];
return new ((e = Intl.PluralRules).bind.apply(e, __spreadArray([void 0], i, !1)))();
}, {
cache: createFastMemoizeCache(t.pluralRules),
strategy: strategies.variadic
})
};
}
var IntlMessageFormat = (
/** @class */
function() {
function t(e, i, n, s) {
var l = this;
if (i === void 0 && (i = t.defaultLocale), this.formatterCache = {
number: {},
dateTime: {},
pluralRules: {}
}, this.format = function(h) {
var _ = l.formatToParts(h);
if (_.length === 1)
return _[0].value;
var c = _.reduce(function(o, r) {
return !o.length || r.type !== PART_TYPE.literal || typeof o[o.length - 1] != "string" ? o.push(r.value) : o[o.length - 1] += r.value, o;
}, []);
return c.length <= 1 ? c[0] || "" : c;
}, this.formatToParts = function(h) {
return formatToParts(l.ast, l.locales, l.formatters, l.formats, h, void 0, l.message);
}, this.resolvedOptions = function() {
return {
locale: l.resolvedLocale.toString()
};
}, this.getAst = function() {
return l.ast;
}, this.locales = i, this.resolvedLocale = t.resolveLocale(i), typeof e == "string") {
if (this.message = e, !t.__parse)
throw new TypeError("IntlMessageFormat.__parse must be set to process `message` of type `string`");
this.ast = t.__parse(e, {
ignoreTag: s == null ? void 0 : s.ignoreTag,
locale: this.resolvedLocale
});
} else
this.ast = e;
if (!Array.isArray(this.ast))
throw new TypeError("A message must be provided as a String or AST.");
this.formats = mergeConfigs(t.formats, n), this.formatters = s && s.formatters || createDefaultFormatters(this.formatterCache);
}
return Object.defineProperty(t, "defaultLocale", {
get: function() {
return t.memoizedDefaultLocale || (t.memoizedDefaultLocale = new Intl.NumberFormat().resolvedOptions().locale), t.memoizedDefaultLocale;
},
enumerable: !1,
configurable: !0
}), t.memoizedDefaultLocale = null, t.resolveLocale = function(e) {
var i = Intl.NumberFormat.supportedLocalesOf(e);
return i.length > 0 ? new Intl.Locale(i[0]) : new Intl.Locale(typeof e == "string" ? e : e[0]);
}, t.__parse = parse, t.formats = {
number: {
integer: {
maximumFractionDigits: 0
},
currency: {
style: "currency"
},
percent: {
style: "percent"
}
},
date: {
short: {
month: "numeric",
day: "numeric",
year: "2-digit"
},
medium: {
month: "short",
day: "numeric",
year: "numeric"
},
long: {
month: "long",
day: "numeric",
year: "numeric"
},
full: {
weekday: "long",
month: "long",
day: "numeric",
year: "numeric"
}
},
time: {
short: {
hour: "numeric",
minute: "numeric"
},
medium: {
hour: "numeric",
minute: "numeric",
second: "numeric"
},
long: {
hour: "numeric",
minute: "numeric",
second: "numeric",
timeZoneName: "short"
},
full: {
hour: "numeric",
minute: "numeric",
second: "numeric",
timeZoneName: "short"
}
}
}, t;
}()
);
function delve(t, e) {
if (e == null)
return;
if (e in t)
return t[e];
const i = e.split(".");
let n = t;
for (let s = 0; s < i.length; s++)
if (typeof n == "object") {
if (s > 0) {
const l = i.slice(s, i.length).join(".");
if (l in n) {
n = n[l];
break;
}
}
n = n[i[s]];
} else
n = void 0;
return n;
}
const lookupCache = {}, addToCache = (t, e, i) => i && (e in lookupCache || (lookupCache[e] = {}), t in lookupCache[e] || (lookupCache[e][t] = i), i), lookup = (t, e) => {
if (e == null)
return;
if (e in lookupCache && t in lookupCache[e])
return lookupCache[e][t];
const i = getPossibleLocales(e);
for (let n = 0; n < i.length; n++) {
const s = i[n], l = getMessageFromDictionary(s, t);
if (l)
return addToCache(t, e, l);
}
};
let dictionary;
const $dictionary = writable({});
function getLocaleDictionary(t) {
return dictionary[t] || null;
}
function hasLocaleDictionary(t) {
return t in dictionary;
}
function getMessageFromDictionary(t, e) {
if (!hasLocaleDictionary(t))
return null;
const i = getLocaleDictionary(t);
return delve(i, e);
}
function getClosestAvailableLocale(t) {
if (t == null)
return;
const e = getPossibleLocales(t);
for (let i = 0; i < e.length; i++) {
const n = e[i];
if (hasLocaleDictionary(n))
return n;
}
}
function addMessages(t, ...e) {
delete lookupCache[t], $dictionary.update((i) => (i[t] = deepmerge$1.all([i[t] || {}, ...e]), i));
}
derived(
[$dictionary],
([t]) => Object.keys(t)
);
$dictionary.subscribe((t) => dictionary = t);
const queue = {};
function removeLoaderFromQueue(t, e) {
queue[t].delete(e), queue[t].size === 0 && delete queue[t];
}
function getLocaleQueue(t) {
return queue[t];
}
function getLocalesQueues(t) {
return getPossibleLocales(t).map((e) => {
const i = getLocaleQueue(e);
return [e, i ? [...i] : []];
}).filter(([, e]) => e.length > 0);
}
function hasLocaleQueue(t) {
return t == null ? !1 : getPossibleLocales(t).some(
(e) => {
var i;
return (i = getLocaleQueue(e)) == null ? void 0 : i.size;
}
);
}
function loadLocaleQueue(t, e) {
return Promise.all(
e.map((n) => (removeLoaderFromQueue(t, n), n().then((s) => s.default || s)))
).then((n) => addMessages(t, ...n));
}
const activeFlushes = {};
function flush(t) {
if (!hasLocaleQueue(t))
return t in activeFlushes ? activeFlushes[t] : Promise.resolve();
const e = getLocalesQueues(t);
return activeFlushes[t] = Promise.all(
e.map(
([i, n]) => loadLocaleQueue(i, n)
)
).then(() => {
if (hasLocaleQueue(t))
return flush(t);
delete activeFlushes[t];
}), activeFlushes[t];
}
const defaultFormats = {
number: {
scientific: { notation: "scientific" },
engineering: { notation: "engineering" },
compactLong: { notation: "compact", compactDisplay: "long" },
compactShort: { notation: "compact", compactDisplay: "short" }
},
date: {
short: { month: "numeric", day: "numeric", year: "2-digit" },
medium: { month: "short", day: "numeric", year: "numeric" },
long: { month: "long", day: "numeric", year: "numeric" },
full: { weekday: "long", month: "long", day: "numeric", year: "numeric" }
},
time: {
short: { hour: "numeric", minute: "numeric" },
medium: { hour: "numeric", minute: "numeric", second: "numeric" },
long: {
hour: "numeric",
minute: "numeric",
second: "numeric",
timeZoneName: "short"
},
full: {
hour: "numeric",
minute: "numeric",
second: "numeric",
timeZoneName: "short"
}
}
}, defaultOptions = {
fallbackLocale: null,
loadingDelay: 200,
formats: defaultFormats,
warnOnMissingMessages: !0,
handleMissingMessage: void 0,
ignoreTag: !0
}, options = defaultOptions;
function getOptions() {
return options;
}
const $isLoading = writable(!1);
var __defProp$1 = Object.defineProperty, __defProps = Object.defineProperties, __getOwnPropDescs = Object.getOwnPropertyDescriptors, __getOwnPropSymbols$1 = Object.getOwnPropertySymbols, __hasOwnProp$1 = Object.prototype.hasOwnProperty, __propIsEnum$1 = Object.prototype.propertyIsEnumerable, __defNormalProp$1 = (t, e, i) => e in t ? __defProp$1(t, e, { enumerable: !0, configurable: !0, writable: !0, value: i }) : t[e] = i, __spreadValues$1 = (t, e) => {
for (var i in e || (e = {}))
__hasOwnProp$1.call(e, i) && __defNormalProp$1(t, i, e[i]);
if (__getOwnPropSymbols$1)
for (var i of __getOwnPropSymbols$1(e))
__propIsEnum$1.call(e, i) && __defNormalProp$1(t, i, e[i]);
return t;
}, __spreadProps = (t, e) => __defProps(t, __getOwnPropDescs(e));
let current;
const internalLocale = writable(null);
function getSubLocales(t) {
return t.split("-").map((e, i, n) => n.slice(0, i + 1).join("-")).reverse();
}
function getPossibleLocales(t, e = getOptions().fallbackLocale) {
const i = getSubLocales(t);
return e ? [.../* @__PURE__ */ new Set([...i, ...getSubLocales(e)])] : i;
}
function getCurrentLocale() {
return current ?? void 0;
}
internalLocale.subscribe((t) => {
current = t ?? void 0, typeof window < "u" && t != null && document.documentElement.setAttribute("lang", t);
});
const set = (t) => {
if (t && getClosestAvailableLocale(t) && hasLocaleQueue(t)) {
const { loadingDelay: e } = getOptions();
let i;
return typeof window < "u" && getCurrentLocale() != null && e ? i = window.setTimeout(
() => $isLoading.set(!0),
e
) : $isLoading.set(!0), flush(t).then(() => {
internalLocale.set(t);
}).finally(() => {
clearTimeout(i), $isLoading.set(!1);
});
}
return internalLocale.set(t);
}, $locale = __spreadProps(__spreadValues$1({}, internalLocale), {
set
}), monadicMemoize = (t) => {
const e = /* @__PURE__ */ Object.create(null);
return (n) => {
const s = JSON.stringify(n);
return s in e ? e[s] : e[s] = t(n);
};
};
var __defProp = Object.defineProperty, __getOwnPropSymbols = Object.getOwnPropertySymbols, __hasOwnProp = Object.prototype.hasOwnProperty, __propIsEnum = Object.prototype.propertyIsEnumerable, __defNormalProp = (t, e, i) => e in t ? __defProp(t, e, { enumerable: !0, configurable: !0, writable: !0, value: i }) : t[e] = i, __spreadValues = (t, e) => {
for (var i in e || (e = {}))
__hasOwnProp.call(e, i) && __defNormalProp(t, i, e[i]);
if (__getOwnPropSymbols)
for (var i of __getOwnPropSymbols(e))
__propIsEnum.call(e, i) && __defNormalProp(t, i, e[i]);
return t;
}, __objRest = (t, e) => {
var i = {};
for (var n in t)
__hasOwnProp.call(t, n) && e.indexOf(n) < 0 && (i[n] = t[n]);
if (t != null && __getOwnPropSymbols)
for (var n of __getOwnPropSymbols(t))
e.indexOf(n) < 0 && __propIsEnum.call(t, n) && (i[n] = t[n]);
return i;
};
const getIntlFormatterOptions = (t, e) => {
const { formats: i } = getOptions();
if (t in i && e in i[t])
return i[t][e];
throw new Error(`[svelte-i18n] Unknown "${e}" ${t} format.`);
}, createNumberFormatter = monadicMemoize(
(t) => {
var e = t, { locale: i, format: n } = e, s = __objRest(e, ["locale", "format"]);
if (i == null)
throw new Error('[svelte-i18n] A "locale" must be set to format numbers');
return n && (s = getIntlFormatterOptions("number", n)), new Intl.NumberFormat(i, s);
}
), createDateFormatter = monadicMemoize(
(t) => {
var e = t, { locale: i, format: n } = e, s = __objRest(e, ["locale", "format"]);
if (i == null)
throw new Error('[svelte-i18n] A "locale" must be set to format dates');
return n ? s = getIntlFormatterOptions("date", n) : Object.keys(s).length === 0 && (s = getIntlFormatterOptions("date", "short")), new Intl.DateTimeFormat(i, s);
}
), createTimeFormatter = monadicMemoize(
(t) => {
var e = t, { locale: i, format: n } = e, s = __objRest(e, ["locale", "format"]);
if (i == null)
throw new Error(
'[svelte-i18n] A "locale" must be set to format time values'
);
return n ? s = getIntlFormatterOptions("time", n) : Object.keys(s).length === 0 && (s = getIntlFormatterOptions("time", "short")), new Intl.DateTimeFormat(i, s);
}
), getNumberFormatter = (t = {}) => {
var e = t, {
locale: i = getCurrentLocale()
} = e, n = __objRest(e, [
"locale"
]);
return createNumberFormatter(__spreadValues({ locale: i }, n));
}, getDateFormatter = (t = {}) => {
var e = t, {
locale: i = getCurrentLocale()
} = e, n = __objRest(e, [
"locale"
]);
return createDateFormatter(__spreadValues({ locale: i }, n));
}, getTimeFormatter = (t = {}) => {
var e = t, {
locale: i = getCurrentLocale()
} = e, n = __objRest(e, [
"locale"
]);
return createTimeFormatter(__spreadValues({ locale: i }, n));
}, getMessageFormatter = monadicMemoize(
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
(t, e = getCurrentLocale()) => new IntlMessageFormat(t, e, getOptions().formats, {
ignoreTag: getOptions().ignoreTag
})
), formatMessage = (t, e = {}) => {
var i, n, s, l;
let h = e;
typeof t == "object" && (h = t, t = h.id);
const {
values: _,
locale: c = getCurrentLocale(),
default: o
} = h;
if (c == null)
throw new Error(
"[svelte-i18n] Cannot format a message without first setting the initial locale."
);
let r = lookup(t, c);
if (!r)
r = (l = (s = (n = (i = getOptions()).handleMissingMessage) == null ? void 0 : n.call(i, { locale: c, id: t, defaultValue: o })) != null ? s : o) != null ? l : t;
else if (typeof r != "string")
return console.warn(
`[svelte-i18n] Message with id "${t}" must be of type "string", found: "${typeof r}". Gettin its value through the "$format" method is deprecated; use the "json" method instead.`
), r;
if (!_)
return r;
let T = r;
try {
T = getMessageFormatter(r, c).format(_);
} catch (S) {
S instanceof Error && console.warn(
`[svelte-i18n] Message "${t}" has syntax error:`,
S.message
);
}
return T;
}, formatTime = (t, e) => getTimeFormatter(e).format(t), formatDate = (t, e) => getDateFormatter(e).format(t), formatNumber = (t, e) => getNumberFormatter(e).format(t), getJSON = (t, e = getCurrentLocale()) => lookup(t, e);
derived([$locale, $dictionary], () => formatMessage);
derived([$locale], () => formatTime);
derived([$locale], () => formatDate);
derived([$locale], () => formatNumber);
derived([$locale, $dictionary], () => getJSON);
const Upload_svelte_svelte_type_style_lang = "", {
SvelteComponent: SvelteComponent$2,
append: append$2,
attr: attr$2,
binding_callbacks: binding_callbacks$1,
bubble,
create_slot,
detach: detach$2,
element: element$2,
get_all_dirty_from_scope,
get_slot_changes,
init: init$2,
insert: insert$2,
listen,
prevent_default,
run_all,
safe_not_equal: safe_not_equal$2,
space: space$2,
stop_propagation,
toggle_class: toggle_class$1,
transition_in: transition_in$2,
transition_out: transition_out$2,
update_slot_base
} = window.__gradio__svelte__internal, { createEventDispatcher: createEventDispatcher$1, tick: tick$1, getContext } = window.__gradio__svelte__internal;
function create_fragment$2(t) {
let e, i, n, s, l, h, _, c, o;
const r = (
/*#slots*/
t[16].default
), T = create_slot(
r,
t,
/*$$scope*/
t[15],
null
);
return {
c() {
e = element$2("button"), T && T.c(), i = space$2(), n = element$2("input"), attr$2(n, "type", "file"), attr$2(
n,
"accept",
/*filetype*/
t[0]
), n.multiple = s = /*file_count*/
t[4] === "multiple" || void 0, attr$2(n, "webkitdirectory", l = /*file_count*/
t[4] === "directory" || void 0), attr$2(n, "mozdirectory", h = /*file_count*/
t[4] === "directory" || void 0), attr$2(n, "class", "svelte-18dlsnh"), attr$2(e, "class", "svelte-18dlsnh"), toggle_class$1(
e,
"hidden",
/*hidden*/
t[5]
), toggle_class$1(
e,
"center",
/*center*/
t[2]
), toggle_class$1(
e,
"boundedheight",
/*boundedheight*/
t[1]
), toggle_class$1(
e,
"flex",
/*flex*/
t[3]
);
},
m(S, w) {
insert$2(S, e, w), T && T.m(e, null), append$2(e, i), append$2(e, n), t[24](n), _ = !0, c || (o = [
listen(
n,
"change",
/*load_files_from_upload*/
t[9]
),
listen(e, "drag", stop_propagation(prevent_default(
/*drag_handler*/
t[17]
))),
listen(e, "dragstart", stop_propagation(prevent_default(
/*dragstart_handler*/
t[18]
))),
listen(e, "dragend", stop_propagation(prevent_default(
/*dragend_handler*/
t[19]
))),
listen(e, "dragover", stop_propagation(prevent_default(
/*dragover_handler*/
t[20]
))),
listen(e, "dragenter", stop_propagation(prevent_default(
/*dragenter_handler*/
t[21]
))),
listen(e, "dragleave", stop_propagation(prevent_default(
/*dragleave_handler*/
t[22]
))),
listen(e, "drop", stop_propagation(prevent_default(
/*drop_handler*/
t[23]
))),
listen(
e,
"click",
/*open_file_upload*/
t[6]
),
listen(
e,
"drop",
/*loadFilesFromDrop*/
t[10]
),
listen(
e,
"dragenter",
/*updateDragging*/
t[8]
),
listen(
e,
"dragleave",
/*updateDragging*/
t[8]
)
], c = !0);
},
p(S, [w]) {
T && T.p && (!_ || w & /*$$scope*/
32768) && update_slot_base(
T,
r,
S,
/*$$scope*/
S[15],
_ ? get_slot_changes(
r,
/*$$scope*/
S[15],
w,
null
) : get_all_dirty_from_scope(
/*$$scope*/
S[15]
),
null
), (!_ || w & /*filetype*/
1) && attr$2(
n,
"accept",
/*filetype*/
S[0]
), (!_ || w & /*file_count*/
16 && s !== (s = /*file_count*/
S[4] === "multiple" || void 0)) && (n.multiple = s), (!_ || w & /*file_count*/
16 && l !== (l = /*file_count*/
S[4] === "directory" || void 0)) && attr$2(n, "webkitdirectory", l), (!_ || w & /*file_count*/
16 && h !== (h = /*file_count*/
S[4] === "directory" || void 0)) && attr$2(n, "mozdirectory", h), (!_ || w & /*hidden*/
32) && toggle_class$1(
e,
"hidden",
/*hidden*/
S[5]
), (!_ || w & /*center*/
4) && toggle_class$1(
e,
"center",
/*center*/
S[2]
), (!_ || w & /*boundedheight*/
2) && toggle_class$1(
e,
"boundedheight",
/*boundedheight*/
S[1]
), (!_ || w & /*flex*/
8) && toggle_class$1(
e,
"flex",
/*flex*/
S[3]
);
},
i(S) {
_ || (transition_in$2(T, S), _ = !0);
},
o(S) {
transition_out$2(T, S), _ = !1;
},
d(S) {
S && detach$2(e), T && T.d(S), t[24](null), c = !1, run_all(o);
}
};
}
function _optionalChain(t) {
let e, i = t[0], n = 1;
for (; n < t.length; ) {
const s = t[n], l = t[n + 1];
if (n += 2, (s === "optionalAccess" || s === "optionalCall") && i == null)
return;
s === "access" || s === "optionalAccess" ? (e = i, i = l(i)) : (s === "call" || s === "optionalCall") && (i = l((...h) => i.call(e, ...h)), e = void 0);
}
return i;
}
function is_valid_mimetype(t, e) {
return !t || t === "*" ? !0 : t.endsWith("/*") ? e.startsWith(t.slice(0, -1)) : t === e;
}
function instance$2(t, e, i) {
let { $$slots: n = {}, $$scope: s } = e, { filetype: l = null } = e, { dragging: h = !1 } = e, { boundedheight: _ = !0 } = e, { center: c = !0 } = e, { flex: o = !0 } = e, { file_count: r = "single" } = e, { disable_click: T = !1 } = e, { root: S } = e, { hidden: w = !1 } = e;
const C = getContext("upload_files");
let P;
const b = createEventDispatcher$1();
function k() {
i(11, h = !h);
}
function F() {
T || (i(7, P.value = "", P), P.click());
}
async function x(B) {
await tick$1();
const ee = await upload(B, S, C);
return b("load", r === "single" ? _optionalChain([ee, "optionalAccess", (Y) => Y[0]]) : ee), ee || [];
}
async function y(B) {
if (!B.length)
return;
let ee = B.map((q) => new File([q], q.name)), Y = await prepare_files(ee);
return await x(Y);
}
async function p(B) {
const ee = B.target;
ee.files && await y(Array.from(ee.files));
}
async function E(B) {
if (i(11, h = !1), !_optionalChain([B, "access", (Y) => Y.dataTransfer, "optionalAccess", (Y) => Y.files]))
return;
const ee = Array.from(B.dataTransfer.files).filter((Y) => _optionalChain([
l,
"optionalAccess",
(q) => q.split,
"call",
(q) => q(","),
"access",
(q) => q.some,
"call",
(q) => q((le) => is_valid_mimetype(le, Y.type))
]) ? !0 : (b("error", `Invalid file type only ${l} allowed.`), !1));
await y(ee);
}
function $(B) {
bubble.call(this, t, B);
}
function M(B) {
bubble.call(this, t, B);
}
function m(B) {
bubble.call(this, t, B);
}
function N(B) {
bubble.call(this, t, B);
}
function D(B) {
bubble.call(this, t, B);
}
function X(B) {
bubble.call(this, t, B);
}
function G(B) {
bubble.call(this, t, B);
}
function I(B) {
binding_callbacks$1[B ? "unshift" : "push"](() => {
P = B, i(7, P);
});
}
return t.$$set = (B) => {
"filetype" in B && i(0, l = B.filetype), "dragging" in B && i(11, h = B.dragging), "boundedheight" in B && i(1, _ = B.boundedheight), "center" in B && i(2, c = B.center), "flex" in B && i(3, o = B.flex), "file_count" in B && i(4, r = B.file_count), "disable_click" in B && i(12, T = B.disable_click), "root" in B && i(13, S = B.root), "hidden" in B && i(5, w = B.hidden), "$$scope" in B && i(15, s = B.$$scope);
}, [
l,
_,
c,
o,
r,
w,
F,
P,
k,
p,
E,
h,
T,
S,
y,
s,
n,
$,
M,
m,
N,
D,
X,
G,
I
];
}
class Upload extends SvelteComponent$2 {
constructor(e) {
super(), init$2(this, e, instance$2, create_fragment$2, safe_not_equal$2, {
filetype: 0,
dragging: 11,
boundedheight: 1,
center: 2,
flex: 3,
file_count: 4,
disable_click: 12,
root: 13,
hidden: 5,
open_file_upload: 6,
load_files: 14
});
}
get open_file_upload() {
return this.$$.ctx[6];
}
get load_files() {
return this.$$.ctx[14];
}
}
const ModifyUpload_svelte_svelte_type_style_lang = "", {
SvelteComponent: SvelteComponent$1,
append: append$1,
attr: attr$1,
check_outros: check_outros$1,
create_component: create_component$1,
destroy_component: destroy_component$1,
detach: detach$1,
element: element$1,
group_outros: group_outros$1,
init: init$1,
insert: insert$1,
mount_component: mount_component$1,
safe_not_equal: safe_not_equal$1,
set_style: set_style$1,
space: space$1,
toggle_class,
transition_in: transition_in$1,
transition_out: transition_out$1
} = window.__gradio__svelte__internal, { createEventDispatcher } = window.__gradio__svelte__internal;
function create_if_block_1$1(t) {
let e, i;
return e = new IconButton({
props: {
Icon: Edit,
label: (
/*i18n*/
t[3]("common.edit")
)
}
}), e.$on(
"click",
/*click_handler*/
t[5]
), {
c() {
create_component$1(e.$$.fragment);
},
m(n, s) {
mount_component$1(e, n, s), i = !0;
},
p(n, s) {
const l = {};
s & /*i18n*/
8 && (l.label = /*i18n*/
n[3]("common.edit")), e.$set(l);
},
i(n) {
i || (transition_in$1(e.$$.fragment, n), i = !0);
},
o(n) {
transition_out$1(e.$$.fragment, n), i = !1;
},
d(n) {
destroy_component$1(e, n);
}
};
}
function create_if_block$1(t) {
let e, i;
return e = new IconButton({
props: {
Icon: Undo,
label: (
/*i18n*/
t[3]("common.undo")
)
}
}), e.$on(
"click",
/*click_handler_1*/
t[6]
), {
c() {
create_component$1(e.$$.fragment);
},
m(n, s) {
mount_component$1(e, n, s), i = !0;
},
p(n, s) {
const l = {};
s & /*i18n*/
8 && (l.label = /*i18n*/
n[3]("common.undo")), e.$set(l);
},
i(n) {
i || (transition_in$1(e.$$.fragment, n), i = !0);
},
o(n) {
transition_out$1(e.$$.fragment, n), i = !1;
},
d(n) {
destroy_component$1(e, n);
}
};
}
function create_fragment$1(t) {
let e, i, n, s, l, h = (
/*editable*/
t[0] && create_if_block_1$1(t)
), _ = (
/*undoable*/
t[1] && create_if_block$1(t)
);
return s = new IconButton({
props: {
Icon: Clear,
label: (
/*i18n*/
t[3]("common.clear")
)
}
}), s.$on(
"click",
/*click_handler_2*/
t[7]
), {
c() {
e = element$1("div"), h && h.c(), i = space$1(), _ && _.c(), n = space$1(), create_component$1(s.$$.fragment), attr$1(e, "class", "svelte-1wj0ocy"), toggle_class(e, "not-absolute", !/*absolute*/
t[2]), set_style$1(
e,
"position",
/*absolute*/
t[2] ? "absolute" : "static"
);
},
m(c, o) {
insert$1(c, e, o), h && h.m(e, null), append$1(e, i), _ && _.m(e, null), append$1(e, n), mount_component$1(s, e, null), l = !0;
},
p(c, [o]) {
/*editable*/
c[0] ? h ? (h.p(c, o), o & /*editable*/
1 && transition_in$1(h, 1)) : (h = create_if_block_1$1(c), h.c(), transition_in$1(h, 1), h.m(e, i)) : h && (group_outros$1(), transition_out$1(h, 1, 1, () => {
h = null;
}), check_outros$1()), /*undoable*/
c[1] ? _ ? (_.p(c, o), o & /*undoable*/
2 && transition_in$1(_, 1)) : (_ = create_if_block$1(c), _.c(), transition_in$1(_, 1), _.m(e, n)) : _ && (group_outros$1(), transition_out$1(_, 1, 1, () => {
_ = null;
}), check_outros$1());
const r = {};
o & /*i18n*/
8 && (r.label = /*i18n*/
c[3]("common.clear")), s.$set(r), (!l || o & /*absolute*/
4) && toggle_class(e, "not-absolute", !/*absolute*/
c[2]), o & /*absolute*/
4 && set_style$1(
e,
"position",
/*absolute*/
c[2] ? "absolute" : "static"
);
},
i(c) {
l || (transition_in$1(h), transition_in$1(_), transition_in$1(s.$$.fragment, c), l = !0);
},
o(c) {
transition_out$1(h), transition_out$1(_), transition_out$1(s.$$.fragment, c), l = !1;
},
d(c) {
c && detach$1(e), h && h.d(), _ && _.d(), destroy_component$1(s);
}
};
}
function instance$1(t, e, i) {
let { editable: n = !1 } = e, { undoable: s = !1 } = e, { absolute: l = !0 } = e, { i18n: h } = e;
const _ = createEventDispatcher(), c = () => _("edit"), o = () => _("undo"), r = (T) => {
_("clear"), T.stopPropagation();
};
return t.$$set = (T) => {
"editable" in T && i(0, n = T.editable), "undoable" in T && i(1, s = T.undoable), "absolute" in T && i(2, l = T.absolute), "i18n" in T && i(3, h = T.i18n);
}, [
n,
s,
l,
h,
_,
c,
o,
r
];
}
class ModifyUpload extends SvelteComponent$1 {
constructor(e) {
super(), init$1(this, e, instance$1, create_fragment$1, safe_not_equal$1, {
editable: 0,
undoable: 1,
absolute: 2,
i18n: 3
});
}
}
function commonjsRequire(t) {
throw new Error('Could not dynamically require "' + t + '". Please configure the dynamicRequireTargets or/and ignoreDynamicRequires option of @rollup/plugin-commonjs appropriately for this require call to work.');
}
var pdf = { exports: {} };
const require$$5$1 = {}, __viteBrowserExternal = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
__proto__: null,
default: require$$5$1
}, Symbol.toStringTag, { value: "Module" })), require$$5 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal);
(function(module, exports) {
(function(e, i) {
module.exports = e.pdfjsLib = i();
})(globalThis, () => (
/******/
(() => {
var __webpack_modules__ = [
,
/* 1 */
/***/
(t, e) => {
var Ye;
Object.defineProperty(e, "__esModule", {
value: !0
}), e.VerbosityLevel = e.Util = e.UnknownErrorException = e.UnexpectedResponseException = e.TextRenderingMode = e.RenderingIntentFlag = e.PromiseCapability = e.PermissionFlag = e.PasswordResponses = e.PasswordException = e.PageActionEventType = e.OPS = e.MissingPDFException = e.MAX_IMAGE_SIZE_TO_CACHE = e.LINE_FACTOR = e.LINE_DESCENT_FACTOR = e.InvalidPDFException = e.ImageKind = e.IDENTITY_MATRIX = e.FormatError = e.FeatureTest = e.FONT_IDENTITY_MATRIX = e.DocumentActionEventType = e.CMapCompressionType = e.BaseException = e.BASELINE_FACTOR = e.AnnotationType = e.AnnotationReplyType = e.AnnotationPrefix = e.AnnotationMode = e.AnnotationFlag = e.AnnotationFieldFlag = e.AnnotationEditorType = e.AnnotationEditorPrefix = e.AnnotationEditorParamsType = e.AnnotationBorderStyleType = e.AnnotationActionEventType = e.AbortException = void 0, e.assert = le, e.bytesToString = z, e.createValidAbsoluteUrl = we, e.getModificationDate = xe, e.getUuid = Xe, e.getVerbosityLevel = B, e.info = ee, e.isArrayBuffer = ge, e.isArrayEqual = Ce, e.isNodeJS = void 0, e.normalizeUnicode = ze, e.objectFromMap = ue, e.objectSize = ce, e.setVerbosityLevel = I, e.shadow = be, e.string32 = Q, e.stringToBytes = ae, e.stringToPDFString = _e, e.stringToUTF8String = ie, e.unreachable = q, e.utf8StringToString = se, e.warn = Y;
const i = typeof process == "object" && process + "" == "[object process]" && !process.versions.nw && !(process.versions.electron && process.type && process.type !== "browser");
e.isNodeJS = i;
const n = [1, 0, 0, 1, 0, 0];
e.IDENTITY_MATRIX = n;
const s = [1e-3, 0, 0, 1e-3, 0, 0];
e.FONT_IDENTITY_MATRIX = s;
const l = 1e7;
e.MAX_IMAGE_SIZE_TO_CACHE = l;
const h = 1.35;
e.LINE_FACTOR = h;
const _ = 0.35;
e.LINE_DESCENT_FACTOR = _;
const c = _ / h;
e.BASELINE_FACTOR = c;
const o = {
ANY: 1,
DISPLAY: 2,
PRINT: 4,
SAVE: 8,
ANNOTATIONS_FORMS: 16,
ANNOTATIONS_STORAGE: 32,
ANNOTATIONS_DISABLE: 64,
OPLIST: 256
};
e.RenderingIntentFlag = o;
const r = {
DISABLE: 0,
ENABLE: 1,
ENABLE_FORMS: 2,
ENABLE_STORAGE: 3
};
e.AnnotationMode = r;
const T = "pdfjs_internal_editor_";
e.AnnotationEditorPrefix = T;
const S = {
DISABLE: -1,
NONE: 0,
FREETEXT: 3,
STAMP: 13,
INK: 15
};
e.AnnotationEditorType = S;
const w = {
RESIZE: 1,
CREATE: 2,
FREETEXT_SIZE: 11,
FREETEXT_COLOR: 12,
FREETEXT_OPACITY: 13,
INK_COLOR: 21,
INK_THICKNESS: 22,
INK_OPACITY: 23
};
e.AnnotationEditorParamsType = w;
const C = {
PRINT: 4,
MODIFY_CONTENTS: 8,
COPY: 16,
MODIFY_ANNOTATIONS: 32,
FILL_INTERACTIVE_FORMS: 256,
COPY_FOR_ACCESSIBILITY: 512,
ASSEMBLE: 1024,
PRINT_HIGH_QUALITY: 2048
};
e.PermissionFlag = C;
const P = {
FILL: 0,
STROKE: 1,
FILL_STROKE: 2,
INVISIBLE: 3,
FILL_ADD_TO_PATH: 4,
STROKE_ADD_TO_PATH: 5,
FILL_STROKE_ADD_TO_PATH: 6,
ADD_TO_PATH: 7,
FILL_STROKE_MASK: 3,
ADD_TO_PATH_FLAG: 4
};
e.TextRenderingMode = P;
const b = {
GRAYSCALE_1BPP: 1,
RGB_24BPP: 2,
RGBA_32BPP: 3
};
e.ImageKind = b;
const k = {
TEXT: 1,
LINK: 2,
FREETEXT: 3,
LINE: 4,
SQUARE: 5,
CIRCLE: 6,
POLYGON: 7,
POLYLINE: 8,
HIGHLIGHT: 9,
UNDERLINE: 10,
SQUIGGLY: 11,
STRIKEOUT: 12,
STAMP: 13,
CARET: 14,
INK: 15,
POPUP: 16,
FILEATTACHMENT: 17,
SOUND: 18,
MOVIE: 19,
WIDGET: 20,
SCREEN: 21,
PRINTERMARK: 22,
TRAPNET: 23,
WATERMARK: 24,
THREED: 25,
REDACT: 26
};
e.AnnotationType = k;
const F = {
GROUP: "Group",
REPLY: "R"
};
e.AnnotationReplyType = F;
const x = {
INVISIBLE: 1,
HIDDEN: 2,
PRINT: 4,
NOZOOM: 8,
NOROTATE: 16,
NOVIEW: 32,
READONLY: 64,
LOCKED: 128,
TOGGLENOVIEW: 256,
LOCKEDCONTENTS: 512
};
e.AnnotationFlag = x;
const y = {
READONLY: 1,
REQUIRED: 2,
NOEXPORT: 4,
MULTILINE: 4096,
PASSWORD: 8192,
NOTOGGLETOOFF: 16384,
RADIO: 32768,
PUSHBUTTON: 65536,
COMBO: 131072,
EDIT: 262144,
SORT: 524288,
FILESELECT: 1048576,
MULTISELECT: 2097152,
DONOTSPELLCHECK: 4194304,
DONOTSCROLL: 8388608,
COMB: 16777216,
RICHTEXT: 33554432,
RADIOSINUNISON: 33554432,
COMMITONSELCHANGE: 67108864
};
e.AnnotationFieldFlag = y;
const p = {
SOLID: 1,
DASHED: 2,
BEVELED: 3,
INSET: 4,
UNDERLINE: 5
};
e.AnnotationBorderStyleType = p;
const E = {
E: "Mouse Enter",
X: "Mouse Exit",
D: "Mouse Down",
U: "Mouse Up",
Fo: "Focus",
Bl: "Blur",
PO: "PageOpen",
PC: "PageClose",
PV: "PageVisible",
PI: "PageInvisible",
K: "Keystroke",
F: "Format",
V: "Validate",
C: "Calculate"
};
e.AnnotationActionEventType = E;
const $ = {
WC: "WillClose",
WS: "WillSave",
DS: "DidSave",
WP: "WillPrint",
DP: "DidPrint"
};
e.DocumentActionEventType = $;
const M = {
O: "PageOpen",
C: "PageClose"
};
e.PageActionEventType = M;
const m = {
ERRORS: 0,
WARNINGS: 1,
INFOS: 5
};
e.VerbosityLevel = m;
const N = {
NONE: 0,
BINARY: 1
};
e.CMapCompressionType = N;
const D = {
dependency: 1,
setLineWidth: 2,
setLineCap: 3,
setLineJoin: 4,
setMiterLimit: 5,
setDash: 6,
setRenderingIntent: 7,
setFlatness: 8,
setGState: 9,
save: 10,
restore: 11,
transform: 12,
moveTo: 13,
lineTo: 14,
curveTo: 15,
curveTo2: 16,
curveTo3: 17,
closePath: 18,
rectangle: 19,
stroke: 20,
closeStroke: 21,
fill: 22,
eoFill: 23,
fillStroke: 24,
eoFillStroke: 25,
closeFillStroke: 26,
closeEOFillStroke: 27,
endPath: 28,
clip: 29,
eoClip: 30,
beginText: 31,
endText: 32,
setCharSpacing: 33,
setWordSpacing: 34,
setHScale: 35,
setLeading: 36,
setFont: 37,
setTextRenderingMode: 38,
setTextRise: 39,
moveText: 40,
setLeadingMoveText: 41,
setTextMatrix: 42,
nextLine: 43,
showText: 44,
showSpacedText: 45,
nextLineShowText: 46,
nextLineSetSpacingShowText: 47,
setCharWidth: 48,
setCharWidthAndBounds: 49,
setStrokeColorSpace: 50,
setFillColorSpace: 51,
setStrokeColor: 52,
setStrokeColorN: 53,
setFillColor: 54,
setFillColorN: 55,
setStrokeGray: 56,
setFillGray: 57,
setStrokeRGBColor: 58,
setFillRGBColor: 59,
setStrokeCMYKColor: 60,
setFillCMYKColor: 61,
shadingFill: 62,
beginInlineImage: 63,
beginImageData: 64,
endInlineImage: 65,
paintXObject: 66,
markPoint: 67,
markPointProps: 68,
beginMarkedContent: 69,
beginMarkedContentProps: 70,
endMarkedContent: 71,
beginCompat: 72,
endCompat: 73,
paintFormXObjectBegin: 74,
paintFormXObjectEnd: 75,
beginGroup: 76,
endGroup: 77,
beginAnnotation: 80,
endAnnotation: 81,
paintImageMaskXObject: 83,
paintImageMaskXObjectGroup: 84,
paintImageXObject: 85,
paintInlineImageXObject: 86,
paintInlineImageXObjectGroup: 87,
paintImageXObjectRepeat: 88,
paintImageMaskXObjectRepeat: 89,
paintSolidColorImageMask: 90,
constructPath: 91
};
e.OPS = D;
const X = {
NEED_PASSWORD: 1,
INCORRECT_PASSWORD: 2
};
e.PasswordResponses = X;
let G = m.WARNINGS;
function I(de) {
Number.isInteger(de) && (G = de);
}
function B() {
return G;
}
function ee(de) {
G >= m.INFOS && console.log(`Info: ${de}`);
}
function Y(de) {
G >= m.WARNINGS && console.log(`Warning: ${de}`);
}
function q(de) {
throw new Error(de);
}
function le(de, ne) {
de || q(ne);
}
function pe(de) {
switch (de == null ? void 0 : de.protocol) {
case "http:":
case "https:":
case "ftp:":
case "mailto:":
case "tel:":
return !0;
default:
return !1;
}
}
function we(de, ne = null, J = null) {
if (!de)
return null;
try {
if (J && typeof de == "string") {
if (J.addDefaultProtocol && de.startsWith("www.")) {
const Se = de.match(/\./g);
(Se == null ? void 0 : Se.length) >= 2 && (de = `http://${de}`);
}
if (J.tryConvertEncoding)
try {
de = ie(de);
} catch {
}
}
const ve = ne ? new URL(de, ne) : new URL(de);
if (pe(ve))
return ve;
} catch {
}
return null;
}
function be(de, ne, J, ve = !1) {
return Object.defineProperty(de, ne, {
value: J,
enumerable: !ve,
configurable: !0,
writable: !1
}), J;
}
const R = function() {
function ne(J, ve) {
this.constructor === ne && q("Cannot initialize BaseException."), this.message = J, this.name = ve;
}
return ne.prototype = new Error(), ne.constructor = ne, ne;
}();
e.BaseException = R;
class d extends R {
constructor(ne, J) {
super(ne, "PasswordException"), this.code = J;
}
}
e.PasswordException = d;
class g extends R {
constructor(ne, J) {
super(ne, "UnknownErrorException"), this.details = J;
}
}
e.UnknownErrorException = g;
class f extends R {
constructor(ne) {
super(ne, "InvalidPDFException");
}
}
e.InvalidPDFException = f;
class v extends R {
constructor(ne) {
super(ne, "MissingPDFException");
}
}
e.MissingPDFException = v;
class A extends R {
constructor(ne, J) {
super(ne, "UnexpectedResponseException"), this.status = J;
}
}
e.UnexpectedResponseException = A;
class O extends R {
constructor(ne) {
super(ne, "FormatError");
}
}
e.FormatError = O;
class H extends R {
constructor(ne) {
super(ne, "AbortException");
}
}
e.AbortException = H;
function z(de) {
(typeof de != "object" || (de == null ? void 0 : de.length) === void 0) && q("Invalid argument for bytesToString");
const ne = de.length, J = 8192;
if (ne < J)
return String.fromCharCode.apply(null, de);
const ve = [];
for (let Se = 0; Se < ne; Se += J) {
const tt = Math.min(Se + J, ne), et = de.subarray(Se, tt);
ve.push(String.fromCharCode.apply(null, et));
}
return ve.join("");
}
function ae(de) {
typeof de != "string" && q("Invalid argument for stringToBytes");
const ne = de.length, J = new Uint8Array(ne);
for (let ve = 0; ve < ne; ++ve)
J[ve] = de.charCodeAt(ve) & 255;
return J;
}
function Q(de) {
return String.fromCharCode(de >> 24 & 255, de >> 16 & 255, de >> 8 & 255, de & 255);
}
function ce(de) {
return Object.keys(de).length;
}
function ue(de) {
const ne = /* @__PURE__ */ Object.create(null);
for (const [J, ve] of de)
ne[J] = ve;
return ne;
}
function me() {
const de = new Uint8Array(4);
return de[0] = 1, new Uint32Array(de.buffer, 0, 1)[0] === 1;
}
function fe() {
try {
return new Function(""), !0;
} catch {
return !1;
}
}
class Pe {
static get isLittleEndian() {
return be(this, "isLittleEndian", me());
}
static get isEvalSupported() {
return be(this, "isEvalSupported", fe());
}
static get isOffscreenCanvasSupported() {
return be(this, "isOffscreenCanvasSupported", typeof OffscreenCanvas < "u");
}
static get platform() {
return typeof navigator > "u" ? be(this, "platform", {
isWin: !1,
isMac: !1
}) : be(this, "platform", {
isWin: navigator.platform.includes("Win"),
isMac: navigator.platform.includes("Mac")
});
}
static get isCSSRoundSupported() {
var ne, J;
return be(this, "isCSSRoundSupported", (J = (ne = globalThis.CSS) == null ? void 0 : ne.supports) == null ? void 0 : J.call(ne, "width: round(1.5px, 1px)"));
}
}
e.FeatureTest = Pe;
const Fe = [...Array(256).keys()].map((de) => de.toString(16).padStart(2, "0"));
class Ee {
static makeHexColor(ne, J, ve) {
return `#${Fe[ne]}${Fe[J]}${Fe[ve]}`;
}
static scaleMinMax(ne, J) {
let ve;
ne[0] ? (ne[0] < 0 && (ve = J[0], J[0] = J[1], J[1] = ve), J[0] *= ne[0], J[1] *= ne[0], ne[3] < 0 && (ve = J[2], J[2] = J[3], J[3] = ve), J[2] *= ne[3], J[3] *= ne[3]) : (ve = J[0], J[0] = J[2], J[2] = ve, ve = J[1], J[1] = J[3], J[3] = ve, ne[1] < 0 && (ve = J[2], J[2] = J[3], J[3] = ve), J[2] *= ne[1], J[3] *= ne[1], ne[2] < 0 && (ve = J[0], J[0] = J[1], J[1] = ve), J[0] *= ne[2], J[1] *= ne[2]), J[0] += ne[4], J[1] += ne[4], J[2] += ne[5], J[3] += ne[5];
}
static transform(ne, J) {
return [ne[0] * J[0] + ne[2] * J[1], ne[1] * J[0] + ne[3] * J[1], ne[0] * J[2] + ne[2] * J[3], ne[1] * J[2] + ne[3] * J[3], ne[0] * J[4] + ne[2] * J[5] + ne[4], ne[1] * J[4] + ne[3] * J[5] + ne[5]];
}
static applyTransform(ne, J) {
const ve = ne[0] * J[0] + ne[1] * J[2] + J[4], Se = ne[0] * J[1] + ne[1] * J[3] + J[5];
return [ve, Se];
}
static applyInverseTransform(ne, J) {
const ve = J[0] * J[3] - J[1] * J[2], Se = (ne[0] * J[3] - ne[1] * J[2] + J[2] * J[5] - J[4] * J[3]) / ve, tt = (-ne[0] * J[1] + ne[1] * J[0] + J[4] * J[1] - J[5] * J[0]) / ve;
return [Se, tt];
}
static getAxialAlignedBoundingBox(ne, J) {
const ve = this.applyTransform(ne, J), Se = this.applyTransform(ne.slice(2, 4), J), tt = this.applyTransform([ne[0], ne[3]], J), et = this.applyTransform([ne[2], ne[1]], J);
return [Math.min(ve[0], Se[0], tt[0], et[0]), Math.min(ve[1], Se[1], tt[1], et[1]), Math.max(ve[0], Se[0], tt[0], et[0]), Math.max(ve[1], Se[1], tt[1], et[1])];
}
static inverseTransform(ne) {
const J = ne[0] * ne[3] - ne[1] * ne[2];
return [ne[3] / J, -ne[1] / J, -ne[2] / J, ne[0] / J, (ne[2] * ne[5] - ne[4] * ne[3]) / J, (ne[4] * ne[1] - ne[5] * ne[0]) / J];
}
static singularValueDecompose2dScale(ne) {
const J = [ne[0], ne[2], ne[1], ne[3]], ve = ne[0] * J[0] + ne[1] * J[2], Se = ne[0] * J[1] + ne[1] * J[3], tt = ne[2] * J[0] + ne[3] * J[2], et = ne[2] * J[1] + ne[3] * J[3], te = (ve + et) / 2, Te = Math.sqrt((ve + et) ** 2 - 4 * (ve * et - tt * Se)) / 2, Ne = te + Te || 1, ke = te - Te || 1;
return [Math.sqrt(Ne), Math.sqrt(ke)];
}
static normalizeRect(ne) {
const J = ne.slice(0);
return ne[0] > ne[2] && (J[0] = ne[2], J[2] = ne[0]), ne[1] > ne[3] && (J[1] = ne[3], J[3] = ne[1]), J;
}
static intersect(ne, J) {
const ve = Math.max(Math.min(ne[0], ne[2]), Math.min(J[0], J[2])), Se = Math.min(Math.max(ne[0], ne[2]), Math.max(J[0], J[2]));
if (ve > Se)
return null;
const tt = Math.max(Math.min(ne[1], ne[3]), Math.min(J[1], J[3])), et = Math.min(Math.max(ne[1], ne[3]), Math.max(J[1], J[3]));
return tt > et ? null : [ve, tt, Se, et];
}
static bezierBoundingBox(ne, J, ve, Se, tt, et, te, Te) {
const Ne = [], ke = [[], []];
let $e, Be, Qe, Ae, Ke, Oe, U, u;
for (let Z = 0; Z < 2; ++Z) {
if (Z === 0 ? (Be = 6 * ne - 12 * ve + 6 * tt, $e = -3 * ne + 9 * ve - 9 * tt + 3 * te, Qe = 3 * ve - 3 * ne) : (Be = 6 * J - 12 * Se + 6 * et, $e = -3 * J + 9 * Se - 9 * et + 3 * Te, Qe = 3 * Se - 3 * J), Math.abs($e) < 1e-12) {
if (Math.abs(Be) < 1e-12)
continue;
Ae = -Qe / Be, 0 < Ae && Ae < 1 && Ne.push(Ae);
continue;
}
U = Be * Be - 4 * Qe * $e, u = Math.sqrt(U), !(U < 0) && (Ke = (-Be + u) / (2 * $e), 0 < Ke && Ke < 1 && Ne.push(Ke), Oe = (-Be - u) / (2 * $e), 0 < Oe && Oe < 1 && Ne.push(Oe));
}
let L = Ne.length, j;
const V = L;
for (; L--; )
Ae = Ne[L], j = 1 - Ae, ke[0][L] = j * j * j * ne + 3 * j * j * Ae * ve + 3 * j * Ae * Ae * tt + Ae * Ae * Ae * te, ke[1][L] = j * j * j * J + 3 * j * j * Ae * Se + 3 * j * Ae * Ae * et + Ae * Ae * Ae * Te;
return ke[0][V] = ne, ke[1][V] = J, ke[0][V + 1] = te, ke[1][V + 1] = Te, ke[0].length = ke[1].length = V + 2, [Math.min(...ke[0]), Math.min(...ke[1]), Math.max(...ke[0]), Math.max(...ke[1])];
}
}
e.Util = Ee;
const De = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 728, 711, 710, 729, 733, 731, 730, 732, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8226, 8224, 8225, 8230, 8212, 8211, 402, 8260, 8249, 8250, 8722, 8240, 8222, 8220, 8221, 8216, 8217, 8218, 8482, 64257, 64258, 321, 338, 352, 376, 381, 305, 322, 339, 353, 382, 0, 8364];
function _e(de) {
if (de[0] >= "ï") {
let J;
if (de[0] === "þ" && de[1] === "ÿ" ? J = "utf-16be" : de[0] === "ÿ" && de[1] === "þ" ? J = "utf-16le" : de[0] === "ï" && de[1] === "»" && de[2] === "¿" && (J = "utf-8"), J)
try {
const ve = new TextDecoder(J, {
fatal: !0
}), Se = ae(de);
return ve.decode(Se);
} catch (ve) {
Y(`stringToPDFString: "${ve}".`);
}
}
const ne = [];
for (let J = 0, ve = de.length; J < ve; J++) {
const Se = De[de.charCodeAt(J)];
ne.push(Se ? String.fromCharCode(Se) : de.charAt(J));
}
return ne.join("");
}
function ie(de) {
return decodeURIComponent(escape(de));
}
function se(de) {
return unescape(encodeURIComponent(de));
}
function ge(de) {
return typeof de == "object" && (de == null ? void 0 : de.byteLength) !== void 0;
}
function Ce(de, ne) {
if (de.length !== ne.length)
return !1;
for (let J = 0, ve = de.length; J < ve; J++)
if (de[J] !== ne[J])
return !1;
return !0;
}
function xe(de = /* @__PURE__ */ new Date()) {
return [de.getUTCFullYear().toString(), (de.getUTCMonth() + 1).toString().padStart(2, "0"), de.getUTCDate().toString().padStart(2, "0"), de.getUTCHours().toString().padStart(2, "0"), de.getUTCMinutes().toString().padStart(2, "0"), de.getUTCSeconds().toString().padStart(2, "0")].join("");
}
class Ue {
constructor() {
W(this, Ye, !1);
this.promise = new Promise((ne, J) => {
this.resolve = (ve) => {
oe(this, Ye, !0), ne(ve);
}, this.reject = (ve) => {
oe(this, Ye, !0), J(ve);
};
});
}
get settled() {
return a(this, Ye);
}
}
Ye = new WeakMap(), e.PromiseCapability = Ue;
let We = null, je = null;
function ze(de) {
return We || (We = /([\u00a0\u00b5\u037e\u0eb3\u2000-\u200a\u202f\u2126\ufb00-\ufb04\ufb06\ufb20-\ufb36\ufb38-\ufb3c\ufb3e\ufb40-\ufb41\ufb43-\ufb44\ufb46-\ufba1\ufba4-\ufba9\ufbae-\ufbb1\ufbd3-\ufbdc\ufbde-\ufbe7\ufbea-\ufbf8\ufbfc-\ufbfd\ufc00-\ufc5d\ufc64-\ufcf1\ufcf5-\ufd3d\ufd88\ufdf4\ufdfa-\ufdfb\ufe71\ufe77\ufe79\ufe7b\ufe7d]+)|(\ufb05+)/gu, je = /* @__PURE__ */ new Map([["ſt", "ſt"]])), de.replaceAll(We, (ne, J, ve) => J ? J.normalize("NFKC") : je.get(ve));
}
function Xe() {
if (typeof crypto < "u" && typeof (crypto == null ? void 0 : crypto.randomUUID) == "function")
return crypto.randomUUID();
const de = new Uint8Array(32);
if (typeof crypto < "u" && typeof (crypto == null ? void 0 : crypto.getRandomValues) == "function")
crypto.getRandomValues(de);
else
for (let ne = 0; ne < 32; ne++)
de[ne] = Math.floor(Math.random() * 255);
return z(de);
}
const Ge = "pdfjs_internal_id_";
e.AnnotationPrefix = Ge;
},
/* 2 */
/***/
(__unused_webpack_module, exports, __w_pdfjs_require__) => {
var t, i, n, s, ut, h, wt, c, o, r, T, S, w, C, P, b, Tt, F, x, Bt, p, E;
Object.defineProperty(exports, "__esModule", {
value: !0
}), exports.RenderTask = exports.PDFWorkerUtil = exports.PDFWorker = exports.PDFPageProxy = exports.PDFDocumentProxy = exports.PDFDocumentLoadingTask = exports.PDFDataRangeTransport = exports.LoopbackPort = exports.DefaultStandardFontDataFactory = exports.DefaultFilterFactory = exports.DefaultCanvasFactory = exports.DefaultCMapReaderFactory = void 0, Object.defineProperty(exports, "SVGGraphics", {
enumerable: !0,
get: function() {
return _displaySvg.SVGGraphics;
}
}), exports.build = void 0, exports.getDocument = getDocument, exports.version = void 0;
var _util = __w_pdfjs_require__(1), _annotation_storage = __w_pdfjs_require__(3), _display_utils = __w_pdfjs_require__(6), _font_loader = __w_pdfjs_require__(9), _displayNode_utils = __w_pdfjs_require__(10), _canvas = __w_pdfjs_require__(11), _worker_options = __w_pdfjs_require__(14), _message_handler = __w_pdfjs_require__(15), _metadata = __w_pdfjs_require__(16), _optional_content_config = __w_pdfjs_require__(17), _transport_stream = __w_pdfjs_require__(18), _displayFetch_stream = __w_pdfjs_require__(19), _displayNetwork = __w_pdfjs_require__(22), _displayNode_stream = __w_pdfjs_require__(23), _displaySvg = __w_pdfjs_require__(24), _xfa_text = __w_pdfjs_require__(25);
const DEFAULT_RANGE_CHUNK_SIZE = 65536, RENDERING_CANCELLED_TIMEOUT = 100, DELAYED_CLEANUP_TIMEOUT = 5e3, DefaultCanvasFactory = _util.isNodeJS ? _displayNode_utils.NodeCanvasFactory : _display_utils.DOMCanvasFactory;
exports.DefaultCanvasFactory = DefaultCanvasFactory;
const DefaultCMapReaderFactory = _util.isNodeJS ? _displayNode_utils.NodeCMapReaderFactory : _display_utils.DOMCMapReaderFactory;
exports.DefaultCMapReaderFactory = DefaultCMapReaderFactory;
const DefaultFilterFactory = _util.isNodeJS ? _displayNode_utils.NodeFilterFactory : _display_utils.DOMFilterFactory;
exports.DefaultFilterFactory = DefaultFilterFactory;
const DefaultStandardFontDataFactory = _util.isNodeJS ? _displayNode_utils.NodeStandardFontDataFactory : _display_utils.DOMStandardFontDataFactory;
exports.DefaultStandardFontDataFactory = DefaultStandardFontDataFactory;
function getDocument(M) {
if (typeof M == "string" || M instanceof URL ? M = {
url: M
} : (0, _util.isArrayBuffer)(M) && (M = {
data: M
}), typeof M != "object")
throw new Error("Invalid parameter in getDocument, need parameter object.");
if (!M.url && !M.data && !M.range)
throw new Error("Invalid parameter object: need either .data, .range or .url");
const m = new PDFDocumentLoadingTask(), {
docId: N
} = m, D = M.url ? getUrlProp(M.url) : null, X = M.data ? getDataProp(M.data) : null, G = M.httpHeaders || null, I = M.withCredentials === !0, B = M.password ?? null, ee = M.range instanceof PDFDataRangeTransport ? M.range : null, Y = Number.isInteger(M.rangeChunkSize) && M.rangeChunkSize > 0 ? M.rangeChunkSize : DEFAULT_RANGE_CHUNK_SIZE;
let q = M.worker instanceof PDFWorker ? M.worker : null;
const le = M.verbosity, pe = typeof M.docBaseUrl == "string" && !(0, _display_utils.isDataScheme)(M.docBaseUrl) ? M.docBaseUrl : null, we = typeof M.cMapUrl == "string" ? M.cMapUrl : null, be = M.cMapPacked !== !1, R = M.CMapReaderFactory || DefaultCMapReaderFactory, d = typeof M.standardFontDataUrl == "string" ? M.standardFontDataUrl : null, g = M.StandardFontDataFactory || DefaultStandardFontDataFactory, f = M.stopAtErrors !== !0, v = Number.isInteger(M.maxImageSize) && M.maxImageSize > -1 ? M.maxImageSize : -1, A = M.isEvalSupported !== !1, O = typeof M.isOffscreenCanvasSupported == "boolean" ? M.isOffscreenCanvasSupported : !_util.isNodeJS, H = Number.isInteger(M.canvasMaxAreaInBytes) ? M.canvasMaxAreaInBytes : -1, z = typeof M.disableFontFace == "boolean" ? M.disableFontFace : _util.isNodeJS, ae = M.fontExtraProperties === !0, Q = M.enableXfa === !0, ce = M.ownerDocument || globalThis.document, ue = M.disableRange === !0, me = M.disableStream === !0, fe = M.disableAutoFetch === !0, Pe = M.pdfBug === !0, Fe = ee ? ee.length : M.length ?? NaN, Ee = typeof M.useSystemFonts == "boolean" ? M.useSystemFonts : !_util.isNodeJS && !z, De = typeof M.useWorkerFetch == "boolean" ? M.useWorkerFetch : R === _display_utils.DOMCMapReaderFactory && g === _display_utils.DOMStandardFontDataFactory && we && d && (0, _display_utils.isValidFetchUrl)(we, document.baseURI) && (0, _display_utils.isValidFetchUrl)(d, document.baseURI), _e = M.canvasFactory || new DefaultCanvasFactory({
ownerDocument: ce
}), ie = M.filterFactory || new DefaultFilterFactory({
docId: N,
ownerDocument: ce
}), se = null;
(0, _util.setVerbosityLevel)(le);
const ge = {
canvasFactory: _e,
filterFactory: ie
};
if (De || (ge.cMapReaderFactory = new R({
baseUrl: we,
isCompressed: be
}), ge.standardFontDataFactory = new g({
baseUrl: d
})), !q) {
const Ue = {
verbosity: le,
port: _worker_options.GlobalWorkerOptions.workerPort
};
q = Ue.port ? PDFWorker.fromPort(Ue) : new PDFWorker(Ue), m._worker = q;
}
const Ce = {
docId: N,
apiVersion: "3.11.174",
data: X,
password: B,
disableAutoFetch: fe,
rangeChunkSize: Y,
length: Fe,
docBaseUrl: pe,
enableXfa: Q,
evaluatorOptions: {
maxImageSize: v,
disableFontFace: z,
ignoreErrors: f,
isEvalSupported: A,
isOffscreenCanvasSupported: O,
canvasMaxAreaInBytes: H,
fontExtraProperties: ae,
useSystemFonts: Ee,
cMapUrl: De ? we : null,
standardFontDataUrl: De ? d : null
}
}, xe = {
ignoreErrors: f,
isEvalSupported: A,
disableFontFace: z,
fontExtraProperties: ae,
enableXfa: Q,
ownerDocument: ce,
disableAutoFetch: fe,
pdfBug: Pe,
styleElement: se
};
return q.promise.then(function() {
if (m.destroyed)
throw new Error("Loading aborted");
const Ue = _fetchDocument(q, Ce), We = new Promise(function(je) {
let ze;
ee ? ze = new _transport_stream.PDFDataTransportStream({
length: Fe,
initialData: ee.initialData,
progressiveDone: ee.progressiveDone,
contentDispositionFilename: ee.contentDispositionFilename,
disableRange: ue,
disableStream: me
}, ee) : X || (ze = ((Ge) => _util.isNodeJS ? new _displayNode_stream.PDFNodeStream(Ge) : (0, _display_utils.isValidFetchUrl)(Ge.url) ? new _displayFetch_stream.PDFFetchStream(Ge) : new _displayNetwork.PDFNetworkStream(Ge))({
url: D,
length: Fe,
httpHeaders: G,
withCredentials: I,
rangeChunkSize: Y,
disableRange: ue,
disableStream: me
})), je(ze);
});
return Promise.all([Ue, We]).then(function([je, ze]) {
if (m.destroyed)
throw new Error("Loading aborted");
const Xe = new _message_handler.MessageHandler(N, je, q.port), Ge = new WorkerTransport(Xe, m, ze, xe, ge);
m._transport = Ge, Xe.send("Ready", null);
});
}).catch(m._capability.reject), m;
}
async function _fetchDocument(M, m) {
if (M.destroyed)
throw new Error("Worker was destroyed");
const N = await M.messageHandler.sendWithPromise("GetDocRequest", m, m.data ? [m.data.buffer] : null);
if (M.destroyed)
throw new Error("Worker was destroyed");
return N;
}
function getUrlProp(M) {
if (M instanceof URL)
return M.href;
try {
return new URL(M, window.location).href;
} catch {
if (_util.isNodeJS && typeof M == "string")
return M;
}
throw new Error("Invalid PDF url data: either string or URL-object is expected in the url property.");
}
function getDataProp(M) {
if (_util.isNodeJS && typeof Buffer < "u" && M instanceof Buffer)
throw new Error("Please provide binary data as `Uint8Array`, rather than `Buffer`.");
if (M instanceof Uint8Array && M.byteLength === M.buffer.byteLength)
return M;
if (typeof M == "string")
return (0, _util.stringToBytes)(M);
if (typeof M == "object" && !isNaN(M == null ? void 0 : M.length) || (0, _util.isArrayBuffer)(M))
return new Uint8Array(M);
throw new Error("Invalid PDF binary data: either TypedArray, string, or array-like object is expected in the data property.");
}
const e = class e {
constructor() {
this._capability = new _util.PromiseCapability(), this._transport = null, this._worker = null, this.docId = `d${_t(e, t)._++}`, this.destroyed = !1, this.onPassword = null, this.onProgress = null;
}
get promise() {
return this._capability.promise;
}
async destroy() {
var m, N, D;
this.destroyed = !0;
try {
(m = this._worker) != null && m.port && (this._worker._pendingDestroy = !0), await ((N = this._transport) == null ? void 0 : N.destroy());
} catch (X) {
throw (D = this._worker) != null && D.port && delete this._worker._pendingDestroy, X;
}
this._transport = null, this._worker && (this._worker.destroy(), this._worker = null);
}
};
t = new WeakMap(), W(e, t, 0);
let PDFDocumentLoadingTask = e;
exports.PDFDocumentLoadingTask = PDFDocumentLoadingTask;
class PDFDataRangeTransport {
constructor(m, N, D = !1, X = null) {
this.length = m, this.initialData = N, this.progressiveDone = D, this.contentDispositionFilename = X, this._rangeListeners = [], this._progressListeners = [], this._progressiveReadListeners = [], this._progressiveDoneListeners = [], this._readyCapability = new _util.PromiseCapability();
}
addRangeListener(m) {
this._rangeListeners.push(m);
}
addProgressListener(m) {
this._progressListeners.push(m);
}
addProgressiveReadListener(m) {
this._progressiveReadListeners.push(m);
}
addProgressiveDoneListener(m) {
this._progressiveDoneListeners.push(m);
}
onDataRange(m, N) {
for (const D of this._rangeListeners)
D(m, N);
}
onDataProgress(m, N) {
this._readyCapability.promise.then(() => {
for (const D of this._progressListeners)
D(m, N);
});
}
onDataProgressiveRead(m) {
this._readyCapability.promise.then(() => {
for (const N of this._progressiveReadListeners)
N(m);
});
}
onDataProgressiveDone() {
this._readyCapability.promise.then(() => {
for (const m of this._progressiveDoneListeners)
m();
});
}
transportReady() {
this._readyCapability.resolve();
}
requestDataRange(m, N) {
(0, _util.unreachable)("Abstract method PDFDataRangeTransport.requestDataRange");
}
abort() {
}
}
exports.PDFDataRangeTransport = PDFDataRangeTransport;
class PDFDocumentProxy {
constructor(m, N) {
this._pdfInfo = m, this._transport = N, Object.defineProperty(this, "getJavaScript", {
value: () => ((0, _display_utils.deprecated)("`PDFDocumentProxy.getJavaScript`, please use `PDFDocumentProxy.getJSActions` instead."), this.getJSActions().then((D) => {
if (!D)
return D;
const X = [];
for (const G in D)
X.push(...D[G]);
return X;
}))
});
}
get annotationStorage() {
return this._transport.annotationStorage;
}
get filterFactory() {
return this._transport.filterFactory;
}
get numPages() {
return this._pdfInfo.numPages;
}
get fingerprints() {
return this._pdfInfo.fingerprints;
}
get isPureXfa() {
return (0, _util.shadow)(this, "isPureXfa", !!this._transport._htmlForXfa);
}
get allXfaHtml() {
return this._transport._htmlForXfa;
}
getPage(m) {
return this._transport.getPage(m);
}
getPageIndex(m) {
return this._transport.getPageIndex(m);
}
getDestinations() {
return this._transport.getDestinations();
}
getDestination(m) {
return this._transport.getDestination(m);
}
getPageLabels() {
return this._transport.getPageLabels();
}
getPageLayout() {
return this._transport.getPageLayout();
}
getPageMode() {
return this._transport.getPageMode();
}
getViewerPreferences() {
return this._transport.getViewerPreferences();
}
getOpenAction() {
return this._transport.getOpenAction();
}
getAttachments() {
return this._transport.getAttachments();
}
getJSActions() {
return this._transport.getDocJSActions();
}
getOutline() {
return this._transport.getOutline();
}
getOptionalContentConfig() {
return this._transport.getOptionalContentConfig();
}
getPermissions() {
return this._transport.getPermissions();
}
getMetadata() {
return this._transport.getMetadata();
}
getMarkInfo() {
return this._transport.getMarkInfo();
}
getData() {
return this._transport.getData();
}
saveDocument() {
return this._transport.saveDocument();
}
getDownloadInfo() {
return this._transport.downloadInfoCapability.promise;
}
cleanup(m = !1) {
return this._transport.startCleanup(m || this.isPureXfa);
}
destroy() {
return this.loadingTask.destroy();
}
get loadingParams() {
return this._transport.loadingParams;
}
get loadingTask() {
return this._transport.loadingTask;
}
getFieldObjects() {
return this._transport.getFieldObjects();
}
hasJSActions() {
return this._transport.hasJSActions();
}
getCalculationOrderIds() {
return this._transport.getCalculationOrderIds();
}
}
exports.PDFDocumentProxy = PDFDocumentProxy;
class PDFPageProxy {
constructor(m, N, D, X = !1) {
W(this, s);
W(this, h);
W(this, i, null);
W(this, n, !1);
this._pageIndex = m, this._pageInfo = N, this._transport = D, this._stats = X ? new _display_utils.StatTimer() : null, this._pdfBug = X, this.commonObjs = D.commonObjs, this.objs = new PDFObjects(), this._maybeCleanupAfterRender = !1, this._intentStates = /* @__PURE__ */ new Map(), this.destroyed = !1;
}
get pageNumber() {
return this._pageIndex + 1;
}
get rotate() {
return this._pageInfo.rotate;
}
get ref() {
return this._pageInfo.ref;
}
get userUnit() {
return this._pageInfo.userUnit;
}
get view() {
return this._pageInfo.view;
}
getViewport({
scale: m,
rotation: N = this.rotate,
offsetX: D = 0,
offsetY: X = 0,
dontFlip: G = !1
} = {}) {
return new _display_utils.PageViewport({
viewBox: this.view,
scale: m,
rotation: N,
offsetX: D,
offsetY: X,
dontFlip: G
});
}
getAnnotations({
intent: m = "display"
} = {}) {
const N = this._transport.getRenderingIntent(m);
return this._transport.getAnnotations(this._pageIndex, N.renderingIntent);
}
getJSActions() {
return this._transport.getPageJSActions(this._pageIndex);
}
get filterFactory() {
return this._transport.filterFactory;
}
get isPureXfa() {
return (0, _util.shadow)(this, "isPureXfa", !!this._transport._htmlForXfa);
}
async getXfa() {
var m;
return ((m = this._transport._htmlForXfa) == null ? void 0 : m.children[this._pageIndex]) || null;
}
render({
canvasContext: m,
viewport: N,
intent: D = "display",
annotationMode: X = _util.AnnotationMode.ENABLE,
transform: G = null,
background: I = null,
optionalContentConfigPromise: B = null,
annotationCanvasMap: ee = null,
pageColors: Y = null,
printAnnotationStorage: q = null
}) {
var g, f;
(g = this._stats) == null || g.time("Overall");
const le = this._transport.getRenderingIntent(D, X, q);
oe(this, n, !1), K(this, h, wt).call(this), B || (B = this._transport.getOptionalContentConfig());
let pe = this._intentStates.get(le.cacheKey);
pe || (pe = /* @__PURE__ */ Object.create(null), this._intentStates.set(le.cacheKey, pe)), pe.streamReaderCancelTimeout && (clearTimeout(pe.streamReaderCancelTimeout), pe.streamReaderCancelTimeout = null);
const we = !!(le.renderingIntent & _util.RenderingIntentFlag.PRINT);
pe.displayReadyCapability || (pe.displayReadyCapability = new _util.PromiseCapability(), pe.operatorList = {
fnArray: [],
argsArray: [],
lastChunk: !1,
separateAnnots: null
}, (f = this._stats) == null || f.time("Page Request"), this._pumpOperatorList(le));
const be = (v) => {
var A, O;
pe.renderTasks.delete(R), (this._maybeCleanupAfterRender || we) && oe(this, n, !0), K(this, s, ut).call(this, !we), v ? (R.capability.reject(v), this._abortOperatorList({
intentState: pe,
reason: v instanceof Error ? v : new Error(v)
})) : R.capability.resolve(), (A = this._stats) == null || A.timeEnd("Rendering"), (O = this._stats) == null || O.timeEnd("Overall");
}, R = new InternalRenderTask({
callback: be,
params: {
canvasContext: m,
viewport: N,
transform: G,
background: I
},
objs: this.objs,
commonObjs: this.commonObjs,
annotationCanvasMap: ee,
operatorList: pe.operatorList,
pageIndex: this._pageIndex,
canvasFactory: this._transport.canvasFactory,
filterFactory: this._transport.filterFactory,
useRequestAnimationFrame: !we,
pdfBug: this._pdfBug,
pageColors: Y
});
(pe.renderTasks || (pe.renderTasks = /* @__PURE__ */ new Set())).add(R);
const d = R.task;
return Promise.all([pe.displayReadyCapability.promise, B]).then(([v, A]) => {
var O;
if (this.destroyed) {
be();
return;
}
(O = this._stats) == null || O.time("Rendering"), R.initializeGraphics({
transparency: v,
optionalContentConfig: A
}), R.operatorListChanged();
}).catch(be), d;
}
getOperatorList({
intent: m = "display",
annotationMode: N = _util.AnnotationMode.ENABLE,
printAnnotationStorage: D = null
} = {}) {
var ee;
function X() {
I.operatorList.lastChunk && (I.opListReadCapability.resolve(I.operatorList), I.renderTasks.delete(B));
}
const G = this._transport.getRenderingIntent(m, N, D, !0);
let I = this._intentStates.get(G.cacheKey);
I || (I = /* @__PURE__ */ Object.create(null), this._intentStates.set(G.cacheKey, I));
let B;
return I.opListReadCapability || (B = /* @__PURE__ */ Object.create(null), B.operatorListChanged = X, I.opListReadCapability = new _util.PromiseCapability(), (I.renderTasks || (I.renderTasks = /* @__PURE__ */ new Set())).add(B), I.operatorList = {
fnArray: [],
argsArray: [],
lastChunk: !1,
separateAnnots: null
}, (ee = this._stats) == null || ee.time("Page Request"), this._pumpOperatorList(G)), I.opListReadCapability.promise;
}
streamTextContent({
includeMarkedContent: m = !1,
disableNormalization: N = !1
} = {}) {
return this._transport.messageHandler.sendWithStream("GetTextContent", {
pageIndex: this._pageIndex,
includeMarkedContent: m === !0,
disableNormalization: N === !0
}, {
highWaterMark: 100,
size(X) {
return X.items.length;
}
});
}
getTextContent(m = {}) {
if (this._transport._htmlForXfa)
return this.getXfa().then((D) => _xfa_text.XfaText.textContent(D));
const N = this.streamTextContent(m);
return new Promise(function(D, X) {
function G() {
I.read().then(function({
value: ee,
done: Y
}) {
if (Y) {
D(B);
return;
}
Object.assign(B.styles, ee.styles), B.items.push(...ee.items), G();
}, X);
}
const I = N.getReader(), B = {
items: [],
styles: /* @__PURE__ */ Object.create(null)
};
G();
});
}
getStructTree() {
return this._transport.getStructTree(this._pageIndex);
}
_destroy() {
this.destroyed = !0;
const m = [];
for (const N of this._intentStates.values())
if (this._abortOperatorList({
intentState: N,
reason: new Error("Page was destroyed."),
force: !0
}), !N.opListReadCapability)
for (const D of N.renderTasks)
m.push(D.completed), D.cancel();
return this.objs.clear(), oe(this, n, !1), K(this, h, wt).call(this), Promise.all(m);
}
cleanup(m = !1) {
oe(this, n, !0);
const N = K(this, s, ut).call(this, !1);
return m && N && this._stats && (this._stats = new _display_utils.StatTimer()), N;
}
_startRenderPage(m, N) {
var X, G;
const D = this._intentStates.get(N);
D && ((X = this._stats) == null || X.timeEnd("Page Request"), (G = D.displayReadyCapability) == null || G.resolve(m));
}
_renderPageChunk(m, N) {
for (let D = 0, X = m.length; D < X; D++)
N.operatorList.fnArray.push(m.fnArray[D]), N.operatorList.argsArray.push(m.argsArray[D]);
N.operatorList.lastChunk = m.lastChunk, N.operatorList.separateAnnots = m.separateAnnots;
for (const D of N.renderTasks)
D.operatorListChanged();
m.lastChunk && K(this, s, ut).call(this, !0);
}
_pumpOperatorList({
renderingIntent: m,
cacheKey: N,
annotationStorageSerializable: D
}) {
const {
map: X,
transfers: G
} = D, B = this._transport.messageHandler.sendWithStream("GetOperatorList", {
pageIndex: this._pageIndex,
intent: m,
cacheKey: N,
annotationStorage: X
}, G).getReader(), ee = this._intentStates.get(N);
ee.streamReader = B;
const Y = () => {
B.read().then(({
value: q,
done: le
}) => {
if (le) {
ee.streamReader = null;
return;
}
this._transport.destroyed || (this._renderPageChunk(q, ee), Y());
}, (q) => {
if (ee.streamReader = null, !this._transport.destroyed) {
if (ee.operatorList) {
ee.operatorList.lastChunk = !0;
for (const le of ee.renderTasks)
le.operatorListChanged();
K(this, s, ut).call(this, !0);
}
if (ee.displayReadyCapability)
ee.displayReadyCapability.reject(q);
else if (ee.opListReadCapability)
ee.opListReadCapability.reject(q);
else
throw q;
}
});
};
Y();
}
_abortOperatorList({
intentState: m,
reason: N,
force: D = !1
}) {
if (m.streamReader) {
if (m.streamReaderCancelTimeout && (clearTimeout(m.streamReaderCancelTimeout), m.streamReaderCancelTimeout = null), !D) {
if (m.renderTasks.size > 0)
return;
if (N instanceof _display_utils.RenderingCancelledException) {
let X = RENDERING_CANCELLED_TIMEOUT;
N.extraDelay > 0 && N.extraDelay < 1e3 && (X += N.extraDelay), m.streamReaderCancelTimeout = setTimeout(() => {
m.streamReaderCancelTimeout = null, this._abortOperatorList({
intentState: m,
reason: N,
force: !0
});
}, X);
return;
}
}
if (m.streamReader.cancel(new _util.AbortException(N.message)).catch(() => {
}), m.streamReader = null, !this._transport.destroyed) {
for (const [X, G] of this._intentStates)
if (G === m) {
this._intentStates.delete(X);
break;
}
this.cleanup();
}
}
}
get stats() {
return this._stats;
}
}
i = new WeakMap(), n = new WeakMap(), s = new WeakSet(), ut = function(m = !1) {
if (K(this, h, wt).call(this), !a(this, n) || this.destroyed)
return !1;
if (m)
return oe(this, i, setTimeout(() => {
oe(this, i, null), K(this, s, ut).call(this, !1);
}, DELAYED_CLEANUP_TIMEOUT)), !1;
for (const {
renderTasks: N,
operatorList: D
} of this._intentStates.values())
if (N.size > 0 || !D.lastChunk)
return !1;
return this._intentStates.clear(), this.objs.clear(), oe(this, n, !1), !0;
}, h = new WeakSet(), wt = function() {
a(this, i) && (clearTimeout(a(this, i)), oe(this, i, null));
}, exports.PDFPageProxy = PDFPageProxy;
class LoopbackPort {
constructor() {
W(this, c, /* @__PURE__ */ new Set());
W(this, o, Promise.resolve());
}
postMessage(m, N) {
const D = {
data: structuredClone(m, N ? {
transfer: N
} : null)
};
a(this, o).then(() => {
for (const X of a(this, c))
X.call(this, D);
});
}
addEventListener(m, N) {
a(this, c).add(N);
}
removeEventListener(m, N) {
a(this, c).delete(N);
}
terminate() {
a(this, c).clear();
}
}
c = new WeakMap(), o = new WeakMap(), exports.LoopbackPort = LoopbackPort;
const PDFWorkerUtil = {
isWorkerDisabled: !1,
fallbackWorkerSrc: null,
fakeWorkerId: 0
};
exports.PDFWorkerUtil = PDFWorkerUtil;
{
if (_util.isNodeJS && typeof commonjsRequire == "function")
PDFWorkerUtil.isWorkerDisabled = !0, PDFWorkerUtil.fallbackWorkerSrc = "./pdf.worker.js";
else if (typeof document == "object") {
const M = (r = document == null ? void 0 : document.currentScript) == null ? void 0 : r.src;
M && (PDFWorkerUtil.fallbackWorkerSrc = M.replace(/(\.(?:min\.)?js)(\?.*)?$/i, ".worker$1$2"));
}
PDFWorkerUtil.isSameOrigin = function(M, m) {
let N;
try {
if (N = new URL(M), !N.origin || N.origin === "null")
return !1;
} catch {
return !1;
}
const D = new URL(m, N);
return N.origin === D.origin;
}, PDFWorkerUtil.createCDNWrapper = function(M) {
const m = `importScripts("${M}");`;
return URL.createObjectURL(new Blob([m]));
};
}
const _PDFWorker = class _PDFWorker {
constructor({
name: M = null,
port: m = null,
verbosity: N = (0, _util.getVerbosityLevel)()
} = {}) {
var D;
if (this.name = M, this.destroyed = !1, this.verbosity = N, this._readyCapability = new _util.PromiseCapability(), this._port = null, this._webWorker = null, this._messageHandler = null, m) {
if ((D = a(_PDFWorker, T)) != null && D.has(m))
throw new Error("Cannot use more than one PDFWorker per port.");
(a(_PDFWorker, T) || oe(_PDFWorker, T, /* @__PURE__ */ new WeakMap())).set(m, this), this._initializeFromPort(m);
return;
}
this._initialize();
}
get promise() {
return this._readyCapability.promise;
}
get port() {
return this._port;
}
get messageHandler() {
return this._messageHandler;
}
_initializeFromPort(M) {
this._port = M, this._messageHandler = new _message_handler.MessageHandler("main", "worker", M), this._messageHandler.on("ready", function() {
}), this._readyCapability.resolve(), this._messageHandler.send("configure", {
verbosity: this.verbosity
});
}
_initialize() {
if (!PDFWorkerUtil.isWorkerDisabled && !_PDFWorker._mainThreadWorkerMessageHandler) {
let {
workerSrc: M
} = _PDFWorker;
try {
PDFWorkerUtil.isSameOrigin(window.location.href, M) || (M = PDFWorkerUtil.createCDNWrapper(new URL(M, window.location).href));
const m = new Worker(M), N = new _message_handler.MessageHandler("main", "worker", m), D = () => {
m.removeEventListener("error", X), N.destroy(), m.terminate(), this.destroyed ? this._readyCapability.reject(new Error("Worker was destroyed")) : this._setupFakeWorker();
}, X = () => {
this._webWorker || D();
};
m.addEventListener("error", X), N.on("test", (I) => {
if (m.removeEventListener("error", X), this.destroyed) {
D();
return;
}
I ? (this._messageHandler = N, this._port = m, this._webWorker = m, this._readyCapability.resolve(), N.send("configure", {
verbosity: this.verbosity
})) : (this._setupFakeWorker(), N.destroy(), m.terminate());
}), N.on("ready", (I) => {
if (m.removeEventListener("error", X), this.destroyed) {
D();
return;
}
try {
G();
} catch {
this._setupFakeWorker();
}
});
const G = () => {
const I = new Uint8Array();
N.send("test", I, [I.buffer]);
};
G();
return;
} catch {
(0, _util.info)("The worker has been disabled.");
}
}
this._setupFakeWorker();
}
_setupFakeWorker() {
PDFWorkerUtil.isWorkerDisabled || ((0, _util.warn)("Setting up fake worker."), PDFWorkerUtil.isWorkerDisabled = !0), _PDFWorker._setupFakeWorkerGlobal.then((M) => {
if (this.destroyed) {
this._readyCapability.reject(new Error("Worker was destroyed"));
return;
}
const m = new LoopbackPort();
this._port = m;
const N = `fake${PDFWorkerUtil.fakeWorkerId++}`, D = new _message_handler.MessageHandler(N + "_worker", N, m);
M.setup(D, m);
const X = new _message_handler.MessageHandler(N, N + "_worker", m);
this._messageHandler = X, this._readyCapability.resolve(), X.send("configure", {
verbosity: this.verbosity
});
}).catch((M) => {
this._readyCapability.reject(new Error(`Setting up fake worker failed: "${M.message}".`));
});
}
destroy() {
var M;
this.destroyed = !0, this._webWorker && (this._webWorker.terminate(), this._webWorker = null), (M = a(_PDFWorker, T)) == null || M.delete(this._port), this._port = null, this._messageHandler && (this._messageHandler.destroy(), this._messageHandler = null);
}
static fromPort(M) {
var N;
if (!(M != null && M.port))
throw new Error("PDFWorker.fromPort - invalid method signature.");
const m = (N = a(this, T)) == null ? void 0 : N.get(M.port);
if (m) {
if (m._pendingDestroy)
throw new Error("PDFWorker.fromPort - the worker is being destroyed.\nPlease remember to await `PDFDocumentLoadingTask.destroy()`-calls.");
return m;
}
return new _PDFWorker(M);
}
static get workerSrc() {
if (_worker_options.GlobalWorkerOptions.workerSrc)
return _worker_options.GlobalWorkerOptions.workerSrc;
if (PDFWorkerUtil.fallbackWorkerSrc !== null)
return _util.isNodeJS || (0, _display_utils.deprecated)('No "GlobalWorkerOptions.workerSrc" specified.'), PDFWorkerUtil.fallbackWorkerSrc;
throw new Error('No "GlobalWorkerOptions.workerSrc" specified.');
}
static get _mainThreadWorkerMessageHandler() {
var M;
try {
return ((M = globalThis.pdfjsWorker) == null ? void 0 : M.WorkerMessageHandler) || null;
} catch {
return null;
}
}
static get _setupFakeWorkerGlobal() {
const loader = async () => {
const mainWorkerMessageHandler = this._mainThreadWorkerMessageHandler;
if (mainWorkerMessageHandler)
return mainWorkerMessageHandler;
if (_util.isNodeJS && typeof commonjsRequire == "function") {
const worker = eval("require")(this.workerSrc);
return worker.WorkerMessageHandler;
}
return await (0, _display_utils.loadScript)(this.workerSrc), window.pdfjsWorker.WorkerMessageHandler;
};
return (0, _util.shadow)(this, "_setupFakeWorkerGlobal", loader());
}
};
T = new WeakMap(), W(_PDFWorker, T, void 0);
let PDFWorker = _PDFWorker;
exports.PDFWorker = PDFWorker;
class WorkerTransport {
constructor(m, N, D, X, G) {
W(this, b);
W(this, S, /* @__PURE__ */ new Map());
W(this, w, /* @__PURE__ */ new Map());
W(this, C, /* @__PURE__ */ new Map());
W(this, P, null);
this.messageHandler = m, this.loadingTask = N, this.commonObjs = new PDFObjects(), this.fontLoader = new _font_loader.FontLoader({
ownerDocument: X.ownerDocument,
styleElement: X.styleElement
}), this._params = X, this.canvasFactory = G.canvasFactory, this.filterFactory = G.filterFactory, this.cMapReaderFactory = G.cMapReaderFactory, this.standardFontDataFactory = G.standardFontDataFactory, this.destroyed = !1, this.destroyCapability = null, this._networkStream = D, this._fullReader = null, this._lastProgress = null, this.downloadInfoCapability = new _util.PromiseCapability(), this.setupMessageHandler();
}
get annotationStorage() {
return (0, _util.shadow)(this, "annotationStorage", new _annotation_storage.AnnotationStorage());
}
getRenderingIntent(m, N = _util.AnnotationMode.ENABLE, D = null, X = !1) {
let G = _util.RenderingIntentFlag.DISPLAY, I = _annotation_storage.SerializableEmpty;
switch (m) {
case "any":
G = _util.RenderingIntentFlag.ANY;
break;
case "display":
break;
case "print":
G = _util.RenderingIntentFlag.PRINT;
break;
default:
(0, _util.warn)(`getRenderingIntent - invalid intent: ${m}`);
}
switch (N) {
case _util.AnnotationMode.DISABLE:
G += _util.RenderingIntentFlag.ANNOTATIONS_DISABLE;
break;
case _util.AnnotationMode.ENABLE:
break;
case _util.AnnotationMode.ENABLE_FORMS:
G += _util.RenderingIntentFlag.ANNOTATIONS_FORMS;
break;
case _util.AnnotationMode.ENABLE_STORAGE:
G += _util.RenderingIntentFlag.ANNOTATIONS_STORAGE, I = (G & _util.RenderingIntentFlag.PRINT && D instanceof _annotation_storage.PrintAnnotationStorage ? D : this.annotationStorage).serializable;
break;
default:
(0, _util.warn)(`getRenderingIntent - invalid annotationMode: ${N}`);
}
return X && (G += _util.RenderingIntentFlag.OPLIST), {
renderingIntent: G,
cacheKey: `${G}_${I.hash}`,
annotationStorageSerializable: I
};
}
destroy() {
var D;
if (this.destroyCapability)
return this.destroyCapability.promise;
this.destroyed = !0, this.destroyCapability = new _util.PromiseCapability(), (D = a(this, P)) == null || D.reject(new Error("Worker was destroyed during onPassword callback"));
const m = [];
for (const X of a(this, w).values())
m.push(X._destroy());
a(this, w).clear(), a(this, C).clear(), this.hasOwnProperty("annotationStorage") && this.annotationStorage.resetModified();
const N = this.messageHandler.sendWithPromise("Terminate", null);
return m.push(N), Promise.all(m).then(() => {
var X;
this.commonObjs.clear(), this.fontLoader.clear(), a(this, S).clear(), this.filterFactory.destroy(), (X = this._networkStream) == null || X.cancelAllRequests(new _util.AbortException("Worker was terminated.")), this.messageHandler && (this.messageHandler.destroy(), this.messageHandler = null), this.destroyCapability.resolve();
}, this.destroyCapability.reject), this.destroyCapability.promise;
}
setupMessageHandler() {
const {
messageHandler: m,
loadingTask: N
} = this;
m.on("GetReader", (D, X) => {
(0, _util.assert)(this._networkStream, "GetReader - no `IPDFStream` instance available."), this._fullReader = this._networkStream.getFullReader(), this._fullReader.onProgress = (G) => {
this._lastProgress = {
loaded: G.loaded,
total: G.total
};
}, X.onPull = () => {
this._fullReader.read().then(function({
value: G,
done: I
}) {
if (I) {
X.close();
return;
}
(0, _util.assert)(G instanceof ArrayBuffer, "GetReader - expected an ArrayBuffer."), X.enqueue(new Uint8Array(G), 1, [G]);
}).catch((G) => {
X.error(G);
});
}, X.onCancel = (G) => {
this._fullReader.cancel(G), X.ready.catch((I) => {
if (!this.destroyed)
throw I;
});
};
}), m.on("ReaderHeadersReady", (D) => {
const X = new _util.PromiseCapability(), G = this._fullReader;
return G.headersReady.then(() => {
var I;
(!G.isStreamingSupported || !G.isRangeSupported) && (this._lastProgress && ((I = N.onProgress) == null || I.call(N, this._lastProgress)), G.onProgress = (B) => {
var ee;
(ee = N.onProgress) == null || ee.call(N, {
loaded: B.loaded,
total: B.total
});
}), X.resolve({
isStreamingSupported: G.isStreamingSupported,
isRangeSupported: G.isRangeSupported,
contentLength: G.contentLength
});
}, X.reject), X.promise;
}), m.on("GetRangeReader", (D, X) => {
(0, _util.assert)(this._networkStream, "GetRangeReader - no `IPDFStream` instance available.");
const G = this._networkStream.getRangeReader(D.begin, D.end);
if (!G) {
X.close();
return;
}
X.onPull = () => {
G.read().then(function({
value: I,
done: B
}) {
if (B) {
X.close();
return;
}
(0, _util.assert)(I instanceof ArrayBuffer, "GetRangeReader - expected an ArrayBuffer."), X.enqueue(new Uint8Array(I), 1, [I]);
}).catch((I) => {
X.error(I);
});
}, X.onCancel = (I) => {
G.cancel(I), X.ready.catch((B) => {
if (!this.destroyed)
throw B;
});
};
}), m.on("GetDoc", ({
pdfInfo: D
}) => {
this._numPages = D.numPages, this._htmlForXfa = D.htmlForXfa, delete D.htmlForXfa, N._capability.resolve(new PDFDocumentProxy(D, this));
}), m.on("DocException", function(D) {
let X;
switch (D.name) {
case "PasswordException":
X = new _util.PasswordException(D.message, D.code);
break;
case "InvalidPDFException":
X = new _util.InvalidPDFException(D.message);
break;
case "MissingPDFException":
X = new _util.MissingPDFException(D.message);
break;
case "UnexpectedResponseException":
X = new _util.UnexpectedResponseException(D.message, D.status);
break;
case "UnknownErrorException":
X = new _util.UnknownErrorException(D.message, D.details);
break;
default:
(0, _util.unreachable)("DocException - expected a valid Error.");
}
N._capability.reject(X);
}), m.on("PasswordRequest", (D) => {
if (oe(this, P, new _util.PromiseCapability()), N.onPassword) {
const X = (G) => {
G instanceof Error ? a(this, P).reject(G) : a(this, P).resolve({
password: G
});
};
try {
N.onPassword(X, D.code);
} catch (G) {
a(this, P).reject(G);
}
} else
a(this, P).reject(new _util.PasswordException(D.message, D.code));
return a(this, P).promise;
}), m.on("DataLoaded", (D) => {
var X;
(X = N.onProgress) == null || X.call(N, {
loaded: D.length,
total: D.length
}), this.downloadInfoCapability.resolve(D);
}), m.on("StartRenderPage", (D) => {
if (this.destroyed)
return;
a(this, w).get(D.pageIndex)._startRenderPage(D.transparency, D.cacheKey);
}), m.on("commonobj", ([D, X, G]) => {
var I;
if (!this.destroyed && !this.commonObjs.has(D))
switch (X) {
case "Font":
const B = this._params;
if ("error" in G) {
const q = G.error;
(0, _util.warn)(`Error during font loading: ${q}`), this.commonObjs.resolve(D, q);
break;
}
const ee = B.pdfBug && ((I = globalThis.FontInspector) != null && I.enabled) ? (q, le) => globalThis.FontInspector.fontAdded(q, le) : null, Y = new _font_loader.FontFaceObject(G, {
isEvalSupported: B.isEvalSupported,
disableFontFace: B.disableFontFace,
ignoreErrors: B.ignoreErrors,
inspectFont: ee
});
this.fontLoader.bind(Y).catch((q) => m.sendWithPromise("FontFallback", {
id: D
})).finally(() => {
!B.fontExtraProperties && Y.data && (Y.data = null), this.commonObjs.resolve(D, Y);
});
break;
case "FontPath":
case "Image":
case "Pattern":
this.commonObjs.resolve(D, G);
break;
default:
throw new Error(`Got unknown common object type ${X}`);
}
}), m.on("obj", ([D, X, G, I]) => {
var ee;
if (this.destroyed)
return;
const B = a(this, w).get(X);
if (!B.objs.has(D))
switch (G) {
case "Image":
if (B.objs.resolve(D, I), I) {
let Y;
if (I.bitmap) {
const {
width: q,
height: le
} = I;
Y = q * le * 4;
} else
Y = ((ee = I.data) == null ? void 0 : ee.length) || 0;
Y > _util.MAX_IMAGE_SIZE_TO_CACHE && (B._maybeCleanupAfterRender = !0);
}
break;
case "Pattern":
B.objs.resolve(D, I);
break;
default:
throw new Error(`Got unknown object type ${G}`);
}
}), m.on("DocProgress", (D) => {
var X;
this.destroyed || (X = N.onProgress) == null || X.call(N, {
loaded: D.loaded,
total: D.total
});
}), m.on("FetchBuiltInCMap", (D) => this.destroyed ? Promise.reject(new Error("Worker was destroyed.")) : this.cMapReaderFactory ? this.cMapReaderFactory.fetch(D) : Promise.reject(new Error("CMapReaderFactory not initialized, see the `useWorkerFetch` parameter."))), m.on("FetchStandardFontData", (D) => this.destroyed ? Promise.reject(new Error("Worker was destroyed.")) : this.standardFontDataFactory ? this.standardFontDataFactory.fetch(D) : Promise.reject(new Error("StandardFontDataFactory not initialized, see the `useWorkerFetch` parameter.")));
}
getData() {
return this.messageHandler.sendWithPromise("GetData", null);
}
saveDocument() {
var D;
this.annotationStorage.size <= 0 && (0, _util.warn)("saveDocument called while `annotationStorage` is empty, please use the getData-method instead.");
const {
map: m,
transfers: N
} = this.annotationStorage.serializable;
return this.messageHandler.sendWithPromise("SaveDocument", {
isPureXfa: !!this._htmlForXfa,
numPages: this._numPages,
annotationStorage: m,
filename: ((D = this._fullReader) == null ? void 0 : D.filename) ?? null
}, N).finally(() => {
this.annotationStorage.resetModified();
});
}
getPage(m) {
if (!Number.isInteger(m) || m <= 0 || m > this._numPages)
return Promise.reject(new Error("Invalid page request."));
const N = m - 1, D = a(this, C).get(N);
if (D)
return D;
const X = this.messageHandler.sendWithPromise("GetPage", {
pageIndex: N
}).then((G) => {
if (this.destroyed)
throw new Error("Transport destroyed");
const I = new PDFPageProxy(N, G, this, this._params.pdfBug);
return a(this, w).set(N, I), I;
});
return a(this, C).set(N, X), X;
}
getPageIndex(m) {
return typeof m != "object" || m === null || !Number.isInteger(m.num) || m.num < 0 || !Number.isInteger(m.gen) || m.gen < 0 ? Promise.reject(new Error("Invalid pageIndex request.")) : this.messageHandler.sendWithPromise("GetPageIndex", {
num: m.num,
gen: m.gen
});
}
getAnnotations(m, N) {
return this.messageHandler.sendWithPromise("GetAnnotations", {
pageIndex: m,
intent: N
});
}
getFieldObjects() {
return K(this, b, Tt).call(this, "GetFieldObjects");
}
hasJSActions() {
return K(this, b, Tt).call(this, "HasJSActions");
}
getCalculationOrderIds() {
return this.messageHandler.sendWithPromise("GetCalculationOrderIds", null);
}
getDestinations() {
return this.messageHandler.sendWithPromise("GetDestinations", null);
}
getDestination(m) {
return typeof m != "string" ? Promise.reject(new Error("Invalid destination request.")) : this.messageHandler.sendWithPromise("GetDestination", {
id: m
});
}
getPageLabels() {
return this.messageHandler.sendWithPromise("GetPageLabels", null);
}
getPageLayout() {
return this.messageHandler.sendWithPromise("GetPageLayout", null);
}
getPageMode() {
return this.messageHandler.sendWithPromise("GetPageMode", null);
}
getViewerPreferences() {
return this.messageHandler.sendWithPromise("GetViewerPreferences", null);
}
getOpenAction() {
return this.messageHandler.sendWithPromise("GetOpenAction", null);
}
getAttachments() {
return this.messageHandler.sendWithPromise("GetAttachments", null);
}
getDocJSActions() {
return K(this, b, Tt).call(this, "GetDocJSActions");
}
getPageJSActions(m) {
return this.messageHandler.sendWithPromise("GetPageJSActions", {
pageIndex: m
});
}
getStructTree(m) {
return this.messageHandler.sendWithPromise("GetStructTree", {
pageIndex: m
});
}
getOutline() {
return this.messageHandler.sendWithPromise("GetOutline", null);
}
getOptionalContentConfig() {
return this.messageHandler.sendWithPromise("GetOptionalContentConfig", null).then((m) => new _optional_content_config.OptionalContentConfig(m));
}
getPermissions() {
return this.messageHandler.sendWithPromise("GetPermissions", null);
}
getMetadata() {
const m = "GetMetadata", N = a(this, S).get(m);
if (N)
return N;
const D = this.messageHandler.sendWithPromise(m, null).then((X) => {
var G, I;
return {
info: X[0],
metadata: X[1] ? new _metadata.Metadata(X[1]) : null,
contentDispositionFilename: ((G = this._fullReader) == null ? void 0 : G.filename) ?? null,
contentLength: ((I = this._fullReader) == null ? void 0 : I.contentLength) ?? null
};
});
return a(this, S).set(m, D), D;
}
getMarkInfo() {
return this.messageHandler.sendWithPromise("GetMarkInfo", null);
}
async startCleanup(m = !1) {
if (!this.destroyed) {
await this.messageHandler.sendWithPromise("Cleanup", null);
for (const N of a(this, w).values())
if (!N.cleanup())
throw new Error(`startCleanup: Page ${N.pageNumber} is currently rendering.`);
this.commonObjs.clear(), m || this.fontLoader.clear(), a(this, S).clear(), this.filterFactory.destroy(!0);
}
}
get loadingParams() {
const {
disableAutoFetch: m,
enableXfa: N
} = this._params;
return (0, _util.shadow)(this, "loadingParams", {
disableAutoFetch: m,
enableXfa: N
});
}
}
S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakSet(), Tt = function(m, N = null) {
const D = a(this, S).get(m);
if (D)
return D;
const X = this.messageHandler.sendWithPromise(m, N);
return a(this, S).set(m, X), X;
};
class PDFObjects {
constructor() {
W(this, x);
W(this, F, /* @__PURE__ */ Object.create(null));
}
get(m, N = null) {
if (N) {
const X = K(this, x, Bt).call(this, m);
return X.capability.promise.then(() => N(X.data)), null;
}
const D = a(this, F)[m];
if (!(D != null && D.capability.settled))
throw new Error(`Requesting object that isn't resolved yet ${m}.`);
return D.data;
}
has(m) {
const N = a(this, F)[m];
return (N == null ? void 0 : N.capability.settled) || !1;
}
resolve(m, N = null) {
const D = K(this, x, Bt).call(this, m);
D.data = N, D.capability.resolve();
}
clear() {
var m;
for (const N in a(this, F)) {
const {
data: D
} = a(this, F)[N];
(m = D == null ? void 0 : D.bitmap) == null || m.close();
}
oe(this, F, /* @__PURE__ */ Object.create(null));
}
}
F = new WeakMap(), x = new WeakSet(), Bt = function(m) {
var N;
return (N = a(this, F))[m] || (N[m] = {
capability: new _util.PromiseCapability(),
data: null
});
};
class RenderTask {
constructor(m) {
W(this, p, null);
oe(this, p, m), this.onContinue = null;
}
get promise() {
return a(this, p).capability.promise;
}
cancel(m = 0) {
a(this, p).cancel(null, m);
}
get separateAnnots() {
const {
separateAnnots: m
} = a(this, p).operatorList;
if (!m)
return !1;
const {
annotationCanvasMap: N
} = a(this, p);
return m.form || m.canvas && (N == null ? void 0 : N.size) > 0;
}
}
p = new WeakMap(), exports.RenderTask = RenderTask;
const $ = class $ {
constructor({
callback: m,
params: N,
objs: D,
commonObjs: X,
annotationCanvasMap: G,
operatorList: I,
pageIndex: B,
canvasFactory: ee,
filterFactory: Y,
useRequestAnimationFrame: q = !1,
pdfBug: le = !1,
pageColors: pe = null
}) {
this.callback = m, this.params = N, this.objs = D, this.commonObjs = X, this.annotationCanvasMap = G, this.operatorListIdx = null, this.operatorList = I, this._pageIndex = B, this.canvasFactory = ee, this.filterFactory = Y, this._pdfBug = le, this.pageColors = pe, this.running = !1, this.graphicsReadyCallback = null, this.graphicsReady = !1, this._useRequestAnimationFrame = q === !0 && typeof window < "u", this.cancelled = !1, this.capability = new _util.PromiseCapability(), this.task = new RenderTask(this), this._cancelBound = this.cancel.bind(this), this._continueBound = this._continue.bind(this), this._scheduleNextBound = this._scheduleNext.bind(this), this._nextBound = this._next.bind(this), this._canvas = N.canvasContext.canvas;
}
get completed() {
return this.capability.promise.catch(function() {
});
}
initializeGraphics({
transparency: m = !1,
optionalContentConfig: N
}) {
var B, ee;
if (this.cancelled)
return;
if (this._canvas) {
if (a($, E).has(this._canvas))
throw new Error("Cannot use the same canvas during multiple render() operations. Use different canvas or ensure previous operations were cancelled or completed.");
a($, E).add(this._canvas);
}
this._pdfBug && ((B = globalThis.StepperManager) != null && B.enabled) && (this.stepper = globalThis.StepperManager.create(this._pageIndex), this.stepper.init(this.operatorList), this.stepper.nextBreakPoint = this.stepper.getNextBreakPoint());
const {
canvasContext: D,
viewport: X,
transform: G,
background: I
} = this.params;
this.gfx = new _canvas.CanvasGraphics(D, this.commonObjs, this.objs, this.canvasFactory, this.filterFactory, {
optionalContentConfig: N
}, this.annotationCanvasMap, this.pageColors), this.gfx.beginDrawing({
transform: G,
viewport: X,
transparency: m,
background: I
}), this.operatorListIdx = 0, this.graphicsReady = !0, (ee = this.graphicsReadyCallback) == null || ee.call(this);
}
cancel(m = null, N = 0) {
var D;
this.running = !1, this.cancelled = !0, (D = this.gfx) == null || D.endDrawing(), a($, E).delete(this._canvas), this.callback(m || new _display_utils.RenderingCancelledException(`Rendering cancelled, page ${this._pageIndex + 1}`, N));
}
operatorListChanged() {
var m;
if (!this.graphicsReady) {
this.graphicsReadyCallback || (this.graphicsReadyCallback = this._continueBound);
return;
}
(m = this.stepper) == null || m.updateOperatorList(this.operatorList), !this.running && this._continue();
}
_continue() {
this.running = !0, !this.cancelled && (this.task.onContinue ? this.task.onContinue(this._scheduleNextBound) : this._scheduleNext());
}
_scheduleNext() {
this._useRequestAnimationFrame ? window.requestAnimationFrame(() => {
this._nextBound().catch(this._cancelBound);
}) : Promise.resolve().then(this._nextBound).catch(this._cancelBound);
}
async _next() {
this.cancelled || (this.operatorListIdx = this.gfx.executeOperatorList(this.operatorList, this.operatorListIdx, this._continueBound, this.stepper), this.operatorListIdx === this.operatorList.argsArray.length && (this.running = !1, this.operatorList.lastChunk && (this.gfx.endDrawing(), a($, E).delete(this._canvas), this.callback())));
}
};
E = new WeakMap(), W($, E, /* @__PURE__ */ new WeakSet());
let InternalRenderTask = $;
const version = "3.11.174";
exports.version = version;
const build = "ce8716743";
exports.build = build;
},
/* 3 */
/***/
(t, e, i) => {
var o, r, T, En, w;
Object.defineProperty(e, "__esModule", {
value: !0
}), e.SerializableEmpty = e.PrintAnnotationStorage = e.AnnotationStorage = void 0;
var n = i(1), s = i(4), l = i(8);
const h = Object.freeze({
map: null,
hash: "",
transfers: void 0
});
e.SerializableEmpty = h;
class _ {
constructor() {
W(this, T);
W(this, o, !1);
W(this, r, /* @__PURE__ */ new Map());
this.onSetModified = null, this.onResetModified = null, this.onAnnotationEditor = null;
}
getValue(P, b) {
const k = a(this, r).get(P);
return k === void 0 ? b : Object.assign(b, k);
}
getRawValue(P) {
return a(this, r).get(P);
}
remove(P) {
if (a(this, r).delete(P), a(this, r).size === 0 && this.resetModified(), typeof this.onAnnotationEditor == "function") {
for (const b of a(this, r).values())
if (b instanceof s.AnnotationEditor)
return;
this.onAnnotationEditor(null);
}
}
setValue(P, b) {
const k = a(this, r).get(P);
let F = !1;
if (k !== void 0)
for (const [x, y] of Object.entries(b))
k[x] !== y && (F = !0, k[x] = y);
else
F = !0, a(this, r).set(P, b);
F && K(this, T, En).call(this), b instanceof s.AnnotationEditor && typeof this.onAnnotationEditor == "function" && this.onAnnotationEditor(b.constructor._type);
}
has(P) {
return a(this, r).has(P);
}
getAll() {
return a(this, r).size > 0 ? (0, n.objectFromMap)(a(this, r)) : null;
}
setAll(P) {
for (const [b, k] of Object.entries(P))
this.setValue(b, k);
}
get size() {
return a(this, r).size;
}
resetModified() {
a(this, o) && (oe(this, o, !1), typeof this.onResetModified == "function" && this.onResetModified());
}
get print() {
return new c(this);
}
get serializable() {
if (a(this, r).size === 0)
return h;
const P = /* @__PURE__ */ new Map(), b = new l.MurmurHash3_64(), k = [], F = /* @__PURE__ */ Object.create(null);
let x = !1;
for (const [y, p] of a(this, r)) {
const E = p instanceof s.AnnotationEditor ? p.serialize(!1, F) : p;
E && (P.set(y, E), b.update(`${y}:${JSON.stringify(E)}`), x || (x = !!E.bitmap));
}
if (x)
for (const y of P.values())
y.bitmap && k.push(y.bitmap);
return P.size > 0 ? {
map: P,
hash: b.hexdigest(),
transfers: k
} : h;
}
}
o = new WeakMap(), r = new WeakMap(), T = new WeakSet(), En = function() {
a(this, o) || (oe(this, o, !0), typeof this.onSetModified == "function" && this.onSetModified());
}, e.AnnotationStorage = _;
class c extends _ {
constructor(b) {
super();
W(this, w, void 0);
const {
map: k,
hash: F,
transfers: x
} = b.serializable, y = structuredClone(k, x ? {
transfer: x
} : null);
oe(this, w, {
map: y,
hash: F,
transfers: x
});
}
get print() {
(0, n.unreachable)("Should not call PrintAnnotationStorage.print");
}
get serializable() {
return a(this, w);
}
}
w = new WeakMap(), e.PrintAnnotationStorage = c;
},
/* 4 */
/***/
(t, e, i) => {
var c, o, r, T, S, w, C, P, b, k, F, x, y, p, E, Ht, M, Ut, N, jt, X, Gt, I, Sn, ee, wn, q, Tn, pe, Wt, be, Cn;
Object.defineProperty(e, "__esModule", {
value: !0
}), e.AnnotationEditor = void 0;
var n = i(5), s = i(1), l = i(6);
const d = class d {
constructor(f) {
W(this, E);
W(this, M);
W(this, X);
W(this, I);
W(this, ee);
W(this, q);
W(this, pe);
W(this, be);
W(this, c, "");
W(this, o, !1);
W(this, r, null);
W(this, T, null);
W(this, S, null);
W(this, w, !1);
W(this, C, null);
W(this, P, this.focusin.bind(this));
W(this, b, this.focusout.bind(this));
W(this, k, !1);
W(this, F, !1);
W(this, x, !1);
nt(this, "_initialOptions", /* @__PURE__ */ Object.create(null));
nt(this, "_uiManager", null);
nt(this, "_focusEventsAllowed", !0);
nt(this, "_l10nPromise", null);
W(this, y, !1);
W(this, p, d._zIndex++);
this.constructor === d && (0, s.unreachable)("Cannot initialize AnnotationEditor."), this.parent = f.parent, this.id = f.id, this.width = this.height = null, this.pageIndex = f.parent.pageIndex, this.name = f.name, this.div = null, this._uiManager = f.uiManager, this.annotationElementId = null, this._willKeepAspectRatio = !1, this._initialOptions.isCentered = f.isCentered, this._structTreeParentId = null;
const {
rotation: v,
rawDims: {
pageWidth: A,
pageHeight: O,
pageX: H,
pageY: z
}
} = this.parent.viewport;
this.rotation = v, this.pageRotation = (360 + v - this._uiManager.viewParameters.rotation) % 360, this.pageDimensions = [A, O], this.pageTranslation = [H, z];
const [ae, Q] = this.parentDimensions;
this.x = f.x / ae, this.y = f.y / Q, this.isAttachedToDOM = !1, this.deleted = !1;
}
get editorType() {
return Object.getPrototypeOf(this).constructor._type;
}
static get _defaultLineColor() {
return (0, s.shadow)(this, "_defaultLineColor", this._colorManager.getHexCode("CanvasText"));
}
static deleteAnnotationElement(f) {
const v = new _({
id: f.parent.getNextId(),
parent: f.parent,
uiManager: f._uiManager
});
v.annotationElementId = f.annotationElementId, v.deleted = !0, v._uiManager.addToAnnotationStorage(v);
}
static initialize(f, v = null) {
if (d._l10nPromise || (d._l10nPromise = new Map(["editor_alt_text_button_label", "editor_alt_text_edit_button_label", "editor_alt_text_decorative_tooltip"].map((O) => [O, f.get(O)]))), v != null && v.strings)
for (const O of v.strings)
d._l10nPromise.set(O, f.get(O));
if (d._borderLineWidth !== -1)
return;
const A = getComputedStyle(document.documentElement);
d._borderLineWidth = parseFloat(A.getPropertyValue("--outline-width")) || 0;
}
static updateDefaultParams(f, v) {
}
static get defaultPropertiesToUpdate() {
return [];
}
static isHandlingMimeForPasting(f) {
return !1;
}
static paste(f, v) {
(0, s.unreachable)("Not implemented");
}
get propertiesToUpdate() {
return [];
}
get _isDraggable() {
return a(this, y);
}
set _isDraggable(f) {
var v;
oe(this, y, f), (v = this.div) == null || v.classList.toggle("draggable", f);
}
center() {
const [f, v] = this.pageDimensions;
switch (this.parentRotation) {
case 90:
this.x -= this.height * v / (f * 2), this.y += this.width * f / (v * 2);
break;
case 180:
this.x += this.width / 2, this.y += this.height / 2;
break;
case 270:
this.x += this.height * v / (f * 2), this.y -= this.width * f / (v * 2);
break;
default:
this.x -= this.width / 2, this.y -= this.height / 2;
break;
}
this.fixAndSetPosition();
}
addCommands(f) {
this._uiManager.addCommands(f);
}
get currentLayer() {
return this._uiManager.currentLayer;
}
setInBackground() {
this.div.style.zIndex = 0;
}
setInForeground() {
this.div.style.zIndex = a(this, p);
}
setParent(f) {
f !== null && (this.pageIndex = f.pageIndex, this.pageDimensions = f.pageDimensions), this.parent = f;
}
focusin(f) {
this._focusEventsAllowed && (a(this, k) ? oe(this, k, !1) : this.parent.setSelected(this));
}
focusout(f) {
var A;
if (!this._focusEventsAllowed || !this.isAttachedToDOM)
return;
const v = f.relatedTarget;
v != null && v.closest(`#${this.id}`) || (f.preventDefault(), (A = this.parent) != null && A.isMultipleSelection || this.commitOrRemove());
}
commitOrRemove() {
this.isEmpty() ? this.remove() : this.commit();
}
commit() {
this.addToAnnotationStorage();
}
addToAnnotationStorage() {
this._uiManager.addToAnnotationStorage(this);
}
setAt(f, v, A, O) {
const [H, z] = this.parentDimensions;
[A, O] = this.screenToPageTranslation(A, O), this.x = (f + A) / H, this.y = (v + O) / z, this.fixAndSetPosition();
}
translate(f, v) {
K(this, E, Ht).call(this, this.parentDimensions, f, v);
}
translateInPage(f, v) {
K(this, E, Ht).call(this, this.pageDimensions, f, v), this.div.scrollIntoView({
block: "nearest"
});
}
drag(f, v) {
const [A, O] = this.parentDimensions;
if (this.x += f / A, this.y += v / O, this.parent && (this.x < 0 || this.x > 1 || this.y < 0 || this.y > 1)) {
const {
x: ce,
y: ue
} = this.div.getBoundingClientRect();
this.parent.findNewParent(this, ce, ue) && (this.x -= Math.floor(this.x), this.y -= Math.floor(this.y));
}
let {
x: H,
y: z
} = this;
const [ae, Q] = K(this, M, Ut).call(this);
H += ae, z += Q, this.div.style.left = `${(100 * H).toFixed(2)}%`, this.div.style.top = `${(100 * z).toFixed(2)}%`, this.div.scrollIntoView({
block: "nearest"
});
}
fixAndSetPosition() {
const [f, v] = this.pageDimensions;
let {
x: A,
y: O,
width: H,
height: z
} = this;
switch (H *= f, z *= v, A *= f, O *= v, this.rotation) {
case 0:
A = Math.max(0, Math.min(f - H, A)), O = Math.max(0, Math.min(v - z, O));
break;
case 90:
A = Math.max(0, Math.min(f - z, A)), O = Math.min(v, Math.max(H, O));
break;
case 180:
A = Math.min(f, Math.max(H, A)), O = Math.min(v, Math.max(z, O));
break;
case 270:
A = Math.min(f, Math.max(z, A)), O = Math.max(0, Math.min(v - H, O));
break;
}
this.x = A /= f, this.y = O /= v;
const [ae, Q] = K(this, M, Ut).call(this);
A += ae, O += Q;
const {
style: ce
} = this.div;
ce.left = `${(100 * A).toFixed(2)}%`, ce.top = `${(100 * O).toFixed(2)}%`, this.moveInDOM();
}
screenToPageTranslation(f, v) {
var A;
return K(A = d, N, jt).call(A, f, v, this.parentRotation);
}
pageTranslationToScreen(f, v) {
var A;
return K(A = d, N, jt).call(A, f, v, 360 - this.parentRotation);
}
get parentScale() {
return this._uiManager.viewParameters.realScale;
}
get parentRotation() {
return (this._uiManager.viewParameters.rotation + this.pageRotation) % 360;
}
get parentDimensions() {
const {
parentScale: f,
pageDimensions: [v, A]
} = this, O = v * f, H = A * f;
return s.FeatureTest.isCSSRoundSupported ? [Math.round(O), Math.round(H)] : [O, H];
}
setDims(f, v) {
var H;
const [A, O] = this.parentDimensions;
this.div.style.width = `${(100 * f / A).toFixed(2)}%`, a(this, w) || (this.div.style.height = `${(100 * v / O).toFixed(2)}%`), (H = a(this, r)) == null || H.classList.toggle("small", f < d.SMALL_EDITOR_SIZE || v < d.SMALL_EDITOR_SIZE);
}
fixDims() {
const {
style: f
} = this.div, {
height: v,
width: A
} = f, O = A.endsWith("%"), H = !a(this, w) && v.endsWith("%");
if (O && H)
return;
const [z, ae] = this.parentDimensions;
O || (f.width = `${(100 * parseFloat(A) / z).toFixed(2)}%`), !a(this, w) && !H && (f.height = `${(100 * parseFloat(v) / ae).toFixed(2)}%`);
}
getInitialTranslation() {
return [0, 0];
}
async addAltTextButton() {
if (a(this, r))
return;
const f = oe(this, r, document.createElement("button"));
f.className = "altText";
const v = await d._l10nPromise.get("editor_alt_text_button_label");
f.textContent = v, f.setAttribute("aria-label", v), f.tabIndex = "0", f.addEventListener("contextmenu", l.noContextMenu), f.addEventListener("pointerdown", (A) => A.stopPropagation()), f.addEventListener("click", (A) => {
A.preventDefault(), this._uiManager.editAltText(this);
}, {
capture: !0
}), f.addEventListener("keydown", (A) => {
A.target === f && A.key === "Enter" && (A.preventDefault(), this._uiManager.editAltText(this));
}), K(this, pe, Wt).call(this), this.div.append(f), d.SMALL_EDITOR_SIZE || (d.SMALL_EDITOR_SIZE = Math.min(128, Math.round(f.getBoundingClientRect().width * 1.4)));
}
getClientDimensions() {
return this.div.getBoundingClientRect();
}
get altTextData() {
return {
altText: a(this, c),
decorative: a(this, o)
};
}
set altTextData({
altText: f,
decorative: v
}) {
a(this, c) === f && a(this, o) === v || (oe(this, c, f), oe(this, o, v), K(this, pe, Wt).call(this));
}
render() {
this.div = document.createElement("div"), this.div.setAttribute("data-editor-rotation", (360 - this.rotation) % 360), this.div.className = this.name, this.div.setAttribute("id", this.id), this.div.setAttribute("tabIndex", 0), this.setInForeground(), this.div.addEventListener("focusin", a(this, P)), this.div.addEventListener("focusout", a(this, b));
const [f, v] = this.parentDimensions;
this.parentRotation % 180 !== 0 && (this.div.style.maxWidth = `${(100 * v / f).toFixed(2)}%`, this.div.style.maxHeight = `${(100 * f / v).toFixed(2)}%`);
const [A, O] = this.getInitialTranslation();
return this.translate(A, O), (0, n.bindEvents)(this, this.div, ["pointerdown"]), this.div;
}
pointerdown(f) {
const {
isMac: v
} = s.FeatureTest.platform;
if (f.button !== 0 || f.ctrlKey && v) {
f.preventDefault();
return;
}
oe(this, k, !0), K(this, be, Cn).call(this, f);
}
moveInDOM() {
var f;
(f = this.parent) == null || f.moveEditorInDOM(this);
}
_setParentAndPosition(f, v, A) {
f.changeParent(this), this.x = v, this.y = A, this.fixAndSetPosition();
}
getRect(f, v) {
const A = this.parentScale, [O, H] = this.pageDimensions, [z, ae] = this.pageTranslation, Q = f / A, ce = v / A, ue = this.x * O, me = this.y * H, fe = this.width * O, Pe = this.height * H;
switch (this.rotation) {
case 0:
return [ue + Q + z, H - me - ce - Pe + ae, ue + Q + fe + z, H - me - ce + ae];
case 90:
return [ue + ce + z, H - me + Q + ae, ue + ce + Pe + z, H - me + Q + fe + ae];
case 180:
return [ue - Q - fe + z, H - me + ce + ae, ue - Q + z, H - me + ce + Pe + ae];
case 270:
return [ue - ce - Pe + z, H - me - Q - fe + ae, ue - ce + z, H - me - Q + ae];
default:
throw new Error("Invalid rotation");
}
}
getRectInCurrentCoords(f, v) {
const [A, O, H, z] = f, ae = H - A, Q = z - O;
switch (this.rotation) {
case 0:
return [A, v - z, ae, Q];
case 90:
return [A, v - O, Q, ae];
case 180:
return [H, v - O, ae, Q];
case 270:
return [H, v - z, Q, ae];
default:
throw new Error("Invalid rotation");
}
}
onceAdded() {
}
isEmpty() {
return !1;
}
enableEditMode() {
oe(this, x, !0);
}
disableEditMode() {
oe(this, x, !1);
}
isInEditMode() {
return a(this, x);
}
shouldGetKeyboardEvents() {
return !1;
}
needsToBeRebuilt() {
return this.div && !this.isAttachedToDOM;
}
rebuild() {
var f, v;
(f = this.div) == null || f.addEventListener("focusin", a(this, P)), (v = this.div) == null || v.addEventListener("focusout", a(this, b));
}
serialize(f = !1, v = null) {
(0, s.unreachable)("An editor must be serializable");
}
static deserialize(f, v, A) {
const O = new this.prototype.constructor({
parent: v,
id: v.getNextId(),
uiManager: A
});
O.rotation = f.rotation;
const [H, z] = O.pageDimensions, [ae, Q, ce, ue] = O.getRectInCurrentCoords(f.rect, z);
return O.x = ae / H, O.y = Q / z, O.width = ce / H, O.height = ue / z, O;
}
remove() {
var f;
this.div.removeEventListener("focusin", a(this, P)), this.div.removeEventListener("focusout", a(this, b)), this.isEmpty() || this.commit(), this.parent ? this.parent.remove(this) : this._uiManager.removeEditor(this), (f = a(this, r)) == null || f.remove(), oe(this, r, null), oe(this, T, null);
}
get isResizable() {
return !1;
}
makeResizable() {
this.isResizable && (K(this, I, Sn).call(this), a(this, C).classList.remove("hidden"));
}
select() {
var f;
this.makeResizable(), (f = this.div) == null || f.classList.add("selectedEditor");
}
unselect() {
var f, v, A;
(f = a(this, C)) == null || f.classList.add("hidden"), (v = this.div) == null || v.classList.remove("selectedEditor"), (A = this.div) != null && A.contains(document.activeElement) && this._uiManager.currentLayer.div.focus();
}
updateParams(f, v) {
}
disableEditing() {
a(this, r) && (a(this, r).hidden = !0);
}
enableEditing() {
a(this, r) && (a(this, r).hidden = !1);
}
enterInEditMode() {
}
get contentDiv() {
return this.div;
}
get isEditing() {
return a(this, F);
}
set isEditing(f) {
oe(this, F, f), this.parent && (f ? (this.parent.setSelected(this), this.parent.setActiveEditor(this)) : this.parent.setActiveEditor(null));
}
setAspectRatio(f, v) {
oe(this, w, !0);
const A = f / v, {
style: O
} = this.div;
O.aspectRatio = A, O.height = "auto";
}
static get MIN_SIZE() {
return 16;
}
};
c = new WeakMap(), o = new WeakMap(), r = new WeakMap(), T = new WeakMap(), S = new WeakMap(), w = new WeakMap(), C = new WeakMap(), P = new WeakMap(), b = new WeakMap(), k = new WeakMap(), F = new WeakMap(), x = new WeakMap(), y = new WeakMap(), p = new WeakMap(), E = new WeakSet(), Ht = function([f, v], A, O) {
[A, O] = this.screenToPageTranslation(A, O), this.x += A / f, this.y += O / v, this.fixAndSetPosition();
}, M = new WeakSet(), Ut = function() {
const [f, v] = this.parentDimensions, {
_borderLineWidth: A
} = d, O = A / f, H = A / v;
switch (this.rotation) {
case 90:
return [-O, H];
case 180:
return [O, H];
case 270:
return [O, -H];
default:
return [-O, -H];
}
}, N = new WeakSet(), jt = function(f, v, A) {
switch (A) {
case 90:
return [v, -f];
case 180:
return [-f, -v];
case 270:
return [-v, f];
default:
return [f, v];
}
}, X = new WeakSet(), Gt = function(f) {
switch (f) {
case 90: {
const [v, A] = this.pageDimensions;
return [0, -v / A, A / v, 0];
}
case 180:
return [-1, 0, 0, -1];
case 270: {
const [v, A] = this.pageDimensions;
return [0, v / A, -A / v, 0];
}
default:
return [1, 0, 0, 1];
}
}, I = new WeakSet(), Sn = function() {
if (a(this, C))
return;
oe(this, C, document.createElement("div")), a(this, C).classList.add("resizers");
const f = ["topLeft", "topRight", "bottomRight", "bottomLeft"];
this._willKeepAspectRatio || f.push("topMiddle", "middleRight", "bottomMiddle", "middleLeft");
for (const v of f) {
const A = document.createElement("div");
a(this, C).append(A), A.classList.add("resizer", v), A.addEventListener("pointerdown", K(this, ee, wn).bind(this, v)), A.addEventListener("contextmenu", l.noContextMenu);
}
this.div.prepend(a(this, C));
}, ee = new WeakSet(), wn = function(f, v) {
v.preventDefault();
const {
isMac: A
} = s.FeatureTest.platform;
if (v.button !== 0 || v.ctrlKey && A)
return;
const O = K(this, q, Tn).bind(this, f), H = this._isDraggable;
this._isDraggable = !1;
const z = {
passive: !0,
capture: !0
};
window.addEventListener("pointermove", O, z);
const ae = this.x, Q = this.y, ce = this.width, ue = this.height, me = this.parent.div.style.cursor, fe = this.div.style.cursor;
this.div.style.cursor = this.parent.div.style.cursor = window.getComputedStyle(v.target).cursor;
const Pe = () => {
this._isDraggable = H, window.removeEventListener("pointerup", Pe), window.removeEventListener("blur", Pe), window.removeEventListener("pointermove", O, z), this.parent.div.style.cursor = me, this.div.style.cursor = fe;
const Fe = this.x, Ee = this.y, De = this.width, _e = this.height;
Fe === ae && Ee === Q && De === ce && _e === ue || this.addCommands({
cmd: () => {
this.width = De, this.height = _e, this.x = Fe, this.y = Ee;
const [ie, se] = this.parentDimensions;
this.setDims(ie * De, se * _e), this.fixAndSetPosition();
},
undo: () => {
this.width = ce, this.height = ue, this.x = ae, this.y = Q;
const [ie, se] = this.parentDimensions;
this.setDims(ie * ce, se * ue), this.fixAndSetPosition();
},
mustExec: !0
});
};
window.addEventListener("pointerup", Pe), window.addEventListener("blur", Pe);
}, q = new WeakSet(), Tn = function(f, v) {
const [A, O] = this.parentDimensions, H = this.x, z = this.y, ae = this.width, Q = this.height, ce = d.MIN_SIZE / A, ue = d.MIN_SIZE / O, me = (ve) => Math.round(ve * 1e4) / 1e4, fe = K(this, X, Gt).call(this, this.rotation), Pe = (ve, Se) => [fe[0] * ve + fe[2] * Se, fe[1] * ve + fe[3] * Se], Fe = K(this, X, Gt).call(this, 360 - this.rotation), Ee = (ve, Se) => [Fe[0] * ve + Fe[2] * Se, Fe[1] * ve + Fe[3] * Se];
let De, _e, ie = !1, se = !1;
switch (f) {
case "topLeft":
ie = !0, De = (ve, Se) => [0, 0], _e = (ve, Se) => [ve, Se];
break;
case "topMiddle":
De = (ve, Se) => [ve / 2, 0], _e = (ve, Se) => [ve / 2, Se];
break;
case "topRight":
ie = !0, De = (ve, Se) => [ve, 0], _e = (ve, Se) => [0, Se];
break;
case "middleRight":
se = !0, De = (ve, Se) => [ve, Se / 2], _e = (ve, Se) => [0, Se / 2];
break;
case "bottomRight":
ie = !0, De = (ve, Se) => [ve, Se], _e = (ve, Se) => [0, 0];
break;
case "bottomMiddle":
De = (ve, Se) => [ve / 2, Se], _e = (ve, Se) => [ve / 2, 0];
break;
case "bottomLeft":
ie = !0, De = (ve, Se) => [0, Se], _e = (ve, Se) => [ve, 0];
break;
case "middleLeft":
se = !0, De = (ve, Se) => [0, Se / 2], _e = (ve, Se) => [ve, Se / 2];
break;
}
const ge = De(ae, Q), Ce = _e(ae, Q);
let xe = Pe(...Ce);
const Ue = me(H + xe[0]), We = me(z + xe[1]);
let je = 1, ze = 1, [Xe, Ge] = this.screenToPageTranslation(v.movementX, v.movementY);
if ([Xe, Ge] = Ee(Xe / A, Ge / O), ie) {
const ve = Math.hypot(ae, Q);
je = ze = Math.max(Math.min(Math.hypot(Ce[0] - ge[0] - Xe, Ce[1] - ge[1] - Ge) / ve, 1 / ae, 1 / Q), ce / ae, ue / Q);
} else
se ? je = Math.max(ce, Math.min(1, Math.abs(Ce[0] - ge[0] - Xe))) / ae : ze = Math.max(ue, Math.min(1, Math.abs(Ce[1] - ge[1] - Ge))) / Q;
const Ye = me(ae * je), de = me(Q * ze);
xe = Pe(..._e(Ye, de));
const ne = Ue - xe[0], J = We - xe[1];
this.width = Ye, this.height = de, this.x = ne, this.y = J, this.setDims(A * Ye, O * de), this.fixAndSetPosition();
}, pe = new WeakSet(), Wt = async function() {
var A;
const f = a(this, r);
if (!f)
return;
if (!a(this, c) && !a(this, o)) {
f.classList.remove("done"), (A = a(this, T)) == null || A.remove();
return;
}
d._l10nPromise.get("editor_alt_text_edit_button_label").then((O) => {
f.setAttribute("aria-label", O);
});
let v = a(this, T);
if (!v) {
oe(this, T, v = document.createElement("span")), v.className = "tooltip", v.setAttribute("role", "tooltip");
const O = v.id = `alt-text-tooltip-${this.id}`;
f.setAttribute("aria-describedby", O);
const H = 100;
f.addEventListener("mouseenter", () => {
oe(this, S, setTimeout(() => {
oe(this, S, null), a(this, T).classList.add("show"), this._uiManager._eventBus.dispatch("reporttelemetry", {
source: this,
details: {
type: "editing",
subtype: this.editorType,
data: {
action: "alt_text_tooltip"
}
}
});
}, H));
}), f.addEventListener("mouseleave", () => {
var z;
clearTimeout(a(this, S)), oe(this, S, null), (z = a(this, T)) == null || z.classList.remove("show");
});
}
f.classList.add("done"), v.innerText = a(this, o) ? await d._l10nPromise.get("editor_alt_text_decorative_tooltip") : a(this, c), v.parentNode || f.append(v);
}, be = new WeakSet(), Cn = function(f) {
if (!this._isDraggable)
return;
const v = this._uiManager.isSelected(this);
this._uiManager.setUpDragSession();
let A, O;
v && (A = {
passive: !0,
capture: !0
}, O = (z) => {
const [ae, Q] = this.screenToPageTranslation(z.movementX, z.movementY);
this._uiManager.dragSelectedEditors(ae, Q);
}, window.addEventListener("pointermove", O, A));
const H = () => {
if (window.removeEventListener("pointerup", H), window.removeEventListener("blur", H), v && window.removeEventListener("pointermove", O, A), oe(this, k, !1), !this._uiManager.endDragSession()) {
const {
isMac: z
} = s.FeatureTest.platform;
f.ctrlKey && !z || f.shiftKey || f.metaKey && z ? this.parent.toggleSelected(this) : this.parent.setSelected(this);
}
};
window.addEventListener("pointerup", H), window.addEventListener("blur", H);
}, W(d, N), nt(d, "_borderLineWidth", -1), nt(d, "_colorManager", new n.ColorManager()), nt(d, "_zIndex", 1), nt(d, "SMALL_EDITOR_SIZE", 0);
let h = d;
e.AnnotationEditor = h;
class _ extends h {
constructor(f) {
super(f), this.annotationElementId = f.annotationElementId, this.deleted = !0;
}
serialize() {
return {
id: this.annotationElementId,
deleted: !0,
pageIndex: this.pageIndex
};
}
}
},
/* 5 */
/***/
(t, e, i) => {
var w, C, P, b, k, qt, y, p, E, $, M, Pn, D, X, G, I, B, ee, Y, q, le, pe, we, be, R, d, g, f, v, A, O, H, z, ae, Q, ce, ue, me, fe, Pe, Fe, Ee, De, _e, ie, se, ge, xn, xe, zt, We, Xt, ze, Ct, Ge, Vt, de, Yt, J, at, Se, mt, et, kn, Te, Rn, ke, Kt, Be, bt, Ae, Jt;
Object.defineProperty(e, "__esModule", {
value: !0
}), e.KeyboardManager = e.CommandManager = e.ColorManager = e.AnnotationEditorUIManager = void 0, e.bindEvents = l, e.opacityToHex = h;
var n = i(1), s = i(6);
function l(U, u, L) {
for (const j of L)
u.addEventListener(j, U[j].bind(U));
}
function h(U) {
return Math.round(Math.min(255, Math.max(1, 255 * U))).toString(16).padStart(2, "0");
}
class _ {
constructor() {
W(this, w, 0);
}
getId() {
return `${n.AnnotationEditorPrefix}${_t(this, w)._++}`;
}
}
w = new WeakMap();
const x = class x {
constructor() {
W(this, k);
W(this, C, (0, n.getUuid)());
W(this, P, 0);
W(this, b, null);
}
static get _isSVGFittingCanvas() {
const u = 'data:image/svg+xml;charset=UTF-8,', 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, onMount } = 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
};