Compare commits
3 Commits
6fbf3064c5
...
af15988c62
| Author | SHA1 | Date | |
|---|---|---|---|
| af15988c62 | |||
| 5b4e948846 | |||
| 9312b760c7 |
@ -1,18 +1,30 @@
|
|||||||
package ru.kamask.pet.todo;
|
package ru.kamask.pet.todo;
|
||||||
|
|
||||||
import ru.kamask.pet.todo.model.SimpleTask;
|
import ru.kamask.pet.todo.model.SimpleTask;
|
||||||
|
import ru.kamask.pet.todo.repo.InMemoryTaskRepository;
|
||||||
|
|
||||||
public class TodoApp {
|
public class TodoApp {
|
||||||
|
|
||||||
@SuppressWarnings("unused")
|
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
var task = new SimpleTask("TodoApp");
|
var repo = new InMemoryTaskRepository();
|
||||||
System.out.println(task);
|
|
||||||
|
|
||||||
task.markAsCompleted();
|
repo.save(new SimpleTask("Задача номер один"));
|
||||||
|
repo.save(new SimpleTask("Задача номер два"));
|
||||||
|
repo.save(new SimpleTask("Задача номер три"));
|
||||||
|
repo.save(new SimpleTask("Задача номер четыре"));
|
||||||
|
|
||||||
var taskData = task.data();
|
System.out.println(repo.findAll());
|
||||||
System.out.println(taskData);
|
|
||||||
|
var taskOption = repo.findById(2);
|
||||||
|
if (taskOption.isPresent()) {
|
||||||
|
SimpleTask task = (SimpleTask) taskOption.get();
|
||||||
|
task.markAsCompleted();
|
||||||
|
var data = task.data();
|
||||||
|
System.out.println(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
repo.delete(1);
|
||||||
|
System.out.println(repo.findAll());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -11,6 +11,10 @@ public abstract class Task {
|
|||||||
this.title = title;
|
this.title = title;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int id() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return String.format("Задача: id - %d, title: \"%s\"", id, title);
|
return String.format("Задача: id - %d, title: \"%s\"", id, title);
|
||||||
|
|||||||
@ -0,0 +1,33 @@
|
|||||||
|
package ru.kamask.pet.todo.repo;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
import ru.kamask.pet.todo.model.Task;
|
||||||
|
|
||||||
|
public class InMemoryTaskRepository implements TaskRepository {
|
||||||
|
private Map<Integer, Task> storage = new HashMap<>();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void save(Task task) {
|
||||||
|
storage.put(task.id(), task);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Optional<Task> findById(int id) {
|
||||||
|
return Optional.ofNullable(storage.get(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<Task> findAll() {
|
||||||
|
return new ArrayList<>(storage.values());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void delete(int id) {
|
||||||
|
storage.remove(id);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,16 @@
|
|||||||
|
package ru.kamask.pet.todo.repo;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
import ru.kamask.pet.todo.model.Task;
|
||||||
|
|
||||||
|
public interface TaskRepository {
|
||||||
|
void save(Task task);
|
||||||
|
|
||||||
|
Optional<Task> findById(int id);
|
||||||
|
|
||||||
|
List<Task> findAll();
|
||||||
|
|
||||||
|
void delete(int id);
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user