UNPKG

@letanure/resend-cli

Version:

A command-line interface for Resend email API

124 lines 5.82 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 { useAudienceSelector, useContactSelector } from '../../../hooks/index.js'; import { updateContact } from './action.js'; import { updateContactFields } from './fields.js'; import { updateContactSchema } 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 [selectedAudienceId, setSelectedAudienceId] = React.useState(''); const [selectedContactId, setSelectedContactId] = React.useState(''); const { isDryRun } = useDryRun(); const { apiKey } = useResend(); // Get initial data from selected IDs const initialFormData = React.useMemo(() => { const data = {}; if (selectedAudienceId) { data.audienceId = selectedAudienceId; } if (selectedContactId) { data.id = selectedContactId; } return Object.keys(data).length > 0 ? data : undefined; }, [selectedAudienceId, selectedContactId]); // Selector for audiences const audienceSelector = useAudienceSelector((audienceId) => setSelectedAudienceId(audienceId)); // Selector for contacts const contactSelector = useContactSelector({ audienceId: selectedAudienceId, onSelect: (contactId) => setSelectedContactId(contactId), }); // Create form fields with selector callbacks const formFields = React.useMemo(() => { return updateContactFields.map((field) => { if (field.name === 'audienceId') { return { ...field, onSelectorOpen: () => audienceSelector.openSelector(), }; } if (field.name === 'id') { return { ...field, onSelectorOpen: () => contactSelector.openSelector(), }; } return field; }); }, [audienceSelector, contactSelector]); const handleSubmit = async (data) => { setLoading(true); if (isDryRun) { setSuccessData({ 'Audience ID': data.audienceId, 'Contact ID': data.id, 'First Name': data.firstName || 'Not provided', 'Last Name': data.lastName || 'Not provided', Unsubscribed: data.unsubscribed ? 'Yes' : 'No', 'API Key': apiKey ? `${apiKey.substring(0, 10)}...` : 'Not set', 'Dry Run': 'true', Status: 'Validation successful! (Contact not updated due to dry-run mode)', }); setIsDryRunSuccess(true); } else { const result = await updateContact(data, apiKey); if (result.success && result.data) { setSuccessData({ Object: result.data.object, 'Contact 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: "Contact Updated Successfully", headerText: `${config.baseTitle} - Contacts - Update`, isDryRun: isDryRunSuccess, onExit: () => { setSuccessData(null); setIsDryRunSuccess(false); onExit(); } })); } if (loading) { return (_jsx(Layout, { headerText: `${config.baseTitle} - Contacts - Update`, showNavigationInstructions: false, navigationContext: "none", children: _jsx(Box, { marginBottom: 1, children: _jsx(Spinner, { label: "Updating contact..." }) }) })); } if (result) { return (_jsx(ErrorScreen, { title: "Contact Update Failed", message: result.error || 'Failed to update contact', suggestion: "Check the contact ID and ensure it exists in your Resend account.", headerText: `${config.baseTitle} - Contacts - Update`, onExit: () => { setResult(null); onExit(); }, showRetry: true, onRetry: () => { setResult(null); setLoading(false); } })); } // Show selectors when open if (audienceSelector.isOpen) { return audienceSelector.selectorComponent; } if (contactSelector.isOpen) { return contactSelector.selectorComponent; } return (_jsxs(Layout, { headerText: `${config.baseTitle} - Contacts - Update`, 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: updateContactSchema, initialData: initialFormData })] })); }; //# sourceMappingURL=Form.js.map