From 85c2a76a43e0e2bb8d0eb88563d2881b6becb6ba Mon Sep 17 00:00:00 2001 From: Ian McEwen Date: Wed, 6 Nov 2024 13:10:04 -0700 Subject: [PATCH] Add a create button for instant launches, plus some error handling --- public/static/locales/en/apps.json | 1 + .../apps/savedLaunch/SavedLaunchListing.js | 76 ++++++++++++++----- 2 files changed, 57 insertions(+), 20 deletions(-) diff --git a/public/static/locales/en/apps.json b/public/static/locales/en/apps.json index b48a6048e..2aa3863a6 100644 --- a/public/static/locales/en/apps.json +++ b/public/static/locales/en/apps.json @@ -94,6 +94,7 @@ "imageLabel": "Image", "inputDescHelpText": "For example, number of files required or file format(s) accepted.", "inputDescLabel": "Briefly describe input file(s) required by this app.", + "instantLaunchCreateError": "Error creating instant launch.", "instantLaunches": "Instant Launches", "intEmail": "Integrator email", "intName": "Integrator name", diff --git a/src/components/apps/savedLaunch/SavedLaunchListing.js b/src/components/apps/savedLaunch/SavedLaunchListing.js index 5c96cc86a..8710f5813 100644 --- a/src/components/apps/savedLaunch/SavedLaunchListing.js +++ b/src/components/apps/savedLaunch/SavedLaunchListing.js @@ -36,6 +36,7 @@ import { import { ALL_INSTANT_LAUNCHES_KEY, listFullInstantLaunches, + addInstantLaunch, } from "serviceFacades/instantlaunches"; import { useConfig } from "contexts/config"; @@ -44,6 +45,7 @@ import { useUserProfile } from "contexts/userProfile"; import buildID from "components/utils/DebugIDUtil"; import CopyTextArea from "components/copy/CopyTextArea"; +import Button from "@mui/material/Button"; import Dialog from "@mui/material/Dialog"; import DialogTitle from "@mui/material/DialogTitle"; import DialogContent from "@mui/material/DialogContent"; @@ -57,6 +59,7 @@ import Typography from "@mui/material/Typography"; import { Link as MuiLink } from "@mui/material"; import { useTheme } from "@mui/material"; +import Add from "@mui/icons-material/Add"; import Code from "@mui/icons-material/Code"; import Play from "@mui/icons-material/PlayArrow"; import Share from "@mui/icons-material/Share"; @@ -196,6 +199,7 @@ function ListSavedLaunches(props) { const [selectedIL, setSelectedIL] = useState(); const [deleteError, setDeleteError] = useState(); const [useInstantLaunch, setUseInstantLaunch] = useState(false); + const [createILError, setCreateILError] = useState(); const userName = userProfile?.id; @@ -248,6 +252,15 @@ function ListSavedLaunches(props) { } ); + const { mutate: createInstantLaunch } = useMutation(addInstantLaunch, { + onSuccess: (createdIL, { onSuccess }) => { + queryClient.invalidateQueries(ALL_INSTANT_LAUNCHES_KEY); + setSelectedIL(createdIL); + setUseInstantLaunch(true); + }, + onError: setCreateILError, + }); + const getShareUrl = useCallback(() => { const host = getHost(); const url = `${host}${getSavedLaunchPath( @@ -420,26 +433,49 @@ function ListSavedLaunches(props) { - - setUseInstantLaunch( - event.target.checked - ) - } - name={t("savedLaunchEmbedUseInstantLaunch")} - /> - } - label={ - - {t("savedLaunchEmbedUseInstantLaunch")} - - } - /> + {!!selectedIL ? ( + + setUseInstantLaunch( + event.target.checked + ) + } + name={t( + "savedLaunchEmbedUseInstantLaunch" + )} + /> + } + label={ + + {t("savedLaunchEmbedUseInstantLaunch")} + + } + /> + ) : ( + + )} + {createILError && ( + + )}