## Translation Files - Add 11 new language files (es, de, pt, ru, zh, ja, ko, ar, hi, nl, pl) - Add 100+ missing translation keys across all 15 languages - New sections: notebook, pagination, ai.batchOrganization, ai.autoLabels - Update nav section with workspace, quickAccess, myLibrary keys ## Component Updates - Update 15+ components to use translation keys instead of hardcoded text - Components: notebook dialogs, sidebar, header, note-input, ghost-tags, etc. - Replace 80+ hardcoded English/French strings with t() calls - Ensure consistent UI across all supported languages ## Code Quality - Remove 77+ console.log statements from codebase - Clean up API routes, components, hooks, and services - Keep only essential error handling (no debugging logs) ## UI/UX Improvements - Update Keep logo to yellow post-it style (from-yellow-400 to-amber-500) - Change selection colors to #FEF3C6 (notebooks) and #EFB162 (nav items) - Make "+" button permanently visible in notebooks section - Fix grammar and syntax errors in multiple components ## Bug Fixes - Fix JSON syntax errors in it.json, nl.json, pl.json, zh.json - Fix syntax errors in notebook-suggestion-toast.tsx - Fix syntax errors in use-auto-tagging.ts - Fix syntax errors in paragraph-refactor.service.ts - Fix duplicate "fusion" section in nl.json 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com> Ou une version plus courte si vous préférez : feat(i18n): Add 15 languages, remove logs, update UI components - Create 11 new translation files (es, de, pt, ru, zh, ja, ko, ar, hi, nl, pl) - Add 100+ translation keys: notebook, pagination, AI features - Update 15+ components to use translations (80+ strings) - Remove 77+ console.log statements from codebase - Fix JSON syntax errors in 4 translation files - Fix component syntax errors (toast, hooks, services) - Update logo to yellow post-it style - Change selection colors (#FEF3C6, #EFB162) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
62 lines
1.9 KiB
TypeScript
62 lines
1.9 KiB
TypeScript
'use client'
|
|
|
|
import { useState } from 'react'
|
|
import { useTitleSuggestions } from '@/hooks/use-title-suggestions'
|
|
|
|
export default function TestTitleSuggestionsPage() {
|
|
const [content, setContent] = useState('')
|
|
|
|
const { suggestions, isAnalyzing, error } = useTitleSuggestions({
|
|
content,
|
|
enabled: true // Always enabled for testing
|
|
})
|
|
|
|
const wordCount = content.split(/\s+/).filter(w => w.length > 0).length
|
|
|
|
return (
|
|
<div style={{ padding: '20px', maxWidth: '800px', margin: '0 auto' }}>
|
|
<h1>Test Title Suggestions</h1>
|
|
|
|
<div style={{ marginBottom: '20px' }}>
|
|
<label>Content (need 50+ words):</label>
|
|
<textarea
|
|
value={content}
|
|
onChange={(e) => setContent(e.target.value)}
|
|
style={{ width: '100%', height: '200px', marginTop: '10px' }}
|
|
placeholder="Type at least 50 words here..."
|
|
/>
|
|
</div>
|
|
|
|
<div style={{ marginBottom: '20px', padding: '10px', background: '#f0f0f0' }}>
|
|
<p><strong>Word count:</strong> {wordCount} / 50</p>
|
|
<p><strong>Status:</strong> {isAnalyzing ? 'Analyzing...' : 'Idle'}</p>
|
|
{error && <p style={{ color: 'red' }}><strong>Error:</strong> {error}</p>}
|
|
</div>
|
|
|
|
<div>
|
|
<h2>Suggestions ({suggestions.length}):</h2>
|
|
{suggestions.length > 0 ? (
|
|
<ul>
|
|
{suggestions.map((s, i) => (
|
|
<li key={i}>
|
|
<strong>{s.title}</strong> (confidence: {s.confidence}%)
|
|
{s.reasoning && <p>→ {s.reasoning}</p>}
|
|
</li>
|
|
))}
|
|
</ul>
|
|
) : (
|
|
<p style={{ color: '#666' }}>No suggestions yet. Type 50+ words and wait 2 seconds.</p>
|
|
)}
|
|
</div>
|
|
|
|
<div style={{ marginTop: '20px' }}>
|
|
<button onClick={() => {
|
|
setContent('word '.repeat(50))
|
|
}}>
|
|
Fill with 50 words (test)
|
|
</button>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|