| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- import React, { useState } from 'react'
- import { X, Plus } from 'lucide-react'
- import { CreateGroupData } from '../types'
- import { useLanguage } from '../contexts/LanguageContext'
- import { useToast } from '../contexts/ToastContext'
- interface CreateNotebookDialogProps {
- isOpen: boolean
- onClose: () => void
- onCreate: (data: CreateGroupData) => Promise<void>
- }
- export const CreateNotebookDialog: React.FC<CreateNotebookDialogProps> = ({
- isOpen,
- onClose,
- onCreate,
- }) => {
- const { t } = useLanguage();
- const { showError } = useToast();
- const [name, setName] = useState('')
- const [description, setDescription] = useState('')
- const [isSubmitting, setIsSubmitting] = useState(false)
- if (!isOpen) return null
- const handleSubmit = async (e: React.FormEvent) => {
- e.preventDefault()
- if (!name.trim()) return
- try {
- setIsSubmitting(true)
- await onCreate({
- name: name.trim(),
- description: description.trim(),
- color: '#3b82f6', // Default color
- })
- // Reset form
- setName('')
- setDescription('')
- onClose()
- } catch (error) {
- console.error('Failed to create notebook:', error)
- showError(t('createFailedRetry'))
- } finally {
- setIsSubmitting(false)
- }
- }
- return (
- <div className="fixed inset-0 z-50 flex items-center justify-center bg-black/50 backdrop-blur-sm">
- <div className="bg-white rounded-xl shadow-xl w-full max-w-lg overflow-hidden animate-in fade-in zoom-in duration-200">
- <div className="flex justify-between items-center px-6 py-4 border-b">
- <h2 className="text-lg font-semibold text-slate-800">{t('createNotebookTitle')}</h2>
- <button
- onClick={onClose}
- className="text-slate-400 hover:text-slate-600 transition-colors"
- >
- <X size={20} />
- </button>
- </div>
- <form onSubmit={handleSubmit} className="p-6 space-y-4">
- <div>
- <label className="block text-sm font-medium text-slate-700 mb-1">
- {t('name')} <span className="text-red-500">*</span>
- </label>
- <input
- type="text"
- value={name}
- onChange={(e) => setName(e.target.value)}
- className="w-full px-3 py-2 border rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500"
- placeholder={t('namePlaceholder')}
- required
- autoFocus
- />
- </div>
- <div>
- <label className="block text-sm font-medium text-slate-700 mb-1">
- {t('shortDescription')}
- </label>
- <input
- type="text"
- value={description}
- onChange={(e) => setDescription(e.target.value)}
- className="w-full px-3 py-2 border rounded-lg focus:outline-none focus:ring-2 focus:ring-blue-500"
- placeholder={t('descPlaceholder')}
- />
- </div>
- <div className="flex justify-end pt-2">
- <button
- type="button"
- onClick={onClose}
- className="px-4 py-2 text-slate-600 hover:bg-slate-100 rounded-lg mr-2 transition-colors"
- >
- {t('cancel')}
- </button>
- <button
- type="submit"
- disabled={isSubmitting || !name.trim()}
- className="flex items-center gap-2 px-4 py-2 bg-blue-600 text-white rounded-lg hover:bg-blue-700 transition-colors disabled:opacity-50 disabled:cursor-not-allowed"
- >
- <Plus size={18} />
- {isSubmitting ? t('creating') : t('createNow')}
- </button>
- </div>
- </form>
- </div>
- </div>
- )
- }
|