|
From: | John Kitchin |
Subject: | [O] html-email in org-mode |
Date: | Sat, 29 Oct 2016 14:37:14 -0400 |
On the org-mode mailing list there was some discussion about sending html mail using orgmode. The support for this in mu4e is deprecated. There is the org-mime library though, and it supports a lot of what is needed for this. I am going to send this post to the orgmode mailing list as an html mail to make sure it works. It should show as a text mail in mu4e, and an html mail in a browser.
As I played around with it though, I came across some limitations:
This post documents some work I did figuring out how to send html mails. After some testing, some of these should probably be patched in org-mime.
First, you need to require this library.
(require 'org-mime)
You can send a whole org buffer in html like with this command: org-mime-org-buffer-htmlize. Not all of the internal links work for me (at least in gmail).
The default behavior leaves you at the end of the buffer, which is not too nice. We lightly modify the function here to leave in the To: field.
(defun org-mime-org-buffer-htmlize () "Create an email buffer containing the current org-mode file exported to html and encoded in both html and in org formats as mime alternatives." (interactive) (org-mime-send-buffer 'html) (message-goto-to))
You can compose an email as an org-heading in any org-buffer, and send it as html. In an org-heading, you need to specify a MAIL_FMT property of html, e.g.:
:PROPERTIES: :MAIL_FMT: html :END:
Note the following properties can also be set to modify the composed email.
(subject (or (funcall mp "MAIL_SUBJECT") (nth 4 (org-heading-components)))) (to (funcall mp "MAIL_TO")) (cc (funcall mp "MAIL_CC")) (bcc (funcall mp "MAIL_BCC"))
Then, send it with org-mime-subtree
Here I modify this function to leave me in the To: field.
(defun org-mime-subtree () "Create an email buffer containing the current org-mode subtree exported to a org format or to the format specified by the MAIL_FMT property of the subtree." (interactive) (org-mime-send-subtree (or (org-entry-get nil "MAIL_FMT" org-mime-use-property-inheritance) 'org)) (message-goto-to))
Here are some sample elements to see if they convert to html reasonably.
bold
underlined
italics
strikethrough
code
Subscripts: H2O Superscripts: H+ An entity: To ∞ and beyond
x | y |
1 | 2 |
A nested list.
A definition list:
A checklist:
[ ]
A checkboxHere is a numbered list:
import numpy as np import matplotlib.pyplot as plt t = np.linspace(0, 10) x = np.cos(t) * np.exp(-t) y = np.sin(t) * np.exp(-t) plt.plot(x, y) plt.savefig('spiral.png')
Figure 1: A spiral
Figure 2: A gold particle
You might prefer to do this directly in an email. Here is how you can do it in mu4e. I use this command to open a message in org-mode. The mode switches if you are in the header, or in the body. If you always do this, you could use a hook instead on message-mode. I do not want default html so I do not do it.
(defun mu4e-compose-org-mail () (interactive) (mu4e-compose-new) (org-mu4e-compose-org-mode))
For sending, we will use org-mime to htmlize it, and add a C-c C-c hook function to send it. This hook is a little tricky, we want to preserve C-c C-c behavior in org-mode, e.g. in code blocks, but send it if there is no other C-c C-c action that makes sense, so we add it to the end of the hook. Alternatively, you could bind a special key for it, or run the special command. Note the C-c C-c hook only works in the body of the email. From the header, a plain text message is sent.
(defun htmlize-and-send () "When in an org-mu4e-compose-org-mode message, htmlize and send it." (interactive) (when (member 'org~mu4e-mime-switch-headers-or-body post-command-hook) (org-mime-htmlize) (message-send-and-exit))) (add-hook 'org-ctrl-c-ctrl-c-hook 'htmlize-and-send t)
Here is a way to do this for non-mu4e users. It doesn't have the nice mode switching capability though, so you lose completion in emails, and header specific functions. You can switch back to message-mode to regain those.
(defun compose-html-org () (interactive) (compose-mail) (message-goto-body) (setq *compose-html-org* t) (org-mode)) (defun org-htmlize-and-send () "When in an org-mu4e-compose-org-mode message, htmlize and send it." (interactive) (when *compose-html-org* (setq *compose-html-org* nil) (message-mode) (org-mime-htmlize) (message-send-and-exit))) (add-hook 'org-ctrl-c-ctrl-c-hook 'org-htmlize-and-send t)
Out of the box, org-mime does not seem to attach file links to emails or make images for equations..
Here is an adaptation of org-mime-compose that does that for html messages.
(defun org-mime-compose (body fmt file &optional to subject headers) (require 'message) (let ((bhook (lambda (body fmt) (let ((hook (intern (concat "org-mime-pre-" (symbol-name fmt) "-hook")))) (if (> (eval `(length ,hook)) 0) (with-temp-buffer (insert body) (goto-char (point-min)) (eval `(run-hooks ',hook)) (buffer-string)) body)))) (fmt (if (symbolp fmt) fmt (intern fmt))) (files (org-element-map (org-element-parse-buffer) 'link (lambda (link) (when (string= (org-element-property :type link) "file") (file-truename (org-element-property :path link))))))) (compose-mail to subject headers nil) (message-goto-body) (cond ((eq fmt 'org) (require 'ox-org) (insert (org-export-string-as (org-babel-trim (funcall bhook body 'org)) 'org t))) ((eq fmt 'ascii) (require 'ox-ascii) (insert (org-export-string-as (concat "#+Title:\n" (funcall bhook body 'ascii)) 'ascii t))) ((or (eq fmt 'html) (eq fmt 'html-ascii)) (require 'ox-ascii) (require 'ox-org) (let* ((org-link-file-path-type 'absolute) ;; we probably don't want to export a huge style file (org-export-htmlize-output-type 'inline-css) (org-html-with-latex 'dvipng) (html-and-images (org-mime-replace-images (org-export-string-as (funcall bhook body 'html) 'html t))) (images (cdr html-and-images)) (html (org-mime-apply-html-hook (car html-and-images)))) (insert (org-mime-multipart (org-export-string-as (org-babel-trim (funcall bhook body (if (eq fmt 'html) 'org 'ascii))) (if (eq fmt 'html) 'org 'ascii) t) html) (mapconcat 'identity images "\n"))))) (mapc #'mml-attach-file files)))
This makes it pretty nice to send rich-formatted html text to people.
spiral.png
Description: PNG image
Au-icosahedron-3.png
Description: PNG image
html-email.org
Description: Text Data
-- Professor John Kitchin Doherty Hall A207F Department of Chemical Engineering Carnegie Mellon University Pittsburgh, PA 15213 412-268-7803 @johnkitchin http://kitchingroup.cheme.cmu.edu
[Prev in Thread] | Current Thread | [Next in Thread] |