doomemacs/modules/lang/web/config.el
marty bc47e72984 tweak(web): detect and set angular in web-mode
- Add @angular/core in detecting angular to set the web-angularjs minor
mode

- At the same time set the web-mode-engine to "angular" so that
`format-all` uses prettier to format ionic `*.page.html` files in
addition to `*.component.html` files.

When `format-all` sees the web-mode-engine is set to "angular", it
applies `prettier` as opposed to `html-tidy`, as `tidy` doesn't
recognise angular component tags and hence errors out. The current
web-mode only sets the engine to "angular" for "*.components.html".
However, ionic angular uses file names such as "*.page.html", setting
engine will apply prettier to these html fils.
2022-01-06 15:27:54 +01:00

57 lines
1.7 KiB
EmacsLisp

;;; lang/web/config.el -*- lexical-binding: t; -*-
(load! "+html")
(load! "+css")
(use-package! emmet-mode
:preface (defvar emmet-mode-keymap (make-sparse-keymap))
:hook (css-mode web-mode html-mode haml-mode nxml-mode rjsx-mode reason-mode)
:config
(when (require 'yasnippet nil t)
(add-hook 'emmet-mode-hook #'yas-minor-mode-on))
(setq emmet-move-cursor-between-quotes t)
(setq-hook! 'rjsx-mode-hook emmet-expand-jsx-className? t)
(map! :map emmet-mode-keymap
:v [tab] #'emmet-wrap-with-markup
[tab] #'+web/indent-or-yas-or-emmet-expand
"M-E" #'emmet-expand-line))
;;
;;; Framework-based minor-modes
(def-project-mode! +web-jekyll-mode
:modes '(web-mode js-mode coffee-mode css-mode haml-mode pug-mode)
:files (and (or "_config.yml" "_config.toml")
(or "_layouts/" "_posts/"))
:on-enter
(when (eq major-mode 'web-mode)
(web-mode-set-engine "django")))
(def-project-mode! +web-django-mode
:modes '(web-mode python-mode)
:files ("manage.py")
:on-enter
(when (derived-mode-p 'web-mode)
(web-mode-set-engine "django")))
(def-project-mode! +web-wordpress-mode
:modes '(php-mode web-mode css-mode haml-mode pug-mode)
:files (or "wp-config.php" "wp-config-sample.php"))
(when (featurep! :lang javascript)
(def-project-mode! +web-angularjs-mode
:modes '(+javascript-npm-mode)
:when (+javascript-npm-dep-p '(angular @angular/core))
:on-enter
(when (derived-mode-p 'web-mode)
(web-mode-set-engine "angular")))
(def-project-mode! +web-react-mode
:modes '(+javascript-npm-mode)
:when (+javascript-npm-dep-p 'react))
(def-project-mode! +web-phaser-mode
:modes '(+javascript-npm-mode)
:when (+javascript-npm-dep-p '(or phaser phaser-ce))))