spacemacs/layers/+emacs/org/README.org

30 KiB
Raw Blame History

Org layer

/TakeV/spacemacs/media/commit/c1e455688229fd498d1b8b1db07c9ed6ed5d3904/layers/+emacs/org/img/org.png

Description

This layer enables org mode for Spacemacs.

Features:

BibTeX

For more extensive support of references through BibTeX files, have a look at the BibTeX layer.

Important Note

Since version 0.104, spacemacs uses the org version from the org ELPA repository instead of the one shipped with emacs. Then, any org related code should not be loaded before dotspacemacs/user-config, otherwise both versions will be loaded and will conflict.

Because of autoloading, calling to org functions will trigger the loading up of the org shipped with emacs which will induce conflicts. One way to avoid conflict is to wrap your org config code in a with-eval-after-load block like this:

  (with-eval-after-load 'org
    ;; here goes your Org config :)
    ;; ....
    )

Install

Layer

To use this configuration layer, add it to your ~/.spacemacs. You will need to add org to the existing dotspacemacs-configuration-layers list in this file.

Github support

To install Github related extensions like ox-gfm to export to Github flavored markdown set the variable org-enable-github-support to t.

  (setq-default dotspacemacs-configuration-layers '(
    (org :variables org-enable-github-support t)))

Twitter Bootstrap support

To install the Twitter Boostrap extension (from ox-twbs), which enables twitter bootstrap formatted html, then set the variable org-enable-bootstrap-support to t.

  (setq-default dotspacemacs-configuration-layers '(
    (org :variables
         org-enable-bootstrap-support t)))

Gnuplot support

Org-mode support the plotting of data within tables through Gnuplot as demonstrated here; unfortunately, this is not terribly well supported on Windows at this stage. It is possible to disable the configuration of gnuplot support as usual by adding the package gnuplot to your dotspacemacs-excluded-packages variable.

Reveal.js support

To enable the export of your org file as a reveal.js presentation, set the variable org-enable-reveal-js-support to t. This will install the org-reveal extension.

  (setq-default dotspacemacs-configuration-layers
   '((org :variables org-enable-reveal-js-support t)))

In order to be able to use org-reveal, download reveal.js from its homepage and set org-reveal-js to the download path, as described in the manual. Alternatively, add the following line to each .org file you want to process:

#+REVEAL_ROOT: http://cdn.jsdelivr.net/reveal.js/3.0.0/

Org-journal support

org-journal is a simple journal management system for keeping a seperate journal file for each day inside a directory.

To install org-journal set the variable org-enable-org-journal-support to t.

  (setq-default dotspacemacs-configuration-layers '(
    (org :variables
         org-enable-org-journal-support t)))

By default journal files are stored in ~/Documents/journal/. You can override this by setting org-journal-dir in dotspacemacs/user-config

    (setq org-journal-dir "~/org/journal/")

You can change the journal file name format by altering org-journal-file-format.

    (setq org-journal-file-format "%Y-%m-%d")

Warning: setting org-journal-file-format to include a file extension like %Y-%m-%d.org breaks calender search functionality.

By default journal files are started with a first level heading (*) followed by the date formatted for the locale. If you prefer that your journal files are formatted differently you can alter org-journal-date-prefix and org-journal-date-format.

For example, to have your new journal files created with this header:

#+TITLE: Tuesday, September 06 2016

Simply define the following in dotspacemacs/user-config

    (setq org-journal-date-prefix "#+TITLE: ")
    (setq org-journal-date-format "%A, %B %d %Y")

The default entry is a second level heading (=** =) followed by a timestamp. If you start your journal files with a Title as shown above you may want to adjust entries to start at the first level heading and you may want to change or omit the timestamp.

    (setq org-journal-time-prefix "* ")
    (setq org-journal-time-format "")

Any of the org-journal settings can be configured in dotspacemacs/user-config or defined along side the layer itself.

For example:

  (setq-default dotspacemacs-configuration-layers '(
                                                    (org :variables
                                                         org-enable-org-journal-support t
                                                         org-journal-dir "~/org/journal/"
                                                         org-journal-file-format "%Y-%m-%d"
                                                         org-journal-date-prefix "#+TITLE: "
                                                         org-journal-date-format "%A, %B %d %Y"
                                                         org-journal-time-prefix "* "
                                                         org-journal-time-format "")
                                                    )
Configure org-journal with the layer

Different bullets

