;;; $DOOMDIR/config.el -*- lexical-binding: t; -*- ;; Place your private configuration here! Remember, you do not need to run 'doom ;; sync' after modifying this file! ;; Some functionality uses this to identify you, e.g. GPG configuration, email ;; clients, file templates and snippets. (setq user-full-name "Levi Olson" user-mail-address "olson.levi@gmail.com") ;; Doom exposes five (optional) variables for controlling fonts in Doom. Here ;; are the three important ones: ;; ;; + `doom-font' ;; + `doom-variable-pitch-font' ;; + `doom-big-font' -- used for `doom-big-font-mode'; use this for ;; presentations or streaming. ;; ;; They all accept either a font-spec, font string ("Input Mono-12"), or xlfd ;; font string. You generally only need these two: ;; (setq doom-font (font-spec :family "monospace" :size 12 :weight 'semi-light) ;; doom-variable-pitch-font (font-spec :family "sans" :size 13)) (setq doom-font (font-spec :family "PragmataPro Liga" :size 18 :weight 'regular) doom-big-font (font-spec :family "PragmataPro Liga" :size 18 :weight 'regular) ;; doom-variable-pitch-font (font-spec :family "PragmataPro Liga" :size 20) doom-variable-pitch-font (font-spec :family "Overpass" :size 20 :weight 'thin) doom-unicode-font (font-spec :family "PragmataPro Liga" :size 18) doom-serif-font (font-spec :family "Baskerville" :size 20)) ;; There are two ways to load a theme. Both assume the theme is installed and ;; available. You can either set `doom-theme' or manually load a theme with the ;; `load-theme' function. This is the default: (setq doom-theme 'doom-one) (remove-hook 'window-setup-hook #'doom-init-theme-h) (add-hook 'after-init-hook #'doom-init-theme-h 'append) (delq! t custom-theme-load-path) (setq doom-modeline-height 45) ;; If you use `org' and don't want your org files in the default location below, ;; change `org-directory'. It must be set before org loads! (setq org-directory "~/Nextcloud/Org") ;; Some nicer defaults (setq doom-fallback-buffer-name "*Doom*" +doom-dashboard-name "*Doom*") (map! :g "s-" #'next-buffer :g "s-" #'previous-buffer) ;; This determines the style of line numbers in effect. If set to `nil', line ;; numbers are disabled. For relative line numbers, set this to `relative'. (setq display-line-numbers-type t) (setq projectile-project-search-path "~/Projects") (require 's) (when (eq system-type 'gnu/linux) (when (s-contains? "microsoft" operating-system-release t) (progn (setq org-directory "/mnt/c/Users/Levi/Nextcloud/Org") (add-to-list 'default-frame-alist '(top . 400)) (add-to-list 'default-frame-alist '(left . 750)) (add-to-list 'default-frame-alist '(height . 60)) (add-to-list 'default-frame-alist '(width . 235)) (setq browse-url-chrome-program "/mnt/c/Program Files (x86)/Microsoft/Edge/Application/msedge.exe") (setq browse-url-chromium-program "/mnt/c/Program Files (x86)/Microsoft/Edge/Application/msedge.exe") ))) (when (eq system-type 'darwin) (progn (setq org-directory "/Users/Levi_Olson/Nextcloud/Org") (add-to-list 'default-frame-alist '(top . 0)) (add-to-list 'default-frame-alist '(left . 0)) (add-to-list 'default-frame-alist '(height . 49)) (add-to-list 'default-frame-alist '(width . 178)) (setq browse-url-chrome-program "/Applications/Safari.app") (setq browse-url-chromium-program "/Applications/Safari.app") )) ;; Here are some additional functions/macros that could help you configure Doom: ;; ;; - `load!' for loading external *.el files relative to this one ;; - `use-package!' for configuring packages ;; - `after!' for running code after a package has loaded ;; - `add-load-path!' for adding directories to the `load-path', relative to ;; this file. Emacs searches the `load-path' when you load packages with ;; `require' or `use-package'. ;; - `map!' for binding new keys ;; ;; To get information about any of these functions/macros, move the cursor over ;; the highlighted symbol at press 'K' (non-evil users must press 'C-c c k'). ;; This will open documentation for it, including demos of how they are used. ;; ;; You can also try 'gd' (or 'C-c c d') to jump to their definition and see how ;; they are implemented. (unless (string-match-p "^Power N/A" (battery)) ; On laptops... (display-battery-mode 1)) (display-time-mode 1) (global-subword-mode 1) (defvar mixed-pitch-modes '(org-mode LaTeX-mode markdown-mode gfm-mode Info-mode) "Modes that `mixed-pitch-mode' should be enabled in, but only after UI initialisation.") (defun init-mixed-pitch-h () "Hook `mixed-pitch-mode' into each mode in `mixed-pitch-modes'. Also immediately enables `mixed-pitch-modes' if currently in one of the modes." (when (memq major-mode mixed-pitch-modes) (mixed-pitch-mode 1)) (dolist (hook mixed-pitch-modes) (add-hook (intern (concat (symbol-name hook) "-hook")) #'mixed-pitch-mode))) (add-hook 'doom-init-ui-hook #'init-mixed-pitch-h) (defun my-generate-tab-stops (&optional width max) "Return a sequence suitable for `tab-stop-list'." (let* ((max-column (or max 200)) (tab-width (or width tab-width)) (count (/ max-column tab-width))) (number-sequence tab-width (* tab-width count) tab-width))) (defun my-setup-indent (n) (setq c-basic-offset n) (setq coffee-tab-width n) ; coffeescript (setq javascript-indent-level n) ; javascript-mode (setq js-indent-level n) ; js-mode (setq js2-basic-offset n) ; js2-mode, in latest js2-mode, it's alias of js-indent-level (setq web-mode-markup-indent-offset n) ; web-mode, html tag in html file (setq web-mode-css-indent-offset n) ; web-mode, css in html file (setq web-mode-code-indent-offset n) ; web-mode, js code in html file (setq css-indent-offset n) ; css-mode (setq tab-width n) (setq indent-tabs-mode nil) (setq tab-stop-list (my-generate-tab-stops)) ) (my-setup-indent 2) (load! "functions.el") (use-package! functions) ;; (load! "setup-elfeed.el") ;; (use-package! setup-elfeed) ;; (load! "fancy-banner.el") ;; (use-package! fancy-banner) (use-package! emacs :config (setq +ligatures-in-modes '(not special-mode comint-mode eshell-mode term-mode vterm-mode Info-mode elfeed-search-mode elfeed-show-mode))) (use-package! magit-delta :hook (magit-mode . magit-delta-mode)) ;; Tabnine::version ;; Which version of Tabnine ;; Tabnine::restart ;; restart the Tabnine service ;; Tabnine::sem ;; enables semantic completion for the current language ;; Tabnine::no_sem ;; disables semantic completion for the current language ;; Tabnine::active ;; checks if Tabnine is activated ;; Tabnine::config ;; to open the config ;; Tabnine::config_dir ;; /Users/leviolson/Library/Preferences/TabNine (use-package company-tabnine :disabled f :config (add-to-list 'company-backends 'company-tabnine)) (use-package! graphql-mode :config (set-company-backend! 'graphql-mode '(:separate company-tabnine company-capf company-yasnippet))) (use-package! emacs :config (set-company-backend! 'emacs-lisp-mode '(:separate company-tabnine company-capf company-yasnippet))) ;; (use-package! typescript-mode ;; :config ;; (set-company-backend! 'typescript-mode '(company-tabnine company-capf company-yasnippet))) (use-package! company :config ;; Trigger completion immediately. (setq company-idle-delay 0.2) ;; Number the candidates (use M-1, M-2 etc to select completions). (setq company-show-quick-access nil)) (use-package! darkroom :commands darkroom-mode :custom (darkroom-margins (cons 40 0)) (darkroom-text-scale-increase 0) (darkroom-fringes-outside-margins nil) (darkroom-margin-increment 0.2) ) (use-package! org ;; :disabled t :commands org-capture :mode ("\\.org\\'" . org-mode) :bind ( ("C-," . org-cycle-agenda-files) ;; ("C-c C-d" . org-capture) :map org-mode-map ("M-n" . leo/org-narrow-next-tree) ("M-p" . leo/org-narrow-prev-tree) ("M-P" . leo/org-present) ) :preface (defvar org-html-validation-link) (defvar org-html-text-markup-alist) (defvar org-capture-templates) :init (setq org-agenda-files (list (concat org-directory "/todo.org") (concat org-directory "/projects.org") (concat org-directory "/Recipies.org") (concat org-directory "/help.org") (concat org-directory "/personal.org") (concat org-directory "/archive.org") )) (setq org-agenda-include-diary t) (add-to-list 'safe-local-variable-values '(eval leo/deft-insert-boilerplate)) (setq org-refile-targets '((nil :maxlevel . 3) (org-agenda-files :maxlevel . 3)) org-default-notes-file (concat org-directory "/todo.org")) (setq org-todo-keyword-faces '(("TODO" . org-roam-link-shielded) ("WAIT" . org-roam-link-shielded) ("HOLD" . org-roam-link-shielded) ("NEXT" . org-roam-link-current) ("PLAN" . org-target) ("SPIKE" . org-target) ("ACTIVE" . org-todo))) (setq org-todo-keywords '( (sequence "TODO(t)" "NEXT(n)" "|" "DONE(d!)") (sequence "PLAN(p)" "SPIKE(s)" "ACTIVE(a)" "WAIT(w@/!)" "HOLD(h)" "|" "DONE(d!)" "CANCELLED(c@)") )) :config (require 'org-protocol) (org-babel-do-load-languages 'org-babel-load-languages '((js . t) (typescript . t) (shell . t) (apex . t) (soql . t) (emacs-lisp . t))) (setq org-capture-templates '(("w" "Default template" entry (file+headline org-default-notes-file "Unfiled") "* %^{Title}%?\n\nSource: %:link\n:COPIED_TEXT:\n %i\n:END:\n") ("t" "new task" entry (file+headline (concat org-directory "/todo.org") "Tasks") "* TODO [#A] %?\nSCHEDULED: %(org-insert-time-stamp (org-read-date nil t \"+0d\"))\n%a\n") ("n" "new note" entry (file+headline org-default-notes-file "Notes") "* %?\n%i\n") ("l" "store link" entry (file+olp org-default-notes-file "Links" "Unfiled") "* %a\n%?\n") )) (setq org-structure-template-alist '(("r" . "src restclient :results raw") ("j" . "src js :cmd \"/usr/local/bin/babel-node\" :results output code") ("e" . "src emacs-lisp :results silent") ("a" . "export ascii") ("c" . "center") ("C" . "comment") ("E" . "export") ("h" . "export html") ("l" . "export latex") ("q" . "quote") ("s" . "src") ("v" . "verse"))) (defconst checkbox-fontlock-keywords-alist (mapcar (lambda (regex-char-pair) `(,(car regex-char-pair) (0 (prog1 () (compose-region (match-beginning 1) (match-end 1) ,(concat (list ?\C-i) (list (decode-char 'ucs (cadr regex-char-pair))))))))) '(("\\(\\[ \\]\\)" #XF096);2B1C;F096; ("\\(\\[-\\]\\)" #XF147);29C7;F458;F147; ("\\(\\[X\\]\\)" #XF046);2BBD;F046; ))) (defun add-checkbox-symbol-keywords () "Add checkbox font to font-lock." (font-lock-add-keywords nil checkbox-fontlock-keywords-alist)) (add-hook 'org-mode-hook 'add-checkbox-symbol-keywords) (add-hook 'org-mode-hook '(lambda () (visual-line-mode 0) (variable-pitch-mode 1) (org-indent-mode) (auto-fill-mode 0) )) ) (use-package org-roam :disabled t :custom (org-roam-directory (concat org-directory "/Roam/")) (org-roam-link-title-format "r::%s") :bind (:map org-roam-mode-map (("C-c n l" . org-roam) ("C-c n f" . org-roam-find-file) ("C-c n g" . org-roam-graph)) :map org-mode-map (("C-c n i" . org-roam-insert)) (("C-c n I" . org-roam-insert-immediate)))) (use-package! deft :bind ("C-c n d" . deft) :config (setq deft-recursive t deft-use-filter-string-for-filename t deft-default-extension "org" deft-directory (concat org-directory "/Roam/") deft-recursive-ignore-dir-regexp "\\(?:\\.\\|\\.\\.\\|setup\\)$")) (use-package! org-pandoc-import :after org :commands (org-pandoc-import-html-as-org org-pandoc-import-html-to-org) :config (org-pandoc-import-backend html) ) (use-package! lsp-mode :config (setq +lsp-company-backends '(:separate company-tabnine company-lsp company-yasnippet company-capf)) (setq lsp-enable-symbol-highlighting nil lsp-headerline-breadcrumb-enable t)) (use-package! apex-mode :mode "\\.cls\\'" :bind ("M-q" . #'leo/kill-this-buffer-unless-scratch) ) (use-package! web-mode :mode "\\.\\(app\\|page\\)\\'") (use-package! so-long :config (setq so-long-action 'so-long-minor-mode)) (use-package! dired :config (setq dired-listing-switches "-ahgo --group-directories-first")) (use-package! dired-x :disabled t :custom (dired-omit-files nil)) (use-package! hydra :ensure t) (use-package! elfeed :after hydra :bind (:map elfeed-search-mode-map ("a" . elfeed-search-clear) ("e" . elfeed-search-emacs) ("E" . (lambda () (interactive) (elfeed-search-toggle "+emacs"))) ("t" . elfeed-search-tesla) ("T" . (lambda () (interactive) (elfeed-search-toggle "+tesla"))) ("y" . elfeed-search-video) ("Y" . (lambda () (interactive) (elfeed-search-toggle "+youtube"))) ("v" . elfeed-search-browse-url) ("o" . elfeed-search-show-entry) ("g" . elfeed-search-fetch) ("U" . elfeed-search-toggle-unread) ) :config (defun elfeed-search-clear () (interactive) (setq elfeed-search-filter "") (elfeed-search-update :force)) (defun elfeed-search-emacs () (interactive) (setq elfeed-search-filter "+emacs") (elfeed-search-update :force)) (defun elfeed-search-tesla () (interactive) (setq elfeed-search-filter "+tesla") (elfeed-search-update :force)) (defun elfeed-search-video () (interactive) (setq elfeed-search-filter "+youtube") (elfeed-search-update :force)) (defun elfeed-search-toggle-unread () (interactive) (let ((filter elfeed-search-filter)) (if (s-contains-p "+unread" filter) (setq elfeed-search-filter (s-trim (s-replace "+unread" "" filter))) (setq elfeed-search-filter (concat filter " +unread")))) (elfeed-search-update :force) ) (defun elfeed-search-toggle (term) "Accepts a TERM and returns a function that toggles TERM in the `elfeed' filter." (interactive "Mtag: ") (let ((filter elfeed-search-filter)) (if (s-contains-p term filter) (setq elfeed-search-filter (s-trim (s-replace term "" filter))) (setq elfeed-search-filter (concat filter " " term)))) (elfeed-search-update :force) ) ) (after! xref (add-to-list '+lookup-provider-url-alist '("Melpa" "https://melpa.org/#/?q=%s")) (add-to-list '+lookup-provider-url-alist '("GitHub - LifeOmic" "https://github.com/search?q=user:LifeOmic+%s"))) ;;;;;;;;;;; ;; HOOKS ;; ;;;;;;;;;;; (add-hook 'text-mode-hook 'leo/remove-dos-eol) ;; Don't show `^M' at the end of lines (add-hook 'prog-mode-hook 'leo/remove-dos-eol) ;; same, but for prog modes ;;;;;;;;;;;;;;;;; ;; KEYBINDINGS ;; ;;;;;;;;;;;;;;;;; (map! :map global-map :prefix "C-x" "C-l" nil (:prefix ("C-l" . "launch app") "a" #'org-agenda "e" #'elfeed "g" #'magit-status )) (map! :map global-map :prefix "C-c" "a" nil (:prefix ("a" . "launch app") "a" #'org-agenda "e" #'elfeed "g" #'magit-status )) (map! :map comint-mode-map "q" '(lambda() (interactive) (if (s-contains? "sfdx" (buffer-name)) (progn (leo/kill-this-buffer-unless-scratch) (+workspace/close-window-or-workspace) )))) (map! :map xwidget-webkit-mode-map "C-i" 'xwidget-webkit-insert-string "C-m" 'xwidget-webkit-insert-string "C-s" 'isearch-forward "M-w" 'xwidget-webkit-copy-selection-as-kill "C-w" 'xwidget-webkit-copy-selection-as-kill "o" 'xwidget-webkit-goto-url "C-l" 'xwidget-webkit-goto-url "n" 'xwidget-webkit-scroll-up "p" 'xwidget-webkit-scroll-down "C-y" 'yank ) (defun leo/search-lifeomic-repos() "Search for LifeOmic Repo" (interactive) (setq query (read-string (format "Search for repository (in %s): " "LifeOmic"))) (funcall +lookup-open-url-fn (format "https://github.com/search?q=user:LifeOmic+%s" (url-encode-url query))) ) (use-package! vs-restclient :bind (:map vs-restclient-mode-map ("C-c C-c" . 'vs-restclient-http-send-current-stay-in-window)) :ensure t) (use-package! vs-restclient-jq :after vs-restclient :ensure t :config (vs-restclient-register-result-func "jq-set-var" #'vs-restclient-jq-json-var-function "Set a vs-restclient variable with the value jq expression, takes var & jq expression as args. eg. -> jq-set-var :my-token .token") (define-key vs-restclient-response-mode-map (kbd "C-c C-j") #'vs-restclient-jq-interactive-result) ) (map! :map global-map "M-t" #'treemacs-select-window "M-q" #'leo/kill-this-buffer-unless-scratch "M-RET" #'eshell :desc "Format Document or Region" "C-" #'leo/tidy :desc "Comment or Uncomment Line or Region" "C-;" #'leo/comment-or-uncomment-region-or-line :desc "Open Private Doom Config" "C-c C-e" #'leo/edit-config "C-c d" #'leo/duplicate-thing "C-c g" #'magit-status "M-n" #'leo/jump-to-next-symbol "M-p" #'leo/jump-to-prev-symbol "M-u" #'upcase-dwim "M-c" #'capitalize-dwim "M-l" #'downcase-dwim :desc "Search LifeOmic Repos" "C-c s g" #'leo/search-lifeomic-repos ;; Perspective.el "C-c C-n" #'persp-next "C-c C-p" #'persp-prev "C-c C-r" #'persp-rename "C-c C-l" #'persp-switch "C-c C-s" #'persp-switch "C-c b" #'ivy-switch-buffer ;; "C-c b" #'counsel-switch-buffer "C-s" #'swiper "C-}" #'mc/mark-next-like-this "C-)" #'mc/unmark-next-like-this "C-{" #'mc/mark-previous-like-this "C-(" #'mc/unmark-previous-like-this "C-M-}" #'mc/mark-next-like-this-word "C-M-)" #'mc/unmark-next-like-this "C-M-{" #'mc/mark-previous-like-this-word "C-M-(" #'mc/unmark-previous-like-this "C-@" #'er/expand-region "C-#" #'er/contract-region )