saleor-dashboard/src/giftCards/GiftCardUpdate/providers/GiftCardUpdateDialogsProvider/GiftCardUpdateDialogsProvider.tsx
mmarkusik dae95cb410
Add Gift Cards #1 (#1291)
* 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
2021-08-16 15:44:00 +02:00

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;