X-Git-Url: http://git.vanrenterghem.biz/Dotty.git/blobdiff_plain/ce959d4594c8fa4e0776c182ff2e02356e8a9d1f..0ef958766a7e652d35981030d9a7c991ee71c9fd:/emacs/.emacs.d/init.el diff --git a/emacs/.emacs.d/init.el b/emacs/.emacs.d/init.el index 51f86f1..ae30d66 100644 --- a/emacs/.emacs.d/init.el +++ b/emacs/.emacs.d/init.el @@ -12,8 +12,17 @@ ;; Use light theme ;;(load-theme 'leuven t) (require 'modus-themes) -(load-theme 'modus-operandi t) (setq modus-themes-mixed-fonts t) +(load-theme 'modus-operandi t) +(variable-pitch-mode) +(define-key global-map (kbd "") #'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) @@ -85,13 +94,13 @@ '(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. - '(default ((t (:family "Source Code Pro" :foundry "ADBO" :slant normal :weight normal :height 143 :width normal))))) + ) ;; Send mail using SMTP via mail.vanrenterghem.io. @@ -102,6 +111,7 @@ (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) @@ -124,10 +134,13 @@ (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) +;; 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) @@ -135,6 +148,29 @@ (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 . @@ -144,9 +180,42 @@ ;; 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 (mu4e-fetch-field msg "X-Spam-Status") " ") 2) " ") ""))))) + (or (string-join (seq-take (split-string (or (mu4e-fetch-field msg "X-Spam-Status") "") " ") 2) " ") ""))))) (add-to-list 'mu4e-view-fields :spam-status) -b + +;; 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") @@ -185,3 +254,23 @@ b ;; Use 'winner' mode to undo and redo windows changes ;; using C-c and C-c . (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"))) + +