From 5387dd32fe19ea991fe1d5921e4986d65fc3b6b8 Mon Sep 17 00:00:00 2001 From: Tyler Perkins Date: Thu, 19 Aug 2021 12:22:42 -0400 Subject: [PATCH] Add aerc --- Makefile | 30 +++++- src/aerc/accounts.conf | 18 ++++ src/aerc/aerc.conf | 209 +++++++++++++++++++++++++++++++++++++++++ src/aerc/binds.conf | 107 +++++++++++++++++++++ 4 files changed, 363 insertions(+), 1 deletion(-) create mode 100644 src/aerc/accounts.conf create mode 100644 src/aerc/aerc.conf create mode 100644 src/aerc/binds.conf diff --git a/Makefile b/Makefile index cd3f5a4..3050637 100644 --- a/Makefile +++ b/Makefile @@ -5,7 +5,7 @@ # SRC = ./src -PROGRAMS = calcurse nvim newsboat mpv bash compton sc-im +PROGRAMS = calcurse nvim newsboat mpv bash compton sc-im aerc .PHONY : install update clean @@ -63,6 +63,17 @@ install : [ -f ~/.config/sc-im/scimrc ] && mv ~/.config/sc-im/scimrc ~/.config/sc-im/scimrc.old; \ cp $(SRC)/sc-im/scimrc ~/.config/sc-im/scimrc; \ fi + #aerc + @which aerc > /dev/null 2>&1 + @if [ $$? -eq 0 ]; then \ + echo "aerc found! Installing configs...";\ + [ -f ~/.config/aerc/accounts.conf ] && mv ~/.config/aerc/accounts.conf ~/.config/aerc/accounts.conf.old; \ + cp $(SRC)/aerc/accounts.conf ~/.config/aerc/accounts.conf; \ + [ -f ~/.config/aerc/aerc.conf ] && mv ~/.config/aerc/aerc.conf ~/.config/aerc/aerc.conf.old; \ + cp $(SRC)/aerc/aerc.conf ~/.config/aerc/aerc.conf; \ + [ -f ~/.config/aerc/binds.conf ] && mv ~/.config/aerc/binds.conf ~/.config/aerc/binds.conf.old; \ + cp $(SRC)/aerc/binds.conf ~/.config/aerc/binds.conf; \ + fi update: #vim @@ -109,6 +120,14 @@ update: echo "sc-im found! Updating config files with existing versions..."; \ [ -f ~/.config/sc-im/scimrc ] && cp ~/.config/sc-im/scimrc $(SRC)/sc-im/scimrc; \ fi + #aerc + @which aerc > /dev/null 2>&1 + @if [ $$? -eq 0 ]; then \ + echo "aerc found! Updating config files with existing versions..."; \ + [ -f ~/.config/aerc/accounts.conf ] && cp ~/.config/aerc/accounts.conf $(SRC)/aerc/accounts.conf; \ + [ -f ~/.config/aerc/aerc.conf ] && cp ~/.config/aerc/aerc.conf $(SRC)/aerc/aerc.conf; \ + [ -f ~/.config/aerc/binds.conf ] && cp ~/.config/aerc/binds.conf $(SRC)/aerc/binds.conf; \ + fi clean : #vim @@ -155,3 +174,12 @@ clean : echo "sc-im found! removing existing config files and reinstalling *.old"; \ [ if ~/.config/sc-im/scimrc ] && mv ~/.config/sc-im/scimrc.old ~/.config/sc-im/scimrc; \ fi + #aerc + @which aerc > /dev/null 2>&1 + @if [ $$? -eq 0 ]; then \ + echo "aerc found! removing existing config files and reinstalling *.old"; \ + [ if ~/.config/aerc/accounts.conf.old ] && mv ~/.config/aerc/accounts.conf.old ~/.config/aerc/accounts.conf; \ + [ if ~/.config/aerc/aerc.conf.old ] && mv ~/.config/aerc/aerc.conf.old ~/.config/aerc/aerc.conf; \ + [ if ~/.config/aerc/binds.conf.old ] && mv ~/.config/aerc/binds.conf.old ~/.config/aerc/binds.conf; \ + fi + diff --git a/src/aerc/accounts.conf b/src/aerc/accounts.conf new file mode 100644 index 0000000..b7aaf1b --- /dev/null +++ b/src/aerc/accounts.conf @@ -0,0 +1,18 @@ +[Gmail] +source = imaps://britishlink12%40gmail.com@imap.gmail.com:993 +source-cred-cmd = pass email/britishlink12@gmail.com +outgoing = smtps+plain://britishlink12%40gmail.com@smtp.gmail.com:465 +outgoing-cred-cmd = pass email/britishlink12@gmail.com +default = INBOX +from = Tyler Perkins +copy-to = Sent + +[School] +source = imaps://tperki17%40kent.edu@imap.gmail.com +source-cred-cmd = pass email/tperki17@kent.edu +outgoing = smtps+plain://tperki17%40kent.edu@smtp.gmail.com +outgoing-cred-cmd = pass email/tperki17@kent.edu +default = INBOX +from = Tyler Perkins +copy-to = Sent + diff --git a/src/aerc/aerc.conf b/src/aerc/aerc.conf new file mode 100644 index 0000000..cefc4c7 --- /dev/null +++ b/src/aerc/aerc.conf @@ -0,0 +1,209 @@ +# +# aerc main configuration + +[ui] +# +# Describes the format for each row in a mailbox view. This field is compatible +# with mutt's printf-like syntax. +# +# Default: %D %-17.17n %Z %s +index-format=%D %-17.17n %Z %s + +# +# See time.Time#Format at https://godoc.org/time#Time.Format +# +# Default: 2006-01-02 03:04 PM (ISO 8601 + 12 hour time) +timestamp-format=2006-01-02 03:04 PM + +# +# Width of the sidebar, including the border. +# +# Default: 20 +sidebar-width=20 + +# +# Message to display when viewing an empty folder. +# +# Default: (no messages) +empty-message=(no messages) + +# Message to display when no folders exists or are all filtered +# +# Default: (no folders) +empty-dirlist=(no folders) + +# Enable mouse events in the ui, e.g. clicking and scrolling with the mousewheel +# +# Default: false +mouse-enabled=false + +# +# Ring the bell when new messages are received +# +# Default: true +new-message-bell=true + +# Marker to show before a pinned tab's name. +# +# Default: ` +pinned-tab-marker='`' + +# Describes the format string to use for the directory list +# +# Default: %n %>r +dirlist-format=%n %>r + +# USER_ADDED +# Spinner, animation shown while loading, split by +# spinner-delimiter +spinner="/,-,\,|" + +# USER_ADDED +# Spinner-delimiter, used for above spinner option +spinner-delimiter="," + +# List of space-separated criteria to sort the messages by, see *sort* +# command in *aerc*(1) for reference. Prefixing a criterion with "-r " +# reverses that criterion. +# +# Example: "from -r date" +# +# Default: "" +sort= + +# Moves to next message when the current message is deleted +# +# Default: true +next-message-on-delete=true + +# The directories where the stylesets are stored. It takes a colon-separated +# list of directories. +# +# default: /usr/share/aerc/stylesets/ +stylesets-dirs=/usr/share/aerc/stylesets/ + +# Sets the styleset to use for the aerc ui elements. +# +# Default: default +styleset-name=default + +[viewer] +# +# Specifies the pager to use when displaying emails. Note that some filters +# may add ANSI codes to add color to rendered emails, so you may want to use a +# pager which supports ANSI codes. +# +# Default: less -R +pager=less -R + +# +# If an email offers several versions (multipart), you can configure which +# mimetype to prefer. For example, this can be used to prefer plaintext over +# html emails. +# +# Default: text/plain,text/html +alternatives=text/plain,text/html + +# +# Default setting to determine whether to show full headers or only parsed +# ones in message viewer. +# +# Default: false +show-headers=false + +# +# Layout of headers when viewing a message. To display multiple headers in the +# same row, separate them with a pipe, e.g. "From|To". Rows will be hidden if +# none of their specified headers are present in the message. +# +# Default: From|To,Cc|Bcc,Date,Subject +header-layout=From|To,Cc|Bcc,Date,Subject + +# Whether to always show the mimetype of an email, even when it is just a single part +# +# Default: false +always-show-mime=true + +# How long to wait after the last input before auto-completion is triggered. +# +# Default: 250ms +completion-delay=250ms + +# +# Global switch for completion popovers +# +# Default: true +completion-popovers=true + +[compose] +# +# Specifies the command to run the editor with. It will be shown in an embedded +# terminal, though it may also launch a graphical window if the environment +# supports it. Defaults to $EDITOR, or vi. +editor= + +# +# Default header fields to display when composing a message. To display +# multiple headers in the same row, separate them with a pipe, e.g. "To|From". +# +# Default: To|From,Subject +header-layout=To|From,Subject + +# +# Specifies the command to be used to tab-complete email addresses. Any +# occurrence of "%s" in the address-book-cmd will be replaced with what the +# user has typed so far. +# +# The command must output the completions to standard output, one completion +# per line. Each line must be tab-delimited, with an email address occurring as +# the first field. Only the email address field is required. The second field, +# if present, will be treated as the contact name. Additional fields are +# ignored. +address-book-cmd= + +[filters] +# +# Filters allow you to pipe an email body through a shell command to render +# certain emails differently, e.g. highlighting them with ANSI escape codes. +# +# The first filter which matches the email's mimetype will be used, so order +# them from most to least specific. +# +# You can also match on non-mimetypes, by prefixing with the header to match +# against (non-case-sensitive) and a comma, e.g. subject,text will match a +# subject which contains "text". Use header,~regex to match against a regex. +subject,~^\[PATCH=awk -f /usr/share/aerc/filters/hldiff +text/html=/usr/share/aerc/filters/html +text/*=awk -f /usr/share/aerc/filters/plaintext +#image/*=catimg -w $(tput cols) - + +[triggers] +# +# Triggers specify commands to execute when certain events occur. +# +# Example: +# new-email=exec notify-send "New email from %n" "%s" + +# +# Executed when a new email arrives in the selected folder +new-email=exec notify-send "New email from %n" "%s" + +[templates] +# Templates are used to populate email bodies automatically. +# + +# The directories where the templates are stored. It takes a colon-separated +# list of directories. +# +# default: /usr/share/aerc/templates/ +template-dirs=/usr/share/aerc/templates/ + +# The template to be used for quoted replies. +# +# default: quoted_reply +quoted-reply=quoted_reply + +# The template to be used for forward as body. +# +# default: forward_as_body +forwards=forward_as_body diff --git a/src/aerc/binds.conf b/src/aerc/binds.conf new file mode 100644 index 0000000..e6b3b56 --- /dev/null +++ b/src/aerc/binds.conf @@ -0,0 +1,107 @@ +# Binds are of the form = +# To use '=' in a key sequence, substitute it with "Eq": "" +# If you wish to bind #, you can wrap the key sequence in quotes: "#" = quit + = :prev-tab +H = :prev-tab + = :next-tab +L = :next-tab + = :term + +[messages] +q = :quit + +j = :next + = :next + = :next 50% + = :next 100% + = :next -s 100% + +k = :prev + = :prev + = :prev 50% + = :prev 100% + = :prev -s 100% +g = :select 0 +G = :select -1 + +J = :next-folder +K = :prev-folder + +v = :mark -t +V = :mark -v + + = :view +l = :view +d = :prompt 'Really delete this message?' 'delete-message' +D = :delete +A = :archive flat + +C = :compose + +rr = :reply -a +rq = :reply -aq +Rr = :reply +Rq = :reply -q + +c = :cf +$ = :term +! = :term +| = :pipe + +/ = :search +\ = :filter +n = :next-result +N = :prev-result + +[view] +q = :close +| = :pipe +D = :delete +S = :save +A = :archive flat + +f = :forward +rr = :reply -a +rq = :reply -aq +Rr = :reply +Rq = :reply -q + +H = :toggle-headers + = :prev-part + = :next-part +J = :next +K = :prev +h = :close + +[compose] +# Keybindings used when the embedded terminal is not selected in the compose +# view +$ex = + = :prev-field + = :next-field + = :next-field + +[compose::editor] +# Keybindings used when the embedded terminal is selected in the compose view +$noinherit = true +$ex = + = :prev-field + = :next-field + = :prev-tab + = :next-tab + +[compose::review] +# Keybindings used when reviewing a message to be sent +y = :send +n = :abort +p = :postpone +q = :abort +e = :edit +a = :attach + +[terminal] +$noinherit = true +$ex = + + = :prev-tab + = :next-tab