feat(ui):增加产品伴随选择。

This commit is contained in:
徐涛 2024-04-07 17:33:45 +08:00
parent 2af30101cc
commit 6d97d437a2

View File

@ -1,9 +1,10 @@
import { concat, pluck, uniq } from "ramda"; import { concat, find, pluck, propEq, uniq } from "ramda";
import { create } from "zustand"; import { create } from "zustand";
interface Product { interface Product {
id: string; id: string;
name: string; name: string;
couple: string[];
} }
interface ProductsStore { interface ProductsStore {
@ -18,8 +19,12 @@ interface ProductsStore {
export const useProductsStore = create<ProductsStore>((set, get) => ({ export const useProductsStore = create<ProductsStore>((set, get) => ({
products: [], products: [],
selectedProducts: [], selectedProducts: [],
append: (code: string) => append: (code: string) => {
set((state) => ({ selectedProducts: [...state.selectedProducts, code] })), const selectedProduct: Product | undefined = find(propEq(code, "id"), get().products);
set((state) => ({
selectedProducts: uniq([...state.selectedProducts, code, ...(selectedProduct.couple ?? [])]),
}));
},
remove: (code: string) => remove: (code: string) =>
set((state) => ({ selectedProducts: state.selectedProducts.filter((item) => item !== code) })), set((state) => ({ selectedProducts: state.selectedProducts.filter((item) => item !== code) })),
unselectAll: () => set({ selectedProducts: [] }), unselectAll: () => set({ selectedProducts: [] }),