forked from semi-23e/nextjs-todo-tutorial
さらにコメントアウトのカバー範囲を拡充
This commit is contained in:
@@ -4,9 +4,9 @@ import { useState } from 'react';
|
||||
|
||||
// Todo型の定義
|
||||
type Todo = {
|
||||
id: number;
|
||||
text: string;
|
||||
completed: boolean;
|
||||
id: number; // ユニークな識別子。今回はDate.now()で一意性をある程度確保。
|
||||
text: string; // TODOの内容。ユーザーが入力する文字列。
|
||||
completed: boolean; // 完了したかどうかのフラグ。チェックボックスに対応。
|
||||
};
|
||||
|
||||
export default function Home() {
|
||||
@@ -28,45 +28,45 @@ export default function Home() {
|
||||
// 新しいTODOを追加する関数
|
||||
const addTodo = () => {
|
||||
// 入力が空欄だったら警告ダイアログ表示
|
||||
if (inputValue.trim() === '') {
|
||||
if (inputValue.trim() === '') { //trim()で前後の空白を除去
|
||||
setShowInputAlert(true); // 警告ダイアログを表示
|
||||
return;
|
||||
}
|
||||
// 新しいTodoオブジェクトを作成
|
||||
const newTodo: Todo = {
|
||||
id: Date.now(), // 一意なID
|
||||
const newTodo: Todo = { // 新規Todoオブジェクト
|
||||
id: Date.now(), // 現在時刻のミリ秒をIDとして使用することで、ほかのTODOと重複しないようにする
|
||||
text: inputValue, // 入力値
|
||||
completed: false // 初期状態は未完了
|
||||
completed: false // 初期状態を未完了に
|
||||
};
|
||||
setTodos([...todos, newTodo]); // Todoリストに追加
|
||||
setInputValue(''); // 入力欄をクリア
|
||||
};
|
||||
|
||||
// フォーム送信時の処理
|
||||
const handleSubmit = (e: React.FormEvent<HTMLFormElement>) => {
|
||||
const handleSubmit = (e: React.FormEvent<HTMLFormElement>) => { // フォーム送信イベント
|
||||
e.preventDefault(); // ページリロード防止
|
||||
addTodo(); // Todo追加処理
|
||||
};
|
||||
|
||||
// Todoの完了状態をトグルする関数
|
||||
const toggleTodo = (id: number) => {
|
||||
const updatedTodos = todos.map(todo => {
|
||||
if (todo.id === id) {
|
||||
return { ...todo, completed: !todo.completed };
|
||||
const toggleTodo = (id: number) => { // Todoの完了状態を切り替える
|
||||
const updatedTodos = todos.map(todo => { // 現在のTodoリストをマッピング
|
||||
if (todo.id === id) { // 対象のTodoを見つけたら
|
||||
return { ...todo, completed: !todo.completed }; // そのtodoの完了状態を反転
|
||||
}
|
||||
return todo;
|
||||
return todo; // 対象外はそのまま返す
|
||||
});
|
||||
setTodos(updatedTodos); // 状態更新
|
||||
};
|
||||
|
||||
// 削除ボタンが押されたときの処理(確認ダイアログ表示)
|
||||
const handleDeleteClick = (id: number) => {
|
||||
const handleDeleteClick = (id: number) => { // 削除ボタン押下時の処理
|
||||
setShowConfirm(true); // 削除確認ダイアログ表示
|
||||
setTargetId(id); // 削除対象IDをセット
|
||||
};
|
||||
|
||||
// ダイアログで「はい」が押されたときの本削除処理
|
||||
const confirmDelete = () => {
|
||||
const confirmDelete = () => { // 削除確認ダイアログで「はい」が押されたときの処理
|
||||
if (targetId !== null) { // 削除対象IDがセットされているか確認
|
||||
setTodos(todos.filter(todo => todo.id !== targetId)); // 該当ID以外を残す
|
||||
setShowConfirm(false); // ダイアログを閉じる
|
||||
@@ -75,13 +75,13 @@ export default function Home() {
|
||||
};
|
||||
|
||||
// ダイアログで「いいえ」が押されたときの処理
|
||||
const cancelDelete = () => {
|
||||
const cancelDelete = () => { // 削除確認ダイアログで「いいえ」が押されたときの処理
|
||||
setShowConfirm(false); // ダイアログを閉じる
|
||||
setTargetId(null); // 削除対象IDをリセット
|
||||
};
|
||||
|
||||
// 空欄入力時ダイアログを閉じる関数
|
||||
const closeInputAlert = () => {
|
||||
const closeInputAlert = () => { //
|
||||
setShowInputAlert(false); // 警告ダイアログを閉じる
|
||||
};
|
||||
|
||||
@@ -89,10 +89,10 @@ export default function Home() {
|
||||
return (
|
||||
<main className="min-h-screen p-8 bg-gray-50"> {/* 全体の背景や余白 */}
|
||||
<div className="max-w-md mx-auto bg-white rounded-lg shadow-md p-6"> {/* カード風の白背景 */}
|
||||
<h1 className="text-2xl font-bold text-gray-800 mb-6">TODOアプリ</h1>
|
||||
<h1 className="text-2xl font-bold text-gray-800 mb-6">TODOアプリ</h1> {/* タイトル */}
|
||||
|
||||
{/* 入力フォーム */}
|
||||
<form onSubmit={handleSubmit} className="mb-4">
|
||||
<form onSubmit={handleSubmit} className="mb-4"> {/* フォーム全体のスタイル */}
|
||||
<input
|
||||
type="text"
|
||||
value={inputValue} // 入力欄の値を状態と連動
|
||||
|
||||
Reference in New Issue
Block a user