diff options
-rw-r--r-- | home/config.scm | 4 | ||||
-rw-r--r-- | home/dots/.emacs | 114 | ||||
-rw-r--r-- | home/dots/.emacs.d/BOGO-dark-theme.el | 2 | ||||
-rw-r--r-- | home/dots/.emacs.d/BOGO-theme.el | 2 | ||||
-rwxr-xr-x | home/dots/.local/bin/sync-mail | 1 | ||||
-rw-r--r-- | home/dots/.notmuch-config | 5 | ||||
-rwxr-xr-x | home/dots/mail/.notmuch/hooks/post-new | 9 | ||||
-rwxr-xr-x | home/dots/mail/.notmuch/hooks/pre-new | 8 |
8 files changed, 103 insertions, 42 deletions
diff --git a/home/config.scm b/home/config.scm index b5bc592..8d79291 100644 --- a/home/config.scm +++ b/home/config.scm @@ -105,7 +105,6 @@ notmuch emacs-notmuch afew - ungoogled-chromium pandoc kmonad git @@ -208,6 +207,9 @@ (home-mcron-configuration (jobs (list #~(job + '(next-hour) + "~/.local/bin/org-sync") + #~(job '(next-minute (range 0 60 5)) "~/.local/bin/sync-mail"))))) diff --git a/home/dots/.emacs b/home/dots/.emacs index 0fadb4e..80b6796 100644 --- a/home/dots/.emacs +++ b/home/dots/.emacs @@ -26,6 +26,8 @@ magit markdown-mode mastodon + org-present + visual-fill-column nix-mode notmuch @@ -371,20 +373,23 @@ :bind (("C-c m" . notmuch-jump-search)) :custom - ((notmuch-show-logo nil))) + (notmuch-address-use-company nil) + (notmuch-always-prompt-for-sender 't) + (notmuch-mua-user-agent-function 'notmuch) + (notmuch-show-logo nil)) (use-package pass :defer t :ensure t) -(defun elfeed-refresh () - (interactive) - (cl-loop for entry in (elfeed-search-selected) - do (elfeed-untag-1 entry 'unread)) - (elfeed-protocol-fever-reinit "https://freshrss@rss.mccd.space")) - (use-package elfeed :ensure t + :init + (defun elfeed-refresh () + (interactive) + (cl-loop for entry in (elfeed-search-selected) + do (elfeed-untag-1 entry 'unread)) + (elfeed-protocol-fever-reinit "https://freshrss@rss.mccd.space")) :bind (:map elfeed-search-mode-map ("G" . elfeed-refresh))) @@ -648,6 +653,9 @@ Index includes links and headings." :hook ((server-after-make-frame . exwm-mff-mode))) +(use-package hide-mode-line + :load-path "elisp") + (use-package isearch :defer t :bind @@ -826,6 +834,50 @@ Index includes links and headings." (eldoc-documentation-strategy 'eldoc-documentation-compose-eagerly) (eldoc-echo-area-use-multiline-p 'truncate-sym-name-if-fit)) +(use-package visual-fill-column + :custom + (visual-fill-column-width 110) + (visual-fill-column-center-text t)) + +(use-package org-present + :after visual-fill-column hide-mode-line + :init + (defun my/org-present-start () + ;; Center the presentation and wrap lines + (visual-fill-column-mode 1) + (hide-mode-line-mode 1) + (setq-local header-line-format " ") + (setq-local image-auto-resize 'fit-width) + (setq-local face-remapping-alist + '((variable-pitch (:height 1.5 :family "Liberation Serif") variable-pitch) + (header-line (:height 4.0) variable-pitch) + (org-document-title (:height 1.75) org-document-title) + (org-level-1 (:weight bold) org-level-1) + (org-code (:height 1.55) org-code) + (org-verbatim (:height 1.55) org-verbatim) + (org-block (:height 1.25) org-block) + (org-block-begin-line (:height 0.7) org-block))) + (variable-pitch-mode 1) + (flyspell-mode 0) + (tab-bar-mode 0) + (org-display-inline-images) + (visual-line-mode 1)) + + (defun my/org-present-end () + ;; Stop centering the document + (visual-fill-column-mode 0) + (setq-local header-line-format nil) + (hide-mode-line-mode 0) + (flyspell-mode 1) + (setq-local image-auto-resize nil) + (setq-local face-remapping-alist '((default variable-pitch default))) + (tab-bar-mode 1) + (visual-line-mode 0)) + + :hook + (org-present-mode . my/org-present-start) + (org-present-mode-quit . my/org-present-end)) + (use-package markdown-mode :defer t :ensure t @@ -980,12 +1032,14 @@ Index includes links and headings." (interactive) (async-shell-command "org-sync")) :custom - (org-complete-tags-always-offer-all-agenda-tags nil) + (org-complete-tags-always-offer-all-agenda-tags 't) (org-use-fast-tag-selection (quote auto)) + (org-goto-interface 'outline-path-completionp) + (org-outline-path-complete-in-steps nil) (org-refile-targets '((nil :maxlevel . 4) - (org-agenda-files :maxlevel . 4))) - (org-default-notes-file "~/personal-db/notes/lore.org") + (org-agenda-text-search-extra-files :maxlevel . 4))) + (org-default-notes-file "~/personal-db/notes/inbox.org") (org-hide-emphasis-markers t) (org-link-keep-stored-after-insertion t) (org-startup-folded t) @@ -1001,15 +1055,6 @@ Index includes links and headings." '((sequence "TODO(t)" "|" "DONE(d)") (sequence "UNREAD(u)" "READING(e)" "|" "READ(r)") (sequence "|" "CANCELED(c)"))) - (org-agenda-custom-commands - '(("t" "Regular" todo "TODO") - ("b" "Books" todo "UNREAD") - ("n" "Agenda and all TODOs" - ((agenda "today") - (todo "TODO"))) - ("p" "Pivå and Agenda" - ((tags-todo "+piva") - (agenda ""))))) (org-priority-lowest ?E) (org-priority-faces '((?A . (:weight bold :inherit org-priority)) (?D . (:foreground "gray50" :inherit org-priority)) @@ -1032,8 +1077,8 @@ Index includes links and headings." (set-face-attribute 'org-meta-line nil :inherit 'fixed-pitch) :hook ((org-mode . org-indent-mode) - (org-capture-after-finalize . sync-org) (org-mode . flyspell-mode) + (org-mode . org-display-inline-images) (org-mode . (lambda () (auto-revert-mode 1))) (org-mode . visual-line-mode) @@ -1097,7 +1142,7 @@ Index includes links and headings." :follow (lambda (kmacro) (kmacro-call-macro nil t nil (kbd kmacro)))) (org-link-set-parameters "goto" - :follow (lambda (keyword) (lgrep keyword "*.org" "~/personal-db/notes" nil))) + :follow (lambda (keyword) (kmacro-call-macro nil t nil (kbd (string-join '("M-x org-agenda <RET> s " keyword " <RET>")))))) :bind (("C-c l" . org-store-link))) @@ -1162,16 +1207,29 @@ Index includes links and headings." (use-package org-agenda :defer t :custom + (org-agenda-custom-commands + '(("t" "Regular" todo "TODO") + ("b" "Books" todo "UNREAD") + ("k" "Knowledge" + search "" ((org-agenda-files '("")) + (org-agenda-overriding-header "Lore"))) + ("n" "Agenda and all TODOs" + ((agenda "today") + (todo "TODO"))) + ("p" "Pivå and Agenda" + ((tags-todo "+piva") + (agenda ""))))) (org-agenda-files '("/home/mccd/personal-db/notes/cal-ios.org" - "/home/mccd/dev/sustainably/README.org" - "/home/mccd/dev/sustainably/exploration.org" - "/home/mccd/system/guix.org" "/home/mccd/personal-db/notes/agenda.org" "/home/mccd/personal-db/notes/log.org" - "/home/mccd/personal-db/notes/log.old.org" + "/home/mccd/personal-db/notes/log.old.org")) + (org-agenda-text-search-extra-files + '("/home/mccd/personal-db/notes/lore.org" + "/home/mccd/dev/sustainably/exploration.org" + "/home/mccd/dev/sustainably/README.org" "/home/mccd/personal-db/notes/inbox.org" - "/home/mccd/personal-db/notes/lore.org")) + "/home/mccd/system/guix.org")) (org-agenda-remove-tags t) (org-agenda-inhibit-startup nil) :config @@ -1404,7 +1462,7 @@ Index includes links and headings." (message-send-mail-function 'message-send-mail-with-sendmail) (message-sendmail-envelope-from 'header) (message-mail-user-agent t) - (mail-user-agent 'message-user-agent) + (mail-user-agent 'notmuch-user-agent) (message-kill-buffer-on-exit t)) (use-package sendmail @@ -1426,8 +1484,6 @@ Index includes links and headings." (mastodon-active-user "marcc") (mastodon-instance-url "https://fosstodon.org")) - - (use-package eww :custom (browse-url-browser-function 'eww-browse-url) ; Use eww as the default browser diff --git a/home/dots/.emacs.d/BOGO-dark-theme.el b/home/dots/.emacs.d/BOGO-dark-theme.el index 7be4377..56f3289 100644 --- a/home/dots/.emacs.d/BOGO-dark-theme.el +++ b/home/dots/.emacs.d/BOGO-dark-theme.el @@ -91,7 +91,7 @@ '(message-header-to ((t nil))) '(message-header-other ((t nil))) '(org-drawer ((t nil))) - '(org-hide ((t (:foreground "#1D1D1D")))) + '(org-hide ((t (:foreground "#1D1D1D" :inherit fixed-pitch)))) '(org-done ((t (:inherit (org-agenda-dimmed-todo-face fixed-pitch) :strike-through nil :extend nil :weight bold)))) '(org-todo ((t (:weight bold :inherit fixed-pitch)))) '(org-checkbox ((t (:weight bold :inherit fixed-pitch)))) diff --git a/home/dots/.emacs.d/BOGO-theme.el b/home/dots/.emacs.d/BOGO-theme.el index d68a25a..bfd0181 100644 --- a/home/dots/.emacs.d/BOGO-theme.el +++ b/home/dots/.emacs.d/BOGO-theme.el @@ -95,7 +95,7 @@ '(org-list-dt ((t (:weight bold)))) '(org-agenda-calendar-event ((t nil))) '(org-drawer ((t :inherit fixed-pitch))) - '(org-hide ((t (:foreground "#FFFFF8")))) + '(org-hide ((t (:foreground "#FFFFF8" :inherit fixed-pitch)))) '(org-done ((t (:inherit (org-agenda-dimmed-todo-face fixed-pitch) :strike-through nil :extend nil :weight bold)))) '(org-todo ((t (:weight bold :inherit fixed-pitch)))) '(org-checkbox ((t (:weight bold :inherit fixed-pitch)))) diff --git a/home/dots/.local/bin/sync-mail b/home/dots/.local/bin/sync-mail index 575d849..ffb126f 100755 --- a/home/dots/.local/bin/sync-mail +++ b/home/dots/.local/bin/sync-mail @@ -1,6 +1,5 @@ #!/usr/bin/env bash set -e -#sh ~/mail/.notmuch/hooks/pre-sync mbsync -a notmuch new diff --git a/home/dots/.notmuch-config b/home/dots/.notmuch-config index 20b3f85..51b771a 100644 --- a/home/dots/.notmuch-config +++ b/home/dots/.notmuch-config @@ -9,9 +9,8 @@ # Notmuch will store its database within a sub-directory of the path # configured here named ".notmuch". # -[show] -extra_headers=X-Mailer,User-Agent [database] +path=mail # User configuration # # Here is where you can let notmuch know how you would like to be @@ -27,6 +26,8 @@ extra_headers=X-Mailer,User-Agent # recipient list of replies, and will set the From address based on the # address to which the original email was addressed. # +[show] +extra_headers=X-Mailer,User-Agent [user] name=Marc Coquand primary_email=marc@coquand.email diff --git a/home/dots/mail/.notmuch/hooks/post-new b/home/dots/mail/.notmuch/hooks/post-new index ef985c0..be2f5bb 100755 --- a/home/dots/mail/.notmuch/hooks/post-new +++ b/home/dots/mail/.notmuch/hooks/post-new @@ -9,5 +9,14 @@ notmuch tag +flight -- path:/home/Archive/Flight/ afew --tag --new +notmuch search --output=files "path:/.*/INBOX/" tag:home and tag:deleted | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Trash/' | sed 's/,U=[0-9]*:/:/'); done +notmuch search --output=files "path:/.*/INBOX/" tag:home and tag:receipt and not tag:inbox | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Archive\/Receipt/' | sed 's/,U=[0-9]*:/:/'); done +notmuch search --output=files "path:/.*/INBOX/" tag:home and tag:flight and not tag:inbox | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Archive\/Flight/' | sed 's/,U=[0-9]*:/:/'); done + +notmuch search --output=files "path:/.*/INBOX/" tag:home and not tag:inbox | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Archive/' | sed 's/,U=[0-9]*:/:/'); done + +# work +notmuch search --output=files "path:/.*/INBOX/" tag:work and tag:deleted | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/\[Gmail\]\/Trash/' | sed 's/,U=[0-9]*:/:/'); done +#notmuch search --output=files "path:/.*/INBOX/" and tag:work and not tag:inbox | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/\[Gmail\]\/All Mail/' | sed 's/,U=[0-9]*:/:/'); done diff --git a/home/dots/mail/.notmuch/hooks/pre-new b/home/dots/mail/.notmuch/hooks/pre-new index 949d909..b39a33c 100755 --- a/home/dots/mail/.notmuch/hooks/pre-new +++ b/home/dots/mail/.notmuch/hooks/pre-new @@ -1,8 +1,2 @@ #!/run/current-system/profile/bin/bash -notmuch search --output=files "path:/.*/INBOX/" tag:home and tag:deleted | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Trash/' | sed 's/,U=[0-9]*:/:/'); done - -notmuch search --output=files "path:/.*/INBOX/" tag:home and tag:receipt and not tag:inbox | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Archive\/Receipt/' | sed 's/,U=[0-9]*:/:/'); done - -notmuch search --output=files "path:/.*/INBOX/" tag:home and tag:flight and not tag:inbox | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Archive\/Flight/' | sed 's/,U=[0-9]*:/:/'); done - -notmuch search --output=files "path:/.*/INBOX/" tag:home and not tag:inbox | while IFS= read -r f; do mv -v $f $(echo $f | sed 's/INBOX/Archive/' | sed 's/,U=[0-9]*:/:/'); done +# Home |