forked from UKSOURCE/cms.hailearning.edu.vn
UI Visa-VisaDetail
This commit is contained in:
@@ -8,12 +8,12 @@ const headerController = require("../controllers/headerController");
|
||||
const footerController = require("../controllers/footerController");
|
||||
const contactController = require("../controllers/contactController");
|
||||
const faqController = require("../controllers/faqController");
|
||||
|
||||
const visaController = require("../controllers/visaController");
|
||||
const safetyController = require("../controllers/safetyController");
|
||||
const campLocationController = require("../controllers/campLocationController");
|
||||
// Booking flow removed
|
||||
|
||||
const insuranceController= require("../controllers/insuranceController");
|
||||
const insuranceController = require("../controllers/insuranceController");
|
||||
const termsController = require("../controllers/termsController"); // <-- IMPORT ĐÃ CÓ
|
||||
const activityController = require("../controllers/activityController");
|
||||
const travelController = require("../controllers/travelController");
|
||||
@@ -61,8 +61,7 @@ router.get("/api/activities/:id", activityController.apiDetail);
|
||||
router.get("/api/camp-location", campLocationController.api);
|
||||
// Booking routes removed
|
||||
// Insurance APi route
|
||||
router.get("/api/insurance", insuranceController.api)
|
||||
|
||||
router.get("/api/insurance", insuranceController.api);
|
||||
|
||||
router.get("/api/terms", termsController.api);
|
||||
|
||||
@@ -71,14 +70,14 @@ router.get("/travel", async (req, res) => {
|
||||
try {
|
||||
const Travel = require("../models/travel");
|
||||
const travel = await Travel.findOne();
|
||||
|
||||
|
||||
if (!travel) {
|
||||
return res.status(404).render("errors/404", {
|
||||
title: "Page Not Found",
|
||||
message: "Travel information not found",
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
res.render("page/travel", {
|
||||
title: travel.page.title,
|
||||
data: travel.toObject(),
|
||||
@@ -95,33 +94,55 @@ router.get("/api/travel", travelController.api);
|
||||
|
||||
// Booking submission APIs (public endpoints)
|
||||
router.post("/api/booking/submit", bookingSubmissionController.submitBooking);
|
||||
router.get("/api/activity/:activityId/sessions", bookingSubmissionController.getAvailableSessions);
|
||||
router.get("/api/activity/:activityId/session/:sessionId/availability", bookingSubmissionController.getSessionAvailability);
|
||||
router.get(
|
||||
"/api/activity/:activityId/sessions",
|
||||
bookingSubmissionController.getAvailableSessions,
|
||||
);
|
||||
router.get(
|
||||
"/api/activity/:activityId/session/:sessionId/availability",
|
||||
bookingSubmissionController.getSessionAvailability,
|
||||
);
|
||||
|
||||
// New API for creating bookings directly into camp sessions (by program)
|
||||
router.post(
|
||||
"/api/camps/:program/sessions/:sessionId/bookings",
|
||||
activityController.createSessionBookingByProgram
|
||||
activityController.createSessionBookingByProgram,
|
||||
);
|
||||
router.get(
|
||||
"/api/camps/:program/sessions/:sessionId/bookings",
|
||||
activityController.getSessionBookingsByProgram
|
||||
activityController.getSessionBookingsByProgram,
|
||||
);
|
||||
// Keep admin-style update/delete by activityId (protected) if needed
|
||||
router.put("/api/camps/:activityId/sessions/:sessionId/bookings/:bookingId", activityController.updateSessionBooking);
|
||||
router.delete("/api/camps/:activityId/sessions/:sessionId/bookings/:bookingId", activityController.deleteSessionBooking);
|
||||
router.put(
|
||||
"/api/camps/:activityId/sessions/:sessionId/bookings/:bookingId",
|
||||
activityController.updateSessionBooking,
|
||||
);
|
||||
router.delete(
|
||||
"/api/camps/:activityId/sessions/:sessionId/bookings/:bookingId",
|
||||
activityController.deleteSessionBooking,
|
||||
);
|
||||
|
||||
// Demo booking form
|
||||
router.get("/demo/booking-form", (req, res) => {
|
||||
res.sendFile(path.join(__dirname, '../views/demo/booking-form.html'));
|
||||
res.sendFile(path.join(__dirname, "../views/demo/booking-form.html"));
|
||||
});
|
||||
|
||||
// Demo session booking API
|
||||
router.get("/demo/session-booking-api", (req, res) => {
|
||||
res.sendFile(path.join(__dirname, '../views/demo/session-booking-api.html'));
|
||||
res.sendFile(path.join(__dirname, "../views/demo/session-booking-api.html"));
|
||||
});
|
||||
|
||||
// // API route cho blog detail
|
||||
// router.get('/api/blog-detail', blogDetailController.api);
|
||||
|
||||
// ==================== PUBLIC API ROUTES ====================
|
||||
|
||||
// 1. Đưa các route cụ thể (chi tiết nhất) lên đầu tiên
|
||||
// 2. Route lấy TOÀN BỘ dữ liệu (phải nằm trên route :slug)
|
||||
router.get("/api/visa", visaController.api);
|
||||
router.get("/api/visa/hero", visaController.apiHero);
|
||||
router.get("/api/visa/countries", visaController.apiCountries);
|
||||
|
||||
// 3. Route lấy chi tiết theo slug (luôn để dưới cùng của nhóm này)
|
||||
router.get("/api/visa/:slug", visaController.apiCountry);
|
||||
module.exports = router;
|
||||
|
||||
Reference in New Issue
Block a user