mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-03-25 02:41:21 +01:00
Add .oxfmtignore to skip generated bindings and wasm-pack output. Add npm format script, update DEVELOPMENT.md for Vite+ toolchain, and format all non-generated files with oxfmt. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
59 lines
1.6 KiB
TypeScript
59 lines
1.6 KiB
TypeScript
import { clear, readText } from "@tauri-apps/plugin-clipboard-manager";
|
|
import * as m from "motion/react-m";
|
|
import { useEffect, useState } from "react";
|
|
import { useImportCurl } from "../hooks/useImportCurl";
|
|
import { useWindowFocus } from "../hooks/useWindowFocus";
|
|
import { Button } from "./core/Button";
|
|
import { Icon } from "./core/Icon";
|
|
|
|
export function ImportCurlButton() {
|
|
const focused = useWindowFocus();
|
|
const [clipboardText, setClipboardText] = useState("");
|
|
|
|
const importCurl = useImportCurl();
|
|
const [isLoading, setIsLoading] = useState(false);
|
|
|
|
// oxlint-disable-next-line react-hooks/exhaustive-deps
|
|
useEffect(() => {
|
|
readText()
|
|
.then(setClipboardText)
|
|
.catch(() => {});
|
|
}, [focused]);
|
|
|
|
if (!clipboardText?.trim().startsWith("curl ")) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<m.div
|
|
initial={{ opacity: 0, scale: 0 }}
|
|
animate={{ opacity: 1, scale: 1 }}
|
|
transition={{ delay: 0.5 }}
|
|
>
|
|
<Button
|
|
size="2xs"
|
|
variant="border"
|
|
color="success"
|
|
className="rounded-full"
|
|
rightSlot={<Icon icon="import" size="sm" />}
|
|
isLoading={isLoading}
|
|
title="Import Curl command from clipboard"
|
|
onClick={async () => {
|
|
setIsLoading(true);
|
|
try {
|
|
await importCurl.mutateAsync({ command: clipboardText });
|
|
await clear(); // Clear the clipboard so the button goes away
|
|
setClipboardText("");
|
|
} catch (e) {
|
|
console.log("Failed to import curl", e);
|
|
} finally {
|
|
setIsLoading(false);
|
|
}
|
|
}}
|
|
>
|
|
Import Curl
|
|
</Button>
|
|
</m.div>
|
|
);
|
|
}
|