2015-06-15 09:06:10 +02:00
|
|
|
;;; module-web.el
|
|
|
|
|
2016-04-23 22:08:46 -04:00
|
|
|
(def-company-backend! sass-mode (css))
|
|
|
|
(def-company-backend! scss-mode (css))
|
|
|
|
(def-docset! scss-mode "sass,bourbon")
|
2016-04-16 00:44:56 -04:00
|
|
|
(add-hook! (sass-mode scss-mode less-css-mode)
|
|
|
|
'(flycheck-mode narf|hl-line-off hs-minor-mode))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
2016-04-21 00:33:08 -04:00
|
|
|
(push '("css" "scss" "sass" "less" "styl") projectile-other-file-alist)
|
|
|
|
|
|
|
|
(use-package haml-mode :mode "\\.haml$")
|
|
|
|
|
|
|
|
(use-package stylus-mode :mode "\\.styl$"
|
|
|
|
:config (push '("styl" "css") projectile-other-file-alist))
|
2016-04-16 00:44:56 -04:00
|
|
|
|
2016-04-16 21:40:17 -04:00
|
|
|
(use-package less-css-mode :mode "\\.less$"
|
|
|
|
:config (push '("less" "css") projectile-other-file-alist))
|
|
|
|
|
|
|
|
(use-package sass-mode :mode "\\.sass$"
|
|
|
|
:config (push '("sass" "css") projectile-other-file-alist))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
|
|
|
(use-package scss-mode
|
|
|
|
:mode "\\.scss$"
|
2016-04-16 00:44:56 -04:00
|
|
|
:preface (require 'css-mode)
|
|
|
|
:init (setq scss-compile-at-save nil)
|
2015-10-09 18:00:24 -04:00
|
|
|
:config
|
2016-04-16 21:40:17 -04:00
|
|
|
(push '("scss" "css") projectile-other-file-alist)
|
2016-03-28 21:39:13 -04:00
|
|
|
(sp-local-pair 'scss-mode "/*" "*/" :post-handlers '(("[d-3]||\n[i]" "RET") ("| " "SPC")))
|
|
|
|
|
2015-11-30 05:31:20 -05:00
|
|
|
(map! :map scss-mode-map
|
|
|
|
:n "M-r" 'narf/web-refresh-browser
|
2016-04-16 00:44:56 -04:00
|
|
|
(:localleader :nv ";" 'narf/append-semicolon)
|
2015-11-30 05:31:20 -05:00
|
|
|
(:leader
|
2016-03-29 23:13:31 -04:00
|
|
|
:n ";" 'helm-css-scss
|
|
|
|
:n ":" 'helm-css-scss-multi))
|
|
|
|
|
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
|
2016-03-29 23:13:31 -04:00
|
|
|
:predicate (lambda () (not (use-region-p))))))
|
2015-10-09 18:00:24 -04:00
|
|
|
|
2016-01-18 01:43:28 -05:00
|
|
|
(use-package jaded-mode
|
2016-04-23 22:08:46 -04:00
|
|
|
:load-path "/Volumes/hlissner/Dropbox/work/plugins/jaded-mode"
|
2015-07-02 23:40:20 +02:00
|
|
|
:mode "\\.jade$"
|
2016-01-18 01:43:28 -05:00
|
|
|
:config
|
2016-04-23 22:08:46 -04:00
|
|
|
(push '("jade" "html") projectile-other-file-alist)
|
2016-01-18 01:43:28 -05:00
|
|
|
(map! :map jaded-mode-map
|
|
|
|
:i [tab] 'narf/dumb-indent
|
|
|
|
:i [backtab] 'narf/dumb-dedent))
|
2015-07-02 23:40:20 +02:00
|
|
|
|
2015-06-15 09:06:10 +02:00
|
|
|
(use-package web-mode
|
2016-04-23 22:08:46 -04:00
|
|
|
:mode ("\\.p?html?$"
|
2016-03-28 21:42:04 -04:00
|
|
|
"\\.\\(tpl\\|blade\\)\\(\\.php\\)?$"
|
2016-03-27 18:18:43 -04:00
|
|
|
"\\.erb$"
|
2016-04-23 22:08:46 -04:00
|
|
|
"\\.as[cp]x$"
|
|
|
|
"\\.mustache$"
|
2016-03-28 21:42:04 -04:00
|
|
|
"wp-content/themes/.+/.+\\.php$")
|
2015-06-15 09:06:10 +02:00
|
|
|
:init
|
2016-04-19 03:14:31 -04:00
|
|
|
(add-hook 'web-mode-hook 'turn-off-smartparens-mode)
|
2016-03-28 21:39:13 -04:00
|
|
|
|
2016-04-19 03:14:31 -04:00
|
|
|
:config
|
2016-04-23 22:08:46 -04:00
|
|
|
(setq web-mode-enable-html-entities-fontification t
|
|
|
|
web-mode-enable-current-column-highlight t)
|
|
|
|
(push '("html" "jade") projectile-other-file-alist)
|
|
|
|
|
2016-04-19 03:14:31 -04:00
|
|
|
(map! :map web-mode-map :i "SPC" 'self-insert-command)
|
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
|
2016-04-23 22:08:46 -04:00
|
|
|
:n "M-r" 'narf/web-refresh-browser
|
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
|
|
|
: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
|
|
|
|
2016-04-19 03:14:31 -04:00
|
|
|
;;
|
2015-06-15 09:06:10 +02:00
|
|
|
(use-package emmet-mode
|
2016-03-26 01:22:06 -04:00
|
|
|
:commands (emmet-mode)
|
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
|
|
|
|
2016-04-16 21:36:24 -04:00
|
|
|
;;
|
2016-04-23 22:08:46 -04:00
|
|
|
(def-project-type! jekyll ":{"
|
2016-04-16 21:36:24 -04:00
|
|
|
:modes (web-mode scss-mode html-mode markdown-mode yaml-mode)
|
2016-01-21 19:33:54 -05:00
|
|
|
:match "/\\(\\(css\\|_\\(layouts\\|posts\\|sass\\)\\)/.+\\|.+.html\\)$"
|
2016-03-28 21:42:04 -04:00
|
|
|
:files ("config.yml" "_layouts/")
|
2016-04-19 03:14:31 -04:00
|
|
|
(add-hook! mode
|
2016-04-16 21:36:24 -04:00
|
|
|
(when (eq major-mode 'web-mode)
|
|
|
|
(web-mode-set-engine "django"))))
|
|
|
|
|
2016-04-23 22:08:46 -04:00
|
|
|
(def-project-type! wordpress "wp"
|
2016-04-16 21:36:24 -04:00
|
|
|
:modes (php-mode web-mode css-mode scss-mode sass-mode)
|
2016-01-21 19:33:54 -05:00
|
|
|
:match "/wp-\\(\\(content\\|admin\\|includes\\)/\\)?.+$"
|
2016-03-28 21:42:04 -04:00
|
|
|
:files ("wp-config.php" "wp-content/"))
|
2016-04-16 21:36:24 -04:00
|
|
|
|
|
|
|
;; TODO Add stylus-mode
|
2015-06-15 09:06:10 +02:00
|
|
|
|
|
|
|
(provide 'module-web)
|
|
|
|
;;; module-web.el ends here
|