Implement mark and unmark
This commit is contained in:
parent
888dd38a40
commit
8378018c8e
1 changed files with 15 additions and 0 deletions
|
@ -37,6 +37,8 @@
|
||||||
(define-key taskwarrior-mode-map (kbd "a") 'taskwarrior-add)
|
(define-key taskwarrior-mode-map (kbd "a") 'taskwarrior-add)
|
||||||
(define-key taskwarrior-mode-map (kbd "d") 'taskwarrior-done)
|
(define-key taskwarrior-mode-map (kbd "d") 'taskwarrior-done)
|
||||||
(define-key taskwarrior-mode-map (kbd "D") 'taskwarrior-delete)
|
(define-key taskwarrior-mode-map (kbd "D") 'taskwarrior-delete)
|
||||||
|
(define-key taskwarrior-mode-map (kbd "m") 'taskwarrior-mark-task)
|
||||||
|
(define-key taskwarrior-mode-map (kbd "u") 'taskwarrior-unmark-task)
|
||||||
(define-key taskwarrior-mode-map (kbd "f") 'taskwarrior-filter)
|
(define-key taskwarrior-mode-map (kbd "f") 'taskwarrior-filter)
|
||||||
(define-key taskwarrior-mode-map (kbd "r") 'taskwarrior-reset-filter)
|
(define-key taskwarrior-mode-map (kbd "r") 'taskwarrior-reset-filter)
|
||||||
(define-key taskwarrior-mode-map (kbd "P") 'taskwarrior-change-project))
|
(define-key taskwarrior-mode-map (kbd "P") 'taskwarrior-change-project))
|
||||||
|
@ -58,6 +60,19 @@
|
||||||
(next-line)
|
(next-line)
|
||||||
(taskwarrior--display-task-details-in-echo-area))
|
(taskwarrior--display-task-details-in-echo-area))
|
||||||
|
|
||||||
|
(defun taskwarrior-unmark-task ()
|
||||||
|
(interactive)
|
||||||
|
(let ((id (taskwarrior-id-at-point)))
|
||||||
|
(if (local-variable-p 'taskwarrior-marks)
|
||||||
|
(setq-local taskwarrior-marks (remove id taskwarrior-marks)))))
|
||||||
|
|
||||||
|
(defun taskwarrior-mark-task ()
|
||||||
|
(interactive)
|
||||||
|
(let ((id (taskwarrior-id-at-point)))
|
||||||
|
(if (local-variable-p 'taskwarrior-marks)
|
||||||
|
(setq-local taskwarrior-marks (delete-dups (cons id taskwarrior-marks)))
|
||||||
|
(setq-local taskwarrior-marks (list id)))))
|
||||||
|
|
||||||
(defun taskwarrior-id-at-point ()
|
(defun taskwarrior-id-at-point ()
|
||||||
(let ((line (thing-at-point 'line t)))
|
(let ((line (thing-at-point 'line t)))
|
||||||
(string-match "^[0-9]*" line)
|
(string-match "^[0-9]*" line)
|
||||||
|
|
Loading…
Reference in a new issue