
* Add gift cards section to menu and add empty list component * Update messages * Change styling of app wide page header to match design * Add gift cards list table wip * Update prop name for status chip component to make it more consistent with other components * Replace old trash icon with new one * Add Size type based on action dialog sizes to be used app wide * Add delete icon button * Add new sizes option to status chip component * Add / update gift cards list components * Add bulk actions type * Work on gift cards list WIP * Small refactor * Fix styling of gift cards table * Remove temp files * Remove unnecessary type * Add gift cards section to menu and add empty list component * Update schema and types * Add link to gift card update page to gift cards list and add route to gift cards index * Extract order page title with status chip into a separate generic component and use it in order page title * wip * Update money component * Add gift card details card balance section * Refactor gift card details * Add vertical spacer component * Update schema and types * Add gift card tag input component along with necessary queries * Add gift card tag input to gift card update page * Add gift card update details card expiry section WIP * Add time period select field WIP * Post rebase refactor * Add time period select field to gift card update view * Fixes after review * Update schema, types and gift cards query * Add getFullName util function and replace existing manual usages * Add text with select field component * Add gift card update info card and refactor * Fix import * Add displaying order link in gift card update * Refactor * Connect gift card list to api * refactor * Add gift card create dialog * Fix gift card list styles, change location for gift card list query, minor refactor * Fix menu structure data for gift cards * Add channel currencies type to shop * Refactor text with select field * Add gift card expiry select component * Add gift card error type and fragment * Update global types * Add default prop to getFormErrors function * Move gift card details provider to providers dir * Update global utils with mapSingleValueNodeToChoice function * Update gift card tag input * Move and refactor time period field * Update schema * move format money function to other money ulities * Update gift card urls * Add content or skeleton component * Add gift card create util for extracting expiry settings input data * Remove content or skeleton component and move displaying logic to existing skeleton * Move displaying logic of gift card create dialog to list * Refactor * Add hooks for gift card bulk actions and gift card list to be used instead of context directly * Fix types for text with select field + add parsing for number typed field * Add initial currency to gift card create form * Fix gift card create dialog closing animation * Add gift card update info card * Refactor gift card update details card * Add gift card balance dialog * Move gift card update form providers to providers dir * Connect gift card update page to api, add necessary contexts etc. * Refactor * Refactor * Add hooks to use instead of gift card contexts directly * Fix types * Fix text field target name missing in passed event in text with select field * Add minimal value option to text with select field, add to gift card inputs * Fix gift card update balance dialog not changing hasChanged prop after submit * Refactor * Fix update balance dialog crashing the app when enetered wrong amount * Fix gift card list table header styles * Add enable / disable section to gift card update * Refactor * Refactor * Refactor * Add metadata to gift card update * Update messages ids * Refactor * Refactor * Refactor * Refactor * Update types after rebase * Fix types * Fixes after qa * Fix tests
70 lines
2 KiB
TypeScript
70 lines
2 KiB
TypeScript
import { giftCardsListPath, giftCardUrl } from "@saleor/giftCards/urls";
|
|
import useNavigator from "@saleor/hooks/useNavigator";
|
|
import createDialogActionHandlers from "@saleor/utils/handlers/dialogActionHandlers";
|
|
import React, { createContext } from "react";
|
|
|
|
import GiftCardUpdateBalanceDialog from "../../GiftCardUpdateBalanceDialog";
|
|
import {
|
|
GiftCardUpdatePageActionParamsEnum,
|
|
GiftCardUpdatePageUrlQueryParams
|
|
} from "../../types";
|
|
import useGiftCardDetails from "../GiftCardDetailsProvider/hooks/useGiftCardDetails";
|
|
|
|
interface GiftCardUpdateDialogsProviderProps {
|
|
children: React.ReactNode;
|
|
params: GiftCardUpdatePageUrlQueryParams;
|
|
id: string;
|
|
}
|
|
|
|
export interface GiftCardUpdateDialogsConsumerProps {
|
|
navigateBack: () => void;
|
|
openSetBalanceDialog: () => void;
|
|
closeDialog: () => void;
|
|
}
|
|
|
|
export const GiftCardUpdateDialogsContext = createContext<
|
|
GiftCardUpdateDialogsConsumerProps
|
|
>(null);
|
|
|
|
const GiftCardUpdateDialogsProvider: React.FC<GiftCardUpdateDialogsProviderProps> = ({
|
|
children,
|
|
params,
|
|
id
|
|
}) => {
|
|
const navigate = useNavigator();
|
|
|
|
const { loading: loadingGiftCard } = useGiftCardDetails();
|
|
|
|
const [openDialog, closeDialog] = createDialogActionHandlers<
|
|
GiftCardUpdatePageActionParamsEnum,
|
|
GiftCardUpdatePageUrlQueryParams
|
|
>(navigate, params => giftCardUrl(id, params), params);
|
|
|
|
const openSetBalanceDialog = () =>
|
|
openDialog(GiftCardUpdatePageActionParamsEnum.SET_BALANCE);
|
|
|
|
const isSetBalanceDialogOpen =
|
|
params?.action === GiftCardUpdatePageActionParamsEnum.SET_BALANCE;
|
|
|
|
const navigateBack = () => navigate(giftCardsListPath);
|
|
|
|
const providerValues: GiftCardUpdateDialogsConsumerProps = {
|
|
openSetBalanceDialog,
|
|
closeDialog,
|
|
navigateBack
|
|
};
|
|
|
|
return (
|
|
<GiftCardUpdateDialogsContext.Provider value={providerValues}>
|
|
{children}
|
|
{!loadingGiftCard && (
|
|
<GiftCardUpdateBalanceDialog
|
|
onClose={closeDialog}
|
|
open={isSetBalanceDialogOpen}
|
|
/>
|
|
)}
|
|
</GiftCardUpdateDialogsContext.Provider>
|
|
);
|
|
};
|
|
|
|
export default GiftCardUpdateDialogsProvider;
|