Добавлены модели и функциональность для работы с избранными товарами, включая мутации и запросы в GraphQL. Обновлены компоненты для отображения и управления избранным, улучшен интерфейс взаимодействия с пользователем. Реализована логика добавления и удаления товаров из избранного.
This commit is contained in:
@ -12,9 +12,10 @@ import { MarketWholesale } from './market-wholesale'
|
||||
import { MarketProducts } from './market-products'
|
||||
import { MarketCategories } from './market-categories'
|
||||
import { MarketRequests } from './market-requests'
|
||||
import { FavoritesDashboard } from '../favorites/favorites-dashboard'
|
||||
|
||||
export function MarketDashboard() {
|
||||
const [productsView, setProductsView] = useState<'categories' | 'products' | 'cart'>('categories')
|
||||
const [productsView, setProductsView] = useState<'categories' | 'products' | 'cart' | 'favorites'>('categories')
|
||||
const [selectedCategory, setSelectedCategory] = useState<{ id: string; name: string } | null>(null)
|
||||
|
||||
const handleSelectCategory = (categoryId: string, categoryName: string) => {
|
||||
@ -32,6 +33,11 @@ export function MarketDashboard() {
|
||||
setSelectedCategory(null)
|
||||
}
|
||||
|
||||
const handleShowFavorites = () => {
|
||||
setProductsView('favorites')
|
||||
setSelectedCategory(null)
|
||||
}
|
||||
|
||||
return (
|
||||
<div className="h-screen bg-gradient-smooth flex overflow-hidden">
|
||||
<Sidebar />
|
||||
@ -122,15 +128,17 @@ export function MarketDashboard() {
|
||||
<TabsContent value="products" className="flex-1 overflow-hidden mt-6">
|
||||
<Card className="glass-card h-full overflow-hidden p-0">
|
||||
{productsView === 'categories' ? (
|
||||
<MarketCategories onSelectCategory={handleSelectCategory} onShowCart={handleShowCart} />
|
||||
<MarketCategories onSelectCategory={handleSelectCategory} onShowCart={handleShowCart} onShowFavorites={handleShowFavorites} />
|
||||
) : productsView === 'products' ? (
|
||||
<MarketProducts
|
||||
selectedCategoryId={selectedCategory?.id}
|
||||
selectedCategoryName={selectedCategory?.name}
|
||||
onBackToCategories={handleBackToCategories}
|
||||
/>
|
||||
) : productsView === 'cart' ? (
|
||||
<MarketRequests onBackToCategories={handleBackToCategories} />
|
||||
) : (
|
||||
<MarketRequests />
|
||||
<FavoritesDashboard onBackToCategories={handleBackToCategories} />
|
||||
)}
|
||||
</Card>
|
||||
</TabsContent>
|
||||
|
Reference in New Issue
Block a user