UNPKG

@letanure/resend-cli

Version:

A command-line interface for Resend email API

102 lines 4.93 kB
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime"; import { Alert, Spinner } from '@inkjs/ui'; import { Box, useInput } from 'ink'; import React from 'react'; import { SimpleForm } from '../../../components/forms/SimpleForm.js'; import { ErrorScreen } from '../../../components/ui/ErrorScreen.js'; import { Layout } from '../../../components/ui/layout.js'; import { SuccessScreen } from '../../../components/ui/SuccessScreen.js'; import { config } from '../../../config/config.js'; import { useDryRun } from '../../../contexts/DryRunProvider.js'; import { useResend } from '../../../contexts/ResendProvider.js'; import { useBroadcastSelector } from '../../../hooks/index.js'; import { sendBroadcast } from './action.js'; import { sendBroadcastFields } from './fields.js'; import { sendBroadcastSchema } from './schema.js'; export const Form = ({ onExit }) => { const [result, setResult] = React.useState(null); const [loading, setLoading] = React.useState(false); const [successData, setSuccessData] = React.useState(null); const [isDryRunSuccess, setIsDryRunSuccess] = React.useState(false); const [selectedBroadcastId, setSelectedBroadcastId] = React.useState(''); const { isDryRun } = useDryRun(); const { apiKey } = useResend(); // Get initial data from selected IDs const initialFormData = React.useMemo(() => { const data = {}; if (selectedBroadcastId) { data.broadcastId = selectedBroadcastId; } return Object.keys(data).length > 0 ? data : undefined; }, [selectedBroadcastId]); // Selector for broadcasts const broadcastSelector = useBroadcastSelector((broadcastId) => setSelectedBroadcastId(broadcastId)); // Create form fields with selector callbacks const formFields = React.useMemo(() => { return sendBroadcastFields.map((field) => { if (field.name === 'broadcastId') { return { ...field, onSelectorOpen: () => broadcastSelector.openSelector(), }; } return field; }); }, [broadcastSelector]); const handleSubmit = async (data) => { setLoading(true); if (isDryRun) { setSuccessData({ 'Broadcast ID': data.broadcastId, 'Scheduled At': data.scheduledAt || 'Send immediately', 'API Key': apiKey ? `${apiKey.substring(0, 10)}...` : 'Not set', 'Dry Run': 'true', Status: 'Validation successful! (Broadcast not sent due to dry-run mode)', }); setIsDryRunSuccess(true); } else { const result = await sendBroadcast(data, apiKey); if (result.success && result.data) { setSuccessData({ 'Broadcast ID': result.data.id, }); setIsDryRunSuccess(false); } else { setResult(result); } } setLoading(false); }; useInput((input, key) => { if ((input === 'q' || key.escape) && !loading) { onExit(); } }); if (successData) { return (_jsx(SuccessScreen, { data: successData, successMessage: "Broadcast Sent Successfully", headerText: `${config.baseTitle} - Broadcasts - Send`, isDryRun: isDryRunSuccess, onExit: () => { setSuccessData(null); setIsDryRunSuccess(false); onExit(); } })); } if (loading) { return (_jsx(Layout, { headerText: `${config.baseTitle} - Broadcasts - Send`, showNavigationInstructions: false, navigationContext: "none", children: _jsx(Box, { marginBottom: 1, children: _jsx(Spinner, { label: "Sending broadcast..." }) }) })); } if (result) { return (_jsx(ErrorScreen, { title: "Broadcast Send Failed", message: result.error || 'Failed to send broadcast', suggestion: "Check the broadcast ID and ensure it exists and is ready to send.", headerText: `${config.baseTitle} - Broadcasts - Send`, onExit: () => { setResult(null); onExit(); }, showRetry: true, onRetry: () => { setResult(null); setLoading(false); } })); } // Show selector when open if (broadcastSelector.isOpen) { return broadcastSelector.selectorComponent; } return (_jsxs(Layout, { headerText: `${config.baseTitle} - Broadcasts - Send`, showNavigationInstructions: true, navigationContext: "form", children: [isDryRun && (_jsx(Box, { marginBottom: 1, children: _jsx(Alert, { variant: "warning", children: "DRY RUN MODE - No API calls will be made" }) })), _jsx(SimpleForm, { fields: formFields, onSubmit: handleSubmit, onCancel: onExit, validateWith: sendBroadcastSchema, initialData: initialFormData })] })); }; //# sourceMappingURL=Form.js.map