summaryrefslogtreecommitdiff
path: root/emacs/.config/emacs-kj/lisp/kj-org.el
blob: b6fda9c7b247162017be2c18de1c377c9d244efa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
;;; -*- lexical-binding: t; -*-

(use-package org
  :config
  (org-babel-do-load-languages 'org-babel-load-languages
			       '((emacs-lisp . t)
                                 (sql . t)
				 (shell . t)))
  (setq org-confirm-babel-evaluate nil
        org-return-follows-link t
        )

  ;; Install the link type
  (org-add-link-type "notmuch" 'org-notmuch-open)
  (add-hook 'org-store-link-functions 'org-notmuch-store-link)

  (defun org-notmuch-store-link ()
    "Store a link to a notmuch search or message."
    (when (eq major-mode 'notmuch-show-mode)
      (let* ((message-id (notmuch-show-get-prop :id))
	     (subject (notmuch-show-get-subject))
	     (to (notmuch-show-get-to))
	     (from (notmuch-show-get-from))
	     desc link)
        (org-store-link-props :type "notmuch" :from from :to to
       			      :subject subject :message-id message-id)
        (setq desc (org-email-link-description))
        (setq link (concat "notmuch:"  "id:" message-id))
        (org-add-link-props :link link :description desc)
        link)))

  (defun org-notmuch-open (path)
    "Follow a notmuch message link specified by PATH."
    (org-notmuch-follow-link path))

  (defun org-notmuch-follow-link (search)
    "Follow a notmuch link to SEARCH.

Can link to more than one message, if so all matching messages are shown."
    (require 'notmuch)
    (notmuch-show (org-link-unescape search)))

  (org-add-link-type "notmuch-search" 'org-notmuch-search-open)
  (add-hook 'org-store-link-functions 'org-notmuch-search-store-link)

  (defun org-notmuch-search-store-link ()
    "Store a link to a notmuch search or message."
    (when (eq major-mode 'notmuch-search-mode)
      (let ((link (concat "notmuch-search:"
			  (org-link-escape notmuch-search-query-string)))
	    (desc (concat "Notmuch search: " notmuch-search-query-string)))
        (org-store-link-props :type "notmuch-search"
			      :link link
			      :description desc)
        link)))

  (defun org-notmuch-search-open (path)
    "Follow a notmuch message link specified by PATH."
    (message path)
    (org-notmuch-search-follow-link path))

  (defun org-notmuch-search-follow-link (search)
    "Follow a notmuch link by displaying SEARCH in notmuch-search mode."
    (require 'notmuch)
    (notmuch-search (org-link-unescape search)))

  ;; If you use `org' and don't want your org files in the default location below,
  ;; change `org-directory'. It must be set before org loads!
  (setq org-directory "~/org/")
  (setq org-todo-keywords
        '((sequence
           "TODO(t)" "ACTIVE(a!)" "WAIT(w@/!)" "|" "DONE(d!)" "CANCELED(c@)")))
  (setq org-refile-use-outline-path nil)
  (setq org-refile-targets '((nil . (:maxlevel . 2))))
  (setq org-log-into-drawer t)
  (setq org-agenda-log-mode-items '(closed clock state))
  (setq org-agenda-start-day nil)
  (setq org-agenda-block-separator nil)
  (setq org-agenda-compact-blocks t)
  (setq org-agenda-start-with-log-mode nil)
  (setq org-habit-show-all-today t)
  (setq org-agenda-time-grid '((daily today require-timed) (800 1600) "......" "----------------------"))
  (setq org-roam-directory (concat org-directory "roam/"))
  (setq-default org-agenda-files '())
  (dolist (file '("tasks.org"
                  "running-2022.org"))
    (add-to-list 'org-agenda-files (concat org-roam-directory file)))
  (setq org-roam-db-location (concat org-roam-directory "/org-roam.db"))
  (setq org-export-with-toc nil)
  (setq deft-directory org-directory)
  (setq deft-recursive t)
  ;; Org html export
  (setq org-html-htmlize-output-type 'css)
  ;; Website publish settings.
  (defvar kj/publish-tag "publish")
  (defvar kj/publish-directory "/ssh:orbekk@dragon.orbekk.com:/storage/srv/kj.orbekk.com")
  (add-to-list 'org-modules 'org-habit)

  (defvar org-publish-project-alist)
  (defun kj/find-agenda-files-containing-tag (tag)
    (setq org-agenda-archives-mode nil)
    (let* ((org-agenda-archives-mode nil)
           (candidates (org-agenda-files nil 'ifmode))
           (matcher (cdr (org-make-tags-matcher tag)))
           (files))
      ;; (message "Results:")
      (dolist (file candidates files)
        (org-check-agenda-file file)
        (with-current-buffer (org-get-agenda-file-buffer file)
          ;; (message "%S" (org-scan-tags 'agenda matcher nil))
          (when (org-scan-tags 'agenda matcher nil)
            (push file files))))))

  (defun kj/org-publish (&optional project force)
    (interactive)
    (setq project (or project "all"))
    (setq force (or force current-prefix-arg))
    (setq org-agenda-files (list org-roam-directory))
    (let* ((static-files-re (string-join '("css" "txt" "jpg" "png" "gif" "svg") "\\|"))
           (files-to-include (kj/find-agenda-files-containing-tag kj/publish-tag))
           ;; Disable org babel exports during publish entirely to speed up publish.
           ;; This messes up babel output handling.
           ;; (org-export-use-babel nil)
           (org-babel-default-header-args
            (kj/assq-replace '((:exports . "both")
                               (:eval . "never-export"))
                             org-babel-default-header-args))
           (org-publish-project-alist
            `(
              ("static"
               :base-directory ,(concat org-roam-directory "/static")
               :base-extension ,static-files-re
               :recursive t
               :publishing-directory ,(concat kj/publish-directory "/static")
               :publishing-function org-publish-attachment)
              ("source"
               :base-directory ,org-roam-directory
               :base-extension "org"
               :exclude ".*"
               :include ,files-to-include
               :recursive t
               :publishing-directory ,kj/publish-directory
               :publishing-function org-publish-attachment)
              ("html"
               :base-directory ,org-roam-directory
               :base-extension "org"
               :recursive t
               :exclude ".*"
               :include ,files-to-include
               :publishing-directory ,kj/publish-directory
               :publishing-function org-html-publish-to-html

               :with-broken-links t
               :with-toc nil
               :with-latex t
               :with-drawers t
               :with-title t
               :section-numbers nil

               ;; HTML options
               :html-toplevel-hlevel 2
               :html-preamble ""
               :html-postamble ""
               :html-html5-fancy t
               :html-doctype "html5"
               :html-head "<link rel=\"stylesheet\" type=\"text/css\" href=\"static/org.css\"/>"
               :html-head-include-scripts nil
               :html-head-include-default-style nil
               :html-container article)

              ("all" :components ("static" "source" "html")))))

      (org-publish project force)))
					; (setq org-appear-autolinks t)
					; (use-package! org-appear
					;   :hook (org-mode . org-appear-mode))

  (setq org-log-done 'time)
  (setq org-todo-keywords
        '((sequence
           "TODO(t)"  ; A task that needs doing & is ready to do
           "PROJ(p)"  ; A project, which usually contains other tasks
           "LOOP(r)"  ; A recurring task
           "STRT(s)"  ; A task that is in progress
           "WAIT(w)"  ; Something external is holding up this task
           "HOLD(h)"  ; This task is paused/on hold because of me
           "IDEA(i)"  ; An unconfirmed and unapproved task or notion
           "|"
           "DONE(d!)"  ; Task successfully completed
           "KILL(k)") ; Task was cancelled, aborted or is no longer applicable
          (sequence
           "[ ](T)"   ; A task that needs doing
           "[-](S)"   ; Task is in progress
           "[?](W)"   ; Task is being held up or paused
           "|"
           "[X](D)")  ; Task was completed
          (sequence
           "|"
           "OKAY(o)"
           "YES(y)"
           "NO(n)")))

  (setq org-journal-file-type 'weekly)
  (setq org-journal-dir org-roam-directory)
  (setq org-journal-file-format "journal-%Y-%m-%d.org")
  (setq org-journal-enable-agenda-integration t)
  (defun kj/org-journal-init ()
    (interactive)
    (save-excursion
      (goto-char (point-min))
      (org-id-get-create)
      (org-set-property "category" "journal")))

  (defun kj/org-journal-file-header (time)
    (format-time-string "#+title: Week of %F (%W)\n"
                        (org-journal--convert-time-to-file-type-time time)))
  (setq org-journal-file-header #'kj/org-journal-file-header)
  (add-hook 'org-journal-after-header-create-hook 'kj/org-journal-init)

  ;; Org
  (add-to-list 'org-export-backends 'md)

  (require 'org-tempo))

(defun org-archive-done-tasks ()
  (interactive)
  (org-map-entries
   (lambda ()
     (org-archive-subtree)
     (setq org-map-continue-from (org-element-property :begin (org-element-at-point))))
   "/DONE" 'file))

(use-package org-pomodoro
  :ensure t
  :after org
  :commands (org-pomodoro)
  :config
  (setq
   org-pomodoro-manual-break t
   org-pomodoro-time-format "%m"
   org-pomodoro-format "🍅%s"
   org-pomodoro-play-sounds nil
   alert-user-configuration (quote ((((:category . "org-pomodoro")) notifications nil))))
  :bind
  (("C-c o p" . org-pomodoro)))

(use-package org-tidy
  :after org
  :hook (org-mode . org-tidy-mode))

(provide 'kj-org)