feat(ui):增加产品伴随选择。
This commit is contained in:
parent
2af30101cc
commit
6d97d437a2
|
@ -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: [] }),
|
||||||
|
|
Loading…
Reference in New Issue
Block a user