Questo plugin permette di gestire i task sparsi per le varie note in Obsidian potendoli raggruppare con delle query dinamiche.
Questo plugin permette di effettuare delle query sulle checklist che hanno un determinato tag (chiamato global filter) o, se tale tag Γ¨ vuoto, tutte le checklist nel vault.
La sintassi markdown per i task Γ¨ elenco puntato con parentesi quadre separate da spazio:
- [ ] #task take out the trash.
Per creare un task con la modale basta evidenziare il testo del task e premere ctrl + alt + t.
I comandi obsidian task utilizzano la sintassi:
```tasks
[comando]
```
Per il toggle del task posso usare ctrl + enter se sono in edit mode, in preview invece basta il click.
PrioritΓ
Ogni task puΓ² avere una prioritΓ che viene identificata tramite una delle seguenti emoji:
- β« alta prioritΓ
- πΌ PrioritΓ media
- π½ Bassa prioritΓ Lo scopo Γ¨ ovviamente permette di filtrare i task in base alle prioritΓ .
Date
Ho tre possibilitΓ :
- π
Due: task che hanno una data entro la quale devono essere completati. Per farlo Γ¨ necessario aggiungere lβemoji π
seguita dalla data nel formato
YYYY-MM-DD. Esempio:- [ ] #task take out the trash π 2021-04-09. La maggior parte dei task utilizzeranno al massimo la due date.; - β³ Scheduled: task che hanno delle date in cui hai pianificato che dovranno essere fatti. Per farlo Γ¨ necessario aggiungere lβemoji β³ seguita dalla data nel formato
YYYY-MM-DD. Tipicamente possono avere delle date schedulate per un task che siano, ovviamente, inferiori alla due date. Esempio:- [ ] #task take out the trash β³ 2021-04-09. - π« Start: PuΓ² capitare che Γ¨ impossibile iniziare un task prima di una certa data o che non voglio vedere un task prima di una certa data. Per farlo Γ¨ necessario aggiungere lβemoji π« seguita dalla data nel formato
YYYY-MM-DD.
Task ripetuti
Eβ possibile creare dei task ricorrenti che si ripetono ogni tot giorni.
Per fare questo Γ¨ necessario usare lβemoji π seguita dalla parola chiave every e da una keyword.
Per esempio π every weekday fa ripetere il task tutti i giorni della settimana dal lunedΓ¬ a venerdΓ¬.
Quando un task ricorrente viene marcato come completato viene creato un task ulteriore con la nuova data sopra il task completato.
Per esempio se ho il seguente task:
- [ ] #task take out the trash π every Sunday π
2021-04-25
Quando viene completato viene creato un nuovo task sopra nel seguente modo:
- [ ] take out the trash π every Sunday π
2021-05-02
- [x] take out the trash π every Sunday π
2021-04-25 β
2021-04-24
Assumiamo che un task sia da lanciare ogni settimana ma io salto una settimana dal completarlo. Una volta fatto il task successivo quando viene creato?
Di default viene creato una settimana dopo lβoriginale, indipendentemente da quando il task Γ¨ stato completato.
Se invece vogliamo che il nuovo task sia creato una settimana dopo la data di completamento devo aggiungere la keyword when done.
In questo esempio il nuovo task Γ¨ creato una settimana dopo il primo.
- [ ] #task sweep the floors π every week β³ 2021-02-13
- [x] sweep the floors π every week β³ 2021-02-06 β
2022-02-13
In questo esempio invece una settimana dopo la data di completamento.
- [ ] #task sweep the floors π every week when done β³ 2022-02-20
- [x] sweep the floors π every week when done β³ 2021-02-06 β
2022-02-13
Esempi:
π every 3 daysπ every 10 days when doneπ every weekday(tutti i giorni da lunedΓ¬ a venerdΓ¬)π every week on Sundayπ every 2 weeksπ every 3 weeks on Fridayπ every 2 monthsπ every month on the 1stπ every month on the lastπ every 6 months on the 2nd Wednesdayπ every January on the 15thπ every February on the lastπ every April and December on the 1st and 24th( ogni primo aprile e 24 dicembre)π every year
Query
Le query sono formate da n righe con i filtri in AND (lβAND Γ¨ sottointeso).
Per aggiungere altri operatori come NOT, AND, OR, AND NOT, OR NOT li devi aggiungere sulla stessa riga raggruppati tra parentesi.
```tasks
not done
(due after yesterday) AND (due before in two weeks)
(tags include #inbox) OR (path includes Inbox) OR (heading includes Inbox)
```
Filtraggio per date
Per filtrare le date posso prendere questi esempi:
2021-05-25yesterdaytodaytomorrownext mondaylast friday14 days agoin two weeks
Done date
donenot doneno done datehas done datedone (before|after|on) <date>
Due date
no due datehas due datedue (before|after|on) <date>
Scheduled date
no scheduled datehas scheduled datescheduled (before|after|on) <date>
Start date
no start datehas start datestarts (before|after|on) <date>
Happens (Due or Scheduled or Start)
happens before tomorrow: tutti i task che sono schedulati, partono o devono essere fatti entro domani.
Description
Permette di matchare la stringa del task.
description (includes|does not include) <string>description (regex matches|regex does not match) /<JavaScript-style Regex>/
PrioritΓ
priority is (above|below)? (low|none|medium|high)
Status
donenot done
Tags
tags (include|do not include) <tag>tags (regex matches|regex does not match) /<JavaScript-style Regex>/
Nome file
filename (includes|does not include) <filename>
Ordinamento
Lβordinamento di default viene effettuato secondo un criterio di βurgenzaβ calcolato dal plugin.
Per modificare tale ordinamento Γ¨ possibile utilizzare la keyword sort by.
Esempi:
statuspriorityduepath
Esempio: Task da fare nei prossimi 7 giorni
Voglio tutti i task che dovranno essere eseguiti entro i prossimi 7 giorni (puΓ² essere utile in un template di un weekly plan).
P.s. per testare una query conviene creare delle βsuite di testβ con dei task fittizzi per capire costa sto matchando o no.
Quindi voglio i task con due date (quindi keyword due) e prima di una certa data, quindi before in .
Conseguentemente il filtro corretto Γ¨:
```tasks
not done
due before in 7 days
```
Notifiche
Eβ possibile far arrivare le notifiche quando bisogna fare un task utilizzando obsidian-reminder. Una volta installato controllare che ci sia abilitata lβopzione βenabled the tasks plugin formatβ. Il plugin si basa sulla reminder date che deve essere messa sempre immediatamente prima della due date.
- [ ] #task #task task name β° YYYY-MM-DD HH:mm π
YYYY-MM-DD β« π every week π« YYYY-MM-DD β³ YYYY-MM-DD