You can tweak the bullets displayed in the org buffer in the function dotspacemacs/user-config of your dotfile by setting the variable org-bullets-bullet-list. By default the list is set to ("◉" "○" "✸" "✿").

  (setq org-bullets-bullet-list '("■" "◆" "▲" "▶"))

You can disable the fancy bullets entirely by adding org-bullets to dotspacemacs-excluded-packages.

  (dotspacemacs-excluded-packages '(org-bullets))

Project support

Set the layer variable org-projectile-file to the filename where you want to store project-specific TODOs. If this is an absolute path, all todos will be stored in the same file (organized by project), whereas if it is just a single filename, todos will be stored in each project root.

  (setq-default dotspacemacs-configuration-layers
    '((org :variables org-projectile-file "TODOs.org")))

The TODO files are not added to the agenda automatically. You can do this with the following snippet. Note that this may have unintended consequences until this bug is fixed.

  (with-eval-after-load 'org-agenda
    (require 'org-projectile)
    (push (org-projectile:todo-files) org-agenda-files))

Mode line support

To temporarily enable mode line display of org clock, press SPC t m c.

To permanently enable mode line display of org clock, add this snippet to your dotspacemacs/user-config function:

  (setq spaceline-org-clock-p t)

Key bindings

Org

Key Binding Description
SPC a o # org agenda list stuck projects
SPC a o / org occur in agenda files
SPC a o a org agenda list
SPC a o c org capture
SPC a o e org store agenda views
SPC a o k i org clock in last
SPC a o k j org jump to current clock
SPC a o k o org clock out
SPC a o l org store link
SPC a o m org tags view
SPC a o o org agenda
SPC a o s org search view
SPC a o t org todo list
SPC C c org-capture

Org with evil-org-mode

Key Binding Description
SPC m <dotspacemacs-major-mode-leader-key> org-ctrl-c-ctrl-c
SPC m * org-ctrl-c-star
SPC m RET org-ctrl-c-ret
SPC m - org-ctrl-c-minus
SPC m ' org-edit-special
SPC m ^ org-sort
SPC m / org-sparse-tree
SPC m . org-time-stamp
SPC m ! org-time-stamp-inactive
SPC m a org-agenda
SPC m b org-tree-to-indirect-buffer
SPC m A org-archive-subtree
SPC m c org-capture
SPC m C evil-org-recompute-clocks
SPC m d org-deadline
SPC m D org-insert-drawer
SPC m e e org-export-dispatch
SPC m f org-set-effort
SPC m I org-clock-in
SPC m l org-open-at-point
SPC m n org-narrow-to-subtree
SPC m N widen
SPC m O org-clock-out
SPC m P org-set-property
SPC m q org-clock-cancel
SPC m R org-refile
SPC m s org-schedule
SPC m T org-show-todo-tree
SPC m L org-shiftright
SPC m H org-shiftleft
SPC m K org-shiftup
SPC m J org-shiftdown
SPC m C-S-l org-shiftcontrolright
SPC m C-S-h org-shiftcontrolleft
SPC m C-S-j org-shiftcontroldown
SPC m C-S-k org-shiftcontrolup
SPC m V toggle space-doc-mode a read-only view mode
SPC s j spacemacs/jump-in-buffer (jump to a heading)

Tables

Key Binding Description
SPC m t a Align the table at point by aligning all vertical bars
SPC m t b Blank the current table field or active region
SPC m t c Convert from org-mode table to table.el and back
SPC m t d c Delete a column from the table
SPC m t d r Delete the current row or horizontal line from the table
SPC m t e Replace the table field value at the cursor by the result of a calculation
SPC m t E Export table to a file, with configurable format
SPC m t h Go to the previous field in the table
SPC m t H Move column to the left
SPC m t i c Insert a new column into the table
SPC m t i h Insert a horizontal-line below the current line into the table
SPC m t i H Insert a hline and move to the row below that line
SPC m t i r Insert a new row above the current line into the table
SPC m t I Import a file as a table
SPC m t j Go to the next row (same column) in the current table
SPC m t J Move table row down
SPC m t K Move table row up
SPC m t l Go to the next field in the current table, creating new lines as needed
SPC m t L Move column to the right
SPC m t n Query for a size and insert a table skeleton
SPC m t N Use the table.el package to insert a new table
SPC m t p Plot the table using org-plot/gnuplot
SPC m t r Recalculate the current table line by applying all stored formulas
SPC m t s Sort table lines according to the column at point
SPC m t t f Toggle the formula debugger in tables
SPC m t t o Toggle the display of Row/Column numbers in tables
SPC m t w Wrap several fields in a column like a paragraph

Tree

Key Binding Description
SPC m S l org-demote-subtree
SPC m S h org-promote-subtree
SPC m S k org-move-subtree-up
SPC m S j org-move-subtree-down
Key Binding Description
TAB org-cycle
$ org-end-of-line
^ org-beginning-of-line
< org-metaleft
> org-metaright
gh outline-up-heading
gj org-forward-heading-same-level
gk org-backward-heading-same-level
gl outline-next-visible-heading
t org-todo
T org-insert-todo-heading nil
H org-beginning-of-line
L org-end-of-line
o always-insert-item
O org-open-above
Key Binding Description
M-l org-metaright
M-h org-metaleft
M-k org-metaup
M-j org-metadown
M-L org-shiftmetaright
M-H org-shiftmetaleft
M-K org-shiftmetaup
M-J org-shiftmetadown
M-o org-insert-heading+org-metaright
M-t org-insert-todo-heading nil+ org-metaright

Element insertion

Key Binding Description
SPC m h i org-insert-heading-after-current
SPC m h I org-insert-heading
SPC m h s org-insert-subheading
SPC m i f org-insert-footnote
SPC m i l org-insert-link
SPC m i a org-attach

Links

Key Binding Description
RET org-open-at-point

Emphasis

Key Binding Description
SPC m x b make region bold
SPC m x c make region code
SPC m x i make region italic
SPC m x r clear region emphasis
SPC m x s make region strike-through
SPC m x u make region underline
SPC m x v make region verbose

Tagging

Key Binding Description
SPC m : org-set-tags

Navigating in calendar

Key Binding Description
M-l One day forward
M-h One day backward
M-j One week forward
M-k One week backward
M-L One month forward
M-H One month backward
M-J One year forward
M-K One year backward

Capture buffers and src blocks

org-capture-mode and org-src-mode both support the confirm and abort conventions.

Key Binding Description
SPC m <dotspacemacs-major-mode-leader-key> confirm in org-capture-mode
SPC m ' confirm in org-src-mode
SPC m c confirm
SPC m a abort
SPC m k abort
SPC m R org-capture-refile in org-capture-mode

Org agenda

Keybindings

The evilified org agenda supports the following bindings:

Key Binding Description
M-SPC or s-M-SPC org-agenda transient state
SPC m : org-agenda-set-tags
SPC m a org-agenda
SPC m d org-agenda-deadline
SPC m f org-agenda-set-effort
SPC m I org-agenda-clock-in
SPC m O org-agenda-clock-out
SPC m p org-pomodoro (if package is used)
SPC m P org-agenda-set-property
SPC m R org-agenda-refile
SPC m q org-agenda-clock-cancel
SPC m s org-agenda-schedule
M-j next item
M-k previous item
M-h earlier view
M-l later view
gr refresh
gd toggle grid
C-v change view
RET org-agenda-goto
M-RET org-agenda-show-and-scroll-up

Org agenda transient state

Use M-SPC or s-M-SPC in an org agenda buffer to activate its transient state. The transient state aims to list the most useful org agenda commands and visually organize them by category. The commands associated with each binding are listed bellow.

Keybinding Description Command
Entry
ht set status org-agenda-todo
hk kill org-agenda-kill
hR refile org-agenda-refile
hA archive org-agenda-archive-default
h: set tags org-agenda-set-tags
hp set priority org-agenda-priority
Visit entry
SPC in other window org-agenda-show-and-scroll-up
TAB & go to location org-agenda-goto
RET & del other windows org-agenda-switch-to
o link link-hint-open-link
Filter
ft by tag org-agenda-filter-by-tag
fr refine by tag org-agenda-filter-by-tag-refine
fc by category org-agenda-filter-by-category
fh by top headline org-agenda-filter-by-top-headline
fx by regexp org-agenda-filter-by-regexp
fd delete all filters org-agenda-filter-remove-all
Date
ds schedule org-agenda-schedule
dd set deadline org-agenda-deadline
dt timestamp org-agenda-date-prompt
+ do later org-agenda-do-date-later
- do earlier org-agenda-do-date-earlier
Toggle
tf follow org-agenda-follow-mode
tl log org-agenda-log-mode
ta archive org-agenda-archives-mode
tr clock report org-agenda-clockreport-mode
td diaries org-agenda-toggle-diary
View
vd day org-agenda-day-view
vw week org-agenda-week-view
vt fortnight org-agenda-fortnight-view
vm month org-agenda-month-view
vy year org-agenda-year-view
vn next span org-agenda-later
vp prev span org-agenda-earlier
vr reset org-agenda-reset-view
Clock
cI in org-agenda-clock-in
cO out org-agenda-clock-out
cq cancel org-agenda-clock-cancel
cj jump org-agenda-clock-goto
Other
gr reload org-agenda-redo
. go to today org-agenda-goto-today
gd go to date org-agenda-goto-date

Pomodoro

Key Binding Description
SPC m p starts a pomodoro

Presentation

org-present must be activated explicitly by typing: SPC SPC org-present

Key Binding Description
h previous slide
l next slide
q quit

Org-MIME

Key Binding Description
SPC m M in message-mode buffers convert into html email
SPC m m send current buffer as HTML email message

Org-download

Key Binding Description
SPC m i s Take screenshot
SPC m i y Yank image url

Org-projectile

Key Binding Description
SPC a o p Capture a TODO for the current project
SPC u SPC a o p Capture a TODO for any given project (choose from list)
SPC p o Go to the TODOs for the current project

Org-journal

Key Binding Description
SPC a o j j New journal entry
SPC a o j s Search journal entries

Journal entries are highlighted in the calander. The following key bindings are available for calander-mode for navigating and manipulating the journal.

Key Binding Description
SPC m r Read journal entry
SPC m i Insert journal entry for date
SPC m n Next journal entry
SPC m p Previous journal entry
SPC m s Search all journal entries
SPC m w Search calendar week journal entries
SPC m m Search calendar month journal entries
SPC m y Search calendar year journal entries

While viewing a journal entry in org-journal-mode the following key bindings are available.

Key Binding Description
SPC m j New journal entry
SPC m p Previous journal entry
SPC m n Next journal entry