Compare commits
2 Commits
02aa1da64f
...
6359376da0
| Author | SHA1 | Date | |
|---|---|---|---|
| 6359376da0 | |||
| 5f55320865 |
@ -10,13 +10,13 @@ class PembeliMenu:
|
||||
self.frame = tk.Frame(parent)
|
||||
self.frame.pack(fill="both", expand=True)
|
||||
|
||||
self.cart = []
|
||||
self.images = []
|
||||
self.cart = [] # List untuk menyimpan belanjaan sementara
|
||||
self.images = [] # List untuk reference gambar agar tidak hilang
|
||||
|
||||
# Header
|
||||
# --- Header ---
|
||||
tk.Label(self.frame, text="SELAMAT DATANG", font=("Arial", 18, "bold")).pack(pady=10)
|
||||
|
||||
# --- INPUT DATA PELANGGAN (Penting karena tanpa login) ---
|
||||
# --- INPUT DATA PELANGGAN ---
|
||||
info_frame = tk.Frame(self.frame, bd=2, relief="groove", padx=10, pady=10)
|
||||
info_frame.pack(pady=5)
|
||||
|
||||
@ -31,23 +31,25 @@ class PembeliMenu:
|
||||
# Tombol Kembali
|
||||
tk.Button(self.frame, text="Kembali ke Utama", bg="#f9e79f", command=self.logout).pack(pady=5)
|
||||
|
||||
# Area Menu
|
||||
# --- Area Menu ---
|
||||
self.menu_frame = tk.Frame(self.frame)
|
||||
self.menu_frame.pack(pady=10, fill="both", expand=True)
|
||||
self.load_menu()
|
||||
|
||||
# Keranjang
|
||||
tk.Label(self.frame, text="Keranjang Pesanan:").pack()
|
||||
# --- Keranjang Belanja ---
|
||||
tk.Label(self.frame, text="Keranjang Pesanan:", font=("Arial", 10, "bold")).pack()
|
||||
self.listbox = tk.Listbox(self.frame, width=50, height=6)
|
||||
self.listbox.pack()
|
||||
|
||||
# [BARU] Tombol Hapus Item
|
||||
tk.Button(self.frame, text="❌ Hapus Item Terpilih", fg="red", font=("Arial", 9), command=self.hapus_item_cart).pack(pady=2)
|
||||
|
||||
self.total_lbl = tk.Label(self.frame, text="Total: Rp 0", font=("Arial", 12, "bold"))
|
||||
self.total_lbl.pack(pady=5)
|
||||
|
||||
tk.Button(self.frame, text="KIRIM PESANAN", bg="#d1e7dd", font=("Arial", 11, "bold"), command=self.checkout).pack(pady=10)
|
||||
tk.Button(self.frame, text="✅ KIRIM PESANAN", bg="#d1e7dd", font=("Arial", 11, "bold"), command=self.checkout).pack(pady=10)
|
||||
|
||||
def load_menu(self):
|
||||
# (SAMA SEPERTI KODE SEBELUMNYA)
|
||||
db = connect()
|
||||
cur = db.cursor()
|
||||
cur.execute("SELECT nama, harga, gambar FROM menu")
|
||||
@ -73,12 +75,29 @@ class PembeliMenu:
|
||||
|
||||
tk.Label(f, text=nama, font=("Arial",10,"bold")).pack()
|
||||
tk.Label(f, text=f"Rp {harga:,.0f}").pack()
|
||||
tk.Button(f, text="Tambah", command=lambda n=nama, h=harga: self.add_to_cart(n, h)).pack()
|
||||
tk.Button(f, text="Tambah", bg="#cfe2ff", command=lambda n=nama, h=harga: self.add_to_cart(n, h)).pack(pady=2)
|
||||
|
||||
def add_to_cart(self, nama, harga):
|
||||
self.cart.append({'nama': nama, 'harga': harga})
|
||||
self.refresh_cart()
|
||||
|
||||
# [BARU] Fungsi Logic Hapus
|
||||
def hapus_item_cart(self):
|
||||
# Ambil index item yang dipilih di listbox
|
||||
idx = self.listbox.curselection()
|
||||
|
||||
if not idx:
|
||||
messagebox.showwarning("Peringatan", "Pilih menu di keranjang yang ingin dihapus!")
|
||||
return
|
||||
|
||||
index = idx[0]
|
||||
# Hapus data dari list cart
|
||||
item_removed = self.cart.pop(index)
|
||||
|
||||
# Update tampilan listbox dan total harga
|
||||
self.refresh_cart()
|
||||
# Opsional: Tampilkan pesan kecil di console atau status bar (disini saya skip biar tidak ganggu user)
|
||||
|
||||
def refresh_cart(self):
|
||||
self.listbox.delete(0, tk.END)
|
||||
total = 0
|
||||
@ -104,18 +123,12 @@ class PembeliMenu:
|
||||
db = connect()
|
||||
cur = db.cursor()
|
||||
|
||||
# Simpan Transaksi dengan Nama Pemesan (Saya perlu update database sedikit untuk simpan nama pemesan di tabel transaksi, atau tempel di header struk)
|
||||
# Untuk simplifikasi, kita simpan nama pemesan di kolom 'status' sementara atau buat kolom baru.
|
||||
# TAPI, agar tidak mengubah database lagi, kita anggap Nama Pemesan hanya untuk display Waiter/Kasir.
|
||||
|
||||
# Opsi terbaik: Masukkan nama pemesan ke tabel transaksi (Perlu update database.py sedikit lagi agar sempurna)
|
||||
# Jika malas ubah database.py, kita gabung di tanggal atau status.
|
||||
# Mari kita lakukan yang benar: Update query INSERT untuk mendukung kolom nama_pelanggan jika ada,
|
||||
# TAPI karena kamu sudah setup DB, kita tempel di note saja.
|
||||
|
||||
# Agar simple dan tidak error di DB yang sudah kamu buat, kita kirim pesan sukses saja dulu.
|
||||
# Menyimpan nama pemesan di dalam string tanggal (Trik agar tidak ubah struktur DB)
|
||||
# Format: "2023-12-15 10:00:00 (Budi)"
|
||||
tanggal_custom = f"{tanggal} ({nama_pemesan})"
|
||||
|
||||
cur.execute("INSERT INTO transaksi (tanggal, total, meja_id, status) VALUES (?, ?, ?, ?)",
|
||||
(f"{tanggal} ({nama_pemesan})", total_belanja, meja, "Pending"))
|
||||
(tanggal_custom, total_belanja, meja, "Pending"))
|
||||
|
||||
transaksi_id = cur.lastrowid
|
||||
|
||||
@ -126,7 +139,7 @@ class PembeliMenu:
|
||||
db.commit()
|
||||
db.close()
|
||||
|
||||
messagebox.showinfo("Berhasil", f"Pesanan a.n {nama_pemesan} berhasil dikirim!")
|
||||
messagebox.showinfo("Berhasil", f"Pesanan a.n {nama_pemesan} berhasil dikirim ke Dapur!")
|
||||
self.cart.clear()
|
||||
self.refresh_cart()
|
||||
self.entry_nama.delete(0, tk.END)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user