Redirect user to created variant after variant create (#1790)

* Redirect user to the created variant after creation

* Refactor variant creation navigation to use onComplete
This commit is contained in:
Wojciech Mista 2022-01-28 09:06:21 +01:00 committed by GitHub
parent 50712e6155
commit 1ee2114153
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 32 additions and 1 deletions

View file

@ -6931,6 +6931,10 @@
"context": "window title",
"string": "Create Variants"
},
"src_dot_products_dot_views_dot_variantCreatedSuccess": {
"context": "variant created success message",
"string": "Variant created"
},
"src_dot_properties": {
"string": "Properties"
},

View file

@ -9,6 +9,7 @@ import { WindowTitle } from "@saleor/components/WindowTitle";
import { DEFAULT_INITIAL_SEARCH_DATA } from "@saleor/config";
import { useFileUploadMutation } from "@saleor/files/mutations";
import useNavigator from "@saleor/hooks/useNavigator";
import useNotifier from "@saleor/hooks/useNotifier";
import useShop from "@saleor/hooks/useShop";
import usePageSearch from "@saleor/searches/usePageSearch";
import useProductSearch from "@saleor/searches/useProductSearch";
@ -32,6 +33,7 @@ import {
useVariantCreateMutation
} from "../mutations";
import { useProductVariantCreateQuery } from "../queries";
import { VariantCreate } from "../types/VariantCreate";
import {
productListUrl,
productUrl,
@ -39,6 +41,7 @@ import {
ProductVariantAddUrlQueryParams,
productVariantEditUrl
} from "../urls";
import { variantCreateMessages as messages } from "./messages";
import { createVariantReorderHandler } from "./ProductUpdate/handlers";
interface ProductVariantCreateProps {
@ -51,6 +54,8 @@ export const ProductVariant: React.FC<ProductVariantCreateProps> = ({
params
}) => {
const navigate = useNavigator();
const notify = useNotifier();
const shop = useShop();
const intl = useIntl();
const warehouses = useWarehouseList({
@ -72,7 +77,21 @@ export const ProductVariant: React.FC<ProductVariantCreateProps> = ({
const product = data?.product;
const [variantCreate, variantCreateResult] = useVariantCreateMutation({});
const handleVariantCreationSuccess = (data: VariantCreate) => {
const variantId = data.productVariantCreate.productVariant.id;
notify({
status: "success",
text: intl.formatMessage(messages.variantCreatedSuccess)
});
navigate(productVariantEditUrl(productId, variantId), {
resetScroll: true
});
};
const [variantCreate, variantCreateResult] = useVariantCreateMutation({
onCompleted: handleVariantCreationSuccess
});
const [updateMetadata] = useMetadataUpdate({});
const [updatePrivateMetadata] = usePrivateMetadataUpdate({});

View file

@ -0,0 +1,8 @@
import { defineMessages } from "react-intl";
export const variantCreateMessages = defineMessages({
variantCreatedSuccess: {
defaultMessage: "Variant created",
description: "variant created success message"
}
});