6778c32028
CI/CD / CI · API (dotnet build + test) (push) Successful in 45s
CI/CD / CI · Admin API (dotnet build) (push) Successful in 32s
CI/CD / CI · Dashboard (tsc) (push) Successful in 1m7s
CI/CD / CI · Admin Web (tsc) (push) Successful in 38s
CI/CD / CI · Website (tsc) (push) Successful in 45s
CI/CD / CI · Koja (tsc) (push) Successful in 49s
CI/CD / Deploy · all services (push) Successful in 2m46s
Completes the four POS v2 roadmap items: 1. Real split payments — split tab records N separate payment rows (equal split, last row takes the remainder), each row toggles Cash/Card; posts payments[]. 2. Card-terminal push — confirmPay sums Card amounts and calls requestPosPayment (POS device) before recording; surfaces POS_DEVICE_* errors. 3. Customer + coupons + loyalty — reuses PosCustomerPicker (attach/search/create) and validates coupons via /coupons/validate (discount in totals). Pay sheet offers loyalty redemption (1 point = 100 toman) when a customer is attached. 4. Promote to default — /pos now renders POS v2 (full-screen, café-themed); the classic terminal moves to /pos-classic with its sidebar+topbar chrome. The "نسخه کلاسیک" link points there. Order submission already carried customerId/guestName/guestPhone/couponId via the shared cart store, so customer + coupon flow straight through send + pay. tsc --noEmit clean. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
"use client";
|
|
|
|
import { useLocale } from "next-intl";
|
|
import { Sidebar } from "@/components/layout/sidebar";
|
|
import { Topbar } from "@/components/layout/topbar";
|
|
import { CafeThemeProvider } from "@/components/theme/cafe-theme-provider";
|
|
|
|
/**
|
|
* Classic POS route layout — wraps the terminal in the standard dashboard
|
|
* chrome (collapsible sidebar + topbar) but keeps the main content area
|
|
* overflow-hidden so PosScreen can manage its own internal scrolling.
|
|
*/
|
|
export default function PosClassicLayout({
|
|
children,
|
|
}: {
|
|
children: React.ReactNode;
|
|
}) {
|
|
const locale = useLocale();
|
|
const isRtl = locale !== "en";
|
|
|
|
const mainColumn = (
|
|
<div className="flex min-h-0 min-w-0 flex-1 flex-col">
|
|
<Topbar />
|
|
<main className="min-h-0 flex-1 overflow-hidden bg-background p-3 md:p-4">
|
|
{children}
|
|
</main>
|
|
</div>
|
|
);
|
|
|
|
return (
|
|
<CafeThemeProvider>
|
|
<div
|
|
className="flex h-screen min-h-0 overflow-hidden bg-background"
|
|
dir={isRtl ? "rtl" : "ltr"}
|
|
>
|
|
{isRtl ? (
|
|
<>
|
|
<Sidebar side="right" />
|
|
{mainColumn}
|
|
</>
|
|
) : (
|
|
<>
|
|
<Sidebar side="left" />
|
|
{mainColumn}
|
|
</>
|
|
)}
|
|
</div>
|
|
</CafeThemeProvider>
|
|
);
|
|
}
|