.active.svelte-16td9du{color:var(--primary-color);background-color:#fff;font-weight:bold}.wrap.svelte-16td9du{width:160px;height:100%;gap:10px}.top-nav.svelte-16td9du{width:100%;background:var(--hanna-primary);margin-bottom:1rem;overflow:hidden}a.svelte-16td9du{display:grid;grid-template-columns:25px 1fr;align-items:center;font-size:16px;font-weight:400;text-decoration:none;color:#fff;width:100%;padding:10px}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVG9wTmF2LnN2ZWx0ZSIsInNvdXJjZXMiOlsiVG9wTmF2LnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAgIGV4cG9ydCBsZXQgc2VnbWVudDtcbiAgICBpbXBvcnQgeyBzdG9yZXMgfSBmcm9tIFwiQHNhcHBlci9hcHBcIjtcbiAgICBjb25zdCB7IHNlc3Npb24gfSA9IHN0b3JlcygpO1xuPC9zY3JpcHQ+XG5cbjxkaXYgY2xhc3M9XCJ3cmFwXCI+XG4gICAgPGRpdiBjbGFzcz1cInRvcC1uYXYgcm91bmRlZC1sZyBzaGFkb3ctc21cIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImQtZmxleCBhbGlnbi1pdGVtcy1jZW50ZXIganVzdGlmeS1jb250ZW50LWNlbnRlciB0ZXh0LWNlbnRlciBteS0zXCI+XG4gICAgICAgICAgICA8aW1nIGhlaWdodD1cIjIwXCIgc3JjPVwiYWx0X2Zhdmljb24ucG5nXCIgYWx0PVwiXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC13aGl0ZSBoNCBtYi0wIG1sLTJcIj5cbiAgICAgICAgICAgICAgICBIYW5uYUNSTVxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8YSBocmVmPVwiL292ZXJ2aWV3XCIgY2xhc3M6YWN0aXZlPXtzZWdtZW50ID09PSBcIm92ZXJ2aWV3XCJ9PlxuICAgICAgICAgICAgPGkgY2xhc3M9XCJmYXMgZmEtZGFzaGJvYXJkIGZhLTF4XCI+PC9pPlxuICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICBPdmVydmlld1xuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvYT5cbiAgICAgICAgPGEgaHJlZj1cIi9pbnZvaWNlc1wiIGNsYXNzOmFjdGl2ZT17c2VnbWVudCA9PT0gXCJpbnZvaWNlc1wifT5cbiAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLWZpbGUtaW52b2ljZS1kb2xsYXIgZmEtMXhcIj48L2k+XG4gICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgIEludm9pY2VzXG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9hPlxuICAgICAgICA8YSBocmVmPVwiL3Byb2Zvcm1hc1wiIGNsYXNzOmFjdGl2ZT17c2VnbWVudCA9PT0gXCJwcm9mb3JtYXNcIn0+XG4gICAgICAgICAgICA8aSBjbGFzcz1cImZhcyBmYS1maWxlLWFsdCBmYS0xeFwiPjwvaT5cbiAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgUHJvZm9ybWFzXG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9hPlxuICAgICAgICA8YSBocmVmPVwiL2NyZWRpdG5vdGVzXCIgIGNsYXNzOmFjdGl2ZT17c2VnbWVudCA9PT0gXCJjcmVkaXRub3Rlc1wifT5cbiAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLWZpbGUtaW52b2ljZS1kb2xsYXIgZmEtMXhcIj48L2k+XG4gICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgIENyZWRpdCBub3RhXG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9hPlxuICAgICAgICA8YSBocmVmPVwiL29mZmVyc1wiICBjbGFzczphY3RpdmU9e3NlZ21lbnQgPT09IFwib2ZmZXJzXCJ9PlxuICAgICAgICAgICAgPGkgY2xhc3M9XCJmYXMgZmEtZmlsZS1hbHQgZmEtMXhcIj48L2k+XG4gICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgIE9mZmVyc1xuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvYT5cbiAgICAgICAgPGEgaHJlZj1cIi9hcnRpY2xlc1wiIGNsYXNzOmFjdGl2ZT17c2VnbWVudCA9PT0gXCJhcnRpY2xlc1wifT5cbiAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLWxpc3QtZG90cyBmYS0xeFwiPjwvaT5cbiAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgQXJ0aWNsZXNcbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2E+XG4gICAgICAgIDxhIGhyZWY9XCIvY2xpZW50c1wiIGNsYXNzOmFjdGl2ZT17c2VnbWVudCA9PT0gXCJjbGllbnRzXCJ9PlxuICAgICAgICAgICAgPGkgY2xhc3M9XCJmYXMgZmEtdXNlciBmYS0xeFwiPjwvaT5cbiAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgQ2xpZW50c1xuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvYT5cbiAgICAgICAgPCEtLSBhIGhyZWY9XCIvbG90c1wiIGNsYXNzOmFjdGl2ZT17c2VnbWVudCA9PT0gXCJsb3RzXCJ9PlxuICAgICAgICAgICAgPGkgY2xhc3M9XCJmYXMgZmEtYm94IGZhLTF4XCI+PC9pPlxuICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICBMb3RzXG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9hIC0tPlxuICAgICAgICA8YSBocmVmPVwiL21vbmV5XCIgY2xhc3M6YWN0aXZlPXtzZWdtZW50ID09PSBcInBheW1lbnRzXCJ9PlxuICAgICAgICAgICAgPGkgY2xhc3M9XCJmYXMgZmEtZXVyby1zaWduIGZhLTF4XCI+PC9pPlxuICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICBNb25leVxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvYT5cblxuICAgICAgICA8ZGl2IHN0eWxlPVwiZ3JpZC1jb2x1bW46IDEvMztcIj5cbiAgICAgICAgICAgIDxociBjbGFzcz1cIm15LTFcIj5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgeyNpZiAoJHNlc3Npb24/LnVzZXIpfVxuICAgICAgICAgICAgPGEgaHJlZj1cIi9hdXRoL2xvZ291dFwiPlxuICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLXNpZ24tb3V0LWFsdCBmYS0xeFwiPjwvaT5cbiAgICAgICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgICAgICBMb2cgb3V0XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2E+XG4gICAgICAgIHs6ZWxzZX1cbiAgICAgICAgICAgIDxhIGhyZWY9XCIvYXV0aFwiPlxuICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLXNpZ24taW4gZmEtMXhcIj48L2k+XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgTG9nIGluXG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2E+XG4gICAgICAgIHsvaWZ9XG4gICAgPC9kaXY+XG48L2Rpdj5cblxuPHN0eWxlPlxuICAgIC5hY3RpdmUge1xuICAgICAgICBjb2xvcjogdmFyKC0tcHJpbWFyeS1jb2xvcik7XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6ICNmZmY7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiBib2xkO1xuICAgIH1cblxuICAgIC53cmFwIHtcbiAgICAgICAgd2lkdGg6IDE2MHB4O1xuICAgICAgICBoZWlnaHQ6IDEwMCU7XG4gICAgICAgIGdhcDogMTBweDtcbiAgICB9XG5cbiAgICAudG9wLW5hdiB7XG4gICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICBiYWNrZ3JvdW5kOiB2YXIoLS1oYW5uYS1wcmltYXJ5KTtcbiAgICAgICAgbWFyZ2luLWJvdHRvbTogMXJlbTtcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICB9XG5cbiAgICBhIHtcbiAgICAgICAgZGlzcGxheTogZ3JpZDtcbiAgICAgICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAyNXB4IDFmcjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgZm9udC1zaXplOiAxNnB4O1xuICAgICAgICBmb250LXdlaWdodDogNDAwO1xuICAgICAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgICAgIGNvbG9yOiAjZmZmO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgcGFkZGluZzogMTBweDtcbiAgICB9XG48L3N0eWxlPlxuXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEZJLHNCQUFRLENBQ0osS0FBSyxDQUFFLElBQUksZUFBZSxDQUFDLENBQzNCLGdCQUFnQixDQUFFLElBQUksQ0FDdEIsV0FBVyxDQUFFLElBQ2pCLENBRUEsb0JBQU0sQ0FDRixLQUFLLENBQUUsS0FBSyxDQUNaLE1BQU0sQ0FBRSxJQUFJLENBQ1osR0FBRyxDQUFFLElBQ1QsQ0FFQSx1QkFBUyxDQUNMLEtBQUssQ0FBRSxJQUFJLENBQ1gsVUFBVSxDQUFFLElBQUksZUFBZSxDQUFDLENBQ2hDLGFBQWEsQ0FBRSxJQUFJLENBQ25CLFFBQVEsQ0FBRSxNQUNkLENBRUEsZ0JBQUUsQ0FDRSxPQUFPLENBQUUsSUFBSSxDQUNiLHFCQUFxQixDQUFFLElBQUksQ0FBQyxHQUFHLENBQy9CLFdBQVcsQ0FBRSxNQUFNLENBQ25CLFNBQVMsQ0FBRSxJQUFJLENBQ2YsV0FBVyxDQUFFLEdBQUcsQ0FDaEIsZUFBZSxDQUFFLElBQUksQ0FDckIsS0FBSyxDQUFFLElBQUksQ0FDWCxLQUFLLENBQUUsSUFBSSxDQUNYLE9BQU8sQ0FBRSxJQUNiIn0= */
.toast-bar.svelte-xy39yx{height:4px;border-radius:4px;background-color:rgba(0, 0, 0, 0.32);transition:100ms ease-in-out}.toast55.svelte-xy39yx{display:grid;grid-template-columns:1fr max-content;align-items:center;grid-gap:15px;color:#fff;padding:5px 15px;border-radius:15px}.toast-success.svelte-xy39yx{background:#038a00}.toast-error.svelte-xy39yx{background:#8f0000}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVG9hc3Quc3ZlbHRlIiwic291cmNlcyI6WyJUb2FzdC5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgICBleHBvcnQgbGV0IHRvYXN0O1xuXG4gICAgaW1wb3J0IHsgb25Nb3VudCwgY3JlYXRlRXZlbnREaXNwYXRjaGVyIH0gZnJvbSBcInN2ZWx0ZVwiO1xuXG4gICAgbGV0IHRpbWVyMSwgdGltZXIyO1xuICAgIGNvbnN0IHR0bCA9IDU7XG4gICAgbGV0IGxlZnRPdmVyID0gdHRsO1xuICAgIGNvbnN0IGRpc3BhdGNoID0gY3JlYXRlRXZlbnREaXNwYXRjaGVyKCk7XG5cbiAgICBvbk1vdW50KCAoKSA9PiB7XG4gICAgICAgIHRpbWVyMSA9IHNldFRpbWVvdXQoZGVsZXRlVG9hc3QsIHR0bCAqIDEwMDApO1xuXG4gICAgICAgIHRpbWVyMiA9IHNldEludGVydmFsKGZ1bmN0aW9uICgpe1xuICAgICAgICAgICAgaWYobGVmdE92ZXIpIGxlZnRPdmVyID0gbGVmdE92ZXIgLSAwLjI7XG4gICAgICAgICAgICBlbHNlIGRlbGV0ZVRvYXN0KCk7XG4gICAgICAgIH0sIDIwMCk7XG5cbiAgICAgICAgcmV0dXJuIGZ1bmN0aW9uICgpe1xuICAgICAgICAgICAgY2xlYXJUaW1lb3V0KHRpbWVyMSk7XG4gICAgICAgICAgICBjbGVhckludGVydmFsKHRpbWVyMik7XG4gICAgICAgIH1cbiAgICB9KTtcblxuICAgIGNvbnN0IGRlbGV0ZVRvYXN0ID0gKCkgPT4ge1xuICAgICAgICBkaXNwYXRjaChcImRlbGV0ZVRvYXN0XCIsIHRvYXN0LmlkKTtcbiAgICB9XG48L3NjcmlwdD5cblxuPGRpdlxuICAgIGNsYXNzPVwidG9hc3Q1NVwiXG4gICAgY2xhc3M6dG9hc3QtZXJyb3I9eyB0b2FzdC50eXBlID09PSBcImVycm9yXCIgfVxuICAgIGNsYXNzOnRvYXN0LXN1Y2Nlc3M9eyB0b2FzdC50eXBlID09PSBcInN1Y2Nlc3NcIiB9XG4+XG4gICAgPGRpdj5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHsgdG9hc3QubWVzc2FnZSB9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IHN0eWxlPXtgd2lkdGg6ICR7MTAwICogbGVmdE92ZXIgLyB0dGx9JWB9IGNsYXNzPVwidG9hc3QtYmFyXCI+PC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGJ1dHRvbiBjbGFzcz1cImJ0biBwLTBcIiBvbjpjbGljaz17IGRlbGV0ZVRvYXN0IH0+XG4gICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLXRpbWVzIHRleHQtd2hpdGVcIj48L2k+XG4gICAgPC9idXR0b24+XG5cbjwvZGl2PlxuXG48c3R5bGU+XG4gICAgLnRvYXN0LWJhciB7XG4gICAgICAgIGhlaWdodDogNHB4O1xuICAgICAgICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6IHJnYmEoMCwgMCwgMCwgMC4zMik7XG4gICAgICAgIHRyYW5zaXRpb246IDEwMG1zIGVhc2UtaW4tb3V0O1xuICAgIH1cblxuICAgIC50b2FzdDU1IHtcbiAgICAgICAgZGlzcGxheTogZ3JpZDtcbiAgICAgICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWF4LWNvbnRlbnQ7XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIGdyaWQtZ2FwOiAxNXB4O1xuICAgICAgICBjb2xvcjogI2ZmZjtcbiAgICAgICAgcGFkZGluZzogNXB4IDE1cHg7XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDE1cHg7XG4gICAgfVxuXG4gICAgLnRvYXN0LXN1Y2Nlc3Mge1xuICAgICAgICBiYWNrZ3JvdW5kOiAjMDM4YTAwO1xuICAgIH1cblxuICAgIC50b2FzdC1lcnJvciB7XG4gICAgICAgIGJhY2tncm91bmQ6ICM4ZjAwMDA7XG4gICAgfVxuPC9zdHlsZT4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0NJLHdCQUFXLENBQ1AsTUFBTSxDQUFFLEdBQUcsQ0FDWCxhQUFhLENBQUUsR0FBRyxDQUNsQixnQkFBZ0IsQ0FBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUNyQyxVQUFVLENBQUUsS0FBSyxDQUFDLFdBQ3RCLENBRUEsc0JBQVMsQ0FDTCxPQUFPLENBQUUsSUFBSSxDQUNiLHFCQUFxQixDQUFFLEdBQUcsQ0FBQyxXQUFXLENBQ3RDLFdBQVcsQ0FBRSxNQUFNLENBQ25CLFFBQVEsQ0FBRSxJQUFJLENBQ2QsS0FBSyxDQUFFLElBQUksQ0FDWCxPQUFPLENBQUUsR0FBRyxDQUFDLElBQUksQ0FDakIsYUFBYSxDQUFFLElBQ25CLENBRUEsNEJBQWUsQ0FDWCxVQUFVLENBQUUsT0FDaEIsQ0FFQSwwQkFBYSxDQUNULFVBQVUsQ0FBRSxPQUNoQiJ9 */
.toasts55-wrap.svelte-bdb71e{position:fixed;z-index:9999;top:0;right:0;display:grid;grid-gap:10px;grid-template-columns:1fr;padding:10px 5px}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVG9hc3Rlci5zdmVsdGUiLCJzb3VyY2VzIjpbIlRvYXN0ZXIuc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gICAgaW1wb3J0IHsgb25Nb3VudCB9IGZyb20gXCJzdmVsdGVcIjtcbiAgICBpbXBvcnQgVG9hc3QgZnJvbSBcIi4vVG9hc3Quc3ZlbHRlXCI7XG5cbiAgICBsZXQgdG9hc3RzID0gW107XG5cbiAgICBvbk1vdW50KCAoKSA9PiB7XG4gICAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKFwibWVzc2FnZVwiLCBlID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHsgdHlwZSwgbWVzc2FnZSB9ID0gZS5kYXRhO1xuICAgICAgICAgICAgaWYoIXR5cGUgfHwgIW1lc3NhZ2UpIHJldHVybjtcblxuICAgICAgICAgICAgdG9hc3RzLnB1c2goZS5kYXRhKTtcbiAgICAgICAgICAgIHRvYXN0cyA9IFsuLi50b2FzdHNdO1xuICAgICAgICB9KTtcbiAgICB9KTtcblxuICAgIGNvbnN0IGRlbGV0ZVRvYXN0ID0gKGUpID0+IHtcbiAgICAgICAgY29uc3QgaW5kID0gdG9hc3RzLmZpbmRJbmRleCh0b2FzdCA9PiB0b2FzdC5pZCA9PT0gZS5kZXRhaWwpO1xuICAgICAgICB0b2FzdHMuc3BsaWNlKGluZCwgMSk7XG4gICAgICAgIHRvYXN0cyA9IFsuLi50b2FzdHNdO1xuICAgIH07XG48L3NjcmlwdD5cblxuPGRpdiBjbGFzcz1cInRvYXN0czU1LXdyYXBcIj5cbiAgICB7I2VhY2ggdG9hc3RzIGFzIHRvYXN0LCBpICh0b2FzdC5pZCl9XG4gICAgICAgIDxUb2FzdCB7dG9hc3R9IG9uOmRlbGV0ZVRvYXN0PXsgZGVsZXRlVG9hc3QgfSAvPlxuICAgIHsvZWFjaH1cbjwvZGl2PlxuXG48c3R5bGU+XG4gICAgLnRvYXN0czU1LXdyYXAge1xuICAgICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICAgIHotaW5kZXg6IDk5OTk7XG4gICAgICAgIHRvcDogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIGRpc3BsYXk6IGdyaWQ7XG4gICAgICAgIGdyaWQtZ2FwOiAxMHB4O1xuICAgICAgICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDFmcjtcbiAgICAgICAgcGFkZGluZzogMTBweCA1cHg7XG4gICAgfVxuPC9zdHlsZT5cblxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCSSw0QkFBZSxDQUNYLFFBQVEsQ0FBRSxLQUFLLENBQ2YsT0FBTyxDQUFFLElBQUksQ0FDYixHQUFHLENBQUUsQ0FBQyxDQUNOLEtBQUssQ0FBRSxDQUFDLENBQ1IsT0FBTyxDQUFFLElBQUksQ0FDYixRQUFRLENBQUUsSUFBSSxDQUNkLHFCQUFxQixDQUFFLEdBQUcsQ0FDMUIsT0FBTyxDQUFFLElBQUksQ0FBQyxHQUNsQiJ9 */
.loader-wrap.svelte-ovc8d1{position:fixed;top:0;left:0;height:100vh;width:100vw;z-index:51;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);display:flex;flex-direction:column;align-items:center;justify-content:center}.spinner-border.svelte-ovc8d1{color:#000!important;width:6rem;height:6rem;border-width:0.35rem!important}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9hZGVyLnN2ZWx0ZSIsInNvdXJjZXMiOlsiTG9hZGVyLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAgIGltcG9ydCB7IGZhZGUgfSBmcm9tICdzdmVsdGUvdHJhbnNpdGlvbic7XG4gICAgaW1wb3J0IHsgcXVpbnRJbk91dCB9IGZyb20gJ3N2ZWx0ZS9lYXNpbmcnO1xuICAgIGltcG9ydCB7IGxvYWRpbmcgfSBmcm9tIFwiLi4vc3RvcmVcIjtcbjwvc2NyaXB0PlxuXG57I2lmICRsb2FkaW5nfVxuICAgIDxkaXZcbiAgICAgICAgICAgIGNsYXNzPVwibG9hZGVyLXdyYXBcIlxuICAgICAgICAgICAgdHJhbnNpdGlvbjpmYWRlPXt7IGRlbGF5OiAwLCBkdXJhdGlvbjogMjAwLCBvcGFjaXR5OiAwLCBlYXNpbmc6IHF1aW50SW5PdXQgfX1cbiAgICA+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzcGlubmVyIHNwaW5uZXItYm9yZGVyXCI+PC9kaXY+XG4gICAgPC9kaXY+XG57L2lmfVxuXG48c3R5bGU+XG4gICAgLmxvYWRlci13cmFwIHtcbiAgICAgICAgcG9zaXRpb246IGZpeGVkO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGhlaWdodDogMTAwdmg7XG4gICAgICAgIHdpZHRoOiAxMDB2dztcbiAgICAgICAgei1pbmRleDogNTE7XG4gICAgICAgIGJhY2tkcm9wLWZpbHRlcjogYmx1cig3cHgpO1xuICAgICAgICAtd2Via2l0LWJhY2tkcm9wLWZpbHRlcjogYmx1cig3cHgpO1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgICB9XG5cbiAgICAuc3Bpbm5lci1ib3JkZXIge1xuICAgICAgICBjb2xvcjogIzAwMCFpbXBvcnRhbnQ7XG4gICAgICAgIHdpZHRoOiA2cmVtO1xuICAgICAgICBoZWlnaHQ6IDZyZW07XG4gICAgICAgIGJvcmRlci13aWR0aDogMC4zNXJlbSFpbXBvcnRhbnQ7XG4gICAgfVxuPC9zdHlsZT4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JJLDBCQUFhLENBQ1QsUUFBUSxDQUFFLEtBQUssQ0FDZixHQUFHLENBQUUsQ0FBQyxDQUNOLElBQUksQ0FBRSxDQUFDLENBQ1AsTUFBTSxDQUFFLEtBQUssQ0FDYixLQUFLLENBQUUsS0FBSyxDQUNaLE9BQU8sQ0FBRSxFQUFFLENBQ1gsZUFBZSxDQUFFLEtBQUssR0FBRyxDQUFDLENBQzFCLHVCQUF1QixDQUFFLEtBQUssR0FBRyxDQUFDLENBQ2xDLE9BQU8sQ0FBRSxJQUFJLENBQ2IsY0FBYyxDQUFFLE1BQU0sQ0FDdEIsV0FBVyxDQUFFLE1BQU0sQ0FDbkIsZUFBZSxDQUFFLE1BQ3JCLENBRUEsNkJBQWdCLENBQ1osS0FBSyxDQUFFLElBQUksVUFBVSxDQUNyQixLQUFLLENBQUUsSUFBSSxDQUNYLE1BQU0sQ0FBRSxJQUFJLENBQ1osWUFBWSxDQUFFLE9BQU8sVUFDekIifQ== */
.login-modal-header.svelte-y39mwz{display:flex;align-items:center;justify-content:space-between;overflow:hidden}.slot-content.svelte-y39mwz{width:100%;overflow:hidden;z-index:2;background:var(--light);border-top-left-radius:1rem;border-top-right-radius:1rem;box-shadow:0 0 8px #cfcfcf!important;height:max-content}.my-modal-shadow.svelte-y39mwz{background:rgba(84,91,98, 0.5);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);overscroll-behavior-y:contain;position:absolute;top:0;left:0;width:100vw;height:100%;z-index:1;touch-action:none}.my-modal-content.svelte-y39mwz{position:relative;touch-action:none;height:var(--tg-viewport-height);width:100%;display:flex;flex-direction:column;justify-content:end;align-items:center}.my-modal-wrap.svelte-y39mwz{position:fixed;top:0;left:0;width:100vw;height:100%;overflow:hidden;z-index:50;overscroll-behavior-y:contain}.login-modal-content.svelte-y39mwz{overscroll-behavior:none;min-height:200px;padding-bottom:100px;overflow-y:auto}@media screen and (min-width: 768px){.slot-content.svelte-y39mwz{width:max-content;min-width:400px;max-width:80vw;margin:20px auto auto;border-bottom-left-radius:1rem;border-bottom-right-radius:1rem}.login-modal-content.svelte-y39mwz{padding-bottom:1rem}}.text-overflow-ellipsis.svelte-y39mwz{text-overflow:ellipsis;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;line-clamp:1}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Modal.svelte","sources":["Modal.svelte"],"sourcesContent":["<script>\n    export let show = false, title = \"\", onClose, withSearch = false, search = \"\";\n\n    import { onMount, onDestroy } from \"svelte\";\n    import { fly, fade } from 'svelte/transition';\n    import { quintOut } from 'svelte/easing';\n    import { modalShowed, bodyNoScroll, forceCloseModal, h, modalIndex } from \"../store\";\n\n    let mounted = false;\n    let time = Date.now();\n    let zIndex = 50;\n\n    onMount( () => {\n        mounted = true;\n        $modalIndex++;\n        zIndex = $modalIndex;\n        $h = window.innerHeight;\n    } );\n\n    $: {\n        if(mounted) {\n            if($forceCloseModal) hideModal();\n            else {\n                if(show) {\n                    time = Date.now();\n                    $modalShowed = true;\n                    $bodyNoScroll = true;\n                }\n                else {\n                    hideModal();\n                }\n            }\n        }\n    }\n\n    //$: console.log(`height: ${$h}px`);\n\n    function nothing() {}\n\n    function hideModal(){\n        show = false;\n        $modalShowed = false;\n        $forceCloseModal = false;\n        if($bodyNoScroll) $bodyNoScroll = false;\n        if(onClose) onClose();\n    }\n</script>\n\n{#if show && mounted}\n    <div class=\"my-modal-wrap\" data-time={time} style={`height: ${$h}px; z-index: ${zIndex};`}>\n        <div\n            class=\"my-modal-content\"\n            style={`height: ${$h}px;`}\n        >\n            <div\n                    in:fly={{ delay: 0, duration: 700, y: $h, opacity: 1, easing: quintOut }}\n                    class=\"slot-content\"\n                    style={`max-height: calc( ${$h}px - var(--tg-safe-area-inset-top, 0px) - var(--tg-content-safe-area-inset-top,0px) - 10px);` }\n            >\n                <div class=\"login-modal-header\">\n                    <div\n                        class=\"mx-3 my-2 text-overflow-ellipsis\"\n                        style=\"font-size: 18px; font-weight: 400;\"\n                    >\n                        {title}\n                    </div>\n                    <button\n                        class=\"btn pr-3 d-flex align-items-center\"\n                        on:click={ hideModal }\n                    >\n                        <i class=\"fas fa-times fa-15x text-dark\" />\n                    </button>\n                </div>\n\n                <div\n                    class=\"login-modal-content px-2 px-md-4\"\n                    style={`max-height: calc( ${$h}px - var(--tg-safe-area-inset-top, 0px) - var(--tg-content-safe-area-inset-top,0px) - 55px);`}\n                    on:click={ nothing }\n                >\n                    <slot></slot>\n                </div>\n            </div>\n            <div\n                class=\"my-modal-shadow\"\n                style={`height: ${$h}px;`}\n                in:fade={{ delay: 0, duration: 300, opacity: 0 }}\n                on:click={ nothing }\n            ></div>\n        </div>\n    </div>\n{/if}\n\n<style>\n    .login-modal-header {\n        display: flex;\n        align-items: center;\n        justify-content: space-between;\n        overflow: hidden;\n    }\n\n    .slot-content {\n        width: 100%;\n        overflow: hidden;\n        z-index: 2;\n        background: var(--light);\n        border-top-left-radius: 1rem;\n        border-top-right-radius: 1rem;\n        box-shadow: 0 0 8px #cfcfcf!important;\n        height: max-content;\n    }\n\n    .my-modal-shadow {\n        background: rgba(84,91,98, 0.5);\n        backdrop-filter: blur(20px);\n        -webkit-backdrop-filter: blur(20px);\n        overscroll-behavior-y: contain;\n        position: absolute;\n        top: 0;\n        left: 0;\n        width: 100vw;\n        height: 100%;\n        z-index: 1;\n        touch-action: none;\n    }\n\n    .my-modal-content {\n        position: relative;\n        touch-action: none;\n        height: var(--tg-viewport-height);\n        width: 100%;\n        display: flex;\n        flex-direction: column;\n        justify-content: end;\n        align-items: center;\n    }\n\n    .my-modal-wrap {\n        position: fixed;\n        top: 0;\n        left: 0;\n        width: 100vw;\n        height: 100%;\n        overflow: hidden;\n        z-index: 50;\n        overscroll-behavior-y: contain;\n    }\n\n    .login-modal-content {\n        overscroll-behavior: none;\n        min-height: 200px;\n        padding-bottom: 100px;\n        overflow-y: auto;\n    }\n\n    @media screen and (min-width: 768px) {\n        .slot-content {\n            width: max-content;\n            min-width: 400px;\n            max-width: 80vw;\n            margin: 20px auto auto;\n            border-bottom-left-radius: 1rem;\n            border-bottom-right-radius: 1rem;\n        }\n\n        .login-modal-content {\n            padding-bottom: 1rem;\n        }\n    }\n\n    .text-overflow-ellipsis {\n        text-overflow: ellipsis;\n        overflow: hidden;\n        display: -webkit-box;\n        -webkit-box-orient: vertical;\n        -webkit-line-clamp: 1;\n        line-clamp: 1;\n    }\n</style>"],"names":[],"mappings":"AA6FI,iCAAoB,CAChB,OAAO,CAAE,IAAI,CACb,WAAW,CAAE,MAAM,CACnB,eAAe,CAAE,aAAa,CAC9B,QAAQ,CAAE,MACd,CAEA,2BAAc,CACV,KAAK,CAAE,IAAI,CACX,QAAQ,CAAE,MAAM,CAChB,OAAO,CAAE,CAAC,CACV,UAAU,CAAE,IAAI,OAAO,CAAC,CACxB,sBAAsB,CAAE,IAAI,CAC5B,uBAAuB,CAAE,IAAI,CAC7B,UAAU,CAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,UAAU,CACrC,MAAM,CAAE,WACZ,CAEA,8BAAiB,CACb,UAAU,CAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAC/B,eAAe,CAAE,KAAK,IAAI,CAAC,CAC3B,uBAAuB,CAAE,KAAK,IAAI,CAAC,CACnC,qBAAqB,CAAE,OAAO,CAC9B,QAAQ,CAAE,QAAQ,CAClB,GAAG,CAAE,CAAC,CACN,IAAI,CAAE,CAAC,CACP,KAAK,CAAE,KAAK,CACZ,MAAM,CAAE,IAAI,CACZ,OAAO,CAAE,CAAC,CACV,YAAY,CAAE,IAClB,CAEA,+BAAkB,CACd,QAAQ,CAAE,QAAQ,CAClB,YAAY,CAAE,IAAI,CAClB,MAAM,CAAE,IAAI,oBAAoB,CAAC,CACjC,KAAK,CAAE,IAAI,CACX,OAAO,CAAE,IAAI,CACb,cAAc,CAAE,MAAM,CACtB,eAAe,CAAE,GAAG,CACpB,WAAW,CAAE,MACjB,CAEA,4BAAe,CACX,QAAQ,CAAE,KAAK,CACf,GAAG,CAAE,CAAC,CACN,IAAI,CAAE,CAAC,CACP,KAAK,CAAE,KAAK,CACZ,MAAM,CAAE,IAAI,CACZ,QAAQ,CAAE,MAAM,CAChB,OAAO,CAAE,EAAE,CACX,qBAAqB,CAAE,OAC3B,CAEA,kCAAqB,CACjB,mBAAmB,CAAE,IAAI,CACzB,UAAU,CAAE,KAAK,CACjB,cAAc,CAAE,KAAK,CACrB,UAAU,CAAE,IAChB,CAEA,OAAO,MAAM,CAAC,GAAG,CAAC,YAAY,KAAK,CAAE,CACjC,2BAAc,CACV,KAAK,CAAE,WAAW,CAClB,SAAS,CAAE,KAAK,CAChB,SAAS,CAAE,IAAI,CACf,MAAM,CAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CACtB,yBAAyB,CAAE,IAAI,CAC/B,0BAA0B,CAAE,IAChC,CAEA,kCAAqB,CACjB,cAAc,CAAE,IACpB,CACJ,CAEA,qCAAwB,CACpB,aAAa,CAAE,QAAQ,CACvB,QAAQ,CAAE,MAAM,CAChB,OAAO,CAAE,WAAW,CACpB,kBAAkB,CAAE,QAAQ,CAC5B,kBAAkB,CAAE,CAAC,CACrB,UAAU,CAAE,CAChB"} */
.btn-sm.svelte-7gakh6{font-size:12px;padding:0px 10px}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2xpZW50TW9kYWwuc3ZlbHRlIiwic291cmNlcyI6WyJDbGllbnRNb2RhbC5zdmVsdGUiXSwic291cmNlc0NvbnRlbnQiOlsiPHNjcmlwdD5cbiAgICBpbXBvcnQgTW9kYWwgZnJvbSBcIi4uL01vZGFsLnN2ZWx0ZVwiO1xuICAgIGltcG9ydCB7IGNsaWVudElkLCBsb2FkaW5nLCByZWZzIH0gZnJvbSBcIi4uLy4uL3N0b3JlXCI7XG4gICAgaW1wb3J0IHsgb25Nb3VudCB9IGZyb20gXCJzdmVsdGVcIjtcbiAgICBpbXBvcnQgeyBlcnJvck5vdGlmaWNhdGlvbiwgc3VjY2Vzc05vdGlmaWNhdGlvbiwgZ2F0ZSB9IGZyb20gXCIuLi8uLi9mcm9udEhlbHBlcnNcIjtcblxuICAgIGxldCBpc05ldztcbiAgICBsZXQgY2xpZW50ID0ge307XG5cbiAgICBvbk1vdW50KCAoKSA9PiB7XG4gICAgICAgIGlzTmV3ID0gJGNsaWVudElkID09PSBcIm5ld1wiO1xuICAgICAgICBnZXRDbGllbnREYXRhKCk7XG4gICAgfSk7XG5cbiAgICBjb25zdCBnZXRDbGllbnREYXRhID0gYXN5bmMgKCkgPT4ge1xuICAgICAgICBpZihpc05ldykgcmV0dXJuO1xuICAgICAgICBpZighJGNsaWVudElkKSByZXR1cm47XG5cbiAgICAgICAgJGxvYWRpbmcgPSB0cnVlO1xuXG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBjbGllbnQgPSBhd2FpdCBnYXRlKHtcbiAgICAgICAgICAgICAgICB1cmw6IGAvY2xpZW50cy8keyRjbGllbnRJZH0uanNvbmAsXG4gICAgICAgICAgICAgICAgbWV0aG9kOiBcIlBPU1RcIlxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgY2F0Y2goZXJyKSB7XG4gICAgICAgICAgICBjb25zb2xlLmxvZyhlcnIpO1xuICAgICAgICB9XG5cbiAgICAgICAgJGxvYWRpbmcgPSBmYWxzZTtcbiAgICB9XG5cbiAgICBjb25zdCBzYXZlRGF0YSA9IGFzeW5jICgpID0+IHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGF3YWl0IGdhdGUoe1xuICAgICAgICAgICAgICAgIHVybDogYC9jbGllbnRzLyR7IGlzTmV3ID8gXCJsaXN0XCIgOiAkY2xpZW50SWQgfS5qc29uYCxcbiAgICAgICAgICAgICAgICBtZXRob2Q6IFwiUEFUQ0hcIixcbiAgICAgICAgICAgICAgICBkYXRhOiBjbGllbnRcbiAgICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgICBzdWNjZXNzTm90aWZpY2F0aW9uKGlzTmV3ID8gXCJzdWNjZXNzZnVsbHkgY3JlYXRlZFwiIDogXCJzdWNjZXNzZnVsbHkgdXBkYXRlZFwiKTtcbiAgICAgICAgICAgIGNsb3NlTW9kYWwoKTtcbiAgICAgICAgfVxuICAgICAgICBjYXRjaChlcnIpIHtcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKGVycik7XG4gICAgICAgICAgICBlcnJvck5vdGlmaWNhdGlvbihlcnIpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgY2xvc2VNb2RhbCA9ICgpID0+IHtcbiAgICAgICAgJGNsaWVudElkID0gbnVsbDtcbiAgICB9O1xuPC9zY3JpcHQ+XG5cbjxNb2RhbCBiaW5kOnNob3c9eyRjbGllbnRJZH0gdGl0bGU9eyBpc05ldyA/IFwiTmV3IENsaWVudFwiIDogY2xpZW50Py5uYW1lIH0+XG4gICAgPGZvcm1cbiAgICAgICAgY2xhc3M9XCJtdC0zIHJvd1wiXG4gICAgICAgIHN0eWxlPVwibWF4LXdpZHRoOiA2MDBweDtcIlxuICAgICAgICBvbjpzdWJtaXR8cHJldmVudERlZmF1bHQ9eyBzYXZlRGF0YSB9XG4gICAgPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS1ncm91cCBjb2wtMTJcIj5cbiAgICAgICAgICAgIDxiPkNsaWVudCBuYW1lPC9iPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgYmluZDp2YWx1ZT17Y2xpZW50Lm5hbWV9IGNsYXNzPVwiZm9ybS1jb250cm9sXCIgLz5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImZvcm0tZ3JvdXAgY29sLThcIj5cbiAgICAgICAgICAgIDxiPkVtYWlsPC9iPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJlbWFpbFwiIGJpbmQ6dmFsdWU9e2NsaWVudC5lbWFpbH0gY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiAvPlxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS1ncm91cCBjb2wtNFwiPlxuICAgICAgICAgICAgPGI+UGhvbmU8L2I+XG4gICAgICAgICAgICA8aW5wdXQgdHlwZT1cInRleHRcIiBiaW5kOnZhbHVlPXtjbGllbnQucGhvbmV9IGNsYXNzPVwiZm9ybS1jb250cm9sXCIgLz5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImZvcm0tZ3JvdXAgY29sLTEyXCI+XG4gICAgICAgICAgICA8Yj5Db250YWN0IHBlcnNvbjwvYj5cbiAgICAgICAgICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIGJpbmQ6dmFsdWU9e2NsaWVudC5jb250YWN0UGVyc29ufSBjbGFzcz1cImZvcm0tY29udHJvbFwiIC8+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwIGNvbC00XCI+XG4gICAgICAgICAgICA8Yj5LVks8L2I+XG4gICAgICAgICAgICA8aW5wdXQgdHlwZT1cInRleHRcIiBiaW5kOnZhbHVlPXtjbGllbnQua3ZrfSBjbGFzcz1cImZvcm0tY29udHJvbFwiIC8+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwIGNvbC04XCI+XG4gICAgICAgICAgICA8Yj5CVFcgbnVtYmVyPC9iPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgYmluZDp2YWx1ZT17Y2xpZW50LmJ0d051bWJlcn0gY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiAvPlxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS1ncm91cCBjb2wtNFwiPlxuICAgICAgICAgICAgPGI+Q291bnRyeTwvYj5cbiAgICAgICAgICAgIDxzZWxlY3QgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiBiaW5kOnZhbHVlPXtjbGllbnQuY291bnRyeX0+XG4gICAgICAgICAgICAgICAgPG9wdGlvbiB2YWx1ZT1cIlwiPjwvb3B0aW9uPlxuICAgICAgICAgICAgICAgIHsjZWFjaCBPYmplY3QuZW50cmllcygkcmVmcz8uY291bnRyaWVzKSBhcyBbY29kZSwgY291bnRyeV19XG4gICAgICAgICAgICAgICAgICAgIDxvcHRpb24gdmFsdWU9e2NvZGV9PlxuICAgICAgICAgICAgICAgICAgICAgICAgeyBjb3VudHJ5IH1cbiAgICAgICAgICAgICAgICAgICAgPC9vcHRpb24+XG4gICAgICAgICAgICAgICAgey9lYWNofVxuICAgICAgICAgICAgPC9zZWxlY3Q+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwIGNvbC0zXCI+XG4gICAgICAgICAgICA8Yj5Qb3N0Y29kZTwvYj5cbiAgICAgICAgICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIGJpbmQ6dmFsdWU9e2NsaWVudC5wb3N0Y29kZX0gY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiAvPlxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS1ncm91cCBjb2wtNVwiPlxuICAgICAgICAgICAgPGI+Q2l0eTwvYj5cbiAgICAgICAgICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIGJpbmQ6dmFsdWU9e2NsaWVudC5jaXR5fSBjbGFzcz1cImZvcm0tY29udHJvbFwiIC8+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwIGNvbC0xMlwiPlxuICAgICAgICAgICAgPGI+QWRkcmVzczwvYj5cbiAgICAgICAgICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIGJpbmQ6dmFsdWU9e2NsaWVudC5hZGRyZXNzfSBjbGFzcz1cImZvcm0tY29udHJvbFwiIC8+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwIGNvbC0xMlwiPlxuICAgICAgICAgICAgPGI+SW52b2ljZSBhZGRyZXNzPC9iPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgYmluZDp2YWx1ZT17Y2xpZW50Lmludm9pY2VBZGRyZXNzfSBjbGFzcz1cImZvcm0tY29udHJvbFwiIC8+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwIGNvbC0xMlwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImQtZmxleCBhbGlnbi1pdGVtcy1jZW50ZXIganVzdGlmeS1jb250ZW50LWJldHdlZW5cIj5cbiAgICAgICAgICAgICAgICA8Yj5EZWxpdmVyeSBhZGRyZXNzPC9iPlxuICAgICAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiYnRuIGJ0bi1zbSByb3VuZGVkLXBpbGwgYnRuLW91dGxpbmUtZGFya1wiXG4gICAgICAgICAgICAgICAgICAgIG9uOmNsaWNrPXsgKCkgPT4gY2xpZW50LmRlbGl2ZXJ5QWRkcmVzcyA9IGNsaWVudC5pbnZvaWNlQWRkcmVzcyB9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICBDb3B5IGludm9pY2UgYWRkclxuICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIGJpbmQ6dmFsdWU9e2NsaWVudC5kZWxpdmVyeUFkZHJlc3N9IGNsYXNzPVwiZm9ybS1jb250cm9sXCIgLz5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImZvcm0tZ3JvdXAgY29sLTEyXCI+XG4gICAgICAgICAgICA8Yj5FT1JJPC9iPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgYmluZDp2YWx1ZT17Y2xpZW50LmVvcml9IGNsYXNzPVwiZm9ybS1jb250cm9sXCIgLz5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cInRleHQtY2VudGVyIGNvbC0xMlwiPlxuICAgICAgICAgICAgPGJ1dHRvbiB0eXBlPVwic3VibWl0XCIgY2xhc3M9XCJidG4gYnRuLWdvbGRcIj5cbiAgICAgICAgICAgICAgICBTYXZlXG4gICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9mb3JtPlxuPC9Nb2RhbD5cblxuPHN0eWxlPlxuICAgIC5idG4tc20ge1xuICAgICAgICBmb250LXNpemU6IDEycHg7XG4gICAgICAgIHBhZGRpbmc6IDBweCAxMHB4O1xuICAgIH1cbjwvc3R5bGU+XG5cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3SkkscUJBQVEsQ0FDSixTQUFTLENBQUUsSUFBSSxDQUNmLE9BQU8sQ0FBRSxHQUFHLENBQUMsSUFDakIifQ== */
.search-wrap.svelte-18i3w1v{background:#fff;position:fixed;top:auto;left:auto;max-height:400px;min-width:300px;overflow:hidden;z-index:3;border:2px solid var(--hanna-primary)}.search-results.svelte-18i3w1v{overflow-x:hidden;overflow-y:auto;max-height:360px;height:100%}.search-result.svelte-18i3w1v{cursor:pointer;white-space:nowrap}.search-result.svelte-18i3w1v:hover{background:#dedede}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VsZWN0LnN2ZWx0ZSIsInNvdXJjZXMiOlsiU2VsZWN0LnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAgIGV4cG9ydCBsZXQgbmFtZUZpZWxkLCBlbmRQb2ludCwgc2VsZWN0ZWQsIHZpZXdGaWVsZCwgbmFtZVByZWZpeCA9IFwiXCI7XG5cbiAgICBpbXBvcnQgeyBvbk1vdW50LCBjcmVhdGVFdmVudERpc3BhdGNoZXIgfSBmcm9tIFwic3ZlbHRlXCI7XG4gICAgaW1wb3J0IHsgZXJyb3JOb3RpZmljYXRpb24sIGdhdGUgfSBmcm9tIFwiLi4vLi4vZnJvbnRIZWxwZXJzXCI7XG4gICAgaW1wb3J0IHsgYXJ0aWNsZUlkLCBsb3RJZCwgY2xpZW50SWQsIGludm9pY2VJZCwgcGF5bWVudElkIH0gZnJvbSBcIi4uLy4uL3N0b3JlXCI7XG5cbiAgICBsZXQgc2VhcmNoID0gXCJcIjtcbiAgICBsZXQgbW91bnRlZDtcbiAgICBsZXQgbG9hZGluZztcbiAgICBsZXQgYWN0aXZlRWxlbWVudDtcbiAgICBsZXQgc2hvd1Jlc3VsdHM7XG4gICAgbGV0IHJlc3VsdHMgPSBbXTtcbiAgICBjb25zdCBkaXNwYXRjaCA9IGNyZWF0ZUV2ZW50RGlzcGF0Y2hlcigpO1xuXG4gICAgJDogZ2V0UmVzdWx0cyhzZWFyY2gpO1xuXG4gICAgb25Nb3VudCgoKSA9PiB7XG4gICAgICAgIGlmKCFuYW1lRmllbGQpIGVycm9yTm90aWZpY2F0aW9uKFwibm8gbmFtZSBmaWVsZFwiKTtcbiAgICAgICAgbW91bnRlZCA9IHRydWU7XG4gICAgfSlcblxuICAgIGNvbnN0IGdldFJlc3VsdHMgPSBhc3luYyAoKSA9PiB7XG4gICAgICAgIGlmKCFlbmRQb2ludCkgcmV0dXJuIGVycm9yTm90aWZpY2F0aW9uKFwiTm8gZW5kcG9pbnQgdG8gc2VhcmNoXCIpO1xuXG4gICAgICAgIGxvYWRpbmcgPSB0cnVlO1xuXG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBjb25zdCBsaXN0ID0gYXdhaXQgZ2F0ZSh7XG4gICAgICAgICAgICAgICAgdXJsOiBlbmRQb2ludCxcbiAgICAgICAgICAgICAgICBtZXRob2Q6IFwiUE9TVFwiLFxuICAgICAgICAgICAgICAgIGRhdGE6IHsgc2VhcmNoLCBmaWVsZDogbmFtZUZpZWxkIH1cbiAgICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgICByZXN1bHRzID0gbGlzdC5maWx0ZXIoKGl0ZW0pID0+IGl0ZW1bbmFtZUZpZWxkXSApO1xuXG4gICAgICAgICAgICBjaGFuZ2VBY3RpdmVFbGVtZW50KCk7XG4gICAgICAgIH1cbiAgICAgICAgY2F0Y2goZXJyKSB7XG4gICAgICAgICAgICBjb25zb2xlLmxvZyhlcnIpO1xuICAgICAgICAgICAgZXJyb3JOb3RpZmljYXRpb24oZXJyKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxvYWRpbmcgPSBmYWxzZTtcbiAgICB9XG5cbiAgICBjb25zdCBjbGVhclNlYXJjaCA9ICgpID0+IHtcbiAgICAgICAgc2VhcmNoID0gXCJcIjtcbiAgICAgICAgc2hvd1Jlc3VsdHMgPSBmYWxzZTtcbiAgICB9XG5cbiAgICBjb25zdCBzZWxlY3RFbCA9IChpZCkgPT4ge1xuICAgICAgICBzZWxlY3RlZCA9IGlkO1xuICAgICAgICBzaG93UmVzdWx0cyA9IGZhbHNlO1xuICAgICAgICBjaGFuZ2VBY3RpdmVFbGVtZW50KCk7XG4gICAgfVxuXG4gICAgY29uc3QgY2hhbmdlQWN0aXZlRWxlbWVudCA9ICgpID0+IHtcbiAgICAgICAgY29uc3QgaW5kID0gcmVzdWx0cy5maW5kSW5kZXgoKGl0ZW0pID0+IGl0ZW0uaWQgPT09IHNlbGVjdGVkIHx8IGl0ZW0uaWQgPT09IHNlbGVjdGVkPy5pZCk7XG4gICAgICAgIGFjdGl2ZUVsZW1lbnQgPSByZXN1bHRzW2luZF07XG4gICAgICAgIHNlbGVjdGVkID0gcmVzdWx0c1tpbmRdO1xuICAgICAgICBkaXNwYXRjaChcInNlbGVjdFwiLCBhY3RpdmVFbGVtZW50KTtcbiAgICB9XG5cbiAgICBjb25zdCBvcGVuVmlldyA9ICgpID0+IHtcbiAgICAgICAgaWYoIXZpZXdGaWVsZCkgcmV0dXJuO1xuICAgICAgICBpZighc2VsZWN0ZWQpIHJldHVybjtcblxuICAgICAgICB0cnkge1xuICAgICAgICAgICAgaWYodmlld0ZpZWxkID09PSBcImFydGljbGVJZFwiKSAkYXJ0aWNsZUlkID0gYWN0aXZlRWxlbWVudD8uaWQ7XG4gICAgICAgICAgICBpZih2aWV3RmllbGQgPT09IFwibG90SWRcIikgJGxvdElkID0gYWN0aXZlRWxlbWVudD8uaWQ7XG4gICAgICAgICAgICBpZih2aWV3RmllbGQgPT09IFwiY2xpZW50SWRcIikgJGNsaWVudElkID0gYWN0aXZlRWxlbWVudD8uaWQ7XG4gICAgICAgICAgICBpZih2aWV3RmllbGQgPT09IFwiaW52b2ljZUlkXCIpICRpbnZvaWNlSWQgPSBhY3RpdmVFbGVtZW50Py5pZDtcbiAgICAgICAgICAgIGlmKHZpZXdGaWVsZCA9PT0gXCJwYXltZW50SWRcIikgJHBheW1lbnRJZCA9IGFjdGl2ZUVsZW1lbnQ/LmlkO1xuICAgICAgICB9XG4gICAgICAgIGNhdGNoKGVycikge1xuICAgICAgICAgICAgY29uc29sZS5sb2coZXJyKTtcbiAgICAgICAgfVxuICAgIH1cbjwvc2NyaXB0PlxuXG48ZGl2IGNsYXNzPVwicG9zaXRpb24tcmVsYXRpdlwiPlxuXG4gICAgPGRpdiBjbGFzcz1cImQtZmxleCBhbGlnbi1pdGVtcy1jZW50ZXJcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImZvcm0tY29udHJvbFwiIG9uOmNsaWNrPXsgKCkgPT4gc2hvd1Jlc3VsdHMgPSB0cnVlIH0+XG4gICAgICAgICAgICB7I2lmIGFjdGl2ZUVsZW1lbnQgJiYgYWN0aXZlRWxlbWVudFtuYW1lRmllbGRdfVxuICAgICAgICAgICAgICAgIHtuYW1lUHJlZml4fXsgYWN0aXZlRWxlbWVudFtuYW1lRmllbGRdIH1cbiAgICAgICAgICAgIHs6ZWxzZX1cbiAgICAgICAgICAgICAgICBDbGljayB0byBzZWxlY3RcbiAgICAgICAgICAgIHsvaWZ9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8YnV0dG9uIGNsYXNzOmQtbm9uZT17IWFjdGl2ZUVsZW1lbnQ/LmlkIHx8ICF2aWV3RmllbGR9IGNsYXNzPVwiYnRuXCIgdHlwZT1cImJ1dHRvblwiIG9uOmNsaWNrPXsgb3BlblZpZXcgfT5cbiAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLWluZm9cIj48L2k+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgIDwvZGl2PlxuXG4gICAgPGRpdiBjbGFzcz1cInNlYXJjaC13cmFwIHJvdW5kZWQtbGdcIiBjbGFzczpkLW5vbmU9eyFzaG93UmVzdWx0c30+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImQtZmxleCBhbGlnbi1pdGVtcy1jZW50ZXIganVzdGlmeS1jb250ZW50LWJldHdlZW5cIiBzdHlsZT1cImdhcDogNXB4OyBwb3NpdGlvbjogc3RpY2t5OyB0b3A6IDA7XCI+XG4gICAgICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICAgICAgICAgdHlwZT1cInRleHRcIlxuICAgICAgICAgICAgICAgICAgICBiaW5kOnZhbHVlPXtzZWFyY2h9XG4gICAgICAgICAgICAgICAgICAgIHBsYWNlaG9sZGVyPVwiU2VhcmNoLi4uXCJcbiAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDxidXR0b24gY2xhc3M9XCJidG5cIiBvbjpjbGlja3xzdG9wUHJvcGFnYXRpb258cHJldmVudERlZmF1bHQ9eyBjbGVhclNlYXJjaCB9PlxuICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLXRpbWVzXCI+PC9pPlxuICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJzZWFyY2gtcmVzdWx0c1wiPlxuICAgICAgICAgICAgeyNpZiBsb2FkaW5nfVxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJwLTMgdGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgICAgICAgICAgU2VhcmNoaW5nLi4uXG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICB7OmVsc2V9XG4gICAgICAgICAgICAgICAgeyNlYWNoIHJlc3VsdHMgYXMgciAoci5pZCl9XG4gICAgICAgICAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjbGFzcz1cInNlYXJjaC1yZXN1bHQgcHgtMyBweS0yXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBvbjpjbGlja3xzdG9wUHJvcGFnYXRpb249eyAoKSA9PiBzZWxlY3RFbChyLmlkKSB9XG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgIHtuYW1lUHJlZml4fXsgcltuYW1lRmllbGRdIH1cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgezplbHNlfVxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwicC0zIHRleHQtY2VudGVyXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICBObyByZXN1bHRzXG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIHsvZWFjaH1cbiAgICAgICAgICAgIHsvaWZ9XG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuPC9kaXY+XG5cbjxzdHlsZT5cbiAgICAuc2VhcmNoLXdyYXAge1xuICAgICAgICBiYWNrZ3JvdW5kOiAjZmZmO1xuICAgICAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgICAgIHRvcDogYXV0bztcbiAgICAgICAgbGVmdDogYXV0bztcbiAgICAgICAgbWF4LWhlaWdodDogNDAwcHg7XG4gICAgICAgIG1pbi13aWR0aDogMzAwcHg7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICAgIHotaW5kZXg6IDM7XG4gICAgICAgIGJvcmRlcjogMnB4IHNvbGlkIHZhcigtLWhhbm5hLXByaW1hcnkpO1xuICAgIH1cblxuICAgIC5zZWFyY2gtcmVzdWx0cyB7XG4gICAgICAgIG92ZXJmbG93LXg6IGhpZGRlbjtcbiAgICAgICAgb3ZlcmZsb3cteTogYXV0bztcbiAgICAgICAgbWF4LWhlaWdodDogMzYwcHg7XG4gICAgICAgIGhlaWdodDogMTAwJTtcbiAgICB9XG5cbiAgICAuc2VhcmNoLXJlc3VsdCB7XG4gICAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgICB9XG5cbiAgICAuc2VhcmNoLXJlc3VsdDpob3ZlciB7XG4gICAgICAgIGJhY2tncm91bmQ6ICNkZWRlZGU7XG4gICAgfVxuPC9zdHlsZT4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0lJLDJCQUFhLENBQ1QsVUFBVSxDQUFFLElBQUksQ0FDaEIsUUFBUSxDQUFFLEtBQUssQ0FDZixHQUFHLENBQUUsSUFBSSxDQUNULElBQUksQ0FBRSxJQUFJLENBQ1YsVUFBVSxDQUFFLEtBQUssQ0FDakIsU0FBUyxDQUFFLEtBQUssQ0FDaEIsUUFBUSxDQUFFLE1BQU0sQ0FDaEIsT0FBTyxDQUFFLENBQUMsQ0FDVixNQUFNLENBQUUsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLGVBQWUsQ0FDekMsQ0FFQSw4QkFBZ0IsQ0FDWixVQUFVLENBQUUsTUFBTSxDQUNsQixVQUFVLENBQUUsSUFBSSxDQUNoQixVQUFVLENBQUUsS0FBSyxDQUNqQixNQUFNLENBQUUsSUFDWixDQUVBLDZCQUFlLENBQ1gsTUFBTSxDQUFFLE9BQU8sQ0FDZixXQUFXLENBQUUsTUFDakIsQ0FFQSw2QkFBYyxNQUFPLENBQ2pCLFVBQVUsQ0FBRSxPQUNoQiJ9 */
.tabs.svelte-1jneoqq{display:flex;align-items:center;gap:30px;margin:0 auto 10px;width:max-content}.tab.svelte-1jneoqq{padding-bottom:5px;display:flex;align-items:center;gap:5px;cursor:pointer;color:var(--dark);font-weight:500;border-bottom:3px solid transparent}.tab-badge.svelte-1jneoqq{width:20px;height:20px;font-size:12px;display:flex;align-items:center;justify-content:center;border-radius:20px;background:var(--hanna-primary);color:#fff}.active.svelte-1jneoqq{color:var(--hanna-primary)!important;border-bottom:3px solid var(--hanna-primary)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGFicy5zdmVsdGUiLCJzb3VyY2VzIjpbIlRhYnMuc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQ+XG4gICAgZXhwb3J0IGxldCB0YWJzID0gW10sIHRhYiA9IDA7XG48L3NjcmlwdD5cblxuPGRpdiBjbGFzcz1cInJvdW5kZWQtbGcgdGFicyByb3VuZGVkLWxnIGJnLXdoaXRlIHB4LTMgcHQtMiBwYi0wIHNoYWRvdy1zbVwiPlxuICAgIHsjZWFjaCB0YWJzIGFzIHQsIGl9XG4gICAgICAgIHsjaWYgdC5zaG93fVxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICBjbGFzcz1cInRhYlwiXG4gICAgICAgICAgICAgICAgICAgIG9uOmNsaWNrPXsgKCkgPT4gdGFiID0gaSB9XG4gICAgICAgICAgICAgICAgICAgIGNsYXNzOmFjdGl2ZT17IHRhYiA9PT0gaSB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgeyB0LmxhYmVsIH1cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICB7I2lmIHQuYmFkZ2UgIT09IHVuZGVmaW5lZH1cbiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInRhYi1iYWRnZVwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgeyB0LmJhZGdlIH1cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgey9pZn1cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICB7L2lmfVxuICAgIHsvZWFjaH1cbjwvZGl2PlxuXG48c3R5bGU+XG4gICAgLnRhYnMge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBnYXA6IDMwcHg7XG4gICAgICAgIG1hcmdpbjogMCBhdXRvIDEwcHg7XG4gICAgICAgIHdpZHRoOiBtYXgtY29udGVudDtcbiAgICB9XG5cbiAgICAudGFiIHtcbiAgICAgICAgcGFkZGluZy1ib3R0b206IDVweDtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgZ2FwOiA1cHg7XG4gICAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgICAgY29sb3I6IHZhcigtLWRhcmspO1xuICAgICAgICBmb250LXdlaWdodDogNTAwO1xuICAgICAgICBib3JkZXItYm90dG9tOiAzcHggc29saWQgdHJhbnNwYXJlbnQ7XG4gICAgfVxuXG4gICAgLnRhYi1iYWRnZSB7XG4gICAgICAgIHdpZHRoOiAyMHB4O1xuICAgICAgICBoZWlnaHQ6IDIwcHg7XG4gICAgICAgIGZvbnQtc2l6ZTogMTJweDtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDIwcHg7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWhhbm5hLXByaW1hcnkpO1xuICAgICAgICBjb2xvcjogI2ZmZjtcbiAgICB9XG5cbiAgICAuYWN0aXZlIHtcbiAgICAgICAgY29sb3I6IHZhcigtLWhhbm5hLXByaW1hcnkpIWltcG9ydGFudDtcbiAgICAgICAgYm9yZGVyLWJvdHRvbTogM3B4IHNvbGlkIHZhcigtLWhhbm5hLXByaW1hcnkpO1xuICAgIH1cbjwvc3R5bGU+XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJJLG9CQUFNLENBQ0YsT0FBTyxDQUFFLElBQUksQ0FDYixXQUFXLENBQUUsTUFBTSxDQUNuQixHQUFHLENBQUUsSUFBSSxDQUNULE1BQU0sQ0FBRSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FDbkIsS0FBSyxDQUFFLFdBQ1gsQ0FFQSxtQkFBSyxDQUNELGNBQWMsQ0FBRSxHQUFHLENBQ25CLE9BQU8sQ0FBRSxJQUFJLENBQ2IsV0FBVyxDQUFFLE1BQU0sQ0FDbkIsR0FBRyxDQUFFLEdBQUcsQ0FDUixNQUFNLENBQUUsT0FBTyxDQUNmLEtBQUssQ0FBRSxJQUFJLE1BQU0sQ0FBQyxDQUNsQixXQUFXLENBQUUsR0FBRyxDQUNoQixhQUFhLENBQUUsR0FBRyxDQUFDLEtBQUssQ0FBQyxXQUM3QixDQUVBLHlCQUFXLENBQ1AsS0FBSyxDQUFFLElBQUksQ0FDWCxNQUFNLENBQUUsSUFBSSxDQUNaLFNBQVMsQ0FBRSxJQUFJLENBQ2YsT0FBTyxDQUFFLElBQUksQ0FDYixXQUFXLENBQUUsTUFBTSxDQUNuQixlQUFlLENBQUUsTUFBTSxDQUN2QixhQUFhLENBQUUsSUFBSSxDQUNuQixVQUFVLENBQUUsSUFBSSxlQUFlLENBQUMsQ0FDaEMsS0FBSyxDQUFFLElBQ1gsQ0FFQSxzQkFBUSxDQUNKLEtBQUssQ0FBRSxJQUFJLGVBQWUsQ0FBQyxVQUFVLENBQ3JDLGFBQWEsQ0FBRSxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksZUFBZSxDQUNoRCJ9 */
.data-grid.svelte-hrp46b{grid-template-columns:max-content max-content 1fr max-content 100px 120px max-content max-content;transition:all 0.5s ease-in-out}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"InvoiceProducts.svelte","sources":["InvoiceProducts.svelte"],"sourcesContent":["<script>\n    export let products = [];\n\n    import Select from \"../nav/Select.svelte\";\n    import { refs } from \"../../store\";\n    import { createEventDispatcher } from \"svelte\";\n\n    $: recalcTotals(products)\n\n    const dispatch = createEventDispatcher();\n\n    const recalcTotals = () => {\n        products.forEach((item) => {\n            item.total = item.qty * item.price;\n            if(isNaN(item.total)) item.total = 0;\n        });\n\n        products = [...products];\n    }\n\n    const addProduct = () => {\n        products.push({ qty: 1, id: Math.random(), price: null, btw: null });\n        products = [...products];\n    };\n\n    const deleteProduct = ind => {\n        products.splice(ind, 1);\n        products = [...products];\n    };\n\n    const fillArticleData = (e,i) => {\n        if(!e?.detail) return;\n\n        if(products[i].price === null) products[i].price = +e?.detail?.price;\n        if(products[i].btw === null) products[i].btw = +e?.detail?.btw;\n\n        products[i].nettoWeight = e?.detail?.nettoWeight;\n        products[i].brutoWeight = e?.detail?.brutoWeight;\n    };\n</script>\n\n<div class=\"data-grid shadow-sm\">\n    <div class=\"data-grid-header\">\n        <div></div>\n        <div class=\"text-center\">\n            #\n        </div>\n        <div>\n            Article\n        </div>\n        <div class=\"text-center\">\n            Article num\n        </div>\n        <div class=\"text-center\">\n            Quantity\n        </div>\n        <div class=\"text-center\">\n            Price\n        </div>\n        <div class=\"text-center\">\n            BTW\n        </div>\n        <div class=\"text-center\">\n            Total\n        </div>\n    </div>\n    <div class=\"data-grid-body\">\n        {#each products as p, i (p.id)}\n            <div class=\"data-grid-body-row\">\n                <div class=\"text-center\">\n                    <i class=\"fas fa-times text-danger\" on:click={ () => deleteProduct(i) }></i>\n                </div>\n                <div class=\"text-center\">\n                    { i + 1 }\n                </div>\n                <div>\n                    <Select\n                        nameField=\"name\"\n                        endPoint=\"/articles/list.json\"\n                        bind:selected={p.article}\n                        on:select={ (e) => fillArticleData(e, i) }\n                    />\n                </div>\n                <div class=\"text-center\">\n                    { p?.article?.number || \"\" }\n                </div>\n                <div>\n                    <input type=\"number\" bind:value={p.qty} class=\"form-control text-center\" />\n                </div>\n                <div class=\"d-flex justify-content-between align-items-center\">\n                    <div class=\"mr-2\">\n                        €\n                    </div>\n                    <input\n                        type=\"text\"\n                        value={ parseFloat(p.price).toFixed(2) }\n                        class=\"form-control text-center\"\n                        on:change={ e => p.price = +e.target.value }\n                    />\n                    <!-- input\n                        type=\"number\"\n                        bind:value={ p.price }\n                        step=\"0.01\"\n                        class=\"form-control\"\n                        on:blur={ () => p.price = parseFloat(p.price).toFixed(2) }\n                    / -->\n                </div>\n                <div>\n                    {#if $refs.btw && $refs.btw.length}\n                        <select class=\"form-control\" bind:value={p.btw}>\n                            {#each $refs.btw as b}\n                                <option value={+b}>\n                                    { b }%\n                                </option>\n                            {/each}\n                        </select>\n                    {/if}\n                </div>\n                <div class=\"d-flex justify-content-between align-items-center\">\n                    <div class=\"mr-2\">\n                        €\n                    </div>\n                    <div>\n                        { p.total.toFixed(2) }\n                    </div>\n                </div>\n            </div>\n        {:else}\n            <div class=\"text-center p-3\" style=\"grid-column: 1/100;\">\n                No products\n            </div>\n        {/each}\n        <div class=\"data-grid-totals-row\">\n            <div style=\"grid-column: 1/4;\">\n                <b>\n                    Totals\n                </b>\n            </div>\n            <div></div>\n            <div class=\"text-center\">\n                <b>\n                    { products.reduce((acc, cur) => acc + +cur.qty, 0) }\n                </b>\n            </div>\n            <div></div>\n            <div></div>\n            <div class=\"d-flex justify-content-between align-items-center\">\n                <div class=\"mr-2\">\n                    <b>€</b>\n                </div>\n                <div>\n                    <b>\n                        { products.reduce((acc, cur) => acc + +cur.total, 0).toFixed(2) }\n                    </b>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n\n<div class=\"d-flex align-items-center justify-content-around mt-3\">\n    <button class=\"btn btn-gold d-flex align-items-center\" style=\"gap: 10px\" type=\"button\" on:click={ addProduct } >\n        <i class=\"far fa-plus-square\"></i>\n        <span>Add product</span>\n    </button>\n    <button class=\"btn btn-outline-dark d-flex align-items-center\" style=\"gap: 10px\" type=\"button\" on:click={ () => dispatch(\"save\") }>\n        <i class=\"fas fa-save\"></i>\n        <span>Save invoice</span>\n    </button>\n</div>\n\n<style>\n    .data-grid {\n        grid-template-columns: max-content max-content 1fr max-content 100px 120px max-content max-content;\n        transition: all 0.5s ease-in-out;\n    }\n</style>"],"names":[],"mappings":"AA4KI,wBAAW,CACP,qBAAqB,CAAE,WAAW,CAAC,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,WAAW,CAClG,UAAU,CAAE,GAAG,CAAC,IAAI,CAAC,WACzB"} */
.data-grid.svelte-1gk6gnb{grid-template-columns:max-content max-content max-content max-content 1fr}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW52b2ljZVBheW1lbnRzLnN2ZWx0ZSIsInNvdXJjZXMiOlsiSW52b2ljZVBheW1lbnRzLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAgIGV4cG9ydCBsZXQgcGF5bWVudHMgPSBbXTtcblxuICAgIGltcG9ydCB7IHN1Y2Nlc3NOb3RpZmljYXRpb24sIGVycm9yTm90aWZpY2F0aW9uLCBnYXRlIH0gZnJvbSBcIi4uLy4uL2Zyb250SGVscGVyc1wiO1xuICAgIGltcG9ydCB7IG9uTW91bnQgfSBmcm9tIFwic3ZlbHRlXCI7XG4gICAgaW1wb3J0IHsgaW52b2ljZUlkLCBsb2FkaW5nLCByZWZzLCBwYXltZW50SWQsIHJlZnJlc2ggfSBmcm9tIFwiLi4vLi4vc3RvcmVcIjtcbiAgICBpbXBvcnQgbW9tZW50IGZyb20gXCJtb21lbnRcIjtcblxuICAgICQ6IGlmKCRyZWZyZXNoKSBnZXRQYXltZW50cygpO1xuXG4gICAgb25Nb3VudCgoKSA9PiB7XG4gICAgICAgIGdldFBheW1lbnRzKCk7XG4gICAgfSk7XG5cbiAgICBjb25zdCBnZXRQYXltZW50cyA9IGFzeW5jICgpID0+IHtcbiAgICAgICAgaWYoISRpbnZvaWNlSWQpIHJldHVybjtcbiAgICAgICAgaWYoJGludm9pY2VJZCA9PT0gXCJuZXdcIikgcmV0dXJuO1xuXG4gICAgICAgICRsb2FkaW5nID0gdHJ1ZTtcblxuICAgICAgICB0cnkge1xuICAgICAgICAgICAgcGF5bWVudHMgPSBhd2FpdCBnYXRlKHtcbiAgICAgICAgICAgICAgICB1cmw6IGAvcGF5bWVudHMvbGlzdC5qc29uYCxcbiAgICAgICAgICAgICAgICBtZXRob2Q6IFwiUE9TVFwiLFxuICAgICAgICAgICAgICAgIGRhdGE6IHsgaW52b2ljZUlkOiAkaW52b2ljZUlkIH1cbiAgICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgICAkcmVmcmVzaCA9IGZhbHNlO1xuICAgICAgICB9XG4gICAgICAgIGNhdGNoKGVycikge1xuICAgICAgICAgICAgY29uc29sZS5sb2coZXJyKTtcbiAgICAgICAgICAgIGVycm9yTm90aWZpY2F0aW9uKFwiQ291bGQgbm90IGdldCBsaXN0IG9mIHBheW1lbnRzIGZvciBpbnZvaWNlXCIpO1xuICAgICAgICB9XG5cbiAgICAgICAgJGxvYWRpbmcgPSBmYWxzZTtcbiAgICB9XG48L3NjcmlwdD5cblxuPGRpdiBjbGFzcz1cImRhdGEtZ3JpZCBzaGFkb3ctc21cIiBzdHlsZT1cIm1pbi13aWR0aDogNjAwcHg7XCI+XG4gICAgPGRpdiBjbGFzcz1cImRhdGEtZ3JpZC1oZWFkZXJcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cInRleHQtY2VudGVyXCI+XG4gICAgICAgICAgICAjXG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgIFR5cGVcbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgQW1vdW50XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgIERhdGVcbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJcIj5cbiAgICAgICAgICAgIENvbW1lbnRcbiAgICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImRhdGEtZ3JpZC1ib2R5XCI+XG4gICAgICAgIHsjZWFjaCBwYXltZW50cyBhcyBwLCBpIChwLmlkKX1cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJkYXRhLWdyaWQtYm9keS1yb3dcIiBvbjpjbGljaz17ICgpID0+ICRwYXltZW50SWQgPSBwLmlkIH0+XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgeyBpICsgMSB9XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgeyAkcmVmcy5wYXltZW50VHlwZXNbcD8udHlwZV0gfVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgICAgIHsgcD8uYW1vdW50LnRvRml4ZWQoMikgfVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgICAgIHsgcD8uZGF0ZSA/IG1vbWVudChwLmRhdGUpLmZvcm1hdChcIkRELk1NLllZWVlcIikgOiBcIlwiIH1cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgICAgICB7IHA/LmNvbW1lbnQgfHwgXCJcIiB9XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgezplbHNlfVxuICAgICAgICAgICAgPGRpdiBzdHlsZT1cImdyaWQtY29sdW1uOiAxLzEwO1wiIGNsYXNzPVwidGV4dC1jZW50ZXIgcC0zXCI+XG4gICAgICAgICAgICAgICAgTm8gcGF5bWVudHNcbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICB7L2VhY2h9XG4gICAgPC9kaXY+XG48L2Rpdj5cblxuPGRpdiBjbGFzcz1cInRleHQtY2VudGVyIG10LTNcIj5cbiAgICA8YnV0dG9uXG4gICAgICAgIGNsYXNzPVwiYnRuIGJ0bi1nb2xkIGJ0bi1zbVwiXG4gICAgICAgIG9uOmNsaWNrPXsgKCkgPT4gJHBheW1lbnRJZCA9IFwibmV3XCIgfVxuICAgID5cbiAgICAgICAgQWRkIHBheW1lbnRcbiAgICA8L2J1dHRvbj5cbjwvZGl2PlxuXG48c3R5bGU+XG4gICAgLmRhdGEtZ3JpZCB7XG4gICAgICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogbWF4LWNvbnRlbnQgbWF4LWNvbnRlbnQgbWF4LWNvbnRlbnQgbWF4LWNvbnRlbnQgMWZyO1xuICAgIH1cbjwvc3R5bGU+Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZGSSx5QkFBVyxDQUNQLHFCQUFxQixDQUFFLFdBQVcsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxHQUMzRSJ9 */
.data-grid.svelte-1taomxp{grid-template-columns:max-content 1fr max-content max-content}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW52b2ljZUNyZWRpdE5vdGVzLnN2ZWx0ZSIsInNvdXJjZXMiOlsiSW52b2ljZUNyZWRpdE5vdGVzLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAgIGV4cG9ydCBsZXQgbm90ZXMgPSBbXTtcblxuICAgIGltcG9ydCB7IHN1Y2Nlc3NOb3RpZmljYXRpb24sIGVycm9yTm90aWZpY2F0aW9uLCBnYXRlIH0gZnJvbSBcIi4uLy4uL2Zyb250SGVscGVyc1wiO1xuICAgIGltcG9ydCB7IG9uTW91bnQgfSBmcm9tIFwic3ZlbHRlXCI7XG4gICAgaW1wb3J0IHsgaW52b2ljZUlkLCBsb2FkaW5nLCByZWZzLCBwYXltZW50SWQsIHJlZnJlc2gsIGNyZWRpdE5vdGVJZCB9IGZyb20gXCIuLi8uLi9zdG9yZVwiO1xuICAgIGltcG9ydCBtb21lbnQgZnJvbSBcIm1vbWVudFwiO1xuICAgIFxuICAgICQ6IGlmKCRyZWZyZXNoKSBnZXRDcmVkaXROb3RlcygpO1xuXG4gICAgb25Nb3VudCgoKSA9PiB7XG4gICAgICAgIGdldENyZWRpdE5vdGVzKCk7XG4gICAgfSk7XG5cbiAgICBjb25zdCBnZXRDcmVkaXROb3RlcyA9IGFzeW5jICgpID0+IHtcbiAgICAgICAgaWYoISRpbnZvaWNlSWQpIHJldHVybjtcbiAgICAgICAgaWYoJGludm9pY2VJZCA9PT0gXCJuZXdcIikgcmV0dXJuO1xuXG4gICAgICAgICRsb2FkaW5nID0gdHJ1ZTtcblxuICAgICAgICB0cnkge1xuICAgICAgICAgICAgbm90ZXMgPSBhd2FpdCBnYXRlKHtcbiAgICAgICAgICAgICAgICB1cmw6IGAvY3JlZGl0bm90ZXMvbGlzdC5qc29uYCxcbiAgICAgICAgICAgICAgICBtZXRob2Q6IFwiUE9TVFwiLFxuICAgICAgICAgICAgICAgIGRhdGE6IHsgaW52b2ljZUlkOiAkaW52b2ljZUlkIH1cbiAgICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgICAkcmVmcmVzaCA9IGZhbHNlO1xuICAgICAgICB9XG4gICAgICAgIGNhdGNoKGVycikge1xuICAgICAgICAgICAgY29uc29sZS5sb2coZXJyKTtcbiAgICAgICAgICAgIGVycm9yTm90aWZpY2F0aW9uKFwiQ291bGQgbm90IGdldCBsaXN0IG9mIGNyZWRpdCBub3RlcyBmb3IgaW52b2ljZVwiKTtcbiAgICAgICAgfVxuXG4gICAgICAgICRsb2FkaW5nID0gZmFsc2U7XG4gICAgfVxuPC9zY3JpcHQ+XG5cbjxkaXYgY2xhc3M9XCJkYXRhLWdyaWQgc2hhZG93LXNtXCIgc3R5bGU9XCJ3aWR0aDogMTAwJTtcIj5cbiAgICA8ZGl2IGNsYXNzPVwiZGF0YS1ncmlkLWhlYWRlclwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgICNcbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgICBOdW1iZXJcbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgQW1vdW50XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgIERhdGVcbiAgICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImRhdGEtZ3JpZC1ib2R5XCI+XG4gICAgICAgIHsjZWFjaCBub3RlcyBhcyBwLCBpIChwLmlkKX1cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJkYXRhLWdyaWQtYm9keS1yb3dcIiBvbjpjbGljaz17ICgpID0+ICRjcmVkaXROb3RlSWQgPSBwLmlkIH0+XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgeyBpICsgMSB9XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgeyBwPy5udW1iZXIgPyBgQy0ke3AubnVtYmVyfWAgOiBcIkRSQUZUXCIgfVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjZWxsLXdpdGgtbGFiZWxcIj5cbiAgICAgICAgICAgICAgICAgICAgPGRpdj7igqw8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgICAgIHsgcD8uYW1vdW50LnRvRml4ZWQoMikgfVxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgICAgICB7IHA/LmRhdGUgPyBtb21lbnQocC5kYXRlKS5mb3JtYXQoXCJERC5NTS5ZWVlZXCIpIDogXCJcIiB9XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgezplbHNlfVxuICAgICAgICAgICAgPGRpdiBzdHlsZT1cImdyaWQtY29sdW1uOiAxLzEwO1wiIGNsYXNzPVwidGV4dC1jZW50ZXIgcC0zXCI+XG4gICAgICAgICAgICAgICAgTm8gY3JlZGl0IG5vdGVzXG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgey9lYWNofVxuICAgICAgICA8ZGl2IGNsYXNzPVwiZGF0YS1ncmlkLXRvdGFscy1yb3dcIj5cbiAgICAgICAgICAgIDxkaXY+PC9kaXY+XG4gICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgIFRvdGFsczpcbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNlbGwtd2l0aC1sYWJlbFwiPlxuICAgICAgICAgICAgICAgIDxkaXY+4oKsPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgeyBub3Rlcy5yZWR1Y2UoIChhY2MsIGN1cikgPT4gYWNjICs9IGN1ci5hbW91bnQsIDApLnRvRml4ZWQoMikgfVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8ZGl2PjwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuXG48ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXIgbXQtM1wiPlxuICAgIDxidXR0b25cbiAgICAgICAgICAgIGNsYXNzPVwiYnRuIGJ0bi1nb2xkIGJ0bi1zbVwiXG4gICAgICAgICAgICBvbjpjbGljaz17ICgpID0+ICRjcmVkaXROb3RlSWQgPSBcIm5ld1wiIH1cbiAgICA+XG4gICAgICAgIEFkZCBjcmVkaXQgbm90ZVxuICAgIDwvYnV0dG9uPlxuPC9kaXY+XG5cbjxzdHlsZT5cbiAgICAuZGF0YS1ncmlkIHtcbiAgICAgICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiBtYXgtY29udGVudCAxZnIgbWF4LWNvbnRlbnQgbWF4LWNvbnRlbnQ7XG4gICAgfVxuPC9zdHlsZT4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUdJLHlCQUFXLENBQ1AscUJBQXFCLENBQUUsV0FBVyxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsV0FDdkQifQ== */
.total-grid.svelte-pgjjx{display:grid;grid-template-columns:max-content 1fr max-content;grid-gap:15px;font-weight:600}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"InvoiceModal.svelte","sources":["InvoiceModal.svelte"],"sourcesContent":["<script>\n    import Modal from \"../Modal.svelte\";\n    import Tabs from \"../nav/Tabs.svelte\";\n    import { invoiceId, loading, refs } from \"../../store\";\n    import { onMount } from \"svelte\";\n    import { errorNotification, successNotification, gate } from \"../../frontHelpers\";\n    import Search from \"../nav/Select.svelte\";\n    import moment from \"moment\";\n    import InvoiceProducts from \"./InvoiceProducts.svelte\";\n    import InvoicePayments from \"./InvoicePayments.svelte\";\n    import InvoiceCreditNotes from \"./InvoiceCreditNotes.svelte\";\n    import TextTemplatesModal from \"../TextTemplatesModal.svelte\";\n\n    let isNew;\n    let invoice = {};\n    let payments = [];\n    let notes = [];\n    let tab = 0;\n    let showTextTemplates;\n\n    $: tabs = [\n        {\n            label: \"Details\",\n            show: true\n        },\n        {\n            label: \"Products\",\n            badge: invoice?.products?.length ? invoice?.products?.length : 0,\n            show: true\n        },\n        {\n            label: \"Lots\",\n            badge: invoice?.lots?.length ? invoice?.lots?.length : 0,\n            show: false\n        },\n        {\n            label: \"Payments\",\n            badge: payments?.length ? payments?.length : 0,\n            show: !isNew\n        },\n        {\n            label: \"Credit Notes\",\n            badge: notes?.length ? notes?.length : 0,\n            show: invoice?._id//(!isNew && invoice?.status > 1)\n        }\n    ];\n\n    $: calcTotals(invoice?.products);\n    $: adjustContainerInfo(invoice?.container);\n\n    onMount( () => {\n        isNew = $invoiceId === \"new\";\n        init();\n    });\n\n    const adjustContainerInfo = () => {\n        if(invoice?.container) return;\n\n        invoice.contractNumber = \"\";\n        invoice.cif = \"\";\n    }\n\n    const calcTotals = () => {\n        try {\n            invoice.amount = invoice?.products?.reduce((acc, cur) => acc + +cur.total, 0);\n            invoice.btw9 = invoice?.products?.filter( p => p.btw === 9 )?.reduce((acc, cur) => acc + +cur.total * cur.btw / 100, 0);\n            invoice.btw21 = invoice?.products?.filter( p => p.btw === 21 )?.reduce((acc, cur) => acc + +cur.total * cur.btw / 100, 0);\n            invoice.bruto = invoice.amount + +invoice.btw9 + +invoice.btw21;\n\n            invoice.nettoWeight = invoice?.products?.reduce((acc, cur) => acc + +cur.nettoWeight, 0);\n            invoice.brutoWeight = invoice?.products?.reduce((acc, cur) => acc + +cur.brutoWeight, 0);\n        }\n        catch(err) {\n            console.log(err);\n        }\n    }\n\n    const init = async () => {\n        await getData();\n    };\n\n    const getData = async () => {\n        if(isNew) return;\n        if(!$invoiceId) return;\n\n        $loading = true;\n\n        try {\n            invoice = await gate({\n                url: `/invoices/${$invoiceId}.json`,\n                method: \"POST\"\n            });\n        }\n        catch(err) {\n            console.log(err);\n        }\n\n        $loading = false;\n    }\n\n    const saveData = async () => {\n        try {\n            await gate({\n                url: `/invoices/${ isNew ? \"list\" : $invoiceId }.json`,\n                method: \"PATCH\",\n                data: invoice\n            });\n\n            successNotification(isNew ? \"successfully created\" : \"successfully updated\");\n            closeModal();\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(err);\n        }\n    }\n\n    const deleteItem = async () => {\n\n        const r = confirm(\"Are you sure you want to delete this invoice?\");\n        if(!r) return;\n\n        $loading = true;\n\n        try {\n            await gate({\n                url: `/invoices/${$invoiceId}.json`,\n                method: \"DELETE\"\n            });\n            successNotification(\"successfully deleted\");\n            closeModal();\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(err);\n        }\n\n        $loading = false;\n    }\n\n    const closeModal = () => {\n        $invoiceId = null;\n    };\n\n    const onChange = e => {\n        invoice[e.target.name] = e.target.value;\n    };\n</script>\n\n<Modal\n    bind:show={$invoiceId}\n    title={ isNew ? \"New invoice\" : `Invoice #${invoice?.number ? invoice?.number : \"DRAFT\"}` }\n>\n    <Tabs {tabs} bind:tab />\n\n    <div class:d-none={tab !== 0}>\n        <form class=\"row\" style=\"max-width: 900px;\" on:submit|preventDefault={ saveData }>\n            <div class=\"col-8\">\n                <div class=\"row rounded-lg bg-white p-3 shadow-sm\">\n\n                    <div class=\"form-group col-12\">\n                        <b>Client</b>\n                        {#if isNew || invoice?.id}\n                            <Search\n                                    nameField=\"name\"\n                                    endPoint=\"/clients/list.json\"\n                                    viewField=\"clientId\"\n                                    bind:selected={invoice.client}\n                            />\n                        {/if}\n                    </div>\n\n                    <div class=\"form-group col-7\">\n                        <b>Status</b>\n                        <select bind:value={invoice.status} class=\"form-control\">\n                            {#each Object.entries($refs.invoiceStatuses) as [key, val]}\n                                <option value={+key}>\n                                    { val }\n                                </option>\n                            {/each}\n                        </select>\n                    </div>\n\n                    <div class=\"form-group col-5\">\n                        <b>Invoice date</b>\n                        <input\n                                type=\"date\"\n                                name=\"date\"\n                                value={ invoice.date ? moment(invoice.date).format(\"YYYY-MM-DD\") : null }\n                                on:change={ onChange }\n                                class=\"form-control\"\n                        />\n                    </div>\n\n                    <div class=\"form-group col-6\">\n                        <b>Order number</b>\n                        <input type=\"text\" bind:value={invoice.orderNumber} class=\"form-control\" />\n                    </div>\n\n                    <div class=\"form-group col-3\">\n                        <b>Group</b>\n                        <select bind:value={invoice.productType} class=\"form-control\">\n                            {#each Object.entries($refs.productCategories) as [key,val]}\n                                <option value={key}>\n                                    { val }\n                                </option>\n                            {/each}\n                        </select>\n                    </div>\n\n                    <div class=\"form-group col-3\">\n                        <b>Container</b>\n                        <select class=\"form-control\" bind:value={invoice.container}>\n                            <option value={false}>\n                                No\n                            </option>\n                            <option value={true}>\n                                Yes\n                            </option>\n                        </select>\n                    </div>\n\n                    {#if invoice?.container}\n                        <div class=\"form-group col-7\">\n                            <b>Contract number</b>\n                            <input type=\"text\" bind:value={invoice.contractNumber} class=\"form-control\" />\n                        </div>\n\n                        <div class=\"form-group col-5\">\n                            <b>CIF</b>\n                            <input type=\"text\" bind:value={invoice.cif} class=\"form-control\" />\n                        </div>\n                    {/if}\n\n                    <div class=\"form-group col-12\">\n                        <div class=\"d-flex align-items-center justify-content-between mb-1\">\n                            <b>Free text</b>\n                            <button\n                                    class=\"btn btn-sm btn-outline-dark rounded-pill py-0 px-3\"\n                                    type=\"button\"\n                                    on:click={ () => showTextTemplates = true }\n                            >\n                                Templates\n                            </button>\n                        </div>\n                        <textarea rows=\"3\" bind:value={invoice.freeText} class=\"form-control\"></textarea>\n                    </div>\n\n                    <!-- div class=\"form-group col-12\">\n                        <b>Comment</b>\n                        <textarea rows=\"3\" bind:value={invoice.comment} class=\"form-control\"></textarea>\n                    </div -->\n\n                    <div class=\"form-group col-12\">\n                        <b>Payment terms</b>\n                        <select class=\"form-control\" bind:value={invoice.paymentTerms} >\n                            {#each Object.entries($refs.paymentsTerms) as [key, val] (key)}\n                                <option value={+key}>\n                                    { val.text }\n                                </option>\n                            {/each}\n                        </select>\n                    </div>\n\n                    <div class=\"form-group col-4\">\n                        <b>Delivery date</b>\n                        <input\n                                type=\"date\"\n                                name=\"deliveryDate\"\n                                value={ invoice.deliveryDate ? moment(invoice.deliveryDate).format(\"YYYY-MM-DD\") : null }\n                                on:change={ onChange }\n                                class=\"form-control\"\n                        />\n                    </div>\n\n                    <div class=\"form-group col-4\">\n                        <b>Payment due date</b>\n                        <input\n                                type=\"date\"\n                                name=\"paymentDueDate\"\n                                value={ invoice.paymentDueDate ? moment(invoice.paymentDueDate).format(\"YYYY-MM-DD\") : null }\n                                on:change={ onChange }\n                                class=\"form-control\"\n                        />\n                    </div>\n\n                    <div class=\"form-group col-4\">\n                        <b>Payment status</b>\n                        <select class=\"form-control\" bind:value={invoice.paid}>\n                            <option value={false}>Not paid</option>\n                            <option value={true}>Paid</option>\n                        </select>\n                    </div>\n                </div>\n            </div>\n            <div class=\"col-4\">\n                <div class=\"rounded-lg bg-white shadow-sm p-3 total-grid mb-3\">\n\n                    <div>\n                        Total netto\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { invoice?.amount?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        BTW 9%\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { invoice?.btw9?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        BTW 21%\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { invoice?.btw21?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        Total bruto\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { invoice?.bruto?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        Netto weight\n                    </div>\n                    <div>\n                        kgs\n                    </div>\n                    <div class=\"text-right\">\n                        { invoice?.nettoWeight?.toFixed(1) }\n                    </div>\n\n                    <div>\n                        Bruto weight\n                    </div>\n                    <div>\n                        kgs\n                    </div>\n                    <div class=\"text-right\">\n                        { invoice?.products?.reduce((acc, cur) => acc + +cur.brutoWeight, 0).toFixed(1) }\n                    </div>\n\n                </div>\n\n                <div class=\"rounded-lg bg-white p-3 shadow-sm\">\n                    <div>\n                        <button\n                            type=\"submit\"\n                            class=\"w-100 btn btn-gold\"\n                        >\n                            Save invoice\n                        </button>\n                    </div>\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        <a\n                            class=\"w-100 btn btn-outline-dark\"\n                            target=\"_blank\"\n                            href={`/invoices/${invoice.id}/invoice.pdf`}\n                        >\n                            Print Invoice\n                        </a>\n                    </div>\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        <a\n                                class=\"w-100 btn btn-outline-dark\"\n                                target=\"_blank\"\n                                href={`/invoices/${invoice.id}/packing-list.pdf`}\n                        >\n                            Print Packing List\n                        </a>\n                    </div>\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        <button\n                            type=\"button\"\n                            class=\"w-100 btn btn-outline-danger\"\n                            on:click={ deleteItem }\n                        >\n                            Delete\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </form>\n    </div>\n\n    <div class:d-none={ tab !== 1 }>\n        <InvoiceProducts bind:products={invoice.products} on:save={saveData} />\n    </div>\n\n    <div class:d-none={ tab !== 3 }>\n        <InvoicePayments bind:payments />\n    </div>\n\n    <div class:d-none={ tab !== 4 }>\n        <InvoiceCreditNotes bind:notes />\n    </div>\n</Modal>\n\n{#if showTextTemplates}\n    <TextTemplatesModal\n            bind:show={showTextTemplates}\n            on:select={ e => invoice.freeText = `${e.detail}\\n\\n${invoice?.freeText || \"\"}` }\n    />\n{/if}\n\n<style>\n    .total-grid {\n        display: grid;\n        grid-template-columns: max-content 1fr max-content;\n        grid-gap: 15px;\n        font-weight: 600;\n    }\n</style>"],"names":[],"mappings":"AAyaI,wBAAY,CACR,OAAO,CAAE,IAAI,CACb,qBAAqB,CAAE,WAAW,CAAC,GAAG,CAAC,WAAW,CAClD,QAAQ,CAAE,IAAI,CACd,WAAW,CAAE,GACjB"} */
.data-grid.svelte-b6ej2l{grid-template-columns:max-content max-content 1fr max-content 120px max-content max-content max-content;transition:all 0.5s ease-in-out;border:2px solid var(--hanna-primary)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ3JlZGl0Tm90ZVByb2R1Y3RzLnN2ZWx0ZSIsInNvdXJjZXMiOlsiQ3JlZGl0Tm90ZVByb2R1Y3RzLnN2ZWx0ZSJdLCJzb3VyY2VzQ29udGVudCI6WyI8c2NyaXB0PlxuICAgIGV4cG9ydCBsZXQgcHJvZHVjdHMgPSBbXTtcblxuICAgICQ6IHJlY2FsY1RvdGFscyhwcm9kdWN0cylcblxuICAgIGNvbnN0IHJlY2FsY1RvdGFscyA9ICgpID0+IHtcbiAgICAgICAgcHJvZHVjdHMuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgICAgICAgICAgaWYoaXRlbS5wcmljZSA+IDApIGl0ZW0ucHJpY2UgPSBpdGVtLnByaWNlICogLTE7XG4gICAgICAgICAgICBpdGVtLnRvdGFsID0gaXRlbS5xdHkgKiBpdGVtLnByaWNlO1xuICAgICAgICAgICAgaWYoaXNOYU4oaXRlbS50b3RhbCkpIGl0ZW0udG90YWwgPSAwO1xuICAgICAgICB9KTtcblxuICAgICAgICBwcm9kdWN0cyA9IFsuLi5wcm9kdWN0c107XG4gICAgfVxuXG4gICAgY29uc3QgYWRkUHJvZHVjdCA9ICgpID0+IHtcbiAgICAgICAgcHJvZHVjdHMucHVzaCh7IHF0eTogMSwgaWQ6IE1hdGgucmFuZG9tKCksIHByaWNlOiBudWxsLCBidHc6IG51bGwgfSk7XG4gICAgICAgIHByb2R1Y3RzID0gWy4uLnByb2R1Y3RzXTtcbiAgICB9O1xuXG4gICAgY29uc3QgZGVsZXRlUHJvZHVjdCA9IGluZCA9PiB7XG4gICAgICAgIHByb2R1Y3RzLnNwbGljZShpbmQsIDEpO1xuICAgICAgICBwcm9kdWN0cyA9IFsuLi5wcm9kdWN0c107XG4gICAgfTtcbjwvc2NyaXB0PlxuXG48ZGl2IGNsYXNzPVwiZGF0YS1ncmlkIHNoYWRvdy1zbVwiPlxuICAgIDxkaXYgY2xhc3M9XCJkYXRhLWdyaWQtaGVhZGVyXCI+XG4gICAgICAgIDxkaXY+PC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgI1xuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIEFydGljbGVcbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgQXJ0aWNsZSBudW1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgUXVhbnRpdHlcbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgUHJpY2VcbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgQlRXXG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgIFRvdGFsXG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJkYXRhLWdyaWQtYm9keVwiPlxuICAgICAgICB7I2VhY2ggcHJvZHVjdHMgYXMgcCwgaSAocC5pZCl9XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZGF0YS1ncmlkLWJvZHktcm93XCI+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInRleHQtY2VudGVyXCI+XG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiZmFzIGZhLXRpbWVzIHRleHQtZGFuZ2VyXCIgb246Y2xpY2s9eyAoKSA9PiBkZWxldGVQcm9kdWN0KGkpIH0+PC9pPlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgICAgICAgICB7IGkgKyAxIH1cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgICAgICB7IHA/LmFydGljbGU/Lm5hbWUgfVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJ0ZXh0LWNlbnRlclwiPlxuICAgICAgICAgICAgICAgICAgICB7IHA/LmFydGljbGU/Lm51bWJlciB8fCBcIlwiIH1cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICAgICAgICAgICAgIHR5cGU9XCJudW1iZXJcIlxuICAgICAgICAgICAgICAgICAgICAgICAgYmluZDp2YWx1ZT17IHAucXR5IH1cbiAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiZm9ybS1jb250cm9sIHRleHQtY2VudGVyXCJcbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1iZXR3ZWVuIGFsaWduLWl0ZW1zLWNlbnRlclwiPlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwibXItMlwiPlxuICAgICAgICAgICAgICAgICAgICAgICAg4oKsXG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgICAgICAgICAgeyBwLnByaWNlLnRvRml4ZWQoMikgfVxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgICAgICAgICAgeyBwLmJ0dyB9JVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJkLWZsZXgganVzdGlmeS1jb250ZW50LWJldHdlZW4gYWxpZ24taXRlbXMtY2VudGVyXCI+XG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJtci0yXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICDigqxcbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgICAgICAgICB7IHA/LnRvdGFsPy50b0ZpeGVkKDIpIH1cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgezplbHNlfVxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInRleHQtY2VudGVyIHAtM1wiIHN0eWxlPVwiZ3JpZC1jb2x1bW46IDEvMTAwO1wiPlxuICAgICAgICAgICAgICAgIE5vIHByb2R1Y3RzXG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgey9lYWNofVxuICAgICAgICA8ZGl2IGNsYXNzPVwiZGF0YS1ncmlkLXRvdGFscy1yb3dcIj5cbiAgICAgICAgICAgIDxkaXYgc3R5bGU9XCJncmlkLWNvbHVtbjogMS80O1wiPlxuICAgICAgICAgICAgICAgIDxiPlxuICAgICAgICAgICAgICAgICAgICBUb3RhbHNcbiAgICAgICAgICAgICAgICA8L2I+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXY+PC9kaXY+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgICAgICA8Yj5cbiAgICAgICAgICAgICAgICAgICAgeyBwcm9kdWN0cy5yZWR1Y2UoKGFjYywgY3VyKSA9PiBhY2MgKyArY3VyLnF0eSwgMCkgfVxuICAgICAgICAgICAgICAgIDwvYj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPGRpdj48L2Rpdj5cbiAgICAgICAgICAgIDxkaXY+PC9kaXY+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1iZXR3ZWVuIGFsaWduLWl0ZW1zLWNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJtci0yXCI+XG4gICAgICAgICAgICAgICAgICAgIDxiPuKCrDwvYj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAgICAgICAgICA8Yj5cbiAgICAgICAgICAgICAgICAgICAgICAgIHsgcHJvZHVjdHMucmVkdWNlKChhY2MsIGN1cikgPT4gYWNjICsgK2N1ci50b3RhbCwgMCkudG9GaXhlZCgyKSB9XG4gICAgICAgICAgICAgICAgICAgIDwvYj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuXG48IS0tIGRpdiBjbGFzcz1cInRleHQtY2VudGVyIG10LTNcIj5cbiAgICA8YnV0dG9uIGNsYXNzPVwiYnRuIGJ0bi1nb2xkXCIgdHlwZT1cImJ1dHRvblwiIG9uOmNsaWNrPXsgYWRkUHJvZHVjdCB9PlxuICAgICAgICBBZGQgcHJvZHVjdFxuICAgIDwvYnV0dG9uPlxuPC9kaXYgLS0+XG5cbjxzdHlsZT5cbiAgICAuZGF0YS1ncmlkIHtcbiAgICAgICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiBtYXgtY29udGVudCBtYXgtY29udGVudCAxZnIgbWF4LWNvbnRlbnQgMTIwcHggbWF4LWNvbnRlbnQgbWF4LWNvbnRlbnQgbWF4LWNvbnRlbnQ7XG4gICAgICAgIHRyYW5zaXRpb246IGFsbCAwLjVzIGVhc2UtaW4tb3V0O1xuICAgICAgICBib3JkZXI6IDJweCBzb2xpZCB2YXIoLS1oYW5uYS1wcmltYXJ5KTtcbiAgICB9XG48L3N0eWxlPiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSUksd0JBQVcsQ0FDUCxxQkFBcUIsQ0FBRSxXQUFXLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUN4RyxVQUFVLENBQUUsR0FBRyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQ2hDLE1BQU0sQ0FBRSxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksZUFBZSxDQUN6QyJ9 */
.total-grid.svelte-pgjjx{display:grid;grid-template-columns:max-content 1fr max-content;grid-gap:15px;font-weight:600}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"CreditNoteModal.svelte","sources":["CreditNoteModal.svelte"],"sourcesContent":["<script>\n    import Modal from \"../Modal.svelte\";\n    import Tabs from \"../nav/Tabs.svelte\";\n    import { creditNoteId, loading, refs, invoiceId, refresh } from \"../../store\";\n    import { onMount } from \"svelte\";\n    import { errorNotification, successNotification, gate } from \"../../frontHelpers\";\n    import moment from \"moment\";\n    import CreditNoteProducts from \"./CreditNoteProducts.svelte\";\n\n    let isNew;\n    let creditNote = { products: [] };\n    let tab = 0;\n\n    $: tabs = [\n        {\n            label: \"Details\",\n            show: true\n        },\n        {\n            label: \"Products\",\n            badge: creditNote?.products?.length ? creditNote?.products?.length : 0,\n            show: true\n        }\n    ];\n    $: calcTotals(creditNote?.products);\n\n    onMount( () => {\n        isNew = $creditNoteId === \"new\";\n\n        if(isNew && $invoiceId && $invoiceId !== \"new\"){\n            creditNote.invoice = { id: $invoiceId };\n            creditNote.status = 1;\n        }\n\n        init();\n    });\n\n    const calcTotals = () => {\n        try {\n            creditNote.amount = creditNote?.products?.reduce((acc, cur) => acc + +cur.total, 0);\n            creditNote.btw9 = creditNote?.products?.filter( p => p.btw === 9 )?.reduce((acc, cur) => acc + +cur.total * cur.btw / 100, 0);\n            creditNote.btw21 = creditNote?.products?.filter( p => p.btw === 21 )?.reduce((acc, cur) => acc + +cur.total * cur.btw / 100, 0);\n            creditNote.bruto = creditNote.amount + +creditNote.btw9 + +creditNote.btw21;\n\n            creditNote.nettoWeight = creditNote?.products?.reduce((acc, cur) => acc + +cur.nettoWeight, 0);\n            creditNote.brutoWeight = creditNote?.products?.reduce((acc, cur) => acc + +cur.brutoWeight, 0);\n        }\n        catch(err) {\n            console.log(err);\n        }\n    }\n\n    const init = async () => {\n        await getData();\n        await getInvoiceData();\n    };\n\n    const getInvoiceData = async () => {\n        $loading = true;\n        if(!$invoiceId) return;\n\n        try {\n            const invoice = await gate({\n                url: `/invoices/${$invoiceId}.json`,\n                method: \"POST\",\n            });\n\n            const {id, _id, number, ...rest } = invoice;\n\n            if(isNew) {\n                creditNote = {...rest};\n                creditNote.status = 1;\n                creditNote.number = null;\n                creditNote.freeText = \"\";\n            }\n\n            creditNote.invoice = {\n                id: invoice.id,\n                number: invoice.number,\n                _id: invoice._id\n            };\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(\"Get invoice data error\");\n        }\n\n        $loading = false;\n    }\n\n    const getData = async () => {\n        if(isNew) return;\n        if(!$creditNoteId) return;\n\n        $loading = true;\n\n        try {\n            creditNote = await gate({\n                url: `/creditnotes/${$creditNoteId}.json`,\n                method: \"POST\"\n            });\n        }\n        catch(err) {\n            console.log(err);\n        }\n\n        $loading = false;\n    }\n\n    const saveData = async () => {\n        try {\n            await gate({\n                url: `/creditnotes/${ isNew ? \"list\" : $creditNoteId }.json`,\n                method: \"PATCH\",\n                data: creditNote\n            });\n\n            successNotification(isNew ? \"Credit note successfully created\" : \"Credit note successfully updated\");\n            closeModal();\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(err);\n        }\n    }\n\n\n    const deleteItem = async () => {\n\n        const r = confirm(\"Are you sure you want to delete this credit note?\");\n        if(!r) return;\n\n        $loading = true;\n\n        try {\n            await gate({\n                url: `/creditnotes/${$creditNoteId}.json`,\n                method: \"DELETE\"\n            });\n            successNotification(\"Credit note successfully deleted\");\n            closeModal();\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(err);\n        }\n\n        $loading = false;\n    }\n\n    const closeModal = () => {\n        $refresh = true;\n        $creditNoteId = null;\n    };\n\n    const onChange = e => {\n        creditNote[e.target.name] = e.target.value;\n    };\n</script>\n\n<Modal\n        bind:show={$creditNoteId}\n        title={ isNew ? \"New Credit Note\" : `Credit Note C-${creditNote?.number}` }\n>\n    <Tabs {tabs} bind:tab />\n\n    <div class:d-none={tab !== 0}>\n        <form class=\"row\" style=\"max-width: 900px;\" on:submit|preventDefault={ saveData }>\n            <div class=\"col-8\">\n                <div class=\"row rounded-lg bg-white p-3 shadow-sm\">\n\n                    <div class=\"form-group col-6\">\n                        <b>Invoice</b>\n                        <div class=\"d-flex align-items-center\">\n                            <input class=\"form-control\" value={ `F-${creditNote?.invoice?.number || \"DRAFT\"}` } disabled />\n                            <button\n                                type=\"button\"\n                                class=\"btn py-0\"\n                                class:d-none={isNew}\n                                on:click={ () => $invoiceId = creditNote?.invoice?.id }\n                            >\n                                <i class=\"fas fa-info fa-15x\"></i>\n                            </button>\n                        </div>\n                    </div>\n\n                    <div class=\"form-group col-6\">\n                        <b>Date</b>\n                        <input\n                                type=\"date\"\n                                name=\"date\"\n                                value={ creditNote.date ? moment(creditNote.date).format(\"YYYY-MM-DD\") : null }\n                                on:change={ onChange }\n                                class=\"form-control\"\n                        />\n                    </div>\n\n                    <div class=\"form-group col-12\">\n                        <b>Free text</b>\n                        <textarea rows=\"3\" bind:value={creditNote.freeText} class=\"form-control\"></textarea>\n                    </div>\n\n                </div>\n            </div>\n            <div class=\"col-4\">\n                <div class=\"rounded-lg bg-white p-3 total-grid mb-3 shadow-sm\">\n\n                    <div>\n                        Total netto\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { creditNote?.amount?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        BTW 9%\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { creditNote?.btw9?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        BTW 21%\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { creditNote?.btw21?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        Total bruto\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { creditNote?.bruto?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        Netto weight\n                    </div>\n                    <div>\n                        kgs\n                    </div>\n                    <div class=\"text-right\">\n                        { creditNote?.nettoWeight?.toFixed(1) }\n                    </div>\n\n                    <div>\n                        Bruto weight\n                    </div>\n                    <div>\n                        kgs\n                    </div>\n                    <div class=\"text-right\">\n                        { creditNote?.products?.reduce((acc, cur) => acc + +cur.brutoWeight, 0).toFixed(1) }\n                    </div>\n\n                </div>\n\n                <div class=\"rounded-lg bg-white p-3 shadow-sm\">\n                    <div>\n                        <button\n                                type=\"submit\"\n                                class=\"w-100 btn btn-gold\"\n                        >\n                            Save\n                        </button>\n                    </div>\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        <a\n                                class=\"w-100 btn btn-outline-dark\"\n                                target=\"_blank\"\n                                href={`/creditnotes/${creditNote.id}/creditnote.pdf`}\n                        >\n                            Print Credit Note\n                        </a>\n                    </div>\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        <button\n                                type=\"button\"\n                                class=\"w-100 btn btn-outline-danger\"\n                                on:click={ deleteItem }\n                        >\n                            Delete\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </form>\n    </div>\n\n    <div class:d-none={ tab !== 1 }>\n        <CreditNoteProducts bind:products={creditNote.products} />\n    </div>\n</Modal>\n\n<style>\n    .total-grid {\n        display: grid;\n        grid-template-columns: max-content 1fr max-content;\n        grid-gap: 15px;\n        font-weight: 600;\n    }\n</style>"],"names":[],"mappings":"AAqTI,wBAAY,CACR,OAAO,CAAE,IAAI,CACb,qBAAqB,CAAE,WAAW,CAAC,GAAG,CAAC,WAAW,CAClD,QAAQ,CAAE,IAAI,CACd,WAAW,CAAE,GACjB"} */
.data-grid.svelte-1tc8jb0{grid-template-columns:max-content max-content 1fr max-content 100px 120px max-content max-content;transition:all 0.5s ease-in-out;border:2px solid var(--hanna-primary)}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ProformaProducts.svelte","sources":["ProformaProducts.svelte"],"sourcesContent":["<script>\n    export let products = [];\n\n    import Select from \"../nav/Select.svelte\";\n    import { refs } from \"../../store\";\n    import { createEventDispatcher } from \"svelte\";\n\n    const dispatch = createEventDispatcher();\n\n    $: recalcTotals(products)\n\n    const recalcTotals = () => {\n        products.forEach((item) => {\n            item.total = item.qty * item.price;\n            if(isNaN(item.total)) item.total = 0;\n        });\n\n        products = [...products];\n    }\n\n    const addProduct = () => {\n        products.push({ qty: 1, id: Math.random(), price: null, btw: null });\n        products = [...products];\n    };\n\n    const deleteProduct = ind => {\n        products.splice(ind, 1);\n        products = [...products];\n    };\n\n    const fillArticleData = (e,i) => {\n        if(!e?.detail) return;\n\n        if(products[i].price === null) products[i].price = +e?.detail?.price;\n        if(products[i].btw === null) products[i].btw = +e?.detail?.btw;\n\n        products[i].nettoWeight = e?.detail?.nettoWeight;\n        products[i].brutoWeight = e?.detail?.brutoWeight;\n    };\n</script>\n\n<div class=\"data-grid\">\n    <div class=\"data-grid-header\">\n        <div></div>\n        <div class=\"text-center\">\n            #\n        </div>\n        <div>\n            Article\n        </div>\n        <div class=\"text-center\">\n            Article num\n        </div>\n        <div class=\"text-center\">\n            Quantity\n        </div>\n        <div class=\"text-center\">\n            Price\n        </div>\n        <div class=\"text-center\">\n            BTW\n        </div>\n        <div class=\"text-center\">\n            Total\n        </div>\n    </div>\n    <div class=\"data-grid-body\">\n        {#each products as p, i (p.id)}\n            <div class=\"data-grid-body-row\">\n                <div class=\"text-center\">\n                    <i class=\"fas fa-times text-danger\" on:click={ () => deleteProduct(i) }></i>\n                </div>\n                <div class=\"text-center\">\n                    { i + 1 }\n                </div>\n                <div>\n                    <Select\n                        nameField=\"name\"\n                        endPoint=\"/articles/list.json\"\n                        bind:selected={p.article}\n                        on:select={ (e) => fillArticleData(e, i) }\n                    />\n                </div>\n                <div class=\"text-center\">\n                    { p?.article?.number || \"\" }\n                </div>\n                <div>\n                    <input type=\"number\" bind:value={p.qty} class=\"form-control text-center\" />\n                </div>\n                <div class=\"d-flex justify-content-between align-items-center\">\n                    <div class=\"mr-2\">\n                        €\n                    </div>\n                    <input\n                        type=\"text\"\n                        value={ parseFloat(p.price).toFixed(2) }\n                        class=\"form-control text-center\"\n                        on:change={ e => p.price = +e.target.value }\n                    />\n                    <!-- input type=\"number\" bind:value={p.price} step=\"0.01\" class=\"form-control\" / -->\n                </div>\n                <div>\n                    {#if $refs.btw && $refs.btw.length}\n                        <select class=\"form-control\" bind:value={p.btw}>\n                            {#each $refs.btw as b}\n                                <option value={+b}>\n                                    { b }%\n                                </option>\n                            {/each}\n                        </select>\n                    {/if}\n                </div>\n                <div class=\"d-flex justify-content-between align-items-center\">\n                    <div class=\"mr-2\">\n                        €\n                    </div>\n                    <div>\n                        { p.total.toFixed(2) }\n                    </div>\n                </div>\n            </div>\n        {:else}\n            <div class=\"text-center p-3\" style=\"grid-column: 1/100;\">\n                No products\n            </div>\n        {/each}\n        <div class=\"data-grid-totals-row\">\n            <div style=\"grid-column: 1/4;\">\n                <b>\n                    Totals\n                </b>\n            </div>\n            <div></div>\n            <div class=\"text-center\">\n                <b>\n                    { products.reduce((acc, cur) => acc + +cur.qty, 0) }\n                </b>\n            </div>\n            <div></div>\n            <div></div>\n            <div class=\"d-flex justify-content-between align-items-center\">\n                <div class=\"mr-2\">\n                    <b>€</b>\n                </div>\n                <div>\n                    <b>\n                        { products.reduce((acc, cur) => acc + +cur.total, 0).toFixed(2) }\n                    </b>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n\n<!-- div class=\"text-center mt-3\">\n    <button class=\"btn btn-gold\" type=\"button\" on:click={ addProduct }>\n        Add product\n    </button>\n</div-->\n\n<div class=\"d-flex align-items-center justify-content-around mt-3\">\n    <button class=\"btn btn-gold d-flex align-items-center\" style=\"gap: 10px\" type=\"button\" on:click={ addProduct } >\n        <i class=\"far fa-plus-square\"></i>\n        <span>Add product</span>\n    </button>\n    <button class=\"btn btn-outline-dark d-flex align-items-center\" style=\"gap: 10px\" type=\"button\" on:click={ () => dispatch(\"save\") }>\n        <i class=\"fas fa-save\"></i>\n        <span>Save proforma</span>\n    </button>\n</div>\n\n<style>\n    .data-grid {\n        grid-template-columns: max-content max-content 1fr max-content 100px 120px max-content max-content;\n        transition: all 0.5s ease-in-out;\n        border: 2px solid var(--hanna-primary);\n    }\n</style>"],"names":[],"mappings":"AA4KI,yBAAW,CACP,qBAAqB,CAAE,WAAW,CAAC,WAAW,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,WAAW,CAClG,UAAU,CAAE,GAAG,CAAC,IAAI,CAAC,WAAW,CAChC,MAAM,CAAE,GAAG,CAAC,KAAK,CAAC,IAAI,eAAe,CACzC"} */
.total-grid.svelte-pgjjx{display:grid;grid-template-columns:max-content 1fr max-content;grid-gap:15px;font-weight:600}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ProformaModal.svelte","sources":["ProformaModal.svelte"],"sourcesContent":["<script>\n    import Modal from \"../Modal.svelte\";\n    import Tabs from \"../nav/Tabs.svelte\";\n    import { loading, refs, proformaId, invoiceId } from \"../../store\";\n    import { onMount } from \"svelte\";\n    import { errorNotification, successNotification, gate } from \"../../frontHelpers\";\n    import Search from \"../nav/Select.svelte\";\n    import moment from \"moment\";\n    import ProformaProducts from \"./ProformaProducts.svelte\";\n    import TextTemplatesModal from \"../../components/TextTemplatesModal.svelte\";\n\n    let isNew;\n    let proforma = {};\n    let payments = [];\n    let tab = 0;\n    let showTextTemplates;\n\n    $: tabs = [\n        {\n            label: \"Details\",\n            show: true\n        },\n        {\n            label: \"Products\",\n            badge: proforma?.products?.length ? proforma?.products?.length : 0,\n            show: true\n        }\n    ];\n    \n    $: calcTotals(proforma?.products);\n    $: adjustContainerInfo(proforma?.container);\n\n    onMount( () => {\n        isNew = $proformaId === \"new\";\n        init();\n    });\n\n    const adjustContainerInfo = () => {\n        if(proforma?.container) return;\n\n        proforma.contractNumber = \"\";\n        proforma.cif = \"\";\n    }\n\n    const calcTotals = () => {\n        try {\n            proforma.amount = proforma?.products?.reduce((acc, cur) => acc + +cur.total, 0);\n            proforma.btw9 = proforma?.products?.filter( p => p.btw === 9 )?.reduce((acc, cur) => acc + +cur.total * cur.btw / 100, 0);\n            proforma.btw21 = proforma?.products?.filter( p => p.btw === 21 )?.reduce((acc, cur) => acc + +cur.total * cur.btw / 100, 0);\n            proforma.bruto = proforma.amount + +proforma.btw9 + +proforma.btw21;\n\n            proforma.nettoWeight = proforma?.products?.reduce((acc, cur) => acc + +cur.nettoWeight, 0);\n            proforma.brutoWeight = proforma?.products?.reduce((acc, cur) => acc + +cur.brutoWeight, 0);\n        }\n        catch(err) {\n            console.log(err);\n        }\n    }\n\n    const init = async () => {\n        await getData();\n    };\n\n    const getData = async () => {\n        if(isNew) return;\n        if(!$proformaId) return;\n\n        $loading = true;\n\n        try {\n            proforma = await gate({\n                url: `/proformas/${$proformaId}.json`,\n                method: \"POST\"\n            });\n        }\n        catch(err) {\n            console.log(err);\n        }\n\n        $loading = false;\n    }\n\n    const saveData = async () => {\n        try {\n            await gate({\n                url: `/proformas/${ isNew ? \"list\" : $proformaId }.json`,\n                method: \"PATCH\",\n                data: proforma\n            });\n\n            successNotification(isNew ? \"Proforma successfully created\" : \"Proforma successfully updated\");\n            closeModal();\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(err);\n        }\n    }\n\n    const deleteItem = async () => {\n\n        const r = confirm(\"Are you sure you want to delete this proforma?\");\n        if(!r) return;\n\n        $loading = true;\n\n        try {\n            await gate({\n                url: `/proformas/${$proformaId}.json`,\n                method: \"DELETE\"\n            });\n            successNotification(\"Proforma successfully deleted\");\n            closeModal();\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(err);\n        }\n\n        $loading = false;\n    }\n\n    const createInvoice = async () => {\n        const r = confirm(\"Do you want to create invoice from this proforma?\");\n        if(!r) return;\n\n        $loading = true;\n\n        try {\n            await gate({\n                url: `/proformas/${$proformaId}/invoice.json`,\n                method: \"POST\"\n            });\n\n            successNotification(\"Invoice successfully created\");\n            await getData();\n        }\n        catch(err) {\n            console.log(err);\n            errorNotification(err);\n        }\n\n        $loading = false;\n    }\n\n    const closeModal = () => {\n        $proformaId = null;\n    };\n\n    const onChange = e => {\n        proforma[e.target.name] = e.target.value;\n    };\n</script>\n\n<Modal\n        bind:show={$proformaId}\n        title={ isNew ? \"New proforma\" : `Proforma P-${proforma?.number}` }\n>\n    <Tabs {tabs} bind:tab />\n\n    <div class:d-none={tab !== 0}>\n        <form class=\"row\" style=\"max-width: 900px;\" on:submit|preventDefault={ saveData }>\n            <div class=\"col-8\">\n                <div class=\"row rounded-lg bg-white p-3\">\n                    <div class=\"form-group col-12\">\n                        <b>Client</b>\n                        {#if isNew || proforma?.id}\n                            <Search\n                                    nameField=\"name\"\n                                    endPoint=\"/clients/list.json\"\n                                    viewField=\"clientId\"\n                                    bind:selected={proforma.client}\n                            />\n                        {/if}\n                    </div>\n\n                    <div class=\"form-group col-6\">\n                        <b>Date</b>\n                        <input\n                                type=\"date\"\n                                name=\"date\"\n                                value={ proforma.date ? moment(proforma.date).format(\"YYYY-MM-DD\") : null }\n                                on:change={ onChange }\n                                class=\"form-control\"\n                        />\n                    </div>\n\n                    <div class=\"form-group col-6\">\n                        <b>Order number</b>\n                        <input type=\"text\" bind:value={proforma.orderNumber} class=\"form-control\" />\n                    </div>\n\n                    <div class=\"form-group col-3\">\n                        <b>Container</b>\n                        <select class=\"form-control\" bind:value={proforma.container}>\n                            <option value={false}>\n                                No\n                            </option>\n                            <option value={true}>\n                                Yes\n                            </option>\n                        </select>\n                    </div>\n\n                    <div class=\"col-9\"></div>\n\n                    {#if proforma.container}\n                        <div class=\"form-group col-6\">\n                            <b>Contract number</b>\n                            <input type=\"text\" bind:value={proforma.contractNumber} class=\"form-control\" />\n                        </div>\n\n                        <div class=\"form-group col-6\">\n                            <b>CIF</b>\n                            <input type=\"text\" bind:value={proforma.cif} class=\"form-control\" />\n                        </div>\n                    {/if}\n\n                    <div class=\"form-group col-12\">\n                        <div class=\"d-flex align-items-center justify-content-between mb-1\">\n                            <b>Free text</b>\n                            <button\n                                class=\"btn btn-sm btn-outline-dark rounded-pill py-0 px-3\"\n                                type=\"button\"\n                                on:click={ () => showTextTemplates = true }\n                            >\n                                Templates\n                            </button>\n                        </div>\n\n                        <textarea rows=\"3\" bind:value={proforma.freeText} class=\"form-control\"></textarea>\n                    </div>\n\n                    <!-- div class=\"form-group col-12\">\n                        <b>Comment</b>\n                        <textarea rows=\"3\" bind:value={proforma.comment} class=\"form-control\"></textarea>\n                    </div -->\n\n                    <div class=\"form-group col-12\">\n                        <b>Payment terms</b>\n                        <select class=\"form-control\" bind:value={proforma.paymentTerms} >\n                            {#each Object.entries($refs.paymentsTerms) as [key, val] (key)}\n                                <option value={+key}>\n                                    { val.text }\n                                </option>\n                            {/each}\n                        </select>\n                    </div>\n\n                    <div class=\"form-group col-4\">\n                        <b>Delivery date</b>\n                        <input\n                                type=\"date\"\n                                name=\"deliveryDate\"\n                                value={ proforma.deliveryDate ? moment(proforma.deliveryDate).format(\"YYYY-MM-DD\") : null }\n                                on:change={ onChange }\n                                class=\"form-control\"\n                        />\n                    </div>\n\n                    <div class=\"form-group col-4\">\n                        <b>Payment due date</b>\n                        <input\n                                type=\"date\"\n                                name=\"paymentDueDate\"\n                                value={ proforma.paymentDueDate ? moment(proforma.paymentDueDate).format(\"YYYY-MM-DD\") : null }\n                                on:change={ onChange }\n                                class=\"form-control\"\n                        />\n                    </div>\n\n                    <div class=\"form-group col-4\">\n                        <b>Payment status</b>\n                        <select class=\"form-control\" bind:value={proforma.paid}>\n                            <option value={false}>Not paid</option>\n                            <option value={true}>Paid</option>\n                        </select>\n                    </div>\n                </div>\n            </div>\n            <div class=\"col-4\">\n                <div class=\"rounded-lg bg-white p-3 total-grid mb-3\">\n\n                    <div>\n                        Total netto\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { proforma?.amount?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        BTW 9%\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { proforma?.btw9?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        BTW 21%\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { proforma?.btw21?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        Total bruto\n                    </div>\n                    <div>\n                        €\n                    </div>\n                    <div class=\"text-right\">\n                        { proforma?.bruto?.toFixed(2) }\n                    </div>\n\n                    <div>\n                        Netto weight\n                    </div>\n                    <div>\n                        kgs\n                    </div>\n                    <div class=\"text-right\">\n                        { proforma?.nettoWeight?.toFixed(1) }\n                    </div>\n\n                    <div>\n                        Bruto weight\n                    </div>\n                    <div>\n                        kgs\n                    </div>\n                    <div class=\"text-right\">\n                        { proforma?.products?.reduce((acc, cur) => acc + +cur.brutoWeight, 0).toFixed(1) }\n                    </div>\n\n                </div>\n\n                <div class=\"rounded-lg bg-white p-3\">\n                    <div>\n                        <button\n                            type=\"submit\"\n                            class=\"w-100 btn btn-gold\"\n                        >\n                            Save\n                        </button>\n                    </div>\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        {#if proforma?.invoice}\n                            <button\n                                    type=\"button\"\n                                    class=\"w-100 btn btn-primary\"\n                                    on:click={ () => $invoiceId = proforma.invoice?.id }\n                            >\n                                Invoice F-{ proforma?.invoice?.number || \"DRAFT\" }\n                            </button>\n                        {:else}\n                            <button\n                                    type=\"button\"\n                                    class=\"w-100 btn btn-primary\"\n                                    on:click={ createInvoice }\n                            >\n                                Create Invoice\n                            </button>\n                        {/if}\n                    </div>\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        <a\n                                class=\"w-100 btn btn-outline-dark\"\n                                target=\"_blank\"\n                                href={`/proformas/${proforma.id}/proforma.pdf`}\n                        >\n                            Print Proforma\n                        </a>\n                    </div>\n\n                    <!-- div class=\"mt-3\" class:d-none={isNew}>\n                        <button\n                                type=\"button\"\n                                class=\"w-100 btn btn-outline-dark\"\n                        >\n                            Print Packing list\n                        </button>\n                    </div -->\n\n                    <div class=\"mt-3\" class:d-none={isNew}>\n                        <button\n                            type=\"button\"\n                            class=\"w-100 btn btn-outline-danger\"\n                            on:click={ deleteItem }\n                        >\n                            Delete\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </form>\n    </div>\n\n    <div class:d-none={ tab !== 1 }>\n        <ProformaProducts bind:products={proforma.products} on:save={saveData} />\n    </div>\n</Modal>\n\n{#if showTextTemplates}\n    <TextTemplatesModal\n        bind:show={showTextTemplates}\n        on:select={ e => proforma.freeText = `${e.detail}\\n\\n${proforma?.freeText || \"\"}` }\n    />\n{/if}\n\n<style>\n    .total-grid {\n        display: grid;\n        grid-template-columns: max-content 1fr max-content;\n        grid-gap: 15px;\n        font-weight: 600;\n    }\n</style>"],"names":[],"mappings":"AAqaI,wBAAY,CACR,OAAO,CAAE,IAAI,CACb,qBAAqB,CAAE,WAAW,CAAC,GAAG,CAAC,WAAW,CAClD,QAAQ,CAAE,IAAI,CACd,WAAW,CAAE,GACjB"} */
.layout-wrapper.svelte-nd3udc{display:grid;grid-template-columns:max-content 1fr;grid-template-rows:1fr;grid-gap:20px;height:100%;width:100%;max-width:1200px;margin:auto;padding:10px}.content.svelte-nd3udc{overflow:auto;height:100%;padding-bottom:100px}
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiX2xheW91dC5zdmVsdGUiLCJzb3VyY2VzIjpbIl9sYXlvdXQuc3ZlbHRlIl0sInNvdXJjZXNDb250ZW50IjpbIjxzY3JpcHQgY29udGV4dD1cIm1vZHVsZVwiPlxuICAgIGV4cG9ydCBhc3luYyBmdW5jdGlvbiBwcmVsb2FkKHBhZ2UsIHNlc3Npb24pIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IHJlcyA9IGF3YWl0IHRoaXMuZmV0Y2goJy9zZXR0aW5ncy9yZWZzLmpzb24nLCB7IG1ldGhvZDogJ1BPU1QnIH0pO1xuICAgICAgICAgICAgY29uc3Qgc2V0dGluZ3MgPSBhd2FpdCByZXMuanNvbigpO1xuICAgICAgICAgICAgcmV0dXJuIHsgc2V0dGluZ3MgfTtcbiAgICAgICAgfVxuICAgICAgICBjYXRjaCAoZSkge1xuICAgICAgICAgICAgY29uc29sZS5sb2coZSk7XG4gICAgICAgIH1cbiAgICB9XG48L3NjcmlwdD5cblxuPHNjcmlwdD5cbiAgICBleHBvcnQgbGV0IHNlZ21lbnQsIHNldHRpbmdzID0ge307XG5cbiAgICBpbXBvcnQgVG9wTmF2IGZyb20gXCIuLi9jb21wb25lbnRzL25hdi9Ub3BOYXYuc3ZlbHRlXCI7XG4gICAgaW1wb3J0IFRvYXN0ZXIgZnJvbSBcIi4uL2NvbXBvbmVudHMvdG9hc3RzL1RvYXN0ZXIuc3ZlbHRlXCI7XG4gICAgaW1wb3J0IExvYWRlciBmcm9tIFwiLi4vY29tcG9uZW50cy9Mb2FkZXIuc3ZlbHRlXCJcbiAgICBpbXBvcnQgQ2xpZW50TW9kYWwgZnJvbSBcIi4uL2NvbXBvbmVudHMvY2xpZW50cy9DbGllbnRNb2RhbC5zdmVsdGVcIjtcbiAgICBpbXBvcnQgQXJ0aWNsZU1vZGFsIGZyb20gXCIuLi9jb21wb25lbnRzL2FydGljbGVzL0FydGljbGVNb2RhbC5zdmVsdGVcIjtcbiAgICBpbXBvcnQgTG90TW9kYWwgZnJvbSBcIi4uL2NvbXBvbmVudHMvbG90cy9Mb3RNb2RhbC5zdmVsdGVcIjtcbiAgICBpbXBvcnQgSW52b2ljZU1vZGFsIGZyb20gXCIuLi9jb21wb25lbnRzL2ludm9pY2VzL0ludm9pY2VNb2RhbC5zdmVsdGVcIjtcbiAgICBpbXBvcnQgUGF5bWVudE1vZGFsIGZyb20gXCIuLi9jb21wb25lbnRzL3BheW1lbnRzL1BheW1lbnRNb2RhbC5zdmVsdGVcIjtcbiAgICBpbXBvcnQgQ3JlZGl0Tm90ZU1vZGFsIGZyb20gXCIuLi9jb21wb25lbnRzL2NyZWRpdG5vdGVzL0NyZWRpdE5vdGVNb2RhbC5zdmVsdGVcIjtcbiAgICBpbXBvcnQgUHJvZm9ybWFNb2RhbCBmcm9tIFwiLi4vY29tcG9uZW50cy9wcm9mb3JtYXMvUHJvZm9ybWFNb2RhbC5zdmVsdGVcIjtcbiAgICBpbXBvcnQgeyBzdG9yZXMsIGdvdG8gfSBmcm9tIFwiQHNhcHBlci9hcHBcIjtcbiAgICBjb25zdCB7IHNlc3Npb24gfSA9IHN0b3JlcygpO1xuICAgIGltcG9ydCB7IG9uTW91bnQgfSBmcm9tIFwic3ZlbHRlXCI7XG4gICAgaW1wb3J0IHsgY2xpZW50SWQsIHJlZnMsIGFydGljbGVJZCwgbG90SWQsIGludm9pY2VJZCwgcGF5bWVudElkLCBjcmVkaXROb3RlSWQsIHByb2Zvcm1hSWQgfSBmcm9tIFwiLi4vc3RvcmVcIjtcbiAgICBpbXBvcnQgeyBnYXRlIH0gZnJvbSBcIi4uL2Zyb250SGVscGVyc1wiO1xuXG4gICAgbGV0IG1vdW50ZWQ7XG5cbiAgICAkcmVmcyA9IHNldHRpbmdzO1xuXG4gICAgJDogZ2V0UmVmcyhzZWdtZW50KTtcblxuICAgIG9uTW91bnQoKCkgPT4ge1xuICAgICAgICBpZighJHNlc3Npb24/LnVzZXIpIGdvdG8oXCIvYXV0aFwiKTtcbiAgICAgICAgbW91bnRlZCA9IHRydWU7XG4gICAgfSlcblxuICAgIGNvbnN0IGdldFJlZnMgPSBhc3luYyAoKSA9PiB7XG4gICAgICAgIGlmKCFtb3VudGVkKSByZXR1cm47XG5cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICRyZWZzID0gYXdhaXQgZ2F0ZSh7XG4gICAgICAgICAgICAgICAgdXJsOiBcIi9zZXR0aW5ncy9yZWZzLmpzb25cIixcbiAgICAgICAgICAgICAgICBtZXRob2Q6IFwiUE9TVFwiLFxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgY2F0Y2goZXJyKSB7XG4gICAgICAgICAgICBjb25zb2xlLmxvZyhlcnIpO1xuICAgICAgICB9XG4gICAgfTtcbjwvc2NyaXB0PlxuXG48TG9hZGVyIHBhZGRpbmc9e3NlZ21lbnQgJiYgc2VnbWVudCAhPT0gXCJhdXRoXCJ9IC8+XG5cbjxUb2FzdGVyIC8+XG5cbjxkaXYgY2xhc3M9XCJsYXlvdXQtd3JhcHBlclwiPlxuICAgIDxkaXY+XG4gICAgICAgIDxkaXYgY2xhc3M6ZC1ub25lPXshJHNlc3Npb24/LnVzZXJ9PlxuICAgICAgICAgICAgPFRvcE5hdiB7c2VnbWVudH0gLz5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG5cbiAgICA8ZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxuICAgICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuXG57I2lmICRjbGllbnRJZH1cbiAgICA8Q2xpZW50TW9kYWwgLz5cbnsvaWZ9XG5cbnsjaWYgJGFydGljbGVJZH1cbiAgICA8QXJ0aWNsZU1vZGFsIC8+XG57L2lmfVxuXG57I2lmICRsb3RJZH1cbiAgICA8TG90TW9kYWwgLz5cbnsvaWZ9XG5cbnsjaWYgJGludm9pY2VJZH1cbiAgICA8SW52b2ljZU1vZGFsIC8+XG57L2lmfVxuXG57I2lmICRwYXltZW50SWR9XG4gICAgPFBheW1lbnRNb2RhbCAvPlxuey9pZn1cblxueyNpZiAkY3JlZGl0Tm90ZUlkfVxuICAgIDxDcmVkaXROb3RlTW9kYWwgLz5cbnsvaWZ9XG5cbnsjaWYgJHByb2Zvcm1hSWR9XG4gICAgPFByb2Zvcm1hTW9kYWwgLz5cbnsvaWZ9XG5cbjxzdHlsZT5cbiAgICAubGF5b3V0LXdyYXBwZXIge1xuICAgICAgICAvKnRvcDowO1xuICAgICAgICBsZWZ0OjA7XG4gICAgICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICAgICAgei1pbmRleDogMTtcblxuICAgICAgICAgKi9cbiAgICAgICAgZGlzcGxheTogZ3JpZDtcbiAgICAgICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiBtYXgtY29udGVudCAxZnI7XG4gICAgICAgIGdyaWQtdGVtcGxhdGUtcm93czogMWZyO1xuICAgICAgICBncmlkLWdhcDogMjBweDtcbiAgICAgICAgaGVpZ2h0OiAxMDAlO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgbWF4LXdpZHRoOiAxMjAwcHg7XG4gICAgICAgIG1hcmdpbjogYXV0bztcbiAgICAgICAgcGFkZGluZzogMTBweDtcbiAgICB9XG5cbiAgICAuY29udGVudCB7XG4gICAgICAgIG92ZXJmbG93OiBhdXRvO1xuICAgICAgICBoZWlnaHQ6IDEwMCU7XG4gICAgICAgIHBhZGRpbmctYm90dG9tOiAxMDBweDtcbiAgICB9XG48L3N0eWxlPiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5R0ksNkJBQWdCLENBT1osT0FBTyxDQUFFLElBQUksQ0FDYixxQkFBcUIsQ0FBRSxXQUFXLENBQUMsR0FBRyxDQUN0QyxrQkFBa0IsQ0FBRSxHQUFHLENBQ3ZCLFFBQVEsQ0FBRSxJQUFJLENBQ2QsTUFBTSxDQUFFLElBQUksQ0FDWixLQUFLLENBQUUsSUFBSSxDQUNYLFNBQVMsQ0FBRSxNQUFNLENBQ2pCLE1BQU0sQ0FBRSxJQUFJLENBQ1osT0FBTyxDQUFFLElBQ2IsQ0FFQSxzQkFBUyxDQUNMLFFBQVEsQ0FBRSxJQUFJLENBQ2QsTUFBTSxDQUFFLElBQUksQ0FDWixjQUFjLENBQUUsS0FDcEIifQ== */
