get products by filter connected
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
"use client";
|
"use client";
|
||||||
|
import { result } from "@/lib/demoData";
|
||||||
import { useFilter } from "@/lib/filter-zustand";
|
import { useFilter } from "@/lib/filter-zustand";
|
||||||
import httpClient from "@/request/api";
|
import httpClient from "@/request/api";
|
||||||
import { endPoints } from "@/request/links";
|
import { endPoints } from "@/request/links";
|
||||||
@@ -18,125 +19,43 @@ export default function Filter() {
|
|||||||
const [dataExpanded, setDataExpanded] = useState<boolean>(false);
|
const [dataExpanded, setDataExpanded] = useState<boolean>(false);
|
||||||
const [numberExpanded, setNumberExpanded] = useState<boolean>(false);
|
const [numberExpanded, setNumberExpanded] = useState<boolean>(false);
|
||||||
|
|
||||||
const sectionData = [
|
const [catalogData, setCatalogData] = useState<
|
||||||
"SLT-Aqua",
|
{ id: number; name: string; type: string }[]
|
||||||
"Вварное седло",
|
>(result[0].items);
|
||||||
"Кран шаровый",
|
const [sizeData, setSizeData] = useState<
|
||||||
"Муфты",
|
{ id: number; name: string; type: string }[]
|
||||||
"Муфты комбинированные",
|
>(result[1].items);
|
||||||
"Муфты переходные",
|
|
||||||
"Тройник комбинированный",
|
|
||||||
"Тройники",
|
|
||||||
"Трубы SDR 6",
|
|
||||||
"Трубы SDR 7,4",
|
|
||||||
"Угол 45",
|
|
||||||
"Угол 90",
|
|
||||||
"Угольник комбинированный",
|
|
||||||
"Фланцы+бурты",
|
|
||||||
];
|
|
||||||
|
|
||||||
const sectionNumber = [
|
|
||||||
"25",
|
|
||||||
'25х1/2"',
|
|
||||||
'25х3/4"',
|
|
||||||
"32",
|
|
||||||
"32x25x25",
|
|
||||||
"32x25x32",
|
|
||||||
'32х1"',
|
|
||||||
'32х1/2"',
|
|
||||||
"32х25",
|
|
||||||
'32х3/4"',
|
|
||||||
"40",
|
|
||||||
"40x25x40",
|
|
||||||
"40x32x40",
|
|
||||||
'40х1 1/4"',
|
|
||||||
'40х1 3/4"',
|
|
||||||
'40х1/2"',
|
|
||||||
"40х25",
|
|
||||||
"40х32",
|
|
||||||
"50",
|
|
||||||
"50x25x50",
|
|
||||||
"50x32x50",
|
|
||||||
"50x40x50",
|
|
||||||
'50х1 1/2"',
|
|
||||||
'50х1/2"',
|
|
||||||
"50х25",
|
|
||||||
"50х32",
|
|
||||||
"50х40",
|
|
||||||
"63",
|
|
||||||
"63x25x63",
|
|
||||||
"63x32x63",
|
|
||||||
"63x40x63",
|
|
||||||
"63x50x63",
|
|
||||||
'63х1/2"',
|
|
||||||
'63х2"',
|
|
||||||
"63х25",
|
|
||||||
"63х32",
|
|
||||||
"63х40",
|
|
||||||
"63х50",
|
|
||||||
"75",
|
|
||||||
"75x25x75",
|
|
||||||
"75x32x75",
|
|
||||||
"75x40x75",
|
|
||||||
"75x50x75",
|
|
||||||
"75x63x75",
|
|
||||||
'75х1/2"',
|
|
||||||
"75х32",
|
|
||||||
"75х40",
|
|
||||||
"75х50",
|
|
||||||
"75х63",
|
|
||||||
"90",
|
|
||||||
"90x40x90",
|
|
||||||
"90x50x90",
|
|
||||||
"90x63x90",
|
|
||||||
"90x75x90",
|
|
||||||
'90х1/2"',
|
|
||||||
"90х32",
|
|
||||||
"90х40",
|
|
||||||
"90х50",
|
|
||||||
"90х63",
|
|
||||||
"90х75",
|
|
||||||
"110",
|
|
||||||
"110x50x110",
|
|
||||||
"110x63x110",
|
|
||||||
"110x75x110",
|
|
||||||
"110x90x110",
|
|
||||||
'110х1/2"',
|
|
||||||
"110х25",
|
|
||||||
"110х32",
|
|
||||||
"110х40",
|
|
||||||
"110х50",
|
|
||||||
"110х63",
|
|
||||||
"110х75",
|
|
||||||
"110х90",
|
|
||||||
"125",
|
|
||||||
"160",
|
|
||||||
];
|
|
||||||
|
|
||||||
const [catalogData, setCatalogData] = useState<string[]>(sectionData);
|
|
||||||
const [sizeData, setSizeData] = useState<string[]>(sectionNumber);
|
|
||||||
|
|
||||||
const { data: catalog } = useQuery({
|
const { data: catalog } = useQuery({
|
||||||
queryKey: ["catalog"],
|
queryKey: ["catalog"],
|
||||||
queryFn: () => httpClient(endPoints.filter.catalogPageItems),
|
queryFn: () => httpClient(endPoints.filter.catalogCategoryId(category.id)),
|
||||||
select: (data) => {
|
select: (data) => {
|
||||||
const catalog = data?.data?.results;
|
const catalogData = data?.data?.results;
|
||||||
return catalog.map((item: any) => item.name) || [];
|
return catalogData.map((item: any) => ({
|
||||||
|
id: item.id,
|
||||||
|
name: item.name,
|
||||||
|
type: "catalog",
|
||||||
|
}));
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const { data: size } = useQuery({
|
const { data: size } = useQuery({
|
||||||
queryKey: ["size"],
|
queryKey: ["size"],
|
||||||
queryFn: () => httpClient(endPoints.filter.sizePageItems),
|
queryFn: () => httpClient(endPoints.filter.sizeCategoryId(category.id)),
|
||||||
select: (data) => {
|
select: (data) => {
|
||||||
const size = data?.data?.results;
|
const sizedata = data?.data?.results;
|
||||||
return size.map((item: any) => item.name) || [];
|
return sizedata.map((item: any) => ({
|
||||||
|
id: item.id,
|
||||||
|
name: item.name,
|
||||||
|
type: "size",
|
||||||
|
}));
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
catalog && setCatalogData(catalog);
|
catalog && setCatalogData(catalog);
|
||||||
size && setSizeData(size);
|
size && setSizeData(size);
|
||||||
|
console.log("catalog: ", catalog, "size: ", size);
|
||||||
}, [size, catalog]);
|
}, [size, catalog]);
|
||||||
|
|
||||||
// Bo'lim uchun ko'rsatiladigan itemlar
|
// Bo'lim uchun ko'rsatiladigan itemlar
|
||||||
@@ -150,9 +69,10 @@ export default function Filter() {
|
|||||||
: sizeData.slice(0, 10);
|
: sizeData.slice(0, 10);
|
||||||
|
|
||||||
console.log("have suncategory: ", category.have_sub_category);
|
console.log("have suncategory: ", category.have_sub_category);
|
||||||
if (category.have_sub_category || subCategory.id!==0) {
|
if (category.have_sub_category || subCategory.id !== 0) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
console.log("filter: ",filter);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="space-y-3 max-w-70 w-full text-white">
|
<div className="space-y-3 max-w-70 w-full text-white">
|
||||||
@@ -164,23 +84,23 @@ export default function Filter() {
|
|||||||
<div className="space-y-3 p-2">
|
<div className="space-y-3 p-2">
|
||||||
{visibleSectionData.map((item) => (
|
{visibleSectionData.map((item) => (
|
||||||
<div
|
<div
|
||||||
key={item}
|
key={item.id}
|
||||||
onClick={() => toggleFilter(item)}
|
onClick={() => toggleFilter(item)}
|
||||||
className="hover:cursor-pointer flex items-center gap-2"
|
className="hover:cursor-pointer flex items-center gap-2"
|
||||||
>
|
>
|
||||||
<span
|
<span
|
||||||
className={`flex h-5 w-5 items-center justify-center rounded border-2 transition ${
|
className={`flex h-5 w-5 items-center justify-center rounded border-2 transition ${
|
||||||
hasData(item)
|
hasData(item.name)
|
||||||
? "border-red-600 bg-red-600"
|
? "border-red-600 bg-red-600"
|
||||||
: "border-gray-400 bg-transparent"
|
: "border-gray-400 bg-transparent"
|
||||||
}`}
|
}`}
|
||||||
aria-label="Filter checkbox"
|
aria-label="Filter checkbox"
|
||||||
>
|
>
|
||||||
{hasData(item) && (
|
{hasData(item.name) && (
|
||||||
<Check className="h-3 w-3 text-white" strokeWidth={3} />
|
<Check className="h-3 w-3 text-white" strokeWidth={3} />
|
||||||
)}
|
)}
|
||||||
</span>
|
</span>
|
||||||
<p>{item}</p>
|
<p>{item.name}</p>
|
||||||
</div>
|
</div>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
@@ -200,23 +120,23 @@ export default function Filter() {
|
|||||||
<div className="grid grid-cols-2 gap-3 p-2">
|
<div className="grid grid-cols-2 gap-3 p-2">
|
||||||
{visibleSectionNumber.map((item) => (
|
{visibleSectionNumber.map((item) => (
|
||||||
<div
|
<div
|
||||||
key={item}
|
key={item.id}
|
||||||
onClick={() => toggleFilter(item)}
|
onClick={() => toggleFilter(item)}
|
||||||
className="hover:cursor-pointer flex items-center gap-2"
|
className="hover:cursor-pointer flex items-center gap-2"
|
||||||
>
|
>
|
||||||
<span
|
<span
|
||||||
className={`flex h-5 w-5 items-center justify-center rounded border-2 transition ${
|
className={`flex h-5 w-5 items-center justify-center rounded border-2 transition ${
|
||||||
hasData(item)
|
hasData(item.name)
|
||||||
? "border-red-600 bg-red-600"
|
? "border-red-600 bg-red-600"
|
||||||
: "border-gray-400 bg-transparent"
|
: "border-gray-400 bg-transparent"
|
||||||
}`}
|
}`}
|
||||||
aria-label="Filter checkbox"
|
aria-label="Filter checkbox"
|
||||||
>
|
>
|
||||||
{hasData(item) && (
|
{hasData(item.name) && (
|
||||||
<Check className="h-3 w-3 text-white" strokeWidth={3} />
|
<Check className="h-3 w-3 text-white" strokeWidth={3} />
|
||||||
)}
|
)}
|
||||||
</span>
|
</span>
|
||||||
<p>{item}</p>
|
<p>{item.name}</p>
|
||||||
</div>
|
</div>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -17,13 +17,13 @@ export default function FilterInfo() {
|
|||||||
{filtered &&
|
{filtered &&
|
||||||
filtered.map((item) => (
|
filtered.map((item) => (
|
||||||
<div
|
<div
|
||||||
key={item}
|
key={item.id}
|
||||||
className="flex items-center gap-1 p-1 rounded-lg bg-gray-700 text-white text-sm "
|
className="flex items-center gap-1 p-1 rounded-lg bg-gray-700 text-white text-sm "
|
||||||
>
|
>
|
||||||
<button onClick={() => togleFilter(item)}>
|
<button onClick={() => togleFilter(item)}>
|
||||||
<X size={16} />
|
<X size={16} />
|
||||||
</button>
|
</button>
|
||||||
{item}
|
{item.name}
|
||||||
</div>
|
</div>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -4,16 +4,41 @@ import { endPoints } from "@/request/links";
|
|||||||
import { useQuery } from "@tanstack/react-query";
|
import { useQuery } from "@tanstack/react-query";
|
||||||
import ProductCard from "./productCard";
|
import ProductCard from "./productCard";
|
||||||
import { useCategory } from "@/store/useCategory";
|
import { useCategory } from "@/store/useCategory";
|
||||||
|
import { useFilter } from "@/lib/filter-zustand";
|
||||||
|
import { useMemo } from "react";
|
||||||
|
|
||||||
export default function MainProduct() {
|
export default function MainProduct() {
|
||||||
const category = useCategory((state) => state.category);
|
const category = useCategory((state) => state.category);
|
||||||
|
const filter = useFilter((state) => state.filter);
|
||||||
|
const getFiltersByType = useFilter((state)=>state.getFiltersByType)
|
||||||
|
|
||||||
const requestLink = category.have_sub_category
|
// Query params yaratish
|
||||||
|
const queryParams = useMemo(() => {
|
||||||
|
const catalog = getFiltersByType("catalog");
|
||||||
|
const size = getFiltersByType("size");
|
||||||
|
|
||||||
|
// Har bir filter uchun query string yaratish
|
||||||
|
const catalogParams = catalog.map((item) => `catalog=${item.id}`).join("&");
|
||||||
|
const sizeParams = size.map((item) => `size=${item.id}`).join("&");
|
||||||
|
|
||||||
|
// Barcha paramslarni birlashtirish
|
||||||
|
const allParams = [catalogParams, sizeParams].filter(Boolean).join("&");
|
||||||
|
|
||||||
|
return allParams ? `&${allParams}` : "";
|
||||||
|
}, [filter, getFiltersByType]);
|
||||||
|
|
||||||
|
// Request link yaratish
|
||||||
|
const requestLink = useMemo(() => {
|
||||||
|
const baseLink = category.have_sub_category
|
||||||
? endPoints.subCategory.byId(category.id)
|
? endPoints.subCategory.byId(category.id)
|
||||||
: endPoints.product.byCategory(category.id || 0);
|
: endPoints.product.byCategory(category.id || 0);
|
||||||
|
|
||||||
|
// Query params qo'shish
|
||||||
|
return `${baseLink}${queryParams}`;
|
||||||
|
}, [category.id, category.have_sub_category, queryParams]);
|
||||||
|
|
||||||
const { data, isLoading, error } = useQuery({
|
const { data, isLoading, error } = useQuery({
|
||||||
queryKey: ["products", category.id],
|
queryKey: ["products", category.id , queryParams],
|
||||||
queryFn: () => httpClient(requestLink),
|
queryFn: () => httpClient(requestLink),
|
||||||
select: (data) => data?.data?.data?.results,
|
select: (data) => data?.data?.data?.results,
|
||||||
});
|
});
|
||||||
|
|||||||
114
lib/demoData.ts
114
lib/demoData.ts
@@ -124,3 +124,117 @@ export const lede = [
|
|||||||
image: "/images/products/lede/troynik_perexadnoy-removebg-preview.png",
|
image: "/images/products/lede/troynik_perexadnoy-removebg-preview.png",
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
|
const sectionData = [
|
||||||
|
"SLT-Aqua",
|
||||||
|
"Вварное седло",
|
||||||
|
"Кран шаровый",
|
||||||
|
"Муфты",
|
||||||
|
"Муфты комбинированные",
|
||||||
|
"Муфты переходные",
|
||||||
|
"Тройник комбинированный",
|
||||||
|
"Тройники",
|
||||||
|
"Трубы SDR 6",
|
||||||
|
"Трубы SDR 7,4",
|
||||||
|
"Угол 45",
|
||||||
|
"Угол 90",
|
||||||
|
"Угольник комбинированный",
|
||||||
|
"Фланцы+бурты",
|
||||||
|
];
|
||||||
|
|
||||||
|
const sectionNumber = [
|
||||||
|
"25",
|
||||||
|
'25х1/2"',
|
||||||
|
'25х3/4"',
|
||||||
|
"32",
|
||||||
|
"32x25x25",
|
||||||
|
"32x25x32",
|
||||||
|
'32х1"',
|
||||||
|
'32х1/2"',
|
||||||
|
"32х25",
|
||||||
|
'32х3/4"',
|
||||||
|
"40",
|
||||||
|
"40x25x40",
|
||||||
|
"40x32x40",
|
||||||
|
'40х1 1/4"',
|
||||||
|
'40х1 3/4"',
|
||||||
|
'40х1/2"',
|
||||||
|
"40х25",
|
||||||
|
"40х32",
|
||||||
|
"50",
|
||||||
|
"50x25x50",
|
||||||
|
"50x32x50",
|
||||||
|
"50x40x50",
|
||||||
|
'50х1 1/2"',
|
||||||
|
'50х1/2"',
|
||||||
|
"50х25",
|
||||||
|
"50х32",
|
||||||
|
"50х40",
|
||||||
|
"63",
|
||||||
|
"63x25x63",
|
||||||
|
"63x32x63",
|
||||||
|
"63x40x63",
|
||||||
|
"63x50x63",
|
||||||
|
'63х1/2"',
|
||||||
|
'63х2"',
|
||||||
|
"63х25",
|
||||||
|
"63х32",
|
||||||
|
"63х40",
|
||||||
|
"63х50",
|
||||||
|
"75",
|
||||||
|
"75x25x75",
|
||||||
|
"75x32x75",
|
||||||
|
"75x40x75",
|
||||||
|
"75x50x75",
|
||||||
|
"75x63x75",
|
||||||
|
'75х1/2"',
|
||||||
|
"75х32",
|
||||||
|
"75х40",
|
||||||
|
"75х50",
|
||||||
|
"75х63",
|
||||||
|
"90",
|
||||||
|
"90x40x90",
|
||||||
|
"90x50x90",
|
||||||
|
"90x63x90",
|
||||||
|
"90x75x90",
|
||||||
|
'90х1/2"',
|
||||||
|
"90х32",
|
||||||
|
"90х40",
|
||||||
|
"90х50",
|
||||||
|
"90х63",
|
||||||
|
"90х75",
|
||||||
|
"110",
|
||||||
|
"110x50x110",
|
||||||
|
"110x63x110",
|
||||||
|
"110x75x110",
|
||||||
|
"110x90x110",
|
||||||
|
'110х1/2"',
|
||||||
|
"110х25",
|
||||||
|
"110х32",
|
||||||
|
"110х40",
|
||||||
|
"110х50",
|
||||||
|
"110х63",
|
||||||
|
"110х75",
|
||||||
|
"110х90",
|
||||||
|
"125",
|
||||||
|
"160",
|
||||||
|
];
|
||||||
|
|
||||||
|
export const result = [
|
||||||
|
{
|
||||||
|
type: "section",
|
||||||
|
items: sectionData.map((name, index) => ({
|
||||||
|
id: index + 1,
|
||||||
|
name,
|
||||||
|
type: "catalog",
|
||||||
|
})),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: "size",
|
||||||
|
items: sectionNumber.map((name, index) => ({
|
||||||
|
id: index + 1,
|
||||||
|
name,
|
||||||
|
type: "size",
|
||||||
|
})),
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|||||||
@@ -1,33 +1,68 @@
|
|||||||
import { create } from "zustand";
|
import { create } from "zustand";
|
||||||
|
import { persist } from "zustand/middleware";
|
||||||
|
import { immer } from "zustand/middleware/immer";
|
||||||
|
|
||||||
interface FilterZustandTypes {
|
export interface FilterItem {
|
||||||
filter: string[];
|
id: number;
|
||||||
removeFilter: (data: string) => void;
|
name: string;
|
||||||
toggleFilter: (data: string) => void;
|
type: string;
|
||||||
resetFilter: () => void;
|
|
||||||
hasFilter: (data: string) => boolean;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export const useFilter = create<FilterZustandTypes>((set, get) => ({
|
interface FilterZustandTypes {
|
||||||
|
filter: FilterItem[];
|
||||||
|
removeFilter: (id: number) => void;
|
||||||
|
toggleFilter: (item: FilterItem) => void;
|
||||||
|
resetFilter: () => void;
|
||||||
|
hasFilter: (name: string) => boolean;
|
||||||
|
getFiltersByType: (type: string) => FilterItem[]; // ✅ Qo'shimcha
|
||||||
|
removeFiltersByType: (type: string) => void; // ✅ Qo'shimcha
|
||||||
|
}
|
||||||
|
|
||||||
|
export const useFilter = create<FilterZustandTypes>()(
|
||||||
|
persist(
|
||||||
|
immer((set, get) => ({
|
||||||
filter: [],
|
filter: [],
|
||||||
|
|
||||||
removeFilter: (data) =>
|
removeFilter: (id) =>
|
||||||
set((state) => ({
|
|
||||||
filter: state.filter.filter((item) => item !== data),
|
|
||||||
})),
|
|
||||||
|
|
||||||
// Toggle: mavjud bo'lsa o'chirish, yo'q bo'lsa qo'shish
|
|
||||||
toggleFilter: (data) =>
|
|
||||||
set((state) => {
|
set((state) => {
|
||||||
if (state.filter.includes(data)) {
|
state.filter = state.filter.filter((item:FilterItem) => item.id !== id);
|
||||||
return { filter: state.filter.filter((item) => item !== data) };
|
|
||||||
}
|
|
||||||
return { filter: [...state.filter, data] };
|
|
||||||
}),
|
}),
|
||||||
|
|
||||||
resetFilter: () => set({ filter: [] }),
|
toggleFilter: (item) =>
|
||||||
|
set((state) => {
|
||||||
|
const index = state.filter.findIndex((f:FilterItem) => f.name === item.name);
|
||||||
|
if (index !== -1) {
|
||||||
|
// Agar bor bo'lsa o'chirish
|
||||||
|
state.filter.splice(index, 1);
|
||||||
|
} else {
|
||||||
|
// Agar yo'q bo'lsa qo'shish
|
||||||
|
state.filter.push(item);
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
|
||||||
hasFilter: (data) => {
|
resetFilter: () =>
|
||||||
return get().filter.includes(data);
|
set((state) => {
|
||||||
|
state.filter = [];
|
||||||
|
}),
|
||||||
|
|
||||||
|
hasFilter: (name) => {
|
||||||
|
return get().filter.some((item) => item.name === name);
|
||||||
},
|
},
|
||||||
}));
|
|
||||||
|
// ✅ Type bo'yicha filterlarni olish
|
||||||
|
getFiltersByType: (type) => {
|
||||||
|
return get().filter.filter((item) => item.type === type);
|
||||||
|
},
|
||||||
|
|
||||||
|
// ✅ Type bo'yicha filterlarni o'chirish
|
||||||
|
removeFiltersByType: (type) =>
|
||||||
|
set((state) => {
|
||||||
|
state.filter = state.filter.filter((item:FilterItem) => item.type !== type);
|
||||||
|
}),
|
||||||
|
})),
|
||||||
|
{
|
||||||
|
name: "filter-storage", // localStorage key nomi
|
||||||
|
partialize: (state) => ({ filter: state.filter }), // Faqat filter'ni saqlash
|
||||||
|
}
|
||||||
|
)
|
||||||
|
);
|
||||||
@@ -48,6 +48,7 @@
|
|||||||
"date-fns": "4.1.0",
|
"date-fns": "4.1.0",
|
||||||
"embla-carousel-react": "8.5.1",
|
"embla-carousel-react": "8.5.1",
|
||||||
"framer-motion": "^12.29.2",
|
"framer-motion": "^12.29.2",
|
||||||
|
"immer": "^11.1.3",
|
||||||
"input-otp": "1.4.1",
|
"input-otp": "1.4.1",
|
||||||
"lucide-react": "^0.454.0",
|
"lucide-react": "^0.454.0",
|
||||||
"negotiator": "^1.0.0",
|
"negotiator": "^1.0.0",
|
||||||
|
|||||||
13
pnpm-lock.yaml
generated
13
pnpm-lock.yaml
generated
@@ -125,6 +125,9 @@ importers:
|
|||||||
framer-motion:
|
framer-motion:
|
||||||
specifier: ^12.29.2
|
specifier: ^12.29.2
|
||||||
version: 12.29.2(react-dom@19.2.0(react@19.2.0))(react@19.2.0)
|
version: 12.29.2(react-dom@19.2.0(react@19.2.0))(react@19.2.0)
|
||||||
|
immer:
|
||||||
|
specifier: ^11.1.3
|
||||||
|
version: 11.1.3
|
||||||
input-otp:
|
input-otp:
|
||||||
specifier: 1.4.1
|
specifier: 1.4.1
|
||||||
version: 1.4.1(react-dom@19.2.0(react@19.2.0))(react@19.2.0)
|
version: 1.4.1(react-dom@19.2.0(react@19.2.0))(react@19.2.0)
|
||||||
@@ -187,7 +190,7 @@ importers:
|
|||||||
version: 3.25.76
|
version: 3.25.76
|
||||||
zustand:
|
zustand:
|
||||||
specifier: ^5.0.10
|
specifier: ^5.0.10
|
||||||
version: 5.0.10(@types/react@19.2.9)(react@19.2.0)(use-sync-external-store@1.6.0(react@19.2.0))
|
version: 5.0.10(@types/react@19.2.9)(immer@11.1.3)(react@19.2.0)(use-sync-external-store@1.6.0(react@19.2.0))
|
||||||
devDependencies:
|
devDependencies:
|
||||||
'@tailwindcss/postcss':
|
'@tailwindcss/postcss':
|
||||||
specifier: ^4.1.9
|
specifier: ^4.1.9
|
||||||
@@ -1689,6 +1692,9 @@ packages:
|
|||||||
resolution: {integrity: sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==}
|
resolution: {integrity: sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==}
|
||||||
engines: {node: '>= 0.4'}
|
engines: {node: '>= 0.4'}
|
||||||
|
|
||||||
|
immer@11.1.3:
|
||||||
|
resolution: {integrity: sha512-6jQTc5z0KJFtr1UgFpIL3N9XSC3saRaI9PwWtzM2pSqkNGtiNkYY2OSwkOGDK2XcTRcLb1pi/aNkKZz0nxVH4Q==}
|
||||||
|
|
||||||
input-otp@1.4.1:
|
input-otp@1.4.1:
|
||||||
resolution: {integrity: sha512-+yvpmKYKHi9jIGngxagY9oWiiblPB7+nEO75F2l2o4vs+6vpPZZmUl4tBNYuTCvQjhvEIbdNeJu70bhfYP2nbw==}
|
resolution: {integrity: sha512-+yvpmKYKHi9jIGngxagY9oWiiblPB7+nEO75F2l2o4vs+6vpPZZmUl4tBNYuTCvQjhvEIbdNeJu70bhfYP2nbw==}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
@@ -3515,6 +3521,8 @@ snapshots:
|
|||||||
dependencies:
|
dependencies:
|
||||||
function-bind: 1.1.2
|
function-bind: 1.1.2
|
||||||
|
|
||||||
|
immer@11.1.3: {}
|
||||||
|
|
||||||
input-otp@1.4.1(react-dom@19.2.0(react@19.2.0))(react@19.2.0):
|
input-otp@1.4.1(react-dom@19.2.0(react@19.2.0))(react@19.2.0):
|
||||||
dependencies:
|
dependencies:
|
||||||
react: 19.2.0
|
react: 19.2.0
|
||||||
@@ -3932,8 +3940,9 @@ snapshots:
|
|||||||
|
|
||||||
zod@3.25.76: {}
|
zod@3.25.76: {}
|
||||||
|
|
||||||
zustand@5.0.10(@types/react@19.2.9)(react@19.2.0)(use-sync-external-store@1.6.0(react@19.2.0)):
|
zustand@5.0.10(@types/react@19.2.9)(immer@11.1.3)(react@19.2.0)(use-sync-external-store@1.6.0(react@19.2.0)):
|
||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
'@types/react': 19.2.9
|
'@types/react': 19.2.9
|
||||||
|
immer: 11.1.3
|
||||||
react: 19.2.0
|
react: 19.2.0
|
||||||
use-sync-external-store: 1.6.0(react@19.2.0)
|
use-sync-external-store: 1.6.0(react@19.2.0)
|
||||||
|
|||||||
@@ -18,8 +18,10 @@ export const endPoints = {
|
|||||||
filter: {
|
filter: {
|
||||||
size: "size/",
|
size: "size/",
|
||||||
sizePageItems: "size/?page_size=500",
|
sizePageItems: "size/?page_size=500",
|
||||||
|
sizeCategoryId:(id:number)=>`size/?category=${id}&page_size=500`,
|
||||||
catalog: "catalog/",
|
catalog: "catalog/",
|
||||||
catalogPageItems: "catalog/?page_size=500",
|
catalogPageItems: "catalog/?page_size=500",
|
||||||
|
catalogCategoryId:(id:number)=>`catalog/?category=${id}&page_size=500`,
|
||||||
},
|
},
|
||||||
post: {
|
post: {
|
||||||
sendNumber: "callBack/",
|
sendNumber: "callBack/",
|
||||||
|
|||||||
Reference in New Issue
Block a user