

GitHub - protesilaos/modus-themes: MIRROR Used ONLY for issue tracking in case s...
source link: https://github.com/protesilaos/modus-themes
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

Modus themes for GNU Emacs (Modus Operandi and Modus Vivendi)
A pair of highly accessible themes that conform with the WCAG AAA standard for colour contrast between background and foreground combinations (a minimum contrast of 7:1---the highest standard of its kind). The Modus themes also strive to empower users with red-green color deficiency: this is achieved through customisation options that replace all relevant instances of green with blue, as well as the overall design of the themes which relies mostly on colours that cover the blue-cyan-magenta side of the spectrum.
The themes are built into GNU Emacs 28 (development target). They are also distributed in several packages formats.
modus-operandi
is light.modus-vivendi
is dark.
For some demo content, check:
Quick setup for the latest version
With use-package
:
(use-package modus-themes :ensure :init ;; Add all your customizations prior to loading the themes (setq modus-themes-italic-constructs t modus-themes-bold-constructs nil modus-themes-region '(bg-only no-extend)) ;; Load the theme files before enabling a theme (modus-themes-load-themes) :config ;; Load the theme of your choice: (modus-themes-load-operandi) ;; OR (modus-themes-load-vivendi) :bind ("<f5>" . modus-themes-toggle))
Without use-package
:
(require 'modus-themes) ;; Add all your customizations prior to loading the themes (setq modus-themes-italic-constructs t modus-themes-bold-constructs nil modus-themes-region '(bg-only no-extend)) ;; Load the theme files before enabling a theme (modus-themes-load-themes) ;; Load the theme of your choice: (modus-themes-load-operandi) ;; OR (modus-themes-load-vivendi) (define-key global-map (kbd "<f5>") #'modus-themes-toggle)
Note: make sure that you do not customise custom-theme-load-path
or custom-theme-directory
after the themes' package declaration.
That will lead to failures in loading the files. If you must change
those variables, do it before the package declaration.
All customisations in short
While you should read the manual for all the details (see next section), here is a snippet with all current customisation options and their possible values. Note that those settings are only for purposes of demonstration:
(setq modus-themes-italic-constructs t modus-themes-bold-constructs nil modus-themes-mixed-fonts nil modus-themes-subtle-line-numbers nil modus-themes-intense-markup t modus-themes-success-deuteranopia t modus-themes-tabs-accented t modus-themes-inhibit-reload t ; only applies to `customize-set-variable' and related modus-themes-fringes nil ; {nil,'subtle,'intense} ;; Options for `modus-themes-lang-checkers' are either nil (the ;; default), or a list of properties that may include any of those ;; symbols: `straight-underline', `text-also', `background', ;; `intense' OR `faint'. modus-themes-lang-checkers nil ;; Options for `modus-themes-mode-line' are either nil, or a list ;; that can combine any of `3d' OR `moody', `borderless', ;; `accented', `padded'. modus-themes-mode-line '(padded accented borderless) ;; This one only works when `modus-themes-mode-line' (above) has ;; the `padded' property. It takes a positive integer. modus-themes-mode-line-padding 3 ;; Options for `modus-themes-syntax' are either nil (the default), ;; or a list of properties that may include any of those symbols: ;; `faint', `yellow-comments', `green-strings', `alt-syntax' modus-themes-syntax nil ;; Options for `modus-themes-hl-line' are either nil (the default), ;; or a list of properties that may include any of those symbols: ;; `accented', `underline', `intense' modus-themes-hl-line '(underline accented) ;; Options for `modus-themes-paren-match' are either nil (the ;; default), or a list of properties that may include any of those ;; symbols: `bold', `intense', `underline' modus-themes-paren-match '(bold intense) ;; Options for `modus-themes-links' are either nil (the default), ;; or a list of properties that may include any of those symbols: ;; `neutral-underline' OR `no-underline', `faint' OR `no-color', ;; `bold', `italic', `background' modus-themes-links '(neutral-underline background) ;; Options for `modus-themes-prompts' are either nil (the ;; default), or a list of properties that may include any of those ;; symbols: `background', `bold', `gray', `intense', `italic' modus-themes-prompts '(intense bold) modus-themes-completions 'moderate ; {nil,'moderate,'opinionated} modus-themes-mail-citations nil ; {nil,'faint,'monochrome} ;; Options for `modus-themes-region' are either nil (the default), ;; or a list of properties that may include any of those symbols: ;; `no-extend', `bg-only', `accented' modus-themes-region '(bg-only no-extend) ;; Options for `modus-themes-diffs': nil, 'desaturated, ;; 'bg-only, 'deuteranopia, 'fg-only-deuteranopia modus-themes-diffs 'fg-only-deuteranopia modus-themes-org-blocks 'gray-background ; {nil,'gray-background,'tinted-background} modus-themes-org-agenda ; this is an alist: read the manual or its doc string '((header-block . (variable-pitch scale-title)) (header-date . (grayscale workaholic bold-today)) (event . (accented scale-small)) (scheduled . uniform) (habit . traffic-light-deuteranopia)) modus-themes-headings ; this is an alist: read the manual or its doc string '((1 . (overline background)) (2 . (rainbow overline)) (t . (no-bold))) modus-themes-variable-pitch-ui nil modus-themes-variable-pitch-headings t modus-themes-scale-headings t modus-themes-scale-1 1.1 modus-themes-scale-2 1.15 modus-themes-scale-3 1.21 modus-themes-scale-4 1.27 modus-themes-scale-title 1.33)
Further information
Read the Info manual HTML
version for how to install, load, enable, and customise the themes. If
you are using the latest version of the themes, you already have the
manual installed: evaluate (info "(modus-themes) Top")
to start
reading it.
The themes cover a broad range of packages and are highly customisable.
Recommend
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK