(defvar +wiki-directory "~/writings/wiki") (defvar +wiki-notebook-name "notebook") (defvar +wiki-notebook-directory (f-join +wiki-directory +wiki-notebook-name)) (defvar my/wiki-asset-directory-name "assets") (+wiki/biblio-setup) (defun my/is-in-wiki-directory () "Return t if the file buffer is in the wiki directory." (if (and (not (string= (f-base (buffer-file-name)) my/wiki-asset-directory-name)) (f-descendant-of-p (buffer-file-name) (expand-file-name +wiki-directory))) t nil)) (defun my/get-assets-folder () "Get the assets folder of the current Org mode document." (if (my/is-in-wiki-directory) (f-join my/wiki-asset-directory-name (f-base buffer-file-name)) nil)) (defun my/concat-assets-folder (&rest args) "Concatenate PATH to the assets folder." (apply #'f-join (my/get-assets-folder) args)) (defun my/create-assets-folder () "A quick convenient function to create an assets folder in the wiki folder." (interactive) (if (my/is-in-wiki-directory) (f-mkdir my/wiki-asset-directory-name (f-join my/wiki-asset-directory-name (file-name-sans-extension (buffer-file-name)))) (message "Not in the wiki directory."))) (defun my/parse-links-in-org (filename) "Returns a list of links in an Org buffer." (let ((ast (with-temp-buffer (insert-file-contents filename) (org-mode) (org-element-parse-buffer)))) (org-element-map ast 'link (lambda (link) (when (or (string= (org-element-property :type link) "http") (string= (org-element-property :type link) "https")) (org-element-property :path link)))))) (defun my/anki-editor-delete-note () "Request AnkiConnect for deleting a note at point." (interactive) (let ((queue (anki-editor--anki-connect-invoke-queue))) (funcall queue 'deleteNotes `((notes . ,(list (org-entry-get (point) anki-editor-prop-note-id))))) (org-entry-delete (point) anki-editor-prop-note-id))) (setq org-roam-v2-ack 't org-roam-capture-templates `(("e" "evergreen" plain "%?" :target (file+head ,(f-join +wiki-notebook-directory "%<%Y-%m-%d-%H-%M-%S>.org") "#+title: ${title} #+date: %<%Y-%m-%d %T %:z> #+date_modified: %<%Y-%m-%d %T %:z> #+language: en") :unnarrowed t) ("c" "cards" plain "%?" :target (file+head ,(f-join +anki-cards-directory-name "%<%Y>.org") "#+title: Anki: ${title} #+date: %<%Y-%m-%d %T %:z> #+date_modified: %<%Y-%m-%d %T %:z> #+language: en #+property: anki_deck ${title}") :unnarrowed t) ("l" "literature" plain "%?" :target (file+head ,(f-join +wiki-notebook-directory "literature.${slug}.org") "#+title: ${title} #+date: %<%Y-%m-%d %T %:z> #+date_modified: %<%Y-%m-%d %T %:z> #+language: en") :unnarrowed t) ("L" "literature reference" plain (file ,(f-join +wiki-directory "templates" "literature.org")) :target (file ,(f-join +wiki-notebook-directory "literature.${citekey}.org")) :unnarrowed t) ("d" "dailies" entry "* %?" :target (file+head ,(expand-file-name "%<%Y-%m-%d>.org" org-roam-dailies-directory) "#+title: %<%Y-%m-%d>\n")) ("s" "structured" plain "%?" :target (file+head ,(f-join +wiki-notebook-directory "${slug}.org") "#+title: ${title}") :unnarrowed t))) ;; Change how slugs are generated. ;; I prefer dashes over the default underscores. ;;(eval-after-load "org-roam" ;; '(cl-defmethod org-roam-node-slug ((node org-roam-node)) ;; (let ((title (org-roam-node-title node))) ;; (cl-flet* ((strip-nonspacing-marks (s) ;; (ucs-normalize-NFC-string (ucs-normalize-NFD-string s))) ;; (cl-replace (title pair) ;; (replace-regexp-in-string (car pair) (cdr pair) title))) ;; (let* ((pairs `(("[^[:alnum:][:digit:]]" . "-") ;; ("--*" . "-") ;; ("^-" . "") ;; ("-$" . ""))) ;; (slug (-reduce-from #'cl-replace (strip-nonspacing-marks title) pairs))) ;; (downcase slug)))))) ;;; config.el ends here