64 lines
2.8 KiB
EmacsLisp
64 lines
2.8 KiB
EmacsLisp
;;; config.el
|
|
|
|
(config! js2-mode
|
|
(add-hook! '(tern-mode flycheck-mode highlight-indent-guides-mode))
|
|
|
|
;; NOTE Do indentation settings after editorconfig has done its thing
|
|
(add-hook! (setq js-switch-indent-offset js-indent-level))
|
|
|
|
(setq js2-skip-preprocessor-directives t
|
|
js2-highlight-external-variables nil
|
|
js2-mode-show-parse-errors nil)
|
|
|
|
;;
|
|
(set! :repl nodejs-repl
|
|
:company-backends (tern)
|
|
:electric (?\} ?\) ?. "||" "&&")
|
|
:map (:localleader :nv ";" 'doom/append-semicolon)
|
|
:emr ((:v js2r-extract-function "extract function")
|
|
(:v js2r-extract-method "extract method")
|
|
(:v js2r-introduce-parameter "introduce parameter")
|
|
(:n js2r-localize-parameter "localize parameter")
|
|
(:n js2r-expand-object "expand object")
|
|
(:n js2r-contract-object "contract object")
|
|
(:n js2r-expand-function "expand function")
|
|
(:n js2r-contract-function "contract function")
|
|
(:n js2r-expand-array "expand array")
|
|
(:n js2r-contract-array "contract array")
|
|
(:n js2r-wrap-buffer-in-iife "wrap buffer in ii function")
|
|
(:v js2r-inject-global-in-iife "inject global in ii function")
|
|
(:n js2r-add-to-globals-annotation "add to globals annotation")
|
|
(:v js2r-extract-var "extract variable")
|
|
(:v js2r-inline-var "inline variable")
|
|
(:n js2r-rename-var "rename variable")
|
|
(:n js2r-var-to-this "var to this")
|
|
(:n js2r-arguments-to-object "arguments to object")
|
|
(:n js2r-ternary-to-if "ternary to if")
|
|
(:n js2r-split-var-declaration "split var declaration")
|
|
(:n js2r-split-string "split string")
|
|
(:v js2r-unwrap "unwrap")
|
|
(:nv js2r-log-this "log this")
|
|
(:nv js2r-debug-this "debug this")
|
|
(:n js2r-forward-slurp "forward slurp")
|
|
(:n js2r-forward-barf "forward barf"))))
|
|
|
|
(config! coffee-mode
|
|
(setq-default coffee-indent-like-python-mode t))
|
|
|
|
|
|
;;
|
|
;; Projects
|
|
;;
|
|
|
|
(project! npm
|
|
:modes (web-mode js2-mode)
|
|
:files ("package.json")
|
|
:config
|
|
(let* ((project-path (doom-project-root))
|
|
(hash (gethash project-path npm-conf))
|
|
(package-file (expand-file-name "package.json" project-path))
|
|
deps)
|
|
(when-let (json (and (not hash) (f-exists? package-file)
|
|
(ignore-errors (json-read-file package-file))))
|
|
(puthash project-path json npm-conf))))
|
|
|