dotfiles/emacs/.emacs.d/init/oni-css-mode-init.org

89 lines
2.5 KiB
Org Mode
Raw Normal View History

#+TITLE: CSS
scss-mode is based on css-mode, so any settings for css-mode also
automatically should work for scss-mode.
Enable electric pairing.
#+BEGIN_SRC emacs-lisp
(add-hook 'css-mode-hook 'electric-pair-local-mode)
#+END_SRC
Enable electric indenting.
#+BEGIN_SRC emacs-lisp
(add-hook 'css-mode-hook 'electric-indent-local-mode)
#+END_SRC
2016-10-19 22:53:07 +02:00
Enable company mode.
#+BEGIN_SRC emacs-lisp
(add-hook 'css-mode-hook 'company-mode)
#+END_SRC
2016-10-20 16:18:39 +02:00
Enable rainbow mode to see all the color specifications (well, most)
as pretty colors.
#+BEGIN_SRC emacs-lisp
(add-hook 'css-mode-hook 'rainbow-mode)
#+END_SRC
Add the scssc compiler's error message output to the compilation error
regexps.
#+BEGIN_SRC emacs-lisp
(eval-when-compile (require 'compile))
(with-eval-after-load 'compile
(defvar oni:scss-error-regexp
(rx (and bol
(zero-or-more space) "on line "
(group (one-or-more digit)) " of "
(group (one-or-more (or word punct (syntax symbol))))
eol)))
(add-to-list 'compilation-error-regexp-alist
(list oni:scss-error-regexp 2 1 nil 2 2)))
#+END_SRC
Add a command to toggle the =!important= flag on CSS properties.
#+BEGIN_SRC emacs-lisp
(defun oni:css-property-important-p ()
"Return whether or not the current property is important."
(save-excursion
(beginning-of-line)
(re-search-forward "!important" (line-end-position) :noerror)))
(defun oni:css-add-important ()
"Add an important flag to the property on the current line."
(interactive)
(unless (oni:css-property-important-p)
(save-excursion
(end-of-line)
(when (re-search-backward ";" (line-beginning-position) :noerror)
(insert " !important")))))
(defun oni:css-remove-important ()
"Remove the important flag from the property on the current line."
(interactive)
(when (oni:css-property-important-p)
(save-excursion
(end-of-line)
(when (re-search-backward " !important" (line-beginning-position) :noerror)
(replace-match "")))))
(defun oni:css-toggle-important ()
"Toggle the important flag on the property on the current line."
(interactive)
(if (oni:css-property-important-p)
(oni:css-remove-important)
(oni:css-add-important)))
#+END_SRC
Add a keybinding to toggle the =!important= flag on the current line.
#+BEGIN_SRC emacs-lisp
(global-set-key (kbd "C-c !") #'oni:css-toggle-important)
#+END_SRC