doomemacs/modules/lang/web/+css.el
2017-03-19 22:50:57 -04:00

59 lines
1.6 KiB
EmacsLisp

;;; lang/web/+css.el
;; css-mode hooks apply to scss and less-css modes
(add-hook 'css-mode-hook 'rainbow-delimiters-mode)
(add-hook! (css-mode sass-mode)
'(yas-minor-mode-on flycheck-mode highlight-numbers-mode))
(sp-with-modes '(css-mode scss-mode less-css-mode stylus-mode)
(sp-local-pair "/*" "*/" :post-handlers '(("[d-3]||\n[i]" "RET") ("| " "SPC"))))
(map! :map* (css-mode-map scss-mode-map less-css-mode-map)
:n "M-R" '+css/web-refresh-browser
(:localleader
:nv ";" '+css/append-semicolon
:n "rb" '+css/toggle-inline-or-block))
;;
;; Packages
;;
(def-package! counsel-css
:when (featurep! :completion ivy)
:commands (counsel-css counsel-css-imenu-setup)
:init
(add-hook 'css-mode-hook 'counsel-css-imenu-setup)
(map! :map* (css-mode-map scss-mode-map less-css-mode-map)
:leader :n ";" 'counsel-css))
(def-package! rainbow-mode
:commands rainbow-mode
:init (add-hook! (css-mode sass-mode) 'rainbow-mode))
(def-package! css-mode
:mode "\\.css$"
:mode ("\\.scss$" . scss-mode)
:config
(set! :company-backend '(css-mode scss-mode) '(company-css company-yasnippet))
(set! :build 'compile 'scss-mode '+css/scss-build))
(def-package! sass-mode
:mode "\\.sass$"
:config
(setq sass-command-options '("--style compressed"))
(set! :company-backend 'sass-mode '(company-css company-yasnippet))
(set! :build 'compile 'sass-mode '+css/sass-build))
(def-package! less-css-mode
:mode "\\.less$")
(def-package! stylus-mode
:mode "\\.styl$"
:init (add-hook! stylus-mode '(yas-minor-mode-on flycheck-mode)))