const { User, Tour , Booking } = require('../models/tourModel'); const pool = require('../config/database'); exports.getTours = async (req, res) => { try { const tours = await Tour.getAllTours(req.session.userId); // ดึงทัวร์ที่สร้างโดยผู้ใช้ที่ล็อกอิน res.render('index', { tours, session: req.session }); } catch (error) { res.status(500).send(error.message); } }; exports.getTourDetails = async (req, res) => { const tourId = req.params.id; try { const tour = await Tour.getTourById(tourId); // ค้นหาทัวร์จาก ID // ถ้าทัวร์ไม่พบ จะส่งข้อความกลับไป if (!tour) { return res.status(404).send('ไม่พบข้อมูลทัวร์ที่ต้องการ'); } res.render('tour-details', { tour }); } catch (error) { console.error('Error fetching tour by ID:', error); res.status(500).send('เกิดข้อผิดพลาดในการดึงข้อมูลทัวร์'); } }; //User// exports.getLogin = (req, res) => { res.render('login', { message: null }); }; exports.getRegister = (req, res) => { res.render('register', { message: null }); }; exports.postRegister = async (req, res) => { const { name, email, password, confirmPassword } = req.body; if (password !== confirmPassword) { return res.render('register', { message: 'Passwords do not match' }); } try { const existingUser = await User.findOne(email); if (existingUser) { return res.render('register', { message: 'Email already in use' }); } const userId = await User.create(name, email, password); req.session.userId = userId; res.redirect('/login'); } catch (err) { console.error(err); res.render('register', { message: 'Error creating user' }); } }; exports.postLogin = async (req, res) => { const { email, password } = req.body; try { const user = await User.findOne(email); // หาผู้ใช้จากฐานข้อมูล if (!user) { return res.render('login', { message: 'Invalid email or password' }); } const isMatch = await User.comparePassword(email, password); // ตรวจสอบรหัสผ่าน if (!isMatch) { return res.render('login', { message: 'Invalid email or password' }); } req.session.userId = user.id; // เก็บ email ใน session req.session.userName = user.name; // เก็บชื่อผู้ใช้ใน session res.redirect('/'); // เมื่อ login สำเร็จให้ไปหน้า home } catch (err) { console.error(err); res.render('login', { message: 'Error logging in' }); } }; exports.Logout = (req, res) => { req.session.destroy((err) => { if (err) { return res.status(500).send('เกิดข้อผิดพลาดในการออกจากระบบ'); } res.redirect('/login'); // หลังจาก logout สำเร็จ ให้ redirect ไปหน้า login }); }; //Profile exports.getProfilePage = (req, res) => { if (req.session.userId) { const user = req.session.userName; res.render('profile', { user, session: req.session }); } else { res.redirect('/login'); } }; exports.getEditProfilePage = async (req, res) => { if (!req.session.userId) { return res.redirect('/profile'); } try { const user = await User.findById(req.session.userId); res.render('edit-profile', { user }); } catch (err) { console.error(err); res.redirect('/profile'); } }; exports.updateProfile = async (req, res) => { const { name, email, password } = req.body; if (!name || !email) { return res.status(400).send('Name and Email are required'); } try { let user = await User.findById(req.session.userId); // อัปเดตชื่อและอีเมล user.name = name; user.email = email; // อัปเดตพาสเวิร์ดถ้ามีการกรอก if (password) { user.password = await bcrypt.hash(password, 10); } await user.save(); res.redirect('/profile'); } catch (err) { console.error(err); res.status(500).send('Error updating profile'); } }; //CRUD // แสดงฟอร์มสร้างทัวร์ exports.getCreateTour = (req, res) => { res.render('createtour'); }; // บันทึกทัวร์ใหม่ exports.createTour = async (req, res) => { const { name, description, price, duration } = req.body; if (!name || !description || !price || !duration) { return res.status(400).send('กรุณากรอกข้อมูลให้ครบทุกช่อง'); } // แปลง userId ให้เป็นตัวเลข const userId = parseInt(req.session.userId, 10); if (isNaN(userId)) { return res.status(400).send('User ID is not valid'); } // ตรวจสอบค่าที่ได้รับจาก req.session และ body console.log('Received Values:'); console.log('UserID:', userId); console.log('Tour Details:'); console.log('Name:', name); console.log('Description:', description); console.log('Price:', price); console.log('Duration:', duration); try { // ส่ง userId ที่เก็บไว้ใน session ไปพร้อมกับข้อมูลทัวร์ await Tour.createTour(name, description, price, duration, req.session.userId); res.redirect('/'); // กลับไปหน้าแรกหลังจากสร้างทัวร์ } catch (error) { console.error('Error creating tour:', error); res.status(500).send('เกิดข้อผิดพลาดในการสร้างทัวร์'); } }; // ฟังก์ชั่นสำหรับสร้างทัวร์ exports.postCreateTour = async (req, res) => { const { name, description, price, duration } = req.body; if (!name || !price || !duration) { return res.render('createtour', { message: 'ข้อมูลไม่ครบถ้วน' }); } try { // ใช้ฟังก์ชันจากโมเดลในการสร้างทัวร์ await Tour.createTour(name, description, price, duration, req.session.userId); res.redirect('/'); // กลับไปหน้าแรกหลังจากสร้างเสร็จ } catch (error) { console.error(error); res.render('createtour', { message: 'เกิดข้อผิดพลาดในการสร้างทัวร์' }); } }; exports.getEditTour = async (req, res) => { try { const tour = await Tour.getTourById(req.params.id); if (!tour) return res.status(404).send('ไม่พบข้อมูลทัวร์'); if (tour.userId !== req.session.userId) { return res.status(403).send('คุณไม่มีสิทธิ์แก้ไขทัวร์นี้'); } res.render('edittour', { tour }); } catch (error) { res.status(500).send('เกิดข้อผิดพลาด'); } }; exports.postEditTour = async (req, res) => { const { name, description, price, duration } = req.body; const tourId = req.params.id; // ดึง id จาก URL parameters console.log('📥 Data received:', req.body); // ตรวจสอบข้อมูลที่ได้รับจากฟอร์ม if (!tourId) { return res.status(400).send('ไม่พบข้อมูลทัวร์'); } if (!name || !description || !price || !duration) { return res.status(400).send('กรุณากรอกข้อมูลให้ครบทุกช่อง'); } const tourData = { name, description, price, duration }; try { const result = await Tour.updateTour(tourId, tourData); // ส่ง tourId และ tourData console.log('Tour updated:', result); res.redirect('/tour/' + tourId); // ไปที่หน้ารายละเอียดทัวร์ } catch (error) { console.error('Error updating tour:', error); res.status(500).send('เกิดข้อผิดพลาดในการแก้ไขทัวร์'); } }; exports.deleteTour = async (req, res) => { try { const tour = await Tour.getTourById(req.params.userId); if (!tour) return res.status(404).send('ไม่พบข้อมูลทัวร์'); if (tour.userId !== req.session.userId) { return res.status(403).send('คุณไม่มีสิทธิ์ลบทัวร์นี้'); } await Tour.deleteTour(req.params.userId); // ลบทัวร์ที่ผู้ใช้เป็นเจ้าของ res.redirect('/'); // ไปที่หน้า home } catch (error) { res.status(500).send('เกิดข้อผิดพลาดในการลบทัวร์'); } }; //ค้นหาทัวร์ exports.searchTours = async (req, res) => { try { const searchQuery = req.query.query; const tours = await Tour.searchTours(searchQuery); // ตรวจสอบว่าผลลัพธ์จาก Tour.searchTours เป็นอาร์เรย์หรือไม่ if (!Array.isArray(tours)) { console.log('ผลลัพธ์จาก searchTours ไม่ใช่ Array:', tours); return res.render('search', { tours: [], session: req.session }); // ส่งอาร์เรย์ว่างไปหากไม่ใช่ Array } res.render('search', { tours, session: req.session }); } catch (error) { console.error('Error searching tours:', error); res.status(500).send("Error searching tours"); } }; //จองทัวร์ exports.getAllTours = async (req, res) => { try { const tours = await Tour.getAllTours(); // เรียกใช้ฟังก์ชันดึงทัวร์ทั้งหมด res.render('booking', { tours }); } catch (error) { console.error('Error fetching tours:', error.message); res.status(500).send('Internal Server Error'); } }; exports.getUserBookings = (req, res) => { const userId = req.user.id; // สมมติว่า req.user เก็บข้อมูลผู้ใช้ที่ล็อกอินแล้ว bookingModel.getBookings(userId, (err, bookings) => { if (err) return res.status(500).json({ error: err.message }); res.render('bookingView', { bookings }); }); }; // ฟังก์ชันสร้างการจอง exports.createBooking = async (req, res) => { const userId = req.session.userId; // สมมติว่าใช้ session ในการจัดการการล็อกอิน const tourId = req.body['tour-id']; // รับ tour_id จากฟอร์ม // ตรวจสอบว่ามีข้อมูล tour-id หรือไม่ if (!tourId) { return res.status(400).send('Tour ID is required.'); } try { // ตรวจสอบว่า tour_id ที่ส่งมาถูกต้องหรือไม่ (สามารถเพิ่มการตรวจสอบว่า tour_id นี้มีอยู่ในฐานข้อมูล) const tourQuery = 'SELECT * FROM tours WHERE id = ?'; const [tour] = await pool.query(tourQuery, [tourId]); if (tour.length === 0) { return res.status(404).send('Tour not found.'); } // ทำการจองทัวร์ await Booking.createBooking(userId, tourId); res.redirect('/my-bookings'); // หลังจากจองเสร็จ เปลี่ยนเส้นทางไปยังหน้าการจองของผู้ใช้ } catch (error) { console.error('Error creating booking:', error.message); res.status(500).send('Internal Server Error'); } }; // ยกเลิกการจอง exports.cancelBooking = (req, res) => { const bookingId = req.params.id; bookingModel.cancelBooking(bookingId, (err, result) => { if (err) return res.status(500).json({ error: err.message }); if (result.affectedRows === 0) { return res.status(404).json({ message: 'Booking not found' }); } res.status(200).json({ message: 'Booking canceled successfully' }); }); };