Commit abe0146d by Ravindra Kanojiya

updated api in home page

1 parent f58d44fd
...@@ -22,7 +22,8 @@ const BrowseExperiences = () => { ...@@ -22,7 +22,8 @@ const BrowseExperiences = () => {
price: "200", price: "200",
offPrice: "40%", offPrice: "40%",
days: "For 1 Night", days: "For 1 Night",
taxes: "Includes taxes & Fees" taxes: "Includes taxes & Fees",
id: 1,
}, },
{ {
image: "/images/Browse-Experiences/02.png", image: "/images/Browse-Experiences/02.png",
...@@ -32,7 +33,8 @@ const BrowseExperiences = () => { ...@@ -32,7 +33,8 @@ const BrowseExperiences = () => {
price: "200", price: "200",
offPrice: "40%", offPrice: "40%",
days: "For 1 Night", days: "For 1 Night",
taxes: "Includes taxes & Fees" taxes: "Includes taxes & Fees",
id: 2,
}, },
{ {
image: "/images/Browse-Experiences/03.png", image: "/images/Browse-Experiences/03.png",
...@@ -42,7 +44,8 @@ const BrowseExperiences = () => { ...@@ -42,7 +44,8 @@ const BrowseExperiences = () => {
price: "200", price: "200",
offPrice: "40%", offPrice: "40%",
days: "For 1 Night", days: "For 1 Night",
taxes: "Includes taxes & Fees" taxes: "Includes taxes & Fees",
id: 3,
}, },
{ {
image: "/images/Browse-Experiences/04.png", image: "/images/Browse-Experiences/04.png",
...@@ -52,7 +55,8 @@ const BrowseExperiences = () => { ...@@ -52,7 +55,8 @@ const BrowseExperiences = () => {
price: "200", price: "200",
offPrice: "40%", offPrice: "40%",
days: "For 1 Night", days: "For 1 Night",
taxes: "Includes taxes & Fees" taxes: "Includes taxes & Fees",
id: 4,
}, },
{ {
image: "/images/Browse-Experiences/01.png", image: "/images/Browse-Experiences/01.png",
...@@ -62,7 +66,8 @@ const BrowseExperiences = () => { ...@@ -62,7 +66,8 @@ const BrowseExperiences = () => {
price: "200", price: "200",
offPrice: "40%", offPrice: "40%",
days: "For 1 Night", days: "For 1 Night",
taxes: "Includes taxes & Fees" taxes: "Includes taxes & Fees",
id: 5,
} }
]; ];
...@@ -116,7 +121,7 @@ const BrowseExperiences = () => { ...@@ -116,7 +121,7 @@ const BrowseExperiences = () => {
{ListingData && {ListingData &&
ListingData.map(data => { ListingData.map(data => {
return ( return (
<SwiperSlide> <SwiperSlide key={data?.id}>
<motion.div <motion.div
variants={zoomIn("left", 0.3)} variants={zoomIn("left", 0.3)}
initial={"hidden"} initial={"hidden"}
......
import React, { Fragment } from "react"; import React, { Fragment, useEffect } from "react";
import Banner from "./Banner"; import Banner from "./Banner";
import SearchBar from "./SearchBar"; import SearchBar from "./SearchBar";
import LetDiscover from "./LetDiscover"; import LetDiscover from "./LetDiscover";
...@@ -6,18 +6,26 @@ import BrowseExperiences from "./BrowseExperiences"; ...@@ -6,18 +6,26 @@ import BrowseExperiences from "./BrowseExperiences";
import GiftAnExperience from "./GiftAnExperience"; import GiftAnExperience from "./GiftAnExperience";
import Testimonial from "./Testimonial"; import Testimonial from "./Testimonial";
import SignUpToExperienceOurPlatform from "./SignUpToExperienceOurPlatform"; import SignUpToExperienceOurPlatform from "./SignUpToExperienceOurPlatform";
import { useDispatch, useSelector } from "react-redux";
const Home = () => { const Home = () => {
const { categories } = useSelector(state => state.categories);
const { testimonial } = useSelector(sate => sate.testimonial);
console.log("categories", categories )
console.log("testimonial", testimonial )
const dispatch = useDispatch();
useEffect(() => {
// dispatch(getHomePage())
}, [dispatch]);
return ( return (
<Fragment> <Fragment>
<main> <main>
<Banner /> <Banner />
<SearchBar /> <SearchBar />
<LetDiscover /> <LetDiscover categories={categories} />
<BrowseExperiences /> <BrowseExperiences />
<GiftAnExperience /> <GiftAnExperience />
<Testimonial /> <Testimonial testimonial={testimonial} />
<SignUpToExperienceOurPlatform /> <SignUpToExperienceOurPlatform />
</main> </main>
</Fragment> </Fragment>
......
...@@ -11,49 +11,8 @@ import { motion } from "framer-motion"; ...@@ -11,49 +11,8 @@ import { motion } from "framer-motion";
import "swiper/css"; import "swiper/css";
import "swiper/css/pagination"; import "swiper/css/pagination";
import "swiper/css/navigation"; import "swiper/css/navigation";
const LetDiscover = () => { import { cleanImage } from "../../services/imageHandling.js";
const letDiscoverData = [ const LetDiscover = ({ categories }) => {
{
image: "/images/discover/01.png",
title: "All"
},
{
image: "/images/discover/02.png",
title: "Art & History"
},
{
image: "/images/discover/03.png",
title: "Experiential Dining "
},
{
image: "/images/discover/04.png",
title: "Family"
},
{
image: "/images/discover/05.png",
title: "Fitness"
},
{
image: "/images/discover/06.png",
title: "Performing Arts"
},
{
image: "/images/discover/01.png",
title: "Pop Ups"
},
{
image: "/images/discover/02.png",
title: "Tour"
},
{
image: "/images/discover/03.png",
title: "Classes"
},
{
image: "/images/discover/04.png",
title: "Wellness"
}
];
return ( return (
<> <>
<section className="let-discover-session"> <section className="let-discover-session">
...@@ -81,7 +40,7 @@ const LetDiscover = () => { ...@@ -81,7 +40,7 @@ const LetDiscover = () => {
<div className="let-discover-carousal position-relative"> <div className="let-discover-carousal position-relative">
<Swiper <Swiper
modules={[Autoplay, Navigation]} modules={[Autoplay, Navigation]}
slidesPerView={6} slidesPerView={3}
// autoplay={{ // autoplay={{
// delay: 7000, // delay: 7000,
// disableOnInteraction: false, // disableOnInteraction: false,
...@@ -107,21 +66,26 @@ const LetDiscover = () => { ...@@ -107,21 +66,26 @@ const LetDiscover = () => {
}} }}
className="mySwiper01 mySwiper02" className="mySwiper01 mySwiper02"
> >
{letDiscoverData &&
letDiscoverData.map((data, index) => {
return (
<SwiperSlide> <SwiperSlide>
<motion.div <motion.div variants={zoomIn("left", 0.3)} initial={"hidden"} whileInView={"show"} viewport={{ once: false, amount: 0.2 }}>
variants={zoomIn("left", 0.3)}
initial={"hidden"}
whileInView={"show"}
viewport={{ once: false, amount: 0.2 }}
>
<a href=""> <a href="">
<span className="image-container"> <span className="image-container">
<Image layout="fill" alt="" className="image img-fluid" src={data.image} /> <Image layout="fill" alt="" className="image img-fluid" src="/images/discover/03.png" />
</span>
<div className="title">ALL</div>
</a>
</motion.div>
</SwiperSlide>
{categories?.data &&
categories.data.map((data, index) => {
return (
<SwiperSlide key={data?.id}>
<motion.div variants={zoomIn("left", 0.3)} initial={"hidden"} whileInView={"show"} viewport={{ once: false, amount: 0.2 }}>
<a href="" >
<span className="image-container">
<Image layout="fill" alt="" className="image img-fluid" src={cleanImage(data?.attributes?.image?.data?.attributes)} />
</span> </span>
<div className="title">{data.title}</div> <div className="title">{data?.attributes?.name}</div>
</a> </a>
</motion.div> </motion.div>
</SwiperSlide> </SwiperSlide>
......
...@@ -11,18 +11,7 @@ import "swiper/css"; ...@@ -11,18 +11,7 @@ import "swiper/css";
import "swiper/css/pagination"; import "swiper/css/pagination";
import "swiper/css/navigation"; import "swiper/css/navigation";
const Testimonial = () => { const Testimonial = ({ testimonial }) => {
const testimonialData = [
{
disc: "“Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud.”",
name: "Erika Payne, Los Angeles CA"
},
{
disc: "“Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud.”",
name: "Erika Payne, Los Angeles CA"
},
];
return ( return (
<> <>
<section className="testimonial-session"> <section className="testimonial-session">
...@@ -39,20 +28,14 @@ const Testimonial = () => { ...@@ -39,20 +28,14 @@ const Testimonial = () => {
autoHeight={true} autoHeight={true}
spaceBetween={10} spaceBetween={10}
navigation={{ nextEl: ".testimonial-arrow-left", prevEl: ".testimonial-arrow-right" }} navigation={{ nextEl: ".testimonial-arrow-left", prevEl: ".testimonial-arrow-right" }}
modules={[Navigation, Autoplay]} modules={[Navigation, Autoplay]}
className="mySwiper01 mySwiper02" className="mySwiper01 mySwiper02"
> >
{testimonialData && {testimonial?.data &&
testimonialData.map(data => { testimonial?.data.map((data, index) => {
return ( return (
<SwiperSlide> <SwiperSlide>
<motion.div <motion.div variants={zoomIn("left", 0.3)} initial={"hidden"} whileInView={"show"} viewport={{ once: false, amount: 0.2 }}>
variants={zoomIn("left", 0.3)}
initial={"hidden"}
whileInView={"show"}
viewport={{ once: false, amount: 0.2 }}
>
<div className="testimonial-item"> <div className="testimonial-item">
<div className="img"> <div className="img">
<span className="image-container"> <span className="image-container">
...@@ -91,19 +74,16 @@ const Testimonial = () => { ...@@ -91,19 +74,16 @@ const Testimonial = () => {
</span> </span>
</a> */} </a> */}
</div> </div>
<div className="disc"> <div className="disc">{data?.attributes?.description}</div>
{data.disc} <div className="name">{data?.attributes?.title}</div>
</div>
<div className="name">{data.name}</div>
</div> </div>
</motion.div> </motion.div>
</SwiperSlide> </SwiperSlide>
); );
})} })}
</Swiper> </Swiper>
<div className="swiper-nav"> <div className="swiper-nav">
<div className="navbutton d-flex justify-content-center justify-content-md-between "> <div className="navbutton d-flex justify-content-between justify-content-md-between ">
<button className="testimonial-arrow-right arrow"> <button className="testimonial-arrow-right arrow">
<span className="image-container"> <span className="image-container">
<Image layout="fill" alt="" className="image img-fluid" src="/images/icons/arrow-left.svg" /> <Image layout="fill" alt="" className="image img-fluid" src="/images/icons/arrow-left.svg" />
...@@ -116,7 +96,6 @@ const Testimonial = () => { ...@@ -116,7 +96,6 @@ const Testimonial = () => {
</button> </button>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
......
...@@ -91,7 +91,10 @@ const Footer = () => { ...@@ -91,7 +91,10 @@ const Footer = () => {
<h3>HELP</h3> <h3>HELP</h3>
<ul> <ul>
<li> <li>
<a href="">Terms & Policy</a> <a href="/terms-and-conditions">Terms & Policy</a>
</li>
<li>
<a href="/privacy-policy">Privacy Policy</a>
</li> </li>
<li> <li>
<a href="">Careers</a> <a href="">Careers</a>
......
import Home from "../components/home/Home"; import Home from "../components/home/Home";
import Layout from "../components/layout/Layout"; import Layout from "../components/layout/Layout";
import { getAllCategories } from "../redux/actions/categoriesAction";
import { getTestimonial } from "../redux/actions/testimonialAction";
import { loadUser } from "../redux/actions/userActions"; import { loadUser } from "../redux/actions/userActions";
import { wrapper } from "../redux/store"; import { wrapper } from "../redux/store";
...@@ -22,13 +24,21 @@ export default function IndexPage() { ...@@ -22,13 +24,21 @@ export default function IndexPage() {
/** For server side rendering */ /** For server side rendering */
export const getServerSideProps = wrapper.getServerSideProps(store => async ({ req, query }) => { export const getServerSideProps = wrapper.getServerSideProps(store => async ({ req, query }) => {
// Get the menu data. try {
await store.dispatch(getAllCategories())
// get the locations data. await store.dispatch(getTestimonial())
// await store.dispatch(loadUser())
return { return {
props: {}, props: {},
// Next.js will attempt to re-generate the page:
// - Any requests to the page after the initial request and before 10 seconds are also cached and instantaneous.
// - After the 10-second window, the next request will still show the cached (stale) page
// - Next.js triggers a regeneration of the page in the background.
// - Once the page generates successfully, Next.js will invalidate the cache and show the updated page. If the background regeneration fails, the old page would still be unaltered.
// In seconds
// revalidate: Number(process.env.NEXT_PUBLIC_ISR_REVALIDATE_AFTER)
}; };
} catch (error) {
console.log("index.js", error);
}
}); });
...@@ -10,18 +10,29 @@ import { ...@@ -10,18 +10,29 @@ import {
} from "../constants/categoryConstants"; } from "../constants/categoryConstants";
export const getAllCategories = () => async dispatch => { export const getAllCategories = () => async dispatch => {
console.log("here >");
try { try {
console.log("here >>");
dispatch({ dispatch({
type: GET_CATEGORIES_REQUEST type: GET_CATEGORIES_REQUEST
}); });
const config = { const config = {
headers: { headers: {
"Content-Type": "application/json" "Content-Type": "application/json"
} }
}; };
const query = {
populate: ["image"]
};
const response = await axios.get(`${process.env.NEXT_PUBLIC_BACKEND_API_URL}/api/categories`, config); const queryString = qs.stringify(query, {
encodeValuesOnly: true
});
const response = await axios.get(`${process.env.NEXT_PUBLIC_BACKEND_API_URL}/api/categories?${queryString}`, config);
console.log("response > ", response);
dispatch({ dispatch({
type: GET_CATEGORIES_SUCCESS, type: GET_CATEGORIES_SUCCESS,
payload: response.data payload: response.data
......
import axios from "axios";
import qs from "qs";
import { GET_TESTIMONIAL_FAIL, GET_TESTIMONIAL_REQUEST, GET_TESTIMONIAL_SUCCESS } from "../constants/testimonialConstants";
export const getTestimonial = () => async dispatch => {
try {
dispatch({
type: GET_TESTIMONIAL_REQUEST
});
const config = {
headers: {
"Content-Type": "application/json"
}
};
const query = {
populate: ["image"]
};
const queryString = qs.stringify(query, {
encodeValuesOnly: true
});
const response = await axios.get(`${process.env.NEXT_PUBLIC_BACKEND_API_URL}/api/testimonials?${queryString}`, config);
console.log("response > ", response);
dispatch({
type: GET_TESTIMONIAL_SUCCESS,
payload: response.data
});
return response.data;
} catch (error) {
dispatch({
type: GET_TESTIMONIAL_FAIL,
payload: error.response.data
});
}
};
export const GET_TESTIMONIAL_REQUEST = "GET_TESTIMONIAL_REQUEST"
export const GET_TESTIMONIAL_SUCCESS = "GET_TESTIMONIAL_SUCCESS"
export const GET_TESTIMONIAL_FAIL = "GET_TESTIMONIAL_FAIL"
export const CLEAR_ERRORS = "CLEAR_ERRORS";
\ No newline at end of file \ No newline at end of file
...@@ -7,6 +7,7 @@ import { displayEnquireNowReducer } from "./enquireNowModalReducer"; ...@@ -7,6 +7,7 @@ import { displayEnquireNowReducer } from "./enquireNowModalReducer";
import { getVendorDetailsReducer, loggedInVendorReducer, updateVendorReducer } from "./vendorReducers"; import { getVendorDetailsReducer, loggedInVendorReducer, updateVendorReducer } from "./vendorReducers";
import { createActivityReducer } from "./activitiesReducer"; import { createActivityReducer } from "./activitiesReducer";
import { getAllCategoriesReducer, getAllSubCategoriesReducer } from "./categoryReducer"; import { getAllCategoriesReducer, getAllSubCategoriesReducer } from "./categoryReducer";
import { getAllTestimonialReducer } from "./testimonialReducer";
const reducers = combineReducers({ const reducers = combineReducers({
townships: townshipsReducer, townships: townshipsReducer,
...@@ -27,6 +28,7 @@ const reducers = combineReducers({ ...@@ -27,6 +28,7 @@ const reducers = combineReducers({
activityData: createActivityReducer, activityData: createActivityReducer,
categories: getAllCategoriesReducer, categories: getAllCategoriesReducer,
subCategories: getAllSubCategoriesReducer, subCategories: getAllSubCategoriesReducer,
testimonial: getAllTestimonialReducer,
}); });
export default reducers; export default reducers;
import { GET_TESTIMONIAL_REQUEST, CLEAR_ERRORS, GET_TESTIMONIAL_SUCCESS, GET_TESTIMONIAL_FAIL } from "../constants/testimonialConstants";
export const getAllTestimonialReducer = (state = { loading: true, success: false, testimonial: null }, action) => {
switch (action.type) {
case GET_TESTIMONIAL_REQUEST:
return {
loading: true,
};
case GET_TESTIMONIAL_SUCCESS:
return {
loading: false,
testimonial: action.payload
};
case GET_TESTIMONIAL_FAIL:
return {
loading: false,
error: action.payload.error.message
};
case CLEAR_ERRORS:
return {
...state,
error: null
};
default:
return state;
}
};
\ No newline at end of file \ No newline at end of file
This diff could not be displayed because it is too large.
Styling with Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!