+ (elfeed-protocol-enable))
+
+
+;; Read and write email using mu4e
+(use-package mu4e
+ :ensure nil
+ ;; :ensure-system-package mu ;; Install from aur
+ :config
+ (setq mail-user-agent 'mu4e-user-agent)
+ ;; Also use mu4e when called from gnus-dired-attach
+ (setq gnus-dired-mail-mode 'mu4e-user-agent
+ mu4e-get-mail-command "mbsync io"
+ mu4e-update-interval 600
+ mu4e-use-fancy-chars t
+ mu4e-view-show-images t
+ mu4e-sent-folder "/Sent"
+ mu4e-drafts-folder "/Drafts"
+ mu4e-trash-folder "/Trash"
+ message-kill-buffer-on-exit t
+ ;;Fixing duplicate UID errors when using mbsync and mu4e
+ mu4e-change-filenames-when-moving 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")
+
+;; Denote config
+(use-package denote
+ :ensure t
+ :hook (dired-mode . denote-dired-mode)
+ :bind
+ (("C-c n n" . denote)
+ ("C-c n r" . denote-rename-file)
+ ("C-c n l" . denote-link)
+ ("C-c n b" . denote-backlinks))
+ :config
+ (setq denote-directory "/home/frederik/Nextcloud/notes/")
+ (denote-rename-buffer-mode 1))
+
+(use-package nerd-icons
+ ;; :custom
+ ;; The Nerd Font you want to use in GUI
+ ;; "Symbols Nerd Font Mono" is the default and is recommended
+ ;; but you can use any other Nerd Font if you want
+ ;; (nerd-icons-font-family "Symbols Nerd Font Mono")
+ )
+
+;; Dired configuration
+(with-eval-after-load 'dired
+ (require 'dired-x)
+ ;; Set dired-x global variables here. For example:
+ ;; (setq dired-x-hands-off-my-keys nil)
+ )
+(add-hook 'dired-mode-hook
+ (lambda ()
+ ;; Set dired-x buffer-local variables here.
+ (dired-omit-mode 1)
+ (dired-hide-details-mode 1)
+ (nerd-icons-dired-mode 1)
+ ))
+(setq delete-by-moving-to-trash t)
+(setq dired-guess-shell-alist-user
+ '(("\\.\\(png\\|jpe?g\\|tiff\\)" "feh" "xdg-open")
+ ("\\.\\(mp[34]\\|m4a\\|ogg\\|flac\\|webm\\|mkv\\)" "mpv" "xdg-open")
+ (".*" "xdg-open")))
+
+;; Use `vertico' package to get a vertical view of the minibuffer.
+(use-package vertico
+ :ensure t
+ :config
+ (setq vertico-resize nil)
+ (vertico-mode 1))
+
+;; Persist history over Emacs restarts. Vertico sorts by history position.
+(use-package savehist
+ :init
+ (savehist-mode))
+
+;; Use `marginalia' package. This will display useful
+;; annotations next to entries in the minibuffer. For example, when
+;; using M-x it will show a brief description of the command as well
+;; as the keybinding associated with it (if any).
+(use-package marginalia
+ :ensure t
+ :config
+ (marginalia-mode 1))
+
+;; Use 'winner' mode to undo and redo windows changes
+;; using C-c <left> and C-c <right>.
+(use-package winner
+ :ensure t
+ :config
+ (winner-mode 1))
+
+;; Use a different spell checker, always
+(use-package jinx
+ :ensure t
+ :config
+ (keymap-global-set "M-$" #'jinx-correct)
+ :hook (emacs-startup . global-jinx-mode))
+
+
+;; Bind embark
+(use-package embark
+ :ensure t
+ :config
+ (keymap-global-set "C-." #'embark-act)
+ (keymap-global-set "C-;" #'embark-dwim))
+
+(use-package consult
+ :ensure t
+ :config
+ ;; Change default bindings to consult- ones
+ :bind
+ (;; C-x bindings in `ctl-x-map'
+ ("C-x b" . consult-buffer) ;; orig. switch-to-buffer
+ ("C-x 4 b" . consult-buffer-other-window) ;; orig. switch-to-buffer-other-window
+ ("C-x r b" . consult-bookmark) ;; orig. bookmark-jump
+ ;; Other custom bindings
+ ("M-y" . consult-yank-pop))) ;; orig. yank-pop
+
+(use-package consult-mu
+ :ensure nil ;; cloned in
+ :load-path "~/.emacs.d/lisp/consult-mu"
+ :after (consult mu4e)
+ :custom
+ ;;maximum number of results shown in minibuffer
+ (consult-mu-maxnum 200)
+ ;;show preview when pressing any keys
+ (consult-mu-preview-key 'any)
+ ;;do not mark email as read when previewed
+ (consult-mu-mark-previewed-as-read nil)
+ ;;do not amrk email as read when selected. This is a good starting point to ensure you would not miss important emails marked as read by mistake especially when trying this package out. Later you can change this to t.
+ (consult-mu-mark-viewed-as-read nil)
+ ;; open the message in mu4e-view-buffer when selected.
+ (consult-mu-action #'consult-mu--view-action)
+ )
+
+;; Configure `world-clock'
+(use-package time
+ :ensure nil
+ :config
+ (setq zoneinfo-style-world-list '(("Europe/Brussels" "Leuven")))
+ (add-to-list 'zoneinfo-style-world-list '("Australia/Perth" "Perth")))
+
+
+;; View PDFs in Emacs
+(pdf-loader-install) ; On demand loading, leads to faster startup time
+(setq pdf-misc-print-programm "/usr/bin/lpr")
+
+(use-package magit
+ :ensure t)
+
+(use-package eat
+ :ensure t
+ :config
+ ;; For `eat-eshell-mode'.
+ (add-hook 'eshell-load-hook #'eat-eshell-mode)
+ (setq eshell-visual-commands '()))
+
+;; Read ePub files
+(use-package nov
+ :ensure t
+ :init
+ (add-to-list 'auto-mode-alist '("\\.epub\\'" . nov-mode))
+ :config
+ (add-hook 'nov-mode-hook #'variable-pitch-mode))
+
+;; Set some preset fonts
+(use-package fontaine
+ :ensure t
+ :config
+ (setq fontaine-presets
+ '((regular-1
+ :default-family "Iosevka Nerd Font"
+ :default-height 120
+ :variable-pitch-family "Linux Biolinum O"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.1
+ :italic-family "Iosevka Etoile"
+ :line-spacing 1)
+ (large-1
+ :default-family "Iosevka Nerd Font"
+ :default-height 150
+ :variable-pitch-family "Linux Biolinum O"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.1
+ :italic-family "Iosevka Etoile"
+ :line-spacing 1)
+ (regular-2
+ :default-family "Fira Mono Nerd Font"
+ :default-height 140
+ :variable-pitch-family "Fira Sans Book"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.0
+ :line-spacing 1)
+ (large-2
+ :default-family "Fira Mono Nerd Font"
+ :default-height 140
+ :variable-pitch-family "Fira Sans Book"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.0
+ :line-spacing 1)
+ (ereader-Baskerville
+ :variable-pitch-family "Libre Baskerville"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.0
+ :line-spacing 1)
+ (ereader-Noto-Serif
+ :variable-pitch-family "Noto Serif"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.0
+ :line-spacing 1)
+ (ereader-Bembo-Tufte
+ :variable-pitch-family "ETBembo"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.1
+ :line-spacing 1)
+ (ereader-Literata
+ :variable-pitch-family "Literata"
+ :variable-pitch-weight normal
+ :variable-pitch-height 1.0
+ :line-spacing 1))))
+
+;; Custom functions
+
+;; Might want to run this automatically
+;; using variable after-focus-change-function
+(defun my/adjust-font-size-based-on-display ()
+ "Change size of fonts based on monitor."
+ (interactive)
+ (let* ((display-name (cdr (assq 'name (frame-monitor-attributes))))
+ (font-height (cond ((string-equal display-name "eDP-1") 140)
+ (t 120) ;; default
+ )))
+ (set-face-attribute 'default (selected-frame) :height font-height)))