2015-06-15 09:06:10 +02:00
|
|
|
;;; module-web.el
|
|
|
|
|
2016-01-01 16:19:44 -05:00
|
|
|
(add-hook! (sass-mode scss-mode) '(rainbow-mode flycheck-mode))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
|
|
|
(use-package sass-mode
|
|
|
|
:mode "\\.sass$"
|
|
|
|
:config
|
2015-10-14 03:39:32 -04:00
|
|
|
(after! company (define-company-backend! sass-mode (css))))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
|
|
|
(use-package scss-mode
|
|
|
|
:mode "\\.scss$"
|
2016-01-02 15:08:10 -05:00
|
|
|
:preface
|
|
|
|
(require 'css-mode)
|
2015-10-09 18:00:24 -04:00
|
|
|
:init
|
2016-01-07 01:11:47 -05:00
|
|
|
(add-hook! scss-mode '(hs-minor-mode narf|hl-line-off))
|
2015-10-09 18:00:24 -04:00
|
|
|
(setq-default css-indent-offset 2)
|
|
|
|
(setq scss-compile-at-save nil)
|
|
|
|
:config
|
2015-11-30 05:31:20 -05:00
|
|
|
(map! :map scss-mode-map
|
|
|
|
:n "M-r" 'narf/web-refresh-browser
|
|
|
|
(:leader
|
|
|
|
:n ";" 'helm-css-scss
|
|
|
|
:n ":" 'helm-css-scss-multi))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
|
|
|
(after! web-beautify
|
|
|
|
(add-hook! scss-mode (setenv "jsbeautify_indent_size" "2"))
|
2015-11-30 05:31:20 -05:00
|
|
|
(map! :map scss-mode-map :m "gQ" 'web-beautify-css))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
|
|
|
(after! emr
|
|
|
|
(emr-declare-command 'narf/scss-toggle-inline-or-block
|
|
|
|
:title "toggle inline/block"
|
|
|
|
:modes 'scss-mode
|
|
|
|
:predicate (lambda () (not (use-region-p)))))
|
|
|
|
|
2015-10-14 03:39:32 -04:00
|
|
|
(after! company (define-company-backend! scss-mode (css))))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
2015-06-15 09:06:10 +02:00
|
|
|
(use-package web-beautify
|
|
|
|
:commands (web-beautify-js web-beautify-css web-beautify-html)
|
|
|
|
:init
|
|
|
|
(after! css-mode
|
|
|
|
(add-hook! css-mode (setenv "jsbeautify_indent_size" "2"))
|
2015-11-30 05:31:20 -05:00
|
|
|
(map! :map css-mode-map :m "gQ" 'web-beautify-css)))
|
2015-06-15 09:06:10 +02:00
|
|
|
|
2015-07-02 23:40:20 +02:00
|
|
|
(use-package jade-mode
|
|
|
|
:mode "\\.jade$"
|
|
|
|
:config (require 'sws-mode))
|
|
|
|
|
2016-01-02 15:08:25 -05:00
|
|
|
(use-package slim-mode :mode "\\.slim$")
|
|
|
|
|
2015-06-15 09:06:10 +02:00
|
|
|
(use-package web-mode
|
2015-08-12 15:07:09 +02:00
|
|
|
:mode ("\\.\\(p\\)?htm\\(l\\)?$" "\\.tpl\\(\\.php\\)?$" "\\.erb$" "wp-content/themes/.+/.+\\.php$")
|
2015-06-15 09:06:10 +02:00
|
|
|
:init
|
|
|
|
(setq web-mode-markup-indent-offset 2
|
|
|
|
web-mode-code-indent-offset 2
|
|
|
|
web-mode-css-indent-offset 2
|
|
|
|
web-mode-style-padding 2
|
|
|
|
web-mode-script-padding 2
|
2015-12-23 03:46:12 -05:00
|
|
|
web-mode-block-padding 2
|
|
|
|
;; smartparens handles this
|
|
|
|
web-mode-enable-auto-pairing nil
|
|
|
|
web-mode-enable-auto-quoting nil)
|
2015-06-15 09:06:10 +02:00
|
|
|
:config
|
|
|
|
(after! web-beautify
|
|
|
|
(add-hook! web-mode (setenv "jsbeautify_indent_size" "4"))
|
2015-11-30 05:31:20 -05:00
|
|
|
(map! :map web-mode-map :m "gQ" 'web-beautify-html))
|
2015-06-15 09:06:10 +02:00
|
|
|
|
2015-07-22 17:36:03 +02:00
|
|
|
(after! nlinum
|
|
|
|
;; Fix blank line numbers after unfolding
|
|
|
|
(advice-add 'web-mode-fold-or-unfold :after 'nlinum--flush))
|
|
|
|
|
2015-11-30 05:31:20 -05:00
|
|
|
(map! :map web-mode-map
|
|
|
|
"M-/" 'web-mode-comment-or-uncomment
|
2015-06-15 09:06:10 +02:00
|
|
|
|
2015-11-30 05:31:20 -05:00
|
|
|
:n "za" 'web-mode-fold-or-unfold
|
|
|
|
(:localleader :n "t" 'web-mode-element-rename)
|
2015-06-15 09:06:10 +02:00
|
|
|
|
2015-11-30 05:31:20 -05:00
|
|
|
:n "M-r" 'narf/web-refresh-browser
|
2015-07-31 18:45:33 +02:00
|
|
|
|
2015-11-30 05:31:20 -05:00
|
|
|
:nv "]a" 'web-mode-attribute-next
|
|
|
|
:nv "[a" 'web-mode-attribute-previous
|
|
|
|
:nv "]t" 'web-mode-tag-next
|
|
|
|
:nv "[t" 'web-mode-tag-previous
|
|
|
|
:nv "]T" 'web-mode-element-child
|
|
|
|
:nv "[T" 'web-mode-element-parent))
|
2015-06-15 09:06:10 +02:00
|
|
|
|
|
|
|
(use-package emmet-mode
|
|
|
|
:defer t
|
2015-11-14 02:41:53 -05:00
|
|
|
:init
|
|
|
|
(add-hook! (scss-mode web-mode html-mode haml-mode nxml-mode) 'emmet-mode)
|
|
|
|
(defvar emmet-mode-keymap (make-sparse-keymap))
|
2015-06-15 09:06:10 +02:00
|
|
|
:config
|
|
|
|
(setq emmet-move-cursor-between-quotes t)
|
2015-11-30 05:31:20 -05:00
|
|
|
(map! :map emmet-mode-keymap
|
|
|
|
:v "M-e" 'emmet-wrap-with-markup
|
|
|
|
:i "M-e" 'emmet-expand-yas
|
|
|
|
:i "M-E" 'emmet-expand-line))
|
2015-06-15 09:06:10 +02:00
|
|
|
|
|
|
|
(define-minor-mode jekyll-mode
|
|
|
|
"Jekyll development mode."
|
|
|
|
:init-value nil
|
|
|
|
:lighter " :{"
|
|
|
|
:keymap (make-sparse-keymap)
|
|
|
|
(add-yas-minor-mode! 'jekyll-mode))
|
|
|
|
(associate! jekyll-mode
|
|
|
|
:match "/_\\(layouts\\|posts\\)/.+$"
|
|
|
|
:files ("config.yml" "_layouts")
|
|
|
|
:in (web-mode scss-mode html-mode markdown-mode))
|
|
|
|
;; (after! company-dict (add-to-list 'company-dict-minor-mode-alist 'jekyll-mode))
|
|
|
|
|
|
|
|
(define-minor-mode wordpress-mode
|
|
|
|
"Wordpress development mode."
|
|
|
|
:init-value nil
|
|
|
|
:lighter " wp"
|
|
|
|
:keymap (make-sparse-keymap)
|
|
|
|
(add-yas-minor-mode! 'wordpress-mode))
|
|
|
|
(associate! wordpress-mode :match "/wp-\\(content\\|admin\\|includes\\)/.+$")
|
|
|
|
(associate! wordpress-mode :match "/wp-.+\\.php$")
|
|
|
|
;; (after! company-dict (add-to-list 'company-dict-minor-mode-alist 'wordpress-mode))
|
|
|
|
|
|
|
|
(provide 'module-web)
|
|
|
|
;;; module-web.el ends here
|