update an existing flow/component in the Store is now possible (#1189)

feat(API): add updateFlowStore function to update an existing flow in
the Store

feat(shareModal): add functionality to update a shared component or flow
This commit is contained in:
anovazzi1 2023-12-08 16:52:20 -03:00 committed by GitHub
commit d11719b66a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 88 additions and 27 deletions

View file

@ -817,3 +817,46 @@ export async function getStoreTags() {
export const postLikeComponent = (componentId: string) => {
return api.post(`${BASE_URL_API}store/users/likes/${componentId}`);
};
/**
* Updates an existing flow in the Store.
*
* @param {FlowType} updatedFlow - The updated flow data.
* @returns {Promise<any>} The updated flow data.
* @throws Will throw an error if the update fails.
*/
export async function updateFlowStore(
newFlow: {
name?: string;
data: ReactFlowJsonObject | null;
description?: string;
style?: FlowStyleType;
is_component?: boolean;
parent?: string;
last_tested_version?: string;
},
tags: string[],
publicFlow = false,
id: string
): Promise<FlowType> {
try {
const response = await api.patch(`${BASE_URL_API}store/components/${id}`, {
name: newFlow.name,
data: newFlow.data,
description: newFlow.description,
is_component: newFlow.is_component,
parent: newFlow.parent,
tags: tags,
private: !publicFlow,
last_tested_version: newFlow.last_tested_version,
});
if (response.status !== 201) {
throw new Error(`HTTP error! status: ${response.status}`);
}
return response.data;
} catch (error) {
console.error(error);
throw error;
}
}

View file

@ -12,6 +12,7 @@ import {
getStoreComponents,
getStoreTags,
saveFlowStore,
updateFlowStore,
} from "../../controllers/API";
import { FlowType } from "../../types/flow";
import {
@ -51,7 +52,9 @@ export default function ShareModal({
const [loadingTags, setLoadingTags] = useState<boolean>(false);
const [sharePublic, setSharePublic] = useState(true);
const [selectedTags, setSelectedTags] = useState<string[]>([]);
const [unavaliableNames, setUnavaliableNames] = useState<string[]>([]);
const [unavaliableNames, setUnavaliableNames] = useState<
{ id: string; name: string }[]
>([]);
const { saveFlow, flows, tabId } = useContext(FlowsContext);
const [nameIsAvailable, setNameIsAvailable] = useState(false);
@ -76,16 +79,17 @@ export default function ShareModal({
async function handleGetNames() {
setLoadingNames(true);
const unavaliableNames: Array<string> = [];
await getStoreComponents({ fields: ["name"], filterByUser: true }).then(
(res) => {
res?.results?.forEach((element: any) => {
unavaliableNames.push(element.name);
});
setUnavaliableNames(unavaliableNames);
setLoadingNames(false);
}
);
const unavaliableNames: Array<{ id: string; name: string }> = [];
await getStoreComponents({
fields: ["name", "id"],
filterByUser: true,
}).then((res) => {
res?.results?.forEach((element: any) => {
unavaliableNames.push({ name: element.name, id: element.id });
});
setUnavaliableNames(unavaliableNames);
setLoadingNames(false);
});
}
useEffect(() => {
@ -93,7 +97,7 @@ export default function ShareModal({
setDescription(component?.description ?? "");
}, [component, open, internalOpen]);
const handleShareComponent = async () => {
const handleShareComponent = async (update = false) => {
//remove file names from flows before sharing
removeFileNameFromComponents(component);
const flow: FlowType = checked
@ -114,28 +118,42 @@ export default function ShareModal({
is_component: is_component,
});
await saveFlow(flows.find((flow) => flow.id === tabId)!, true);
function successShare() {
if (is_component) {
addFlow(true, flow);
}
setSuccessData({
title: `${nameComponent} shared successfully`,
});
}
saveFlowStore(flow!, getTagsIds(selectedTags, tags), sharePublic).then(
() => {
if (is_component) {
addFlow(true, flow);
await saveFlow(flows.find((flow) => flow.id === tabId)!, true);
if (!update)
saveFlowStore(flow!, getTagsIds(selectedTags, tags), sharePublic).then(
successShare,
(err) => {
setErrorData({
title: "Error sharing " + is_component ? "component" : "flow",
list: [err["response"]["data"]["detail"]],
});
}
setSuccessData({
title: `${nameComponent} shared successfully`,
});
},
(err) => {
);
else
updateFlowStore(
flow!,
getTagsIds(selectedTags, tags),
sharePublic,
unavaliableNames.find((e) => e.name === name)!.id
).then(successShare, (err) => {
setErrorData({
title: "Error sharing " + is_component ? "component" : "flow",
list: [err["response"]["data"]["detail"]],
});
}
);
});
};
const handleUpdateComponent = () => {
handleShareComponent();
handleShareComponent(true);
if (setOpen) setOpen(false);
else internalSetOpen(false);
};
@ -143,7 +161,7 @@ export default function ShareModal({
let modalConfirmationButton = useMemo(() => {
return (
<>
{unavaliableNames.includes(name) ? (
{unavaliableNames.find((element) => element.name === name) ? (
<ConfirmationModal
title="Update"
titleHeader={name}
@ -235,7 +253,7 @@ export default function ShareModal({
<BaseModal.Content>
<EditFlowSettings
name={name}
invalidNameList={unavaliableNames}
invalidNameList={unavaliableNames.map((element) => element.name)}
description={description}
setName={setName}
setDescription={setDescription}