calcom/packages/app-store/giphy/components/SelectGifInput.tsx
Omar López 2e6bc5e5b4 Fixes/app store keys in db (#2651)
* Adds available apps

* Adds App Model

* WIP

* Updates seeder script

* Seeder fixes

* lowercase categories

* Upgrades prisma

* WIP

* WIP

* Hopefully fixes circular deps

* Type fixes

* Fixes seeder

* Adds migration to connect Credentials to Apps

* Updates app store callbacks

* Updates google credentials

* Uses dirName from DB

* Type fixes

* Update reschedule.ts

* Seeder fixes

* Fixes categories listing

* Update index.ts

* Update schema.prisma

* Updates dependencies

* Renames giphy app

* Uses dynamic imports for app metadata

* Fixes credentials error

* Uses dynamic import for api handlers

* Dynamic import fixes

* Allows for simple folder names in app store

* Squashes app migrations

* seeder fixes

* Fixes dyamic imports

* Update apiHandlers.tsx
2022-05-02 16:21:11 -06:00

52 lines
1.4 KiB
TypeScript

import { SearchIcon, TrashIcon } from "@heroicons/react/solid";
import { useState } from "react";
import { useLocale } from "@calcom/lib/hooks/useLocale";
import Button from "@calcom/ui/Button";
import { SearchDialog } from "./SearchDialog";
interface ISelectGifInput {
defaultValue?: string | null;
onChange: (url: string) => void;
}
export default function SelectGifInput(props: ISelectGifInput) {
const { t } = useLocale();
const [selectedGif, setSelectedGif] = useState(props.defaultValue);
const [showDialog, setShowDialog] = useState(false);
return (
<div className="flex flex-col items-start space-x-2 space-y-2">
{selectedGif && (
<div>
<img alt={"Selected Gif Image"} src={selectedGif} />
</div>
)}
<div className="flex">
<Button color="secondary" type="button" StartIcon={SearchIcon} onClick={() => setShowDialog(true)}>
Search on Giphy
</Button>
{selectedGif && (
<Button
color="warn"
type="button"
StartIcon={TrashIcon}
onClick={() => {
setSelectedGif("");
props.onChange("");
}}>
{t("remove")}
</Button>
)}
</div>
<SearchDialog
isOpenDialog={showDialog}
setIsOpenDialog={setShowDialog}
onSave={(url) => {
setSelectedGif(url);
props.onChange(url);
}}
/>
</div>
);
}