(setq doom-font (font-spec :family "Maple Mono" :size 20)) (add-to-list 'default-frame-alist '(height . 53)) (add-to-list 'default-frame-alist '(width . 120)) (setq catppuccin-flavor 'catppuccin) (setq doom-theme 'modus-operandi-tinted) (setq display-line-numbers-type 'relative) (setq org-directory "~/org/") (use-package! nano-modeline :config (add-hook 'prog-mode-hook #'nano-modeline-prog-mode) (add-hook 'text-mode-hook #'nano-modeline-text-mode) (add-hook 'org-mode-hook #'nano-modeline-org-mode) (add-hook 'pdf-view-mode-hook #'nano-modeline-pdf-mode) (add-hook 'mu4e-headers-mode-hook #'nano-modeline-mu4e-headers-mode) (add-hook 'mu4e-view-mode-hook #'nano-modeline-mu4e-message-mode) (add-hook 'elfeed-show-mode-hook #'nano-modeline-elfeed-entry-mode) (add-hook 'elfeed-search-mode-hook #'nano-modeline-elfeed-search-mode) (add-hook 'term-mode-hook #'nano-modeline-term-mode) (add-hook 'xwidget-webkit-mode-hook #'nano-modeline-xwidget-mode) (add-hook 'messages-buffer-mode-hook #'nano-modeline-message-mode) (add-hook 'org-capture-mode-hook #'nano-modeline-org-capture-mode) (add-hook 'org-agenda-mode-hook #'nano-modeline-org-agenda-mode) (global-hide-mode-line-mode t)) (use-package! yasnippet :config (defun my-yas-try-expanding-auto-snippets () (when yas-minor-mode (let ((yas-buffer-local-condition ''(require-snippet-condition . auto))) (yas-expand)))) (add-hook 'post-command-hook #'my-yas-try-expanding-auto-snippets) ) (use-package! gptel :config (setq! gptel-api-key "e994f45f9b46cc8608bd2e9cd508417255514e96913b1764aab612512aa66449") (setq gptel-model 'claude-sonnet-4.5) (setq gptel-backend (gptel-make-gh-copilot "Copilot")) (map! "M-s RET" #'gptel-send) (map! "M-s m" #'gptel-menu) ) (use-package! typst-ts-mode :init (add-hook 'typst-ts-mode-hook #'eglot-ensure) :custom ;; (typst-ts-watch-options "--open") (typst-ts-mode-grammar-location (expand-file-name "tree-sitter/libtree-sitter-typst.so" user-emacs-directory)) (typst-ts-mode-enable-raw-blocks-highlight t) :config (keymap-set typst-ts-mode-map "C-c C-c" #'typst-ts-tmenu)) (with-eval-after-load 'eglot (with-eval-after-load 'typst-ts-mode (add-to-list 'eglot-server-programs `((typst-ts-mode) . ,(eglot-alternatives `(,"tinymist" "typst-lsp")))))) (use-package! websocket) (use-package! typst-preview ;; :load-path "path/to/typst-preview.el" ;; if installed manually :init (setq typst-preview-autostart t) ; start preview automatically when typst-preview-mode is activated (setq typst-preview-open-browser-automatically t) ; open browser automatically when typst-preview-start is run :custom (typst-preview-browser "default") ; this is the default option; other options are `eaf-browser' or `xwidget'. (typst-preview-invert-colors "auto") ; invert colors depending on system theme (typst-preview-executable "tinymist") ; path to tinymist binary (relative or absolute) (typst-preview-partial-rendering t) ; enable partial rendering :config (define-key typst-preview-mode-map (kbd "C-c C-j") 'typst-preview-send-position) (define-key typst-ts-mode-map (kbd "C-c C-l") #'typst-preview-mode) ) (use-package org-latex-preview :config ;; Increase preview width (plist-put org-latex-preview-appearance-options :page-width 0.8) (add-hook 'org-mode-hook 'org-latex-preview-mode) ;; ;; Block C-n, C-p etc from opening up previews when using `org-latex-preview-mode' ;; (setq org-latex-preview-mode-ignored-commands ;; '(next-line previous-line mwheel-scroll ;; scroll-up-command scroll-down-command)) ;; ;; Enable consistent equation numbering (setq org-latex-preview-numbered t) ;; Bonus: Turn on live previews. This shows you a live preview of a LaTeX ;; fragment and updates the preview in real-time as you edit it. ;; To preview only environments, set it to '(block edit-special) instead (setq org-latex-preview-mode-display-live t) ;; More immediate live-previews -- the default delay is 1 second (setq org-latex-preview-mode-update-delay 0) (defun my/org-latex-preview-uncenter (ov) (overlay-put ov 'before-string nil)) (defun my/org-latex-preview-recenter (ov) (overlay-put ov 'before-string (overlay-get ov 'justify))) (defun my/org-latex-preview-center (ov) (save-excursion (goto-char (overlay-start ov)) (when-let* ((elem (org-element-context)) ((or (eq (org-element-type elem) 'latex-environment) (string-match-p "^\\\\\\[" (org-element-property :value elem)))) (img (overlay-get ov 'display)) (prop `(space :align-to (- center (0.55 . ,img)))) (justify (propertize " " 'display prop 'face 'default))) (overlay-put ov 'justify justify) (overlay-put ov 'before-string (overlay-get ov 'justify))))) (define-minor-mode org-latex-preview-center-mode "Center equations previewed with `org-latex-preview'." :global nil (if org-latex-preview-center-mode (progn (add-hook 'org-latex-preview-overlay-open-functions #'my/org-latex-preview-uncenter nil :local) (add-hook 'org-latex-preview-overlay-close-functions #'my/org-latex-preview-recenter nil :local) (add-hook 'org-latex-preview-overlay-update-functions #'my/org-latex-preview-center nil :local)) (remove-hook 'org-latex-preview-overlay-close-functions #'my/org-latex-preview-recenter) (remove-hook 'org-latex-preview-overlay-update-functions #'my/org-latex-preview-center) (remove-hook 'org-latex-preview-overlay-open-functions #'my/org-latex-preview-uncenter))))