diff --git a/project/pembeli_menu.py b/project/pembeli_menu.py index c31559c..7f9159a 100644 --- a/project/pembeli_menu.py +++ b/project/pembeli_menu.py @@ -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)