Commit e1745b51 by Chetan

breadcrumb and listing page filter by id

1 parent d6fa700f
import React, { Fragment, useEffect, useState } from "react"; import React, { Fragment, useEffect, useState } from "react";
import DetailGallery from "./DetailGallery"; import DetailGallery from "./DetailGallery";
import DetailInfo from "./DetailInfo"; import DetailInfo from "./DetailInfo";
import { Breadcrumb } from "react-bootstrap";
import GuestReviews from "./GuestReviews"; import GuestReviews from "./GuestReviews";
import SimilarExperiences from "./SimilarExperiences"; import SimilarExperiences from "./SimilarExperiences";
import Faqs from "./Faqs"; import Faqs from "./Faqs";
...@@ -11,6 +10,8 @@ import { getActivitiesByFilters } from "../../redux/actions/activityAction"; ...@@ -11,6 +10,8 @@ import { getActivitiesByFilters } from "../../redux/actions/activityAction";
import { useRouter } from "next/router"; import { useRouter } from "next/router";
import Image from "next/image"; import Image from "next/image";
import DetailSchedule from "./DetailSchedule"; import DetailSchedule from "./DetailSchedule";
import { Breadcrumb, ConfigProvider } from "antd";
import { RightOutlined } from "@ant-design/icons";
const Detail = () => { const Detail = () => {
const router = useRouter(); const router = useRouter();
...@@ -26,12 +27,46 @@ const Detail = () => { ...@@ -26,12 +27,46 @@ const Detail = () => {
// console.log("faqs=>", faqs); // console.log("faqs=>", faqs);
console.log("activityById", activityById); console.log("activityById", activityById);
console.log("loadedUser", loadedUser); // console.log("loadedUser", loadedUser);
return ( return (
<Fragment> <Fragment>
<main> <main>
<section className="main-mt"> <section className="main-mt">
<div className="container mt-5"> <div className="container mt-5">
<div className="py-5">
<ConfigProvider
theme={{
components: {
Breadcrumb: {
separatorMargin: 20,
fontWeight: 500,
fontSize: 16,
fontFamily: 'Sofia Pro',
}
}
}}
>
<Breadcrumb
separator={<RightOutlined />}
items={[
{
title: 'Home',
href: '/'
},
{
title: activityById?.data?.attributes?.vendor?.data?.attributes?.city,
},
{
title: activityById?.data?.attributes?.category?.data?.attributes?.name,
href: `/listing?category=${activityById?.data.attributes.category?.data?.id}`,
},
{
title: activityById?.data?.attributes?.name,
},
]}
/>
</ConfigProvider>
</div>
<div className="row hide-on-mobile"> <div className="row hide-on-mobile">
<div className="col-12"> <div className="col-12">
<div className="breadcrum$eq: categoryb-container"> <div className="breadcrum$eq: categoryb-container">
......
import Image from "next/image"; import Image from "next/image";
import React, { useEffect, useState } from "react"; import React, { useEffect, useState } from "react";
import { fadeIn, zoomIn, slideFromLeft, slideFromRight } from "../animationvariants.js"; import { zoomIn, slideFromRight } from "../animationvariants.js";
import { Button } from "react-bootstrap";
import { Swiper, SwiperSlide } from "swiper/react"; import { Swiper, SwiperSlide } from "swiper/react";
import { Navigation, Autoplay } from "swiper/modules"; import { Navigation, Autoplay } from "swiper/modules";
import { motion } from "framer-motion"; import { motion } from "framer-motion";
// Import Swiper styles // Import Swiper styles
...@@ -16,7 +13,7 @@ import { useRouter } from "next/router.js"; ...@@ -16,7 +13,7 @@ import { useRouter } from "next/router.js";
import { Loader } from "react-bootstrap-typeahead"; import { Loader } from "react-bootstrap-typeahead";
import { useDispatch, useSelector } from "react-redux"; import { useDispatch, useSelector } from "react-redux";
import { getSubCategoriesByCategoryId } from "../../redux/actions/categoriesAction.js"; import { getSubCategoriesByCategoryId } from "../../redux/actions/categoriesAction.js";
import { setActivityFilters } from "../../redux/actions/activityAction.js"; import { getActivitiesByFilters, setActivityFilters } from "../../redux/actions/activityAction.js";
import SubCategoryChips from "./SubCategoryChips.js"; import SubCategoryChips from "./SubCategoryChips.js";
const LetDiscover = ({ categories }) => { const LetDiscover = ({ categories }) => {
const { subCategories, loading } = useSelector(sate => sate.subCategories); const { subCategories, loading } = useSelector(sate => sate.subCategories);
...@@ -35,6 +32,7 @@ const LetDiscover = ({ categories }) => { ...@@ -35,6 +32,7 @@ const LetDiscover = ({ categories }) => {
return; // Do nothing if it's already active return; // Do nothing if it's already active
} }
// Toggle the active index if it's different from the clicked index // Toggle the active index if it's different from the clicked index
// console.log("activeIndex",activeIndex, index);
setActiveIndex(index); setActiveIndex(index);
// setloading(false); // setloading(false);
}; };
...@@ -44,12 +42,18 @@ const LetDiscover = ({ categories }) => { ...@@ -44,12 +42,18 @@ const LetDiscover = ({ categories }) => {
// }, [router]); // }, [router]);
useEffect(() => { useEffect(() => {
console.log("router.query.category", router.query.category); console.log("router.query.category", router.query.category);
console.log("getting id to filtered categoryiiiiiiiiiiifsdkhdjkskiiiiiiiiiiiiiiiiiiiiiiiii", parseInt(router.query.category))
if (router.query.category) { if (router.query.category) {
dispatch(setActivityFilters({ filters: { category: router.query.category, subCategories: [] } })); dispatch(setActivityFilters({ filters: { category: Number(router.query.category), subCategories: [] } }));
setActiveIndex(router.query.category); setActiveIndex((parseInt(router.query.category)));
dispatch(getSubCategoriesByCategoryId(router.query.category)); dispatch(getSubCategoriesByCategoryId(parseInt(router.query.category)));
dispatch(getActivitiesByFilters({ category: { id: { $eq: Number(router.query.category) } } }));
console.log("router >>",router.query.category);
setActiveIndex(Number(router.query.category))
} }
}, []); }, []);
const [showCloseIcon, setShowCloseIcon] = useState({}); const [showCloseIcon, setShowCloseIcon] = useState({});
const handleToggleCloseIcon = index => { const handleToggleCloseIcon = index => {
setShowCloseIcon(prevShowCloseIcon => ({ setShowCloseIcon(prevShowCloseIcon => ({
...@@ -124,7 +128,7 @@ const LetDiscover = ({ categories }) => { ...@@ -124,7 +128,7 @@ const LetDiscover = ({ categories }) => {
</SwiperSlide> </SwiperSlide>
{categories && {categories &&
categories.data.map((data, index) => { categories.data.map((data, index) => {
const isActive = activeIndex === index; const isActive = activeIndex === data.id;
return ( return (
<> <>
<SwiperSlide> <SwiperSlide>
...@@ -135,7 +139,7 @@ const LetDiscover = ({ categories }) => { ...@@ -135,7 +139,7 @@ const LetDiscover = ({ categories }) => {
// router.push(`?category=${data.id}`); // router.push(`?category=${data.id}`);
dispatch(setActivityFilters({ filters: { ...activityFilters, category: data.id, subCategories: [] } })); dispatch(setActivityFilters({ filters: { ...activityFilters, category: data.id, subCategories: [] } }));
dispatch(getSubCategoriesByCategoryId(data.id)); dispatch(getSubCategoriesByCategoryId(data.id));
handleTitleClick({ index, data }); handleTitleClick({ index: data.id, data });
}} }}
> >
<span className="image-container"> <span className="image-container">
......
...@@ -93,7 +93,7 @@ const ListingInner = ({ allActivitiesData, loading, totalCount }) => { ...@@ -93,7 +93,7 @@ const ListingInner = ({ allActivitiesData, loading, totalCount }) => {
if (activityFilters.priceUpperLimit) { if (activityFilters.priceUpperLimit) {
filters["priceUpperLimit"] = activityFilters.priceUpperLimit; filters["priceUpperLimit"] = activityFilters.priceUpperLimit;
} }
console.log("router >>", router.query.page); console.log("router query", filters.category);
dispatch( dispatch(
getActivitiesByFilters({ getActivitiesByFilters({
subCategory: filters.subCategory, subCategory: filters.subCategory,
...@@ -112,9 +112,9 @@ const ListingInner = ({ allActivitiesData, loading, totalCount }) => { ...@@ -112,9 +112,9 @@ const ListingInner = ({ allActivitiesData, loading, totalCount }) => {
}) })
); );
}, [activityFilters]); }, [activityFilters]);
useEffect(() => { // useEffect(() => {
dispatch(getActivitiesByFilters({ currentPage: router.query.page })); // dispatch(getActivitiesByFilters({ currentPage: router.query.page }));
}, []); // }, []);
return ( return (
<> <>
......
...@@ -22,10 +22,13 @@ export default function ListingPage() { ...@@ -22,10 +22,13 @@ export default function ListingPage() {
/** 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 }) => {
try { try {
console.log("query", query);
await store.dispatch(getActivitiesByFilters({ currentPage: query.page })); await store.dispatch(getActivitiesByFilters({ currentPage: query.page }));
await store.dispatch(getAllCategories()); await store.dispatch(getAllCategories());
await store.dispatch(getSubCategoriesByCategoryId()); await store.dispatch(getSubCategoriesByCategoryId());
// if (query.category) {
// await store.dispatch(getActivitiesByFilters({ currentPage: query.page, category: query.category }));
// }
return { return {
props: {} props: {}
// Next.js will attempt to re-generate the page: // Next.js will attempt to re-generate the page:
......
...@@ -356,7 +356,7 @@ export const getActivitiesForEndUser = () => async dispatch => { ...@@ -356,7 +356,7 @@ export const getActivitiesForEndUser = () => async dispatch => {
// }; // };
const response = await axios.get(`${process.env.NEXT_PUBLIC_BACKEND_API_URL}/api/experiences?${queryString}`, config); const response = await axios.get(`${process.env.NEXT_PUBLIC_BACKEND_API_URL}/api/experiences?${queryString}`, config);
// console.log("Response", response.data); // console.log("router query 2", response.data);
dispatch({ dispatch({
type: GET_ACTIVITIES_SUCCESS, type: GET_ACTIVITIES_SUCCESS,
payload: response.data payload: response.data
...@@ -491,9 +491,9 @@ export const getActivitiesByFilters = ...@@ -491,9 +491,9 @@ export const getActivitiesByFilters =
const queryString = qs.stringify(query, { const queryString = qs.stringify(query, {
encodeValuesOnly: true encodeValuesOnly: true
}); });
console.log("router query 1", query);
const response = await axios.get(`${process.env.NEXT_PUBLIC_BACKEND_API_URL}/api/experiences?${queryString}`, config); const response = await axios.get(`${process.env.NEXT_PUBLIC_BACKEND_API_URL}/api/experiences?${queryString}`, config);
// console.log("activity res", response); console.log("router query 2", response);
dispatch({ dispatch({
type: GET_ACTIVITIES_SUCCESS, type: GET_ACTIVITIES_SUCCESS,
payload: response.data payload: response.data
......
Styling with Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!