dialog.svelte-3m6ty5::backdrop{background-color:#0006}#print-area.svelte-17nugd8{display:none}@media print{body *{visibility:hidden!important}#print-area,#print-area *{visibility:visible!important}#print-area{display:block!important;position:absolute;left:0;top:0;width:100%;padding:20mm}}
/*# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["ModalDialog.svelte", "ConfirmOrderDialog.svelte"],
  "sourcesContent": ["<script>\n\timport { onMount, onDestroy } from \"svelte\";\n\tlet dialog;\n\tonMount(() => {\n\t\tdialog.showModal();\n\t});\n\tonDestroy(() => {\n\t\tdialog.close(); //will dispatch \"close\" from the root <dialog> element\n\t});\n\tfunction closeOnBackdropClick(event) {\n\t\tif (event.target === event.currentTarget) {\n\t\t\tevent.target.close();\n\t\t}\n\t}\n</script>\n<!-- dialog is centered by browser via margin -->\n<dialog\n\tbind:this={dialog}\n\tclass=\"rounded min-h-2/5 max-h-4/5 shadow-xl p-0 flex flex-col divide-y overflow-hidden\"\n\ton:close\n\ton:click={closeOnBackdropClick}\n>\n\t<header\n\t\tclass=\"\n\t\t\tp-4 bg-zinc-100 w-full\n\t\t\tflex-initial\n\t\t\tflex justify-between items-center text-sm space-x-4\n\t\t\">\n\t\t<div>\n\t\t\t<slot name=header/>\n\t\t</div>\n\t\t<button\n\t\t\tclass=\"focus:outline-none font-medium px-4 py-1 rounded bg-zinc-200 hover:bg-zinc-300\"\n\t\t\ton:click={() => dialog.close()}\n\t\t>\n\t\t\tClose\n\t\t</button>\n\t</header>\n\t<div class=\"p-4 flex-grow overflow-y-scroll\">\n\t\t<slot/>\n\t</div>\n</dialog>\n<style>\n\tdialog::backdrop {\n\t\tbackground-color: rgba(0, 0, 0, 0.4);\n\t}\n</style>", "<script>\n\timport { createEventDispatcher } from \"svelte\";\n\timport QRCode from 'qrcode'\n\n\texport let submitFunction; // The function to call when submitting\n\texport let validateFunction;\n\texport let choices; // The order choices object { param: value, ... }\n\texport let l10n; // Localization data\n\texport let formspec; // The full formspec object from the backend\n\texport let skuminskickModelNumber; // modelnumber (for skuminskick)\n\n\tconst dispatch = createEventDispatcher();\n\n\tlet submitting = false;\n\tlet error = null;\n\tlet successResult = null; // Store success info if needed\n\tlet printed = false;\n\n\t/* \n\tSome option values are considered empty for summary\n\t*/\n\tfunction isEmpty(value) {\n\t\tif (value === undefined || value === null) return true;\n\t\tconst commonEmptyValues = [\"\", \"0mm\", \"0°\", \"0\", \"-\"];\n\t\tif (commonEmptyValues.includes(value)) return true;\n\t\treturn false;\n\t}\n\n\t// --- Localization Helpers ---\n\tfunction getParamLabel(param) {\n\t\treturn l10n?.param?.[param] || param || \"N/A\";\n\t}\n\n\tfunction getTitleLabel(titleKey) {\n\t\treturn l10n?.title?.[titleKey] || titleKey || \"N/A\";\n\t}\n\n\tfunction getLocalizedValue(param, value) {\n\t\tif (value === undefined || value === null) return \"\";\n\t\tconst localizationKey = `${param}=${value}`;\n\t\t// Prefer specific value localization, fallback to raw value\n\t\treturn l10n?.value?.[localizationKey] || value;\n\t}\n\n\t// --- Reactive Derivation for Order Summary Rows ---\n\t// This now prepares data specifically for the 3-column layout\n\t$: summaryTableRows = (formspec?.summary || [])\n\t\t.map((item) => {\n\t\t\tconst leftParam = item.left;\n\t\t\tconst rightParam = item.right; // Only present if item.title is also present\n\t\t\tconst titleKey = item.title; // Only present for chiral rows\n\n\t\t\tconst leftValue = choices?.[leftParam];\n\t\t\tconst rightValue = choices?.[rightParam];\n\n\t\t\tconst hasLeftValue =\n\t\t\t\t!isEmpty(leftValue) &&\n\t\t\t\t!(item.unless && item.unless.includes(leftValue));\n\t\t\t// Only check right value if it's a chiral row (titleKey exists)\n\t\t\tconst hasRightValue =\n\t\t\t\ttitleKey &&\n\t\t\t\trightParam &&\n\t\t\t\t!isEmpty(rightValue) &&\n\t\t\t\t!(item.unless && item.unless.includes(rightValue));\n\n\t\t\tif (!hasLeftValue && !hasRightValue) {\n\t\t\t\treturn null; // Skip row entirely if neither relevant value is present\n\t\t\t}\n\n\t\t\tconst isChiral = !!rightParam; // Determine if it's a chiral row\n\n\t\t\tconst row = {\n\t\t\t\tisChiral: isChiral,\n\t\t\t\tkeyLabel: isChiral\n\t\t\t\t\t? getTitleLabel(titleKey)\n\t\t\t\t\t: getParamLabel(leftParam),\n\t\t\t\tleftParam: leftParam, // Keep param names for localization\n\t\t\t\trightParam: rightParam,\n\t\t\t\tleftValueLocalized: hasLeftValue\n\t\t\t\t\t? getLocalizedValue(leftParam, leftValue)\n\t\t\t\t\t: \"—\", // Show dash if default/empty in chiral\n\t\t\t\trightValueLocalized: hasRightValue\n\t\t\t\t\t? getLocalizedValue(rightParam, rightValue)\n\t\t\t\t\t: \"—\", // Show dash if default/empty in chiral\n\t\t\t\t// For simple rows, we'll use leftValueLocalized directly with colspan\n\t\t\t};\n\n\t\t\t// For simple rows, store the actual value without the dash placeholder\n\t\t\tif (!isChiral && hasLeftValue) {\n\t\t\t\trow.leftValueLocalized = getLocalizedValue(\n\t\t\t\t\tleftParam,\n\t\t\t\t\tleftValue,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn row;\n\t\t})\n\t\t.filter(Boolean); // Remove null entries\n\n\n\tlet choiceDiffsTableRows = []\n\tfunction buildChoiceDiffsTable(choiceDiffs) {\n\t\tchoiceDiffsTableRows = formspec.summary.map(item => {\n\t\t\tconst leftParam = item.left;\n\t\t\tconst rightParam = item.right; // Only present if item.title is also present\n\t\t\tconst titleKey = item.title; // Only present for chiral rows\n\n\t\t\tconst leftValue = choiceDiffs?.[leftParam];\n\t\t\tconst rightValue = choiceDiffs?.[rightParam];\n\n\t\t\tconst hasLeftValue = !!leftValue\n\t\t\t// Only check right value if it's a chiral row (titleKey exists)\n\t\t\tconst hasRightValue =\n\t\t\t\ttitleKey &&\n\t\t\t\trightParam &&\n\t\t\t\t!!rightValue\n\n\t\t\tif (!hasLeftValue && !hasRightValue) {\n\t\t\t\treturn null; // Skip row entirely if neither relevant value is present\n\t\t\t}\n\n\t\t\tconst isChiral = !!rightParam; // Determine if it's a chiral row\n\n\t\t\tconst row = {\n\t\t\t\tisChiral: isChiral,\n\t\t\t\tkeyLabel: isChiral\n\t\t\t\t\t? getTitleLabel(titleKey)\n\t\t\t\t\t: getParamLabel(leftParam),\n\t\t\t\tleftParam: leftParam, // Keep param names for localization\n\t\t\t\trightParam: rightParam,\n\t\t\t\tleftValueLocalized: hasLeftValue\n\t\t\t\t\t? getLocalizedValue(leftParam, leftValue.new)\n\t\t\t\t\t: \"—\", // Show dash if default/empty in chiral\n\t\t\t\trightValueLocalized: hasRightValue\n\t\t\t\t\t? getLocalizedValue(rightParam, rightValue.new)\n\t\t\t\t\t: \"—\", // Show dash if default/empty in chiral\n\t\t\t\t// For simple rows, we'll use leftValueLocalized directly with colspan\n\t\t\t};\n\n\t\t\t// For simple rows, store the actual value without the dash placeholder\n\t\t\tif (!isChiral && hasLeftValue) {\n\t\t\t\trow.leftValueLocalized = getLocalizedValue(\n\t\t\t\t\tleftParam,\n\t\t\t\t\tleftValue.new,\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn row;\n\t\t}).filter(Boolean)\n\t}\n\tasync function validate() {\n\t\tsubmitting = true;\n\t\terror = null;\n\t\ttry {\n\t\t\tconst result = await validateFunction();\n\t\t\tbuildChoiceDiffsTable(result.choiceDiffs)\n\t\t} catch (err) {\n\t\t\tconsole.error(\"validation error:\", err);\n\t\t\terror = err.message || \"An unknown error occurred.\";\n\t\t\tif (err.diagnostics) {\n\t\t\t\terror = Array.isArray(err.diagnostics)\n\t\t\t\t\t? err.diagnostics.join(\", \")\n\t\t\t\t\t: String(err.diagnostics); // Ensure it's a string\n\t\t\t}\n\t\t\tsubmitting = false;\n\t\t\tthrow new Error(\"failed to validate order for skuminskick\")\n\t\t} finally {\n\t\t\tsubmitting = false;\n\t\t}\n\t}\n\n\t// --- Event Handlers ---\n\tasync function handleSubmit() {\n\t\tsubmitting = true;\n\t\terror = null;\n\t\tsuccessResult = null;\n\t\ttry {\n\t\t\tconst result = await submitFunction();\n\t\t\tsuccessResult = result;\n\t\t} catch (err) {\n\t\t\tconsole.error(\"Submission error:\", err);\n\t\t\terror = err.message || \"An unknown error occurred.\";\n\t\t\tif (err.diagnostics) {\n\t\t\t\terror = Array.isArray(err.diagnostics)\n\t\t\t\t\t? err.diagnostics.join(\", \")\n\t\t\t\t\t: String(err.diagnostics); // Ensure it's a string\n\t\t\t}\n\t\t} finally {\n\t\t\tsubmitting = false;\n\t\t}\n\t}\n\n\tfunction handleClose() {\n\t\tif (successResult) {\n\t\t\tdispatch(\"submitted\");\n\t\t} else {\n\t\t\tdispatch(\"close\");\n\t\t}\n\t}\n\n\tlet tableElement\n\tlet copyButtonText = \"Kopiera Tabellen\"\n\tasync function handleCopy() {\n\t\tif (!tableElement) return\n\n\t\t// Get all 'tr' (table row) elements from the table\n\t\tconst rows = tableElement.querySelectorAll('tr')\n\n\t\tconst tableText = Array.from(rows).map(row => {\n\t\t\tconst cells = row.querySelectorAll('td, th');\n\t\t\treturn Array.from(cells).map(cell => cell.textContent.trim()).join('\\t')\n\t\t}).join('\\n')\n\n\t\ttry {\n\t\t\tawait navigator.clipboard.writeText(tableText)\n\n\t\t\tcopyButtonText = \"Kopierad!\"\n\t\t} catch (err) {\n\t\t\tconsole.error('Failed to copy text: ', err)\n\t\t\tcopyButtonText = \"Kunde inte kopiera\"\n\t\t}\n\t}\n\n\tlet skuminskickQrCodeDataURL;\n\tasync function makeSkuminskickQR() {\n\t\ttry {\n\t\t\tskuminskickQrCodeDataURL = await QRCode.toDataURL(successResult.orderIdentifier, {\n\t\t\t\twidth: 200,\n\t\t\t\tmargin: 2\n\t\t\t})\n\t\t} catch (error) {\n\t\t\talert(\"Ett fel inträffade. Försök igen.\");\n\t\t\tthrow new Error(\"failed to generate qr for skuminskick\")\n\t\t}\n\t}\n\n\t// --- Event Handlers ---\n\tasync function handlePrint() {\n\t\tif (!skuminskickQrCodeDataURL) {\n\t\t\tawait makeSkuminskickQR() \n\t\t}\n\t\tsetTimeout(() => {\n\t\t\ttry {\n\t\t\t  document.execCommand('print', false, null) // safari\n\t\t\t} catch {\n\t\t\t  window.print()\n\t\t\t}\n\t\t}, 500)\n\t\tprinted = true\n\t}\n\n\timport { onMount } from \"svelte\";\n\tonMount(async () => {\n\t\tif (skuminskickModelNumber) {\n\t\t\tawait validate()\n\t\t}\n\t});\n</script>\n\n<div\n\tclass=\"absolute inset-0 bg-black bg-opacity-50 flex items-center justify-center z-50\"\n\ton:click|self={handleClose}\n>\n\t<div\n\t\tid=\"confirm-dialog\"\n\t\tclass=\"bg-white rounded-lg shadow-lg p-6 md:p-8 w-11/12 md:w-2/3 lg:w-1/2 max-w-2xl max-h-[85vh] flex flex-col\"\n\t>\n\t\t{#if successResult}\n\t\t\t<!-- Success State -->\n\t\t\t<div class=\"flex-grow overflow-auto text-center\">\n\t\t\t\t<h1 class=\"font-bold text-xl mb-4 text-success\">\n\t\t\t\t\tBeställning genomförd!\n\t\t\t\t</h1>\n\t\t\t\t<p class=\"mb-4\">Din beställning har skickats.</p>\n\t\t\t\t<!-- Display Order Identifier -->\n\t\t\t\t{#if successResult.orderIdentifier}\n\t\t\t\t\t<p class=\"mb-4\">\n\t\t\t\t\t\tOrdernummer: <span class=\"font-semibold\"\n\t\t\t\t\t\t\t>{successResult.orderIdentifier}</span\n\t\t\t\t\t\t>\n\t\t\t\t\t</p>\n\t\t\t\t\t{#if skuminskickModelNumber}\n\t\t\t\t\t\t<p>\n\t\t\t\t\t\t\tVänligen skriv ut följesdel och skicka denna\n\t\t\t\t\t\t\tmed skumformarna så att de kan bindas till rätt order.\n\t\t\t\t\t\t</p>\n\t\t\t\t\t\t<button\n\t\t\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-secondary text-white shadow min-w-[150px]\"\n\t\t\t\t\t\t\ton:click={handlePrint}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\tSkriv ut följesedel\n\t\t\t\t\t\t</button>\n\t\t\t\t\t{/if}\n\t\t\t\t\t<p>\n\t\t\t\t\t\t{#if skuminskickModelNumber}\n\t\t\t\t\t\t\tDu kan göra en ytterligare beställning med samma\n\t\t\t\t\t\t\tskumformar.\n\t\t\t\t\t\t{:else}\n\t\t\t\t\t\t\tDu kan göra en ytterligare beställning med samma\n\t\t\t\t\t\t\tskanningar.\n\t\t\t\t\t\t{/if}\n\t\t\t\t\t</p>\n\t\t\t\t\t{#if skuminskickModelNumber}\n\t\t\t\t\t\t<button\n\t\t\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-secondary text-white shadow\"\n\t\t\t\t\t\t\tdisabled={!printed}\n\t\t\t\t\t\t\ton:click={() =>\n\t\t\t\t\t\t\t\tdispatch(\"repeatOrder\", {\n\t\t\t\t\t\t\t\t\torderIdentifier: successResult.orderIdentifier,\n\t\t\t\t\t\t\t\t\tskuminskickModelNumber: skuminskickModelNumber,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\tNy beställning med samma skumformar\n\t\t\t\t\t\t</button>\n\t\t\t\t\t{:else}\n\t\t\t\t\t\t<button\n\t\t\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-secondary text-white shadow\"\n\t\t\t\t\t\t\tdisabled=\"\"\n\t\t\t\t\t\t\ton:click={() =>\n\t\t\t\t\t\t\t\tdispatch(\"repeatOrder\", {\n\t\t\t\t\t\t\t\t\torderIdentifier: successResult.orderIdentifier,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\tNy beställning med samma skanningar\n\t\t\t\t\t\t</button>\n\t\t\t\t\t{/if}\n\t\t\t\t{:else}\n\t\t\t\t\t<p class=\"mb-4 text-sm text-gray-500\">\n\t\t\t\t\t\t(Kunde inte hämta ordernummer)\n\t\t\t\t\t</p>\n\t\t\t\t{/if}\n\t\t\t</div>\n\t\t\t<div class=\"flex justify-center mt-4\">\n\t\t\t\t<button\n\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-secondary text-white shadow\"\n\t\t\t\t\tdisabled={skuminskickModelNumber && !printed}\n\t\t\t\t\ton:click={handleClose}\n\t\t\t\t>\n\t\t\t\t\tÅtergå till huvudmeny\n\t\t\t\t</button>\n\t\t\t</div>\n\t\t{:else if error}\n\t\t\t<!-- Error State -->\n\t\t\t<div class=\"flex-grow overflow-auto\">\n\t\t\t\t<h1 class=\"font-bold text-xl mb-4 text-error\">\n\t\t\t\t\tFel vid beställning\n\t\t\t\t</h1>\n\t\t\t\t<p\n\t\t\t\t\tclass=\"mb-4 bg-error-light p-3 rounded border border-error text-sm\"\n\t\t\t\t>\n\t\t\t\t\t{error}\n\t\t\t\t</p>\n\t\t\t</div>\n\t\t\t<div class=\"flex justify-end mt-4 space-x-4\">\n\t\t\t\t<button\n\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-secondary text-white shadow\"\n\t\t\t\t\ton:click={() => (error = null)}\n\t\t\t\t\tdisabled={submitting}\n\t\t\t\t>\n\t\t\t\t\tFörsök igen\n\t\t\t\t</button>\n\t\t\t\t<button\n\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-tertiary text-white shadow\"\n\t\t\t\t\ton:click={handleClose}\n\t\t\t\t\tdisabled={submitting}\n\t\t\t\t>\n\t\t\t\t\tAvbryt\n\t\t\t\t</button>\n\t\t\t</div>\n\t\t{:else}\n\t\t\t<!-- Confirmation State -->\n\t\t\t<div class=\"flex-grow overflow-auto flex flex-col\">\n\t\t\t\t<h1 class=\"font-bold text-xl mb-4 text-center flex-shrink-0\">\n\t\t\t\t\tBekräfta beställning\n\t\t\t\t</h1>\n\n\t\t\t\t<!-- Order Summary Table Wrapper for Scrolling -->\n\t\t\t\t<div class=\"mb-6 border rounded flex-grow overflow-y-auto\">\n\t\t\t\t\t{#if summaryTableRows.length > 0}\n\t\t\t\t\t\t<table bind:this={tableElement} class=\"w-full text-left text-sm table-fixed\">\n\t\t\t\t\t\t\t<thead class=\"sticky top-0 bg-gray-100 z-10\">\n\t\t\t\t\t\t\t\t<tr>\n\t\t\t\t\t\t\t\t\t<th class=\"p-2 w-[40%] font-semibold\"\n\t\t\t\t\t\t\t\t\t\t>Val</th\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<th class=\"p-2 w-[30%] font-semibold\"\n\t\t\t\t\t\t\t\t\t\t>Vänster</th\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<th class=\"p-2 w-[30%] font-semibold\"\n\t\t\t\t\t\t\t\t\t\t>Höger</th\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t\t</thead>\n\t\t\t\t\t\t\t<tbody class=\"divide-y divide-gray-200\">\n\t\t\t\t\t\t\t\t{#each summaryTableRows as row (row.keyLabel + row.leftParam)}\n\t\t\t\t\t\t\t\t\t<tr>\n\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top font-semibold break-words\"\n\t\t\t\t\t\t\t\t\t\t\t>{row.keyLabel}</td\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{#if row.isChiral}\n\t\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top break-words\"\n\t\t\t\t\t\t\t\t\t\t\t\t>{row.leftValueLocalized}</td\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top break-words\"\n\t\t\t\t\t\t\t\t\t\t\t\t>{row.rightValueLocalized}</td\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{:else}\n\t\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top break-words\"\n\t\t\t\t\t\t\t\t\t\t\t\tcolspan=\"2\"\n\t\t\t\t\t\t\t\t\t\t\t\t>{row.leftValueLocalized}</td\n\t\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{/if}\n\t\t\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t\t\t{/each}\n\t\t\t\t\t\t\t</tbody>\n\t\t\t\t\t\t</table>\n\t\t\t\t\t{:else}\n\t\t\t\t\t\t<p class=\"text-gray-500 p-4 text-center\">\n\t\t\t\t\t\t\tInga val har gjorts som avviker från standard.\n\t\t\t\t\t\t</p>\n\t\t\t\t\t{/if}\n\t\t\t\t</div>\n\t\t\t\t<p class=\"text-xs text-gray-500 text-center mb-4 flex-shrink-0\">\n\t\t\t\t\tKontrollera att alla val stämmer innan du skickar.\n\t\t\t\t</p>\n\t\t\t\t{#if skuminskickModelNumber}\n\t\t\t\t<p>\n\t\t\t\t\tSkuminskick har valts. Din beställning kommer att\n\t\t\t\t\tpåbörjas först när vi emottagit skum som skickas med\n\t\t\t\t\tposten.\n\t\t\t\t</p>\n\t\t\t\t{/if}\n\t\t\t</div>\n\n\t\t\t<div class=\"flex justify-end mt-4 space-x-4 flex-shrink-0\">\n\t\t\t\t<button\n\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-tertiary text-white shadow\"\n\t\t\t\t\ton:click={handleCopy}\n\t\t\t\t\tdisabled={submitting}\n\t\t\t\t>\n\t\t\t\t\t{ copyButtonText }\n\t\t\t\t</button>\n\t\t\t\t<button\n\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-tertiary text-white shadow\"\n\t\t\t\t\ton:click={handleClose}\n\t\t\t\t\tdisabled={submitting}\n\t\t\t\t>\n\t\t\t\t\tAvbryt\n\t\t\t\t</button>\n\t\t\t\t<!-- {#if skuminskickModelNumber} -->\n\t\t\t\t<!-- <button -->\n\t\t\t\t<!-- \tclass=\"font-medium rounded px-6 py-3 bg-secondary text-white shadow min-w-[150px]\" -->\n\t\t\t\t<!-- \ton:click={handlePrint} -->\n\t\t\t\t<!-- \tdisabled={submitting} -->\n\t\t\t\t<!-- > -->\n\t\t\t\t<!-- \tSkriv ut följesedel\t -->\n\t\t\t\t<!-- </button> -->\n\t\t\t\t<!-- {/if} -->\n\t\t\t\t<button\n\t\t\t\t\tclass=\"font-medium rounded px-6 py-3 bg-secondary text-white shadow min-w-[150px]\"\n\t\t\t\t\ton:click={handleSubmit}\n\t\t\t\t\tdisabled={submitting}\n\t\t\t\t>\n\t\t\t\t\t{#if submitting}\n\t\t\t\t\t\t<span class=\"animate-pulse\">Skickar...</span>\n\t\t\t\t\t{:else}\n\t\t\t\t\t\tSkicka beställning\n\t\t\t\t\t{/if}\n\t\t\t\t</button>\n\t\t\t</div>\n\t\t{/if}\n\t</div>\n\t{#if skuminskickQrCodeDataURL}\n\t\t<div id=\"print-area\">\n\t\t\t<div class=\"flex flex-col w-full items-center\">\n\t\t\t\t<img src=\"static/logo.png\" alt=\"Ortolab\" class=\"w-32 py-3\" />\n\t\t\t\t<h1 class=\"text-xl\">Följesedel för Skuminskick</h1>\n\t\t\t\t<p>\n\t\t\t\t\tOrdernummer: {successResult.orderIdentifier}.\n\t\t\t\t</p>\n\t\t\t\t<p>\n\t\t\t\t\tMärkning: {choices.clinicLabel}.\n\t\t\t\t</p>\n\t\t\t\t<img src={skuminskickQrCodeDataURL} class=\"w-64 py-3\" />\n\n\t\t\t\t{#if choiceDiffsTableRows.length > 0}\n\t\t\t\t\t<p class=\"py-3\">Förändringar mot orderns förlaga</p>\n\t\t\t\t\t<table class=\"w-full text-left text-sm table-fixed\">\n\t\t\t\t\t\t<thead class=\"sticky top-0 bg-gray-100 z-10\">\n\t\t\t\t\t\t\t<tr>\n\t\t\t\t\t\t\t\t<th class=\"p-2 w-[34%] font-semibold\"\n\t\t\t\t\t\t\t\t\t>Val</th\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<th class=\"p-2 w-[22%] font-semibold\"\n\t\t\t\t\t\t\t\t\t>Vänster</th\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<th class=\"p-2 w-[22%] font-semibold\"\n\t\t\t\t\t\t\t\t\t>Höger</th\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<th class=\"p-2 w-[22%] font-semibold\"\n\t\t\t\t\t\t\t\t\t>Båda</th\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t</thead>\n\t\t\t\t\t\t<tbody class=\"divide-y divide-gray-200\">\n\t\t\t\t\t\t\t{#each choiceDiffsTableRows as row (row.keyLabel + row.leftParam)}\n\t\t\t\t\t\t\t\t<tr>\n\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top font-semibold break-words\"\n\t\t\t\t\t\t\t\t\t\t>{row.keyLabel}</td\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{#if row.isChiral}\n\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top break-words\"\n\t\t\t\t\t\t\t\t\t\t\t>{row.leftValueLocalized}</td\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top break-words\"\n\t\t\t\t\t\t\t\t\t\t\t>{row.rightValueLocalized}</td\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t<td></td>\n\t\t\t\t\t\t\t\t\t{:else}\n\t\t\t\t\t\t\t\t\t\t<td></td>\n\t\t\t\t\t\t\t\t\t\t<td></td>\n\t\t\t\t\t\t\t\t\t\t<td\n\t\t\t\t\t\t\t\t\t\t\tclass=\"p-2 align-top break-words\"\n\t\t\t\t\t\t\t\t\t\t\t>{row.leftValueLocalized}</td\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{/if}\n\t\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t\t{/each}\n\t\t\t\t\t\t</tbody>\n\t\t\t\t\t</table>\n\t\t\t\t{:else}\n\t\t\t\t\t<p class=\"p-4 text-center\">\n\t\t\t\t\t\tInga val som avviker från orderns förlaga har gjorts.\n\t\t\t\t\t</p>\n\t\t\t\t{/if}\n\t\t\t\t<p class=\"p-4\">\n\t\t\t\t\tOBS! Glöm ej att skicka med denna tillsammans med skumformarna.\n\t\t\t\t</p>\n\t\t\t</div>\n\t\t</div>\n\t{/if}\n</div>\n<style>\n/* initially hide print area on screen */\n#print-area {\n\tdisplay: none;\n}\n\n/* print styles: hide everything except the print area */\n@media print {\n\t:global(body *) {\n\t\tvisibility: hidden !important;\n\t}\n\t:global(#print-area),\n\t:global(#print-area *) {\n\t\tvisibility: visible !important;\n\t}\n\t:global(#print-area) {\n\t\tdisplay: block !important;\n\t\tposition: absolute;\n\t\tleft: 0;\n\t\ttop: 0;\n\t\twidth: 100%;\n\t\tpadding: 20mm;\n\t}\n}\n</style>\n"],
  "mappings": "AA2CC,MAAA,CAAA,aAAM,WACL,iBAAkB,KACnB,CCyfD,CAAA,UAAA,CAAA,eACC,QAAS,IACV,CAGA,OAAO,MACE,KAAA,EACP,WAAY,gBACb,CACQ,CATT,WAUS,CAVT,WAUS,EACP,WAAY,iBACb,CACQ,CAbT,WAcE,QAAS,gBACT,SAAU,SACV,KAAM,EACN,IAAK,EACL,MAAO,KAlBT,QAmBW,IACV,CACD",
  "names": []
}
 */
