import React, { useState, useEffect } from 'react' import { useAuth } from './auth/AuthContext' import './Integrations.css' function TodoistIntegration({ onBack }) { const { authFetch } = useAuth() const [webhookURL, setWebhookURL] = useState('') const [loading, setLoading] = useState(true) const [copied, setCopied] = useState(false) const [error, setError] = useState('') useEffect(() => { fetchWebhookURL() }, []) const fetchWebhookURL = async () => { try { setLoading(true) setError('') const response = await authFetch('/api/integrations/todoist/webhook-url') if (!response.ok) { const errorData = await response.json().catch(() => ({})) throw new Error(errorData.error || 'Ошибка при загрузке URL webhook') } const data = await response.json() if (data.webhook_url) { setWebhookURL(data.webhook_url) } else { throw new Error('Webhook URL не найден в ответе') } } catch (error) { console.error('Error fetching webhook URL:', error) setError(error.message || 'Не удалось загрузить webhook URL') } finally { setLoading(false) } } const copyToClipboard = async () => { try { await navigator.clipboard.writeText(webhookURL) setCopied(true) setTimeout(() => setCopied(false), 2000) } catch (error) { console.error('Error copying to clipboard:', error) } } return (

TODOist интеграция

Webhook URL

{loading ? (
Загрузка...
) : error ? (

{error}

) : (
)}

Как использовать в приложении TODOist

  1. Откройте приложение TODOist на вашем устройстве
  2. Перейдите в настройки проекта или задачи
  3. Найдите раздел "Интеграции" или "Webhooks"
  4. Вставьте скопированный URL webhook в соответствующее поле
  5. Сохраните настройки
  6. Теперь при закрытии задач в TODOist они будут автоматически обрабатываться системой
) } export default TodoistIntegration