adminFront/src/stores/discounts.ts

55 lines
1.7 KiB
TypeScript
Raw Normal View History

2023-03-06 13:22:12 +00:00
import { GridSelectionModel } from "@mui/x-data-grid";
import { AnyDiscount } from "@root/model/cart";
import { create } from "zustand";
2023-05-18 20:31:36 +00:00
import { devtools } from "zustand/middleware";
2023-03-06 13:22:12 +00:00
import { exampleCartValues } from "./mocks/exampleCartValues";
2023-02-18 13:59:36 +00:00
interface DiscountStore {
2023-03-06 13:22:12 +00:00
discounts: AnyDiscount[];
selectedDiscountIds: GridSelectionModel,
2023-02-18 13:59:36 +00:00
}
export const useDiscountStore = create<DiscountStore>()(
devtools(
2023-05-18 20:31:36 +00:00
(set, get) => ({
discounts: exampleCartValues.discounts,
selectedDiscountIds: [],
}),
2023-02-18 13:59:36 +00:00
{
name: "Discount store"
}
)
2023-05-18 20:31:36 +00:00
);
export const addDiscounts = (newDiscounts: AnyDiscount[]) => useDiscountStore.setState(state => ({ discounts: [...state.discounts, ...newDiscounts] }));
export const setSelectedDiscountIds = (selectedDiscountIds: DiscountStore["selectedDiscountIds"]) => useDiscountStore.setState({ selectedDiscountIds });
export const activateDiscounts = () => useDiscountStore.setState(state => {
const discounts: AnyDiscount[] = [];
state.discounts.forEach(discount => {
if (!state.selectedDiscountIds.includes(discount._id)) return discounts.push(discount);
discounts.push({
...discount,
disabled: false,
});
});
return { discounts };
});
export const deactivateDiscounts = () => useDiscountStore.setState(state => {
const discounts: AnyDiscount[] = [];
state.discounts.forEach(discount => {
if (!state.selectedDiscountIds.includes(discount._id)) return discounts.push(discount);
discounts.push({
...discount,
disabled: true,
});
});
return { discounts };
});