;;; my-nov.el -- Extensions for nov.el -*- lexical-binding: t -*-

;; Copyright (C) 2023 Free Software Foundation.

;; Author: Yuchen Pei <id@ypei.org>
;; Package-Requires: ((emacs "28.2"))

;; This file is part of dotfiles.

;; dotfiles is free software: you can redistribute it and/or modify it under
;; the terms of the GNU Affero General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.

;; dotfiles is distributed in the hope that it will be useful, but WITHOUT
;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
;; or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Affero General
;; Public License for more details.

;; You should have received a copy of the GNU Affero General Public
;; License along with dotfiles.  If not, see <https://www.gnu.org/licenses/>.

;;; Commentary:

;; Extensions for nov.el.

;;; Code:

(require 'nov)

;; override nov-render-title
;; this is because header line does not work with follow mode
(defun my-nov-render-title (dom)
  "Custom <title> rendering function for DOM.
Sets `header-line-format' to a combination of the EPUB title and
chapter title."
  (let ((title (cdr (assq 'title nov-metadata)))
        (chapter-title (car (esxml-node-children dom))))
    (when (not chapter-title)
      (setq chapter-title "No title"))
    ;; this shouldn't happen for properly authored EPUBs
    (when (not title)
      (setq title "No title"))
    (setq mode-line-buffer-identification
	        (concat title ": " chapter-title))
    ))

(defun my-nov-scroll-up (arg)
  "Scroll with `scroll-up' or visit next chapter if at bottom."
  (interactive "P")
  (if (>= (follow-window-end) (point-max))
      (nov-next-document)
    (follow-scroll-up arg)))

(defun my-nov-copy-buffer-file-with-staging ()
  (interactive)
  (unless (derived-mode-p 'nov-mode) (error "Not in nov mode"))
  (pcase-let* ((name
                (completing-read (format "Copy %s to: " nov-file-name)
                                 my-copy-file-targets
                                 nil t))
               (`(,dest ,staging) (alist-get name my-copy-file-targets
                                             nil nil #'equal)))
    (my-copy-file-with-staging
     nov-file-name dest staging)))

(defun my-nov-set-margins ()
  (set-window-margins nil 3 2)
  (set-window-fringes nil 0 0))

(provide 'my-nov)
;;; my-nov.el ends here