]> git.vanrenterghem.biz Git - Dotty.git/blobdiff - emacs/.emacs.d/init.el
Various emacs config edits:
[Dotty.git] / emacs / .emacs.d / init.el
index 4d58dfe1031f2b8d83e2a70edf9ce0acc1530c59..ae30d66baee3aee38ebe6a4a5612de9f5a9e7d60 100644 (file)
 ;; Use light theme
 ;;(load-theme 'leuven t)
 (require 'modus-themes)
 ;; Use light theme
 ;;(load-theme 'leuven t)
 (require 'modus-themes)
-(load-theme 'modus-operandi t)
 (setq modus-themes-mixed-fonts t)
 (setq modus-themes-mixed-fonts t)
+(load-theme 'modus-operandi t)
+(variable-pitch-mode)
+(define-key global-map (kbd "<f5>") #'modus-themes-toggle)
+
+(require 'orderless)
+(setq completion-styles '(orderless basic)
+      completion-category-overrides '((file (styles basic partial-completion))))
+
+;; follow links to version-controlled files without confirming
+vc-follow-symlinks t
 
 ;; ESS - for working in R
 (autoload 'R-mode "ess-site.el" "Major mode for editing R source." t)
 
 ;; ESS - for working in R
 (autoload 'R-mode "ess-site.el" "Major mode for editing R source." t)
  '(denote-directory "/home/frederik/Nextcloud/notes/" t)
  '(org-export-backends '(ascii html icalendar latex md odt))
  '(package-selected-packages
  '(denote-directory "/home/frederik/Nextcloud/notes/" t)
  '(org-export-backends '(ascii html icalendar latex md odt))
  '(package-selected-packages
-   '(ftable flx nerd-icons-dired nerd-icons all-the-icons-dired marginalia vertico denote ox-rss org-ql org-contrib mustache org-static-blog haskell-mode julia-mode elfeed-protocol ack company magit auctex lsp-mode elpy ## org htmlize leuven-theme lua-mode ess-smart-underscore ess-R-data-view ess)))
+   '(emms mpdel-embark libmpdel pass password-store fontaine osm orderless embark-consult embark consult jinx dired-preview ftable flx nerd-icons-dired nerd-icons all-the-icons-dired marginalia vertico denote ox-rss org-ql org-contrib mustache org-static-blog haskell-mode julia-mode elfeed-protocol ack company magit auctex lsp-mode elpy ## org htmlize leuven-theme lua-mode ess-smart-underscore ess-R-data-view ess)))
 (custom-set-faces
  ;; custom-set-faces was added by Custom.
  ;; If you edit it by hand, you could mess it up, so be careful.
  ;; Your init file should contain only one such instance.
  ;; If there is more than one, they won't work right.
 (custom-set-faces
  ;; custom-set-faces was added by Custom.
  ;; If you edit it by hand, you could mess it up, so be careful.
  ;; Your init file should contain only one such instance.
  ;; If there is more than one, they won't work right.
'(default ((t (:family "Source Code Pro" :foundry "ADBO" :slant normal :weight normal :height 143 :width normal)))))
+ )
 
 
 ;; Send mail using SMTP via mail.vanrenterghem.io.
 
 
 ;; Send mail using SMTP via mail.vanrenterghem.io.
 (setq user-full-name "Frederik Vanrenterghem"
       smtpmail-local-domain "vanrenterghem.io"
       user-mail-address (concat "frederik@" smtpmail-local-domain))
 (setq user-full-name "Frederik Vanrenterghem"
       smtpmail-local-domain "vanrenterghem.io"
       user-mail-address (concat "frederik@" smtpmail-local-domain))
+;; Ignored in mu4e as it sets user-agent
 (setq mail-default-headers
       (concat "X-Mailer: GNU Emacs " (symbol-value 'emacs-version))) 
 (setq w3m-pop-up-frames t)
 (setq mail-default-headers
       (concat "X-Mailer: GNU Emacs " (symbol-value 'emacs-version))) 
 (setq w3m-pop-up-frames t)
 (elfeed-protocol-enable)
 (define-key elfeed-search-mode-map (kbd "*") (lambda () (interactive) (apply 'elfeed-search-toggle-all '(star))))
 (define-key elfeed-show-mode-map (kbd "*") (lambda () (interactive) (apply 'elfeed-show-tag '(star))))
 (elfeed-protocol-enable)
 (define-key elfeed-search-mode-map (kbd "*") (lambda () (interactive) (apply 'elfeed-search-toggle-all '(star))))
 (define-key elfeed-show-mode-map (kbd "*") (lambda () (interactive) (apply 'elfeed-show-tag '(star))))
+(add-hook 'elfeed-show-mode 'variable-pitch-mode)
 
 
-;; Read email using mu4e
+;; Read and write email using mu4e
 (require 'mu4e)
 (setq mail-user-agent 'mu4e-user-agent)
 (require 'mu4e)
 (setq mail-user-agent 'mu4e-user-agent)
+;; Also use mu4e when called from gnus-dired-attach
+(setq gnus-dired-mail-mode 'mu4e-user-agent)
 (setq mu4e-get-mail-command "mbsync io")
 (setq mu4e-update-interval 600)
 (setq mu4e-use-fancy-chars t)
 (setq mu4e-get-mail-command "mbsync io")
 (setq mu4e-update-interval 600)
 (setq mu4e-use-fancy-chars t)
 (setq mu4e-sent-folder   "/Sent"
       mu4e-drafts-folder "/Drafts"
       mu4e-trash-folder  "/Trash")
 (setq mu4e-sent-folder   "/Sent"
       mu4e-drafts-folder "/Drafts"
       mu4e-trash-folder  "/Trash")
-              
+(setq message-kill-buffer-on-exit t)
+;; attach files to mu4e messages by marking the file(s) in dired and pressing C-c RET C-a
+(add-hook 'dired-mode-hook 'turn-on-gnus-dired-mode)
+;; Define all bookmarks starting with favourite query used in mailcount modeline
+(setq mu4e-bookmarks
+      '(( :name "Last 24h's messages"
+         :key ?l
+         :favorite y
+         :query "date:24h..now AND NOT flag:trashed")
+       ( :name "Unread messages"
+         :query "flag:unread AND NOT flag:trashed"
+         :key ?u)
+       ( :name "Today's messages"
+         :query "date:today..now AND NOT flag:trashed"
+         :key ?t)
+       ( :name "Last 7 days"
+         :query "date:7d..now AND NOT flag:trashed"
+         :hide-unread t
+         :key ?w)
+       ( :name "Messages with images"
+         :query "mime:image/* AND NOT flag:trashed"
+         :key ?p)))
+
+;; Create custom spam status header and show in message view
+(add-to-list 'mu4e-header-info-custom
+ '(:spam-status .
+     ( :name "Spam-Status"     ;; long name, as seen in the message-view
+       :shortname "Spam"      ;; short name, as seen in the headers view
+       :help "The Spam status" ;; tooltip
+       ;; uses mu4e-fetch-field which is rel. slow, so only appropriate
+       ;; for mu4e-view-fields, and _not_ mu4e-headers-fields
+       :function (lambda (msg)
+                  (or (string-join (seq-take (split-string (or (mu4e-fetch-field msg "X-Spam-Status") "") " ") 2) " ") "")))))
+(add-to-list 'mu4e-view-fields :spam-status)
+
+;; Resize image attachments when sending email
+(defvar mu4e-resize-image-types '("jpg" "png" "svg" "jpeg")
+  "List of attached image types to resize.")
+
+(defvar mu4e-inhibit-resize nil)
+
+(defun mu4e-resize-image-attachments ()
+  (unless mu4e-inhibit-resize
+    (let (cmds
+      (image-types
+       (mapconcat #'identity mu4e-resize-image-types "\\|")))
+      (save-excursion
+    (message-goto-body-1)
+    (while (re-search-forward 
+        (format "<#part.+\\(filename=\"\\)\\(.+\\(\\.%s\\)\\)\""
+            image-types)
+        nil t)
+      (let* ((infile (match-string-no-properties 2))
+         (outfile (concat (temporary-file-directory)
+                  (file-name-nondirectory infile))))
+        (push (format "magick convert %s -resize 1200x1200\\> %s"
+              (shell-quote-argument infile)
+              (shell-quote-argument outfile))
+          cmds)
+        (replace-match outfile t t nil 2)))
+    (mapcar #'shell-command cmds)))))
+
+(add-hook 'message-send-hook 'mu4e-resize-image-attachments)
+
+(defun mu4e-inhibit-resize()
+  (interactive)
+  (set (make-local-variable 'mu4e-inhibit-resize) t))
+
 ;; Load configuration for website
 ;(load "mustache-html")
 
 ;; Load configuration for website
 ;(load "mustache-html")
 
 ;; Use 'winner' mode to undo and redo windows changes
 ;; using C-c <left> and C-c <right>.
 (winner-mode 1)
 ;; Use 'winner' mode to undo and redo windows changes
 ;; using C-c <left> and C-c <right>.
 (winner-mode 1)
+
+;; Use a different spell checker, always
+(add-hook 'emacs-startup-hook #'global-jinx-mode)
+(keymap-global-set "M-$" #'jinx-correct)
+
+;; Bind embark
+(keymap-global-set "C-." #'embark-act)
+(keymap-global-set "C-;" #'embark-dwim)
+
+;; Change default bindings to consult- ones
+(keymap-set ctl-x-map "b" #'consult-buffer)
+(global-set-key (kbd "M-y") 'consult-yank-pop)
+
+;; Configure `world-clock'
+
+(with-eval-after-load 'time
+  (setq zoneinfo-style-world-list '(("Europe/Brussels" "Leuven")))
+  (add-to-list 'zoneinfo-style-world-list '("Australia/Perth" "Perth")))
+
+