Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Add Reminder Field Support #2750

Draft
wants to merge 83 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
0dd8b80
not updating tests
stevendkwtz Mar 12, 2024
b1b41ce
Add toggle task endpoint
stevendkwtz Mar 7, 2024
25bfe3a
Make toggleTask return tasks
stevendkwtz Mar 7, 2024
b107bf2
add new api function
stevendkwtz Mar 7, 2024
424c90c
add reminder
stevendkwtz Mar 11, 2024
0ff168b
fix Edit Task
stevendkwtz Mar 11, 2024
767129a
Fix reminders
stevendkwtz Mar 11, 2024
7348320
Fix reminders
stevendkwtz Mar 11, 2024
40cd2e5
updating tests
stevendkwtz Mar 14, 2024
2904b16
remove mapObjToTasks from custom API
stevendkwtz Mar 14, 2024
87db8b3
not updating tests
stevendkwtz Mar 12, 2024
7955956
Merge branch 'main' of github.com:stevendkwtz/obsidian-tasks into main
stevendkwtz Mar 20, 2024
68f6a7c
Add toggle task endpoint
stevendkwtz Mar 7, 2024
8579952
Make toggleTask return tasks
stevendkwtz Mar 7, 2024
1842d84
add new api function
stevendkwtz Mar 7, 2024
22192d0
add reminder
stevendkwtz Mar 11, 2024
478a2f4
Fix reminders
stevendkwtz Mar 11, 2024
7710e90
Fix reminders
stevendkwtz Mar 11, 2024
ec76d68
updating tests
stevendkwtz Mar 14, 2024
15578cc
remove mapObjToTasks from custom API
stevendkwtz Mar 14, 2024
7fafed2
rebase from upstream
stevendkwtz Mar 20, 2024
2ff6393
rebase from upstream
stevendkwtz Mar 20, 2024
1a39f3e
Merge branch 'develop' of github.com:stevendkwtz/obsidian-tasks into …
stevendkwtz Mar 20, 2024
dec9acf
rebase from upstream
stevendkwtz Mar 20, 2024
235b898
not updating tests
stevendkwtz Mar 12, 2024
d72285a
Add toggle task endpoint
stevendkwtz Mar 7, 2024
b3aecd6
Make toggleTask return tasks
stevendkwtz Mar 7, 2024
18c5178
add new api function
stevendkwtz Mar 7, 2024
f22d7c8
add reminder
stevendkwtz Mar 11, 2024
9a9049d
fix Edit Task
stevendkwtz Mar 11, 2024
038f9fc
Fix reminders
stevendkwtz Mar 11, 2024
fa94474
Fix reminders
stevendkwtz Mar 11, 2024
ec23842
updating tests
stevendkwtz Mar 14, 2024
4c43766
remove mapObjToTasks from custom API
stevendkwtz Mar 14, 2024
8f21185
not updating tests
stevendkwtz Mar 12, 2024
7062e3b
Add toggle task endpoint
stevendkwtz Mar 7, 2024
4c9cf2e
Make toggleTask return tasks
stevendkwtz Mar 7, 2024
b1221d3
add new api function
stevendkwtz Mar 7, 2024
7a7b139
add reminder
stevendkwtz Mar 11, 2024
2b17fb0
Fix reminders
stevendkwtz Mar 11, 2024
9cfc974
Fix reminders
stevendkwtz Mar 11, 2024
a8bdbfe
updating tests
stevendkwtz Mar 14, 2024
0f170fb
remove mapObjToTasks from custom API
stevendkwtz Mar 14, 2024
f480d58
rebase from upstream
stevendkwtz Mar 20, 2024
c37aca1
rebase from upstream
stevendkwtz Mar 20, 2024
0b675ab
rebase from upstream
stevendkwtz Mar 20, 2024
7c21f36
Omg im out of rebase hell
stevendkwtz Mar 29, 2024
7ac756a
Omg im out of rebase hell
stevendkwtz Mar 29, 2024
0bba78b
Merge branch 'develop' of github.com:stevendkwtz/obsidian-tasks into …
stevendkwtz Mar 29, 2024
cceec32
more merge hell
stevendkwtz Mar 29, 2024
f858e2f
Fix tests with Clare for reminders
stevendkwtz Apr 2, 2024
01b97a8
Fix failing tests, saving of reminder fields with date time
stevendkwtz Apr 5, 2024
33e3271
chore: Revert changes to lefthook.yml
claremacrae Apr 5, 2024
6eb0648
chore: Revert changes to manifest.json
claremacrae Apr 5, 2024
678cf49
chore: Revert changes to package.json
claremacrae Apr 5, 2024
1b5b1a9
chore: Remove added file package-lock.json
claremacrae Apr 5, 2024
1637a48
refactor: Remove stray spaces in EditTask.svelte
claremacrae Apr 5, 2024
d283759
revert: Remove changes in src/Api/
claremacrae Apr 5, 2024
4d0dd69
chore: Revert changes to yarn.lock
claremacrae Apr 5, 2024
d58efdb
comment: Revert likely accidental change
claremacrae Apr 5, 2024
5b81fba
test: Reinstate an accidentally deleted test
claremacrae Apr 5, 2024
cd1c134
test: Revert changes to what turned out to be a fragile test
claremacrae Apr 5, 2024
02f467d
test: - Add tests for recurrence based on reminder - one is failing
claremacrae Apr 9, 2024
22e5261
test: - Confirm Recurrence honours recurrence time
claremacrae Apr 9, 2024
f4069dd
refactor: Move isDateTime() to DateTools.ts
claremacrae Apr 9, 2024
7690614
test: Add tests for isDateTime()
claremacrae Apr 9, 2024
d5370e6
test: - Extract helper function
claremacrae Apr 9, 2024
26eda75
test: - Reuse helper function
claremacrae Apr 9, 2024
a1f5a17
Merge branch '7.1.0-temp' into fork/stevendkwtz-reminders-merge-7.1.0
claremacrae May 7, 2024
3bc67e2
Merge branch 'main' into fork/stevendkwtz-reminders-merge-7.1.0
claremacrae May 7, 2024
d26f995
test: Check DateTools functions with times. One test marked 'failing'
claremacrae May 7, 2024
8e559b2
test: Check TaskBuilder retains times on Reminder (it doesn't)
claremacrae May 7, 2024
fa22287
test: Confirm that Task parses times on reminders
claremacrae May 7, 2024
9ab7365
test: Check that EditTask preserves time on reminder (1 failing test)
claremacrae May 7, 2024
906d702
test: Add TODO to add a time to the sample reminder value
claremacrae May 7, 2024
1a9b4f5
test: Add formatAsDateAndTimeOrDate() to Task Properties snippet, for…
claremacrae May 7, 2024
cb1aaa3
Update DateTools.parseTypedDateForDisplay to handle date time for rem…
stevendkwtz May 7, 2024
e385b25
Update DateTools.parseTypedDateForDisplay to handle partial reminder …
stevendkwtz May 7, 2024
62f119b
Update DateTools.parseTypedDateForDisplay to handle reminder date par…
stevendkwtz May 7, 2024
bc2f9df
Fix failing EditTask test for reminder date time, add new function to…
stevendkwtz May 21, 2024
0f50f43
test: Add failing test showing reminder does not parse free text
claremacrae May 21, 2024
c93fa6b
refactor: Reformat long line
claremacrae May 21, 2024
791fd53
Merge branch 'main' into fork/stevendkwtz-reminders
claremacrae May 25, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/Renderer/TaskLineRenderer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import { StatusMenu } from '../ui/Menus/StatusMenu';
import { TaskFieldRenderer } from './TaskFieldRenderer';

/**
* The function used to render a Markdown task line into an existing HTML element
* The function used to render a Markdown task line into an existing HTML element.
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

😅 if you're wondering where this came from. git rebase --continue wouldn't work during an ongoing massive rebase because it kept saying no file changed. so I had to make a small edit to get it to continue.

*/
export type TextRenderer = (
text: string,
Expand Down
4 changes: 4 additions & 0 deletions tests/Renderer/TaskLineRenderer.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -266,6 +266,10 @@ describe('task line rendering - layout options', () => {
await testLayoutOptions(['Do exercises #todo #health', ' ⏳ 2023-07-03'], [TaskLayoutComponent.ScheduledDate]);
});

it('renders with due date', async () => {
await testLayoutOptions(['Do exercises #todo #health', ' 📅 2023-07-04'], [TaskLayoutComponent.DueDate]);
});

it('renders with reminder date', async () => {
await testLayoutOptions(['Do exercises #todo #health', ' ⏰ 2023-07-07'], [TaskLayoutComponent.ReminderDate]);
});
Expand Down
35 changes: 4 additions & 31 deletions tests/TaskSerializer/TaskSerializer.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ import type { TaskDetails, TaskSerializer } from '../../src/TaskSerializer';
import { TaskBuilder } from '../TestingTools/TaskBuilder';
import { Priority } from '../../src/Task/Priority';
import { TaskRegularExpressions } from '../../src/Task/TaskRegularExpressions';
import { isDateTime } from '../../src/Scripting/TasksDate';

jest.mock('obsidian');
window.moment = moment;
Expand Down Expand Up @@ -36,7 +35,7 @@ describe('TaskSerializer Example', () => {
deserialize(line: string): TaskDetails {
// Parse tokens
const parsedTokens = line.trim().split(/\s+/);
const [priorityString, dueDateString, reminderDateString, ...descriptionParts] = parsedTokens;
const [priorityString, dueDateString, ...descriptionParts] = parsedTokens;

// Validate dueDate
let dueDate = null;
Expand All @@ -50,23 +49,6 @@ describe('TaskSerializer Example', () => {
}
}

// Validate reminderDate
let reminderDate = null;
if (reminderDateString) {
const parsedReminderDate = moment(
reminderDateString,
reminderDateString.length > 10
? TaskRegularExpressions.dateTimeFormat
: TaskRegularExpressions.dateFormat,
);
if (parsedReminderDate.isValid()) {
reminderDate = parsedReminderDate;
} else {
// Add back to description if invalid
descriptionParts.unshift(reminderDateString);
}
}

// Validate priority
let priority = Priority.None;
if (priorityString) {
Expand All @@ -83,8 +65,8 @@ describe('TaskSerializer Example', () => {
description,
tags: Task.extractHashtags(description),
dueDate,
reminderDate,
priority,
reminderDate: null,
startDate: null,
createdDate: null,
scheduledDate: null,
Expand All @@ -98,16 +80,7 @@ describe('TaskSerializer Example', () => {

/* Represents task as a string */
serialize(task: Task): string {
return [
task.priority,
task.dueDate?.format(TaskRegularExpressions.dateFormat),
task.description,
task.reminderDate?.format(
isDateTime(task.reminderDate)
? TaskRegularExpressions.dateTimeFormat
: TaskRegularExpressions.dateFormat,
),
]
return [task.priority, task.dueDate?.format(TaskRegularExpressions.dateFormat), task.description]
.filter((x) => x)
.join(' ');
}
Expand All @@ -124,7 +97,7 @@ describe('TaskSerializer Example', () => {
expect(ts.deserialize('1')).toMatchTaskDetails({ priority: Priority.High });
});

it.failing('should parse just a description', () => {
it('should parse just a description', () => {
expect(ts.deserialize('Hello World, this is a task description')).toMatchTaskDetails({
description: 'Hello World, this is a task description',
});
Expand Down