36 lines
1.1 KiB
TypeScript
36 lines
1.1 KiB
TypeScript
import { useMutation } from "react-query";
|
|
|
|
import type { IntegrationOAuthCallbackState } from "@calcom/app-store/types";
|
|
import { WEBAPP_URL } from "@calcom/lib/constants";
|
|
import { App } from "@calcom/types/App";
|
|
|
|
function useAddAppMutation(_type: App["type"] | null, options?: Parameters<typeof useMutation>[2]) {
|
|
const mutation = useMutation<unknown, Error, { type?: App["type"] } | "">(async (variables) => {
|
|
let type: string | null | undefined;
|
|
if (variables === "") {
|
|
type = _type;
|
|
} else {
|
|
type = variables.type;
|
|
}
|
|
const state: IntegrationOAuthCallbackState = {
|
|
returnTo: WEBAPP_URL + "/apps/installed" + location.search,
|
|
};
|
|
const stateStr = encodeURIComponent(JSON.stringify(state));
|
|
const searchParams = `?state=${stateStr}`;
|
|
|
|
const res = await fetch(`/api/integrations/${type}/add` + searchParams);
|
|
|
|
if (!res.ok) {
|
|
const errorBody = await res.json();
|
|
throw new Error(errorBody.message || "Something went wrong");
|
|
}
|
|
|
|
const json = await res.json();
|
|
window.location.href = json.url;
|
|
}, options);
|
|
|
|
return mutation;
|
|
}
|
|
|
|
export default useAddAppMutation;
|