mirror of
https://codeberg.org/vyn/mirai.git
synced 2025-07-03 01:33:19 +00:00
Support multiple files
This commit is contained in:
parent
f8f49233dc
commit
689eea07a7
22 changed files with 528 additions and 131 deletions
|
@ -6,7 +6,14 @@
|
|||
|
||||
#include "Mirai.h"
|
||||
#include "TaskItem.h"
|
||||
#include "cpp-utils/vector.h"
|
||||
#include "core/TasksFile.h"
|
||||
#include "utils.h"
|
||||
#include <algorithm>
|
||||
#include <iostream>
|
||||
#include <memory>
|
||||
#include <optional>
|
||||
#include <ostream>
|
||||
#include <vector>
|
||||
|
||||
namespace mirai
|
||||
{
|
||||
|
@ -16,10 +23,12 @@ void Mirai::loadFile(const std::string &path)
|
|||
auto tasksFile = TodoMdFormat::readFile(path);
|
||||
files->push_back(std::move(tasksFile));
|
||||
tags.clear();
|
||||
for (auto &task : (*files)[0].getTasks()) {
|
||||
for (auto &tag : task->getTags()) {
|
||||
if (!vectorUtils::contains(tags, tag)) {
|
||||
tags.push_back(tag);
|
||||
for (auto &file : *files) {
|
||||
for (auto &task : file->getTasks()) {
|
||||
for (auto &tag : task->getTags()) {
|
||||
if (!vectorUtils::contains(tags, tag)) {
|
||||
tags.push_back(tag);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -28,13 +37,16 @@ void Mirai::loadFile(const std::string &path)
|
|||
void Mirai::save()
|
||||
{
|
||||
for (auto &file : *files) {
|
||||
TodoMdFormat::writeFile(file);
|
||||
if (file->isDirty()) {
|
||||
TodoMdFormat::writeFile(*file);
|
||||
file->setDirty(false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void Mirai::addTask(TaskItem taskItem)
|
||||
void Mirai::addTask(TaskItemData taskItem)
|
||||
{
|
||||
(*files)[0].addTask(taskItem);
|
||||
(*files)[0]->addTask(taskItem);
|
||||
for (auto &view : views) {
|
||||
view->update();
|
||||
}
|
||||
|
@ -46,7 +58,7 @@ void Mirai::addTask(std::string text, std::string date)
|
|||
/*std::tm tm = *std::localtime(&t);*/
|
||||
/*std::stringstream ssCreationDate;*/
|
||||
/*ssCreationDate << std::put_time(&tm, "%Y-%m-%d");*/
|
||||
(*files)[0].addTask(text, date);
|
||||
(*files)[0]->addTask(text, date);
|
||||
for (auto &view : views) {
|
||||
view->update();
|
||||
}
|
||||
|
@ -54,12 +66,31 @@ void Mirai::addTask(std::string text, std::string date)
|
|||
|
||||
void Mirai::removeTask(const TaskItem *taskItem)
|
||||
{
|
||||
(*files)[0].removeTask(taskItem);
|
||||
for (auto &file : *files) {
|
||||
file->removeTask(taskItem);
|
||||
}
|
||||
for (auto &view : views) {
|
||||
view->update();
|
||||
}
|
||||
}
|
||||
|
||||
std::vector<std::unique_ptr<TasksFile>> &Mirai::getFiles()
|
||||
{
|
||||
return *files.get();
|
||||
}
|
||||
|
||||
std::optional<std::reference_wrapper<TasksFile>> Mirai::getFileByPath(const std::string &path)
|
||||
{
|
||||
auto fileIterator = std::ranges::find_if(*files, [&](const std::unique_ptr<TasksFile> &file) {
|
||||
return file->getPath() == path;
|
||||
});
|
||||
|
||||
if (fileIterator == files->end()) {
|
||||
return std::nullopt;
|
||||
}
|
||||
return *(fileIterator->get());
|
||||
}
|
||||
|
||||
std::weak_ptr<TasksView> Mirai::getTasks()
|
||||
{
|
||||
auto view = std::make_shared<TasksView>(files);
|
||||
|
@ -71,4 +102,5 @@ const std::vector<std::string> &Mirai::getTags()
|
|||
{
|
||||
return tags;
|
||||
}
|
||||
|
||||
} // namespace mirai
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue