forked from janek/mostr
feat: correctly display path for unnamed and unknown tasks
This commit is contained in:
parent
98d921b941
commit
e255ce0676
|
@ -43,6 +43,12 @@ impl Task {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub(crate) fn get_title(&self) -> String {
|
||||||
|
Some(self.event.content.trim().to_string())
|
||||||
|
.filter(|s| !s.is_empty())
|
||||||
|
.unwrap_or_else(|| self.get_id().to_string())
|
||||||
|
}
|
||||||
|
|
||||||
fn descriptions(&self) -> impl Iterator<Item = &String> + '_ {
|
fn descriptions(&self) -> impl Iterator<Item = &String> + '_ {
|
||||||
self.props.iter().filter_map(|event| {
|
self.props.iter().filter_map(|event| {
|
||||||
if event.kind == Kind::TextNote {
|
if event.kind == Kind::TextNote {
|
||||||
|
|
33
src/tasks.rs
33
src/tasks.rs
|
@ -92,6 +92,9 @@ impl Tasks {
|
||||||
|
|
||||||
pub(crate) fn get_task_path(&self, id: Option<EventId>) -> String {
|
pub(crate) fn get_task_path(&self, id: Option<EventId>) -> String {
|
||||||
join_tasks(self.traverse_up_from(id))
|
join_tasks(self.traverse_up_from(id))
|
||||||
|
.filter(|s| !s.is_empty())
|
||||||
|
.or_else(|| id.map(|id| id.to_string()))
|
||||||
|
.unwrap_or(String::new())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn traverse_up_from(&self, id: Option<EventId>) -> ParentIterator {
|
pub(crate) fn traverse_up_from(&self, id: Option<EventId>) -> ParentIterator {
|
||||||
|
@ -191,11 +194,11 @@ impl Tasks {
|
||||||
"rpath" => join_tasks(
|
"rpath" => join_tasks(
|
||||||
self.traverse_up_from(Some(task.event.id))
|
self.traverse_up_from(Some(task.event.id))
|
||||||
.take_while(|t| Some(t.event.id) != self.position)
|
.take_while(|t| Some(t.event.id) != self.position)
|
||||||
),
|
).unwrap_or(task.event.id.to_string()),
|
||||||
"rtime" => {
|
"rtime" => {
|
||||||
let time = self.total_time_tracked(&task.event.id);
|
let time = self.total_time_tracked(&task.event.id);
|
||||||
format!("{:02}:{:02}", time / 3600, time / 60 % 60)
|
format!("{:02}:{:02}", time / 3600, time / 60 % 60)
|
||||||
},
|
}
|
||||||
prop => task.get(prop).unwrap_or(String::new()),
|
prop => task.get(prop).unwrap_or(String::new()),
|
||||||
})
|
})
|
||||||
.collect::<Vec<String>>()
|
.collect::<Vec<String>>()
|
||||||
|
@ -350,13 +353,21 @@ impl Tasks {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn join_tasks<'a>(iter: impl IntoIterator<Item = &'a Task>) -> String {
|
pub(crate) fn join_tasks<'a>(iter: impl Iterator<Item = &'a Task>) -> Option<String> {
|
||||||
iter.into_iter()
|
let tasks: Vec<&Task> = iter.collect();
|
||||||
.map(|t| t.event.content.clone())
|
tasks
|
||||||
|
.iter()
|
||||||
|
.map(|t| t.get_title())
|
||||||
|
.chain(
|
||||||
|
tasks
|
||||||
|
.last()
|
||||||
|
.and_then(|t| t.parent_id())
|
||||||
|
.map(|id| id.to_string())
|
||||||
|
.into_iter(),
|
||||||
|
)
|
||||||
.fold(None, |acc, val| {
|
.fold(None, |acc, val| {
|
||||||
Some(acc.map_or_else(|| val.clone(), |cur| format!("{}>{}", val, cur)))
|
Some(acc.map_or_else(|| val.clone(), |cur| format!("{}>{}", val, cur)))
|
||||||
})
|
})
|
||||||
.unwrap_or(String::new())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct ParentIterator<'a> {
|
struct ParentIterator<'a> {
|
||||||
|
@ -387,6 +398,7 @@ fn test_depth() {
|
||||||
tx,
|
tx,
|
||||||
keys: Keys::generate(),
|
keys: Keys::generate(),
|
||||||
});
|
});
|
||||||
|
|
||||||
let t1 = tasks.make_task("t1");
|
let t1 = tasks.make_task("t1");
|
||||||
let task1 = tasks.get_by_id(&t1.unwrap()).unwrap();
|
let task1 = tasks.get_by_id(&t1.unwrap()).unwrap();
|
||||||
assert_eq!(tasks.depth, 1);
|
assert_eq!(tasks.depth, 1);
|
||||||
|
@ -440,4 +452,13 @@ fn test_depth() {
|
||||||
assert_eq!(tasks.current_tasks().len(), 4);
|
assert_eq!(tasks.current_tasks().len(), 4);
|
||||||
tasks.depth = -1;
|
tasks.depth = -1;
|
||||||
assert_eq!(tasks.current_tasks().len(), 2);
|
assert_eq!(tasks.current_tasks().len(), 2);
|
||||||
|
|
||||||
|
let empty = tasks.make_task("");
|
||||||
|
let empty_task = tasks.get_by_id(&empty.unwrap()).unwrap();
|
||||||
|
let empty_id = empty_task.event.id.to_string();
|
||||||
|
assert_eq!(empty_task.get_title(), empty_id);
|
||||||
|
assert_eq!(tasks.get_task_path(empty), empty_id);
|
||||||
|
|
||||||
|
let zero = EventId::all_zeros();
|
||||||
|
assert_eq!(tasks.get_task_path(Some(zero)), zero.to_string());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue