313 lines
14 KiB
HTML
313 lines
14 KiB
HTML
<!doctype html>
|
||
<html lang="pl">
|
||
|
||
<head>
|
||
<meta charset="UTF-8" />
|
||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||
<title>Karczma Biesiada – Twoje Zamówienie</title>
|
||
<link rel="preconnect" href="https://fonts.googleapis.com">
|
||
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
||
<link
|
||
href="https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;600;700&family=Playfair+Display:wght@700&display=swap"
|
||
rel="stylesheet">
|
||
<link rel="stylesheet" href="assets/css/app.css">
|
||
</head>
|
||
|
||
<body>
|
||
|
||
<div id="loadingScreen">
|
||
<div class="loader-icon"></div>
|
||
<div class="loader-text">
|
||
<h2>Karczma Biesiada</h2>
|
||
<div class="loader-msg" id="loaderMsg">Łączenie z kuchnią...</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="geoScreen" class="hidden">
|
||
<div class="geo-icon">📍</div>
|
||
<div class="geo-text">
|
||
<h2>Prywatność i Lokalizacja</h2>
|
||
<div class="geo-msg" id="geoMsg">
|
||
Aby zapewnić bezpieczeństwo Twojego zamówienia, musimy upewnić się, że znajdujesz się na terenie restauracji.<br><br>Prosimy o udzielenie zgody na dostęp do lokalizacji w przeglądarce.
|
||
</div>
|
||
<button class="btn btn-primary" style="margin-top: 24px; max-width: 250px; margin-left: auto; margin-right: auto;" onclick="initGeolocation()">Udziel zgody / Sprawdź</button>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="container">
|
||
<header id="mainHeader">
|
||
<h1 class="logo-text">Karczma Biesiada</h1>
|
||
<div id="tableLabel" class="table-badge">Wybierz stolik</div>
|
||
</header>
|
||
<div id="greetingBanner"
|
||
style="display:none; text-align:center; padding: 10px; font-weight:600; color:var(--primary); font-family:'Playfair Display', serif; font-size:18px;">
|
||
</div>
|
||
|
||
<main id="mainContent">
|
||
<div id="statusView" class="view-section active">
|
||
|
||
<section class="status-card">
|
||
<div class="status-header">
|
||
<div>
|
||
<span class="status-title">Aktualny status</span>
|
||
<div id="prepStatus" class="status-value">Oczekiwanie...</div>
|
||
</div>
|
||
<div id="statusIcon" style="font-size: 28px;">⏳</div>
|
||
</div>
|
||
|
||
<div class="progress-container">
|
||
<div id="progressBar" class="progress-bar"></div>
|
||
</div>
|
||
|
||
<div id="statusMeta" style="font-size: 12px; color: var(--text-muted);">
|
||
Sprawdzamy co pysznego się przygotowuje...
|
||
</div>
|
||
</section>
|
||
|
||
<section class="items-container" id="ordersContainer">
|
||
<h3 id="ordersTitle">Twoje zamówione dania</h3>
|
||
<div id="emptyState" class="empty-state hidden">
|
||
<div class="empty-icon">📖</div>
|
||
<p style="color: var(--text-muted)">Jeśli właśnie złożyłeś zamówienie, daj nam chwilkę na jego
|
||
przetworzenie.</p>
|
||
<button class="btn btn-primary" style="margin-top: 15px; padding: 12px 20px; font-size: 15px;"
|
||
onclick="switchTab('menu')">Przeglądaj menu</button>
|
||
</div>
|
||
<div id="itemsList"></div>
|
||
</section>
|
||
|
||
<section id="historySection" class="items-container history-section hidden">
|
||
<h3>Twoje poprzednie zamówienia</h3>
|
||
<p class="history-note">To są pozycje z innych wizyt, które były widoczne na tym telefonie po zeskanowaniu
|
||
kodów QR. Jeśli kiedyś byłeś w restauracji bez skanowania kodu, tych pozycji tu nie będzie 🙂</p>
|
||
<div id="historyList"></div>
|
||
<div style="text-align: center; margin-top: 15px;">
|
||
<a href="#" onclick="clearGlobalHistory(event)"
|
||
style="font-size: 12px; color: var(--text-muted); text-decoration: underline;">Usuń historię</a>
|
||
</div>
|
||
</section>
|
||
|
||
<div id="metaFooter" class="meta-footer"></div>
|
||
</div> <!-- Koniec statusView -->
|
||
|
||
<div id="menuView" class="view-section hidden">
|
||
<div class="menu-search-container">
|
||
<input type="text" id="menuSearchInput" placeholder="Szukaj dania..." oninput="filterMenu()" />
|
||
</div>
|
||
|
||
<div class="restaurant-menu-container">
|
||
<nav class="menu-categories-nav">
|
||
<ul>
|
||
<li><a href="#" class="active" data-category-badge="0" onclick="showCategory(0)">Wszystko</a></li>
|
||
<li><a href="#" onclick="showCategory(1)" data-category-badge="1">Przystawki</a></li>
|
||
<li><a href="#" onclick="showCategory(2)" data-category-badge="2">Zupy</a></li>
|
||
<li><a href="#" onclick="showCategory(3)" data-category-badge="3">Dania główne</a></li>
|
||
<li><a href="#" onclick="showCategory(4)" data-category-badge="4">Dania swojskie</a></li>
|
||
<li><a href="#" onclick="showCategory(5)" data-category-badge="5">Ryby</a></li>
|
||
<li><a href="#" onclick="showCategory(7)" data-category-badge="7">Sałatki</a></li>
|
||
<li><a href="#" onclick="showCategory(6)" data-category-badge="6">Makarony</a></li>
|
||
<li><a href="#" onclick="showCategory(9)" data-category-badge="9">Dla dzieci</a></li>
|
||
<li><a href="#" onclick="showCategory(8)" data-category-badge="8">Dodatki</a></li>
|
||
<li><a href="#" onclick="showCategory(10)" data-category-badge="10">Desery</a></li>
|
||
<li><a href="#" onclick="showCategory(11)" data-category-badge="11">Napoje</a></li>
|
||
</ul>
|
||
</nav>
|
||
|
||
<div class="restaurant-menu-scroll" id="menuContainer">
|
||
<!-- Dynamiczne menu załaduje się tutaj -->
|
||
</div>
|
||
</div>
|
||
</div> <!-- Koniec menuView -->
|
||
|
||
</main>
|
||
|
||
<footer style="text-align: center; padding: 10px 0 20px; margin-top: 5px;">
|
||
<a href="https://magico.pl" target="_blank"
|
||
style="font-size: 12px; color: var(--text-muted); text-decoration: none;">
|
||
© Magico Software
|
||
</a>
|
||
</footer>
|
||
</div>
|
||
|
||
<!-- Bottom Navigation Bar -->
|
||
<nav class="bottom-nav" id="bottomNav" style="display: none;">
|
||
<div class="nav-item active" onclick="switchTab('status')" id="navStatus">
|
||
<span class="nav-icon">🍽️</span>
|
||
<span class="nav-label">Zamówienie</span>
|
||
</div>
|
||
<div class="nav-item" onclick="switchTab('menu')" id="navMenu">
|
||
<span class="nav-icon">📖</span>
|
||
<span class="nav-label">Menu</span>
|
||
</div>
|
||
<!-- <div class="nav-item action-call" onclick="openWaiterDialog()">
|
||
<span class="nav-icon">🛎️</span>
|
||
<span class="nav-label">Kelner</span>
|
||
</div> -->
|
||
<div class="nav-item action-bill" onclick="openBillDialog()">
|
||
<span class="nav-icon">💳</span>
|
||
<span class="nav-label">Rachunek</span>
|
||
</div>
|
||
</nav>
|
||
|
||
<!-- WAITER DIALOG -->
|
||
<div class="modal-overlay" id="waiterModal">
|
||
<div class="modal-content" style="text-align: center;">
|
||
<div style="font-size: 48px; margin-bottom: 15px;">🛎️</div>
|
||
<h3 style="margin-top: 0; color: var(--text-main); font-family: 'Playfair Display', serif; font-size: 24px;">
|
||
Przywołać obsługę?</h3>
|
||
<p style="color: var(--text-muted); font-size: 15px; margin-bottom: 25px; line-height: 1.5;">
|
||
Kelner otrzyma natychmiastowe powiadomienie na swoim panelu i podejdzie do Twojego stolika najszybciej jak to
|
||
możliwe.
|
||
</p>
|
||
<div style="display: flex; gap: 12px; flex-direction: column;">
|
||
<button class="btn btn-primary" onclick="confirmCallWaiter()" style="padding: 14px; font-size: 16px;">Tak,
|
||
poproś kelnera</button>
|
||
<button class="btn btn-secondary" onclick="closeWaiterDialog()" style="padding: 14px;">Anuluj</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<!-- NAME DIALOG -->
|
||
<div class="modal-overlay" id="nameModal">
|
||
<div class="modal-content" style="text-align: center;">
|
||
<div style="font-size: 48px; margin-bottom: 15px;">👋</div>
|
||
<h3 style="margin-top: 0; color: var(--text-main); font-family: 'Playfair Display', serif; font-size: 24px;">Podaj
|
||
swoje imię</h3>
|
||
<p style="color: var(--text-muted); font-size: 15px; margin-bottom: 20px; line-height: 1.5;">
|
||
Dzięki temu będziemy mogli powitać Cię osobiście podczas Twojej wizyty!
|
||
</p>
|
||
<div class="input-group" style="margin-bottom: 25px; text-align: left;">
|
||
<input type="text" id="userNameInput" class="input-field" placeholder="Twoje imię..." autocomplete="off" />
|
||
</div>
|
||
<div style="display: flex; gap: 12px; flex-direction: column;">
|
||
<button class="btn btn-primary" onclick="saveUserName()" style="padding: 14px; font-size: 16px;">Idę
|
||
dalej</button>
|
||
<button class="btn btn-secondary" onclick="declineUserName()" style="padding: 14px;">Nie chcę podawać</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<!-- BILL DIALOG -->
|
||
<div class="modal-overlay" id="billModal">
|
||
<div class="modal-content">
|
||
<div class="modal-header">
|
||
<h3 id="modalTitle">Rozliczenie</h3>
|
||
<button class="close-btn" onclick="closeBillDialog()">×</button>
|
||
</div>
|
||
|
||
<!-- Step 0: Loading or List of Bills -->
|
||
<div class="step active" id="stepBillList">
|
||
<div id="billLoading" style="text-align:center; padding: 20px;">
|
||
⏳ Pobieranie rachunków...
|
||
</div>
|
||
<div id="billListContainer" class="hidden">
|
||
<p style="margin-top:0; color:var(--text-muted); font-size:14px; margin-bottom: 20px;">Mamy kilka otwartych
|
||
rachunków na tym stoliku. Który chcesz opłacić?</p>
|
||
<div id="billListItems" style="display:flex; flex-direction:column; gap:10px;"></div>
|
||
</div>
|
||
</div>
|
||
|
||
<!-- Step 0.5: Bill Review -->
|
||
<div class="step" id="stepBillReview">
|
||
<p style="margin-top:0; color:var(--text-muted); font-size:14px; margin-bottom: 20px;">Podsumowanie rachunku:
|
||
</p>
|
||
<div id="billReviewContent"
|
||
style="background: var(--surface-light); padding: 15px; border-radius: 12px; max-height: 40vh; overflow-y: auto; margin-bottom: 15px;">
|
||
</div>
|
||
<div style="display:flex; justify-content:space-between; font-weight:700; font-size:18px; margin-bottom: 20px;">
|
||
<span>Do zapłaty:</span>
|
||
<span id="billTotalAmount" style="color:var(--primary);">0.00 PLN</span>
|
||
</div>
|
||
<div style="display:flex; gap:12px;">
|
||
<button class="btn btn-secondary" style="flex:1;" onclick="goBackToBillList()"
|
||
id="btnBackToBills">Wróć</button>
|
||
<!-- <button class="btn btn-primary" style="flex:2;" onclick="goToStep('stepPayment')">Poproś rachunek</button> -->
|
||
</div>
|
||
</div>
|
||
|
||
<!-- Step 1: Payment Method -->
|
||
<div class="step" id="stepPayment">
|
||
<p style="margin-top:0; color:var(--text-muted); font-size:14px; margin-bottom: 20px;">Wybierz preferowaną formę
|
||
płatności:</p>
|
||
<div class="option-grid">
|
||
<div class="option-card" onclick="selectPayment('karta')">
|
||
<span class="option-icon">💳</span>
|
||
<span class="option-label">Karta</span>
|
||
</div>
|
||
<div class="option-card" onclick="selectPayment('gotówka')">
|
||
<span class="option-icon">💵</span>
|
||
<span class="option-label">Gotówka</span>
|
||
</div>
|
||
</div>
|
||
<button class="btn btn-secondary" onclick="goToStep('stepBillReview')" style="margin-top: 15px;">Wróć do
|
||
podsumowania</button>
|
||
</div>
|
||
|
||
<!-- Step 2: Document Type -->
|
||
<div class="step" id="stepDocument">
|
||
<p style="margin-top:0; color:var(--text-muted); font-size:14px; margin-bottom: 20px;">Jakiego dokumentu
|
||
potrzebujesz?</p>
|
||
<div class="option-grid">
|
||
<div class="option-card" onclick="selectDocument('paragon')">
|
||
<span class="option-icon">🧾</span>
|
||
<span class="option-label">Paragon</span>
|
||
</div>
|
||
<div class="option-card" onclick="selectDocument('faktura')">
|
||
<span class="option-icon">📄</span>
|
||
<span class="option-label">Faktura</span>
|
||
</div>
|
||
</div>
|
||
<button class="btn btn-secondary" onclick="goToStep('stepPayment')" style="margin-top: 8px;">Wróć</button>
|
||
</div>
|
||
|
||
<!-- Step 3: NIP Input -->
|
||
<div class="step" id="stepNIP">
|
||
<p style="margin-top:0; color:var(--text-muted); font-size:14px; margin-bottom: 20px;">Wprowadź NIP firmy,
|
||
abyśmy mogli automatycznie pobrać dane.</p>
|
||
<div class="input-group">
|
||
<label class="input-label">Numer NIP</label>
|
||
<input type="number" id="nipInput" class="input-field" placeholder="np. 1234567890" autocomplete="off" />
|
||
</div>
|
||
<div style="display:flex; gap:12px; margin-top: 24px;">
|
||
<button class="btn btn-secondary" style="flex:1;" onclick="goToStep('stepDocument')">Wróć</button>
|
||
<button class="btn btn-primary" style="flex:2;" onclick="fetchGUS()" id="btnGUS">Pobierz z GUS</button>
|
||
</div>
|
||
</div>
|
||
|
||
<!-- Step 4: Verify Data -->
|
||
<div class="step" id="stepVerify">
|
||
<p style="margin-top:0; color:var(--text-muted); font-size:14px; margin-bottom: 20px;">Czy poniższe dane do
|
||
faktury są prawidłowe?</p>
|
||
|
||
<div class="company-details">
|
||
<input type="text" id="cmpName" class="company-input" style="font-weight:700; margin-bottom:4px;" readonly />
|
||
<input type="text" id="cmpStreet" class="company-input" placeholder="Ulica i numer" style="margin-bottom:4px;"
|
||
readonly />
|
||
<div style="display: flex; gap: 8px; margin-bottom: 4px;">
|
||
<input type="text" id="cmpZip" class="company-input" placeholder="Kod" style="flex: 1;" readonly />
|
||
<input type="text" id="cmpCity" class="company-input" placeholder="Miasto" style="flex: 2;" readonly />
|
||
</div>
|
||
<input type="text" id="cmpNip" class="company-input muted" readonly />
|
||
</div>
|
||
|
||
<div style="display:flex; gap:12px; flex-direction:column;">
|
||
<button class="btn btn-primary" onclick="confirmInvoice()">Tak, poproszę fakturę!</button>
|
||
<div style="display:flex; gap:12px;">
|
||
<button class="btn btn-secondary" onclick="goToStep('stepNIP')">Zmień NIP</button>
|
||
<button class="btn btn-secondary" onclick="editCompanyData()" id="btnEditCompany">Popraw ręcznie</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
</div>
|
||
</div>
|
||
|
||
<!-- Toast -->
|
||
<div class="toast" id="toastMsg">
|
||
<span style="font-size:20px;">✓</span> <span id="toastText">Wysłano!</span>
|
||
</div>
|
||
|
||
<script src="assets/js/app.js"></script>
|
||
</body>
|
||
|
||
</html> |