Move CSS configuration out of Org-mode
This commit is contained in:
parent
a2227eb50a
commit
accea011e3
2 changed files with 80 additions and 88 deletions
80
emacs/.emacs.d/init/oni-css-mode-init.el
Normal file
80
emacs/.emacs.d/init/oni-css-mode-init.el
Normal file
|
@ -0,0 +1,80 @@
|
||||||
|
;;; oni-css-mode-init.el --- CSS Mode configuration -*- lexical-binding: t; -*-
|
||||||
|
|
||||||
|
;; Copyright (C) 2018 Tom Willemse
|
||||||
|
|
||||||
|
;; Author: Tom Willemse <tom@ryuslash.org>
|
||||||
|
;; Keywords: local
|
||||||
|
|
||||||
|
;; This program is free software; you can redistribute it and/or modify
|
||||||
|
;; it under the terms of the GNU General Public License as published by
|
||||||
|
;; the Free Software Foundation, either version 3 of the License, or
|
||||||
|
;; (at your option) any later version.
|
||||||
|
|
||||||
|
;; This program is distributed in the hope that it will be useful,
|
||||||
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
;; GNU General Public License for more details.
|
||||||
|
|
||||||
|
;; You should have received a copy of the GNU General Public License
|
||||||
|
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
;;; Commentary:
|
||||||
|
|
||||||
|
;; Configuration for `css-mode'.
|
||||||
|
|
||||||
|
;;; Code:
|
||||||
|
|
||||||
|
(require 'css-mode)
|
||||||
|
(eval-when-compile (require 'compile))
|
||||||
|
|
||||||
|
(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)))
|
||||||
|
|
||||||
|
(add-hook 'css-mode-hook 'electric-pair-local-mode)
|
||||||
|
(add-hook 'css-mode-hook 'electric-indent-local-mode)
|
||||||
|
(add-hook 'css-mode-hook 'company-mode)
|
||||||
|
(add-hook 'css-mode-hook 'fci-mode)
|
||||||
|
|
||||||
|
(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)))
|
||||||
|
|
||||||
|
(define-key css-mode-map (kbd "C-c !") #'oni:css-toggle-important)
|
||||||
|
|
||||||
|
(provide 'oni-css-mode-init)
|
||||||
|
;;; oni-css-mode-init.el ends here
|
|
@ -1,88 +0,0 @@
|
||||||
#+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
|
|
||||||
|
|
||||||
Enable company mode.
|
|
||||||
|
|
||||||
#+BEGIN_SRC emacs-lisp
|
|
||||||
(add-hook 'css-mode-hook 'company-mode)
|
|
||||||
#+END_SRC
|
|
||||||
|
|
||||||
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
|
|
Loading…
Reference in a new issue