Klimi's new dotfiles with stow.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

119 lines
4.9 KiB

;;; org-re-reveal-ref.el --- Citations and bibliography for org-re-reveal -*- lexical-binding: t; -*-
;; -*- Mode: Emacs-Lisp -*-
;; -*- coding: utf-8 -*-
;; Copyright (C) 2018-2019 Jens Lechtenbörger
;; SPDX-License-Identifier: GPL-3.0-or-later
;; Author: Jens Lechtenbörger
;; URL: https://gitlab.com/oer/org-re-reveal-ref
;; Version: 0.10.0
;; Package-Requires: ((emacs "24.4") (org-ref "1.1.1") (org-re-reveal "0.9.3"))
;; Keywords: hypermedia, tools, slideshow, presentation, bibliography
;;; License:
;; This program is free software; you can redistribute it and/or
;; modify it under the terms of the GNU General Public License as
;; published by the Free Software Foundation; either version 3, or
;; (at your option) any later version.
;; This program 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
;; General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs; see the file COPYING.
;; If not, see http://www.gnu.org/licenses/ or write to the
;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
;; Boston, MA 02110-1301, USA.
;;; Commentary:
;; This package extends `org-re-reveal' with support for a
;; bibliography slide based on package `org-ref'. Thus, `cite'
;; commands of `org-ref' are translated into hyperlinks to the
;; bibliography slide upon export by `org-re-reveal'. Also, export to
;; PDF via LaTeX and export to HTML with Org's usual export
;; functionality work.
;;
;; * Install
;; 0. Install reveal.js: https://revealjs.com/
;; 1. Install org-re-reveal and org-re-reveal-ref, either from MELPA
;; or GitLab:
;; - https://gitlab.com/oer/org-re-reveal/
;; - https://gitlab.com/oer/org-re-reveal-ref/
;; (a) Place their directories into your load path or install from MELPA
;; (https://melpa.org/#/getting-started).
;; (b) Load package manually ("M-x load-library" followed by
;; "org-re-reveal-ref") or place "(require 'org-re-reveal-ref)" into
;; your ~/.emacs and restart.
;; 2. Load an Org file and export it to HTML.
;; (a) Make sure that reveal.js is available in your current directory
;; (e.g., as sub-directory or symbolic link).
;; (b) Load "README.org" (coming with org-re-reveal-ref).
;; (c) Export to HTML: Key bindings depend upon version of org-re-reveal.
;; Starting with version 1.0.0, press "C-c C-e v v" (write HTML file)
;; or "C-c C-e v b" (write HTML file and open in browser)
;;
;; * Customizable options
;; Customizable variables are `org-re-reveal-ref-bib' and
;; `org-re-reveal-ref-class'.
;; The value of `org-re-reveal-ref-bib' is used to generate hyperlinks
;; to the bibliography. You must use its value as CUSTOM_ID on your
;; bibliography slide.
;; The value of `org-re-reveal-ref-class' is assigned as class
;; attribute of hyperlinks to the bibliography slide.
;; Furthermore, the following variables of `org-ref' are changed by
;; this package:
;; - `org-ref-bib-html' is set to the empty string
;; - `org-ref-bib-html-sorted' is set to t
;; - `org-ref-printbibliography-cmd' is configured not to produce a
;; heading (as the bibliography slide has a heading already)
;; - `org-ref-ref-html' is configured to link to the bibliography
;;; Code:
(require 'org-ref)
(require 'org-re-reveal)
(defcustom org-re-reveal-ref-bib "bibliography"
"Specify name for link targets generated from citations.
Use that name as CUSTOM_ID for your bibliography slide."
:group 'org-export-re-reveal
:type 'string)
(defcustom org-re-reveal-ref-class "org-ref-reference"
"Specify class of hyperlinks generated from citations.
Set to empty string if no class should be assigned."
:group 'org-export-re-reveal
:type 'string)
(defun org-re-reveal-ref-filter-bib-para (text backend info)
"Replace incorrect p tags around bibliography.
This function is added to `org-export-filter-paragraph-functions',
where TEXT is the paragraph, BACKEND is checked for `re-reveal' or
`html', and INFO is unused."
(ignore info) ; Silence byte compiler
(when (and (or (org-export-derived-backend-p backend 're-reveal)
(org-export-derived-backend-p backend 'html))
(string-match-p "<p>[ \n]*<ul" text))
(replace-regexp-in-string
"<p>[ \n]*<ul" "<ul"
(replace-regexp-in-string "</p>\n" "" text))))
(add-to-list 'org-export-filter-paragraph-functions
#'org-re-reveal-ref-filter-bib-para)
(setq org-ref-bib-html ""
org-ref-bib-html-sorted t
org-ref-printbibliography-cmd "\\printbibliography[heading=none]"
org-ref-ref-html (concat
"<a"
(if (< 0 (length org-re-reveal-ref-class))
(format " class=\"%s\"" org-re-reveal-ref-class)
"")
" href=\"#"
org-re-reveal--href-fragment-prefix
org-re-reveal-ref-bib
"\">[%s]</a>"))
(provide 'org-re-reveal-ref)
;;; org-re-reveal-ref.el ends here