2015-07-24 20:07:03 +00:00
|
|
|
;;; packages.el --- react Layer packages File for Spacemacs
|
|
|
|
;;
|
2016-01-12 02:40:54 +00:00
|
|
|
;; Copyright (c) 2012-2016 Sylvain Benner & Contributors
|
2015-07-24 20:07:03 +00:00
|
|
|
;;
|
|
|
|
;; Author: Andrea Moretti <axyzxp@gmail.com>
|
|
|
|
;; URL: https://github.com/axyz
|
|
|
|
;;
|
|
|
|
;; This file is not part of GNU Emacs.
|
|
|
|
;;
|
|
|
|
;;; License: GPLv3
|
|
|
|
|
|
|
|
(setq react-packages
|
2015-07-28 22:05:16 +00:00
|
|
|
'(
|
2015-08-25 01:37:42 +00:00
|
|
|
company
|
|
|
|
company-tern
|
2016-10-10 01:44:35 +00:00
|
|
|
emmet-mode
|
2016-02-28 08:15:24 +00:00
|
|
|
evil-matchit
|
2015-08-25 01:37:42 +00:00
|
|
|
flycheck
|
|
|
|
js-doc
|
2016-04-21 14:35:28 +00:00
|
|
|
smartparens
|
2015-08-27 03:04:53 +00:00
|
|
|
tern
|
2015-07-28 22:05:16 +00:00
|
|
|
web-beautify
|
2015-08-25 01:37:42 +00:00
|
|
|
web-mode
|
2015-07-28 22:05:16 +00:00
|
|
|
))
|
2015-07-24 20:07:03 +00:00
|
|
|
|
2016-05-30 02:39:21 +00:00
|
|
|
(defun react/post-init-company ()
|
|
|
|
(spacemacs|add-company-hook react-mode))
|
2015-08-25 01:37:42 +00:00
|
|
|
|
2016-05-30 02:39:21 +00:00
|
|
|
(defun react/post-init-company-tern ()
|
|
|
|
(push 'company-tern company-backends-react-mode))
|
2015-07-24 20:07:03 +00:00
|
|
|
|
2016-10-10 01:44:35 +00:00
|
|
|
(defun react/post-init-emmet-mode ()
|
2016-10-03 21:54:21 +00:00
|
|
|
(add-hook 'react-mode-hook 'emmet-mode))
|
|
|
|
|
2016-02-28 08:15:24 +00:00
|
|
|
(defun react/post-init-evil-matchit ()
|
|
|
|
(with-eval-after-load 'evil-matchit
|
|
|
|
(plist-put evilmi-plugins 'react-mode '((evilmi-simple-get-tag evilmi-simple-jump)
|
|
|
|
(evilmi-javascript-get-tag evilmi-javascript-jump)
|
|
|
|
(evilmi-html-get-tag evilmi-html-jump)))))
|
|
|
|
|
2015-08-26 00:57:56 +00:00
|
|
|
(defun react/post-init-flycheck ()
|
2016-04-21 08:42:22 +00:00
|
|
|
(with-eval-after-load 'flycheck
|
2016-06-05 08:08:41 +00:00
|
|
|
(dolist (checker '(javascript-eslint javascript-standard))
|
|
|
|
(flycheck-add-mode checker 'react-mode)))
|
2016-04-22 07:27:38 +00:00
|
|
|
(defun react/use-eslint-from-node-modules ()
|
|
|
|
(let* ((root (locate-dominating-file
|
|
|
|
(or (buffer-file-name) default-directory)
|
|
|
|
"node_modules"))
|
|
|
|
(global-eslint (executable-find "eslint"))
|
|
|
|
(local-eslint (expand-file-name "node_modules/.bin/eslint"
|
|
|
|
root))
|
|
|
|
(eslint (if (file-executable-p local-eslint)
|
|
|
|
local-eslint
|
|
|
|
global-eslint)))
|
|
|
|
(setq-local flycheck-javascript-eslint-executable eslint)))
|
|
|
|
|
|
|
|
(add-hook 'react-mode-hook #'react/use-eslint-from-node-modules)
|
|
|
|
|
2016-01-27 20:08:25 +00:00
|
|
|
(spacemacs/add-flycheck-hook 'react-mode))
|
2015-07-27 22:26:47 +00:00
|
|
|
|
2015-08-26 00:57:56 +00:00
|
|
|
(defun react/post-init-js-doc ()
|
|
|
|
(add-hook 'react-mode-hook 'spacemacs/js-doc-require)
|
|
|
|
(spacemacs/js-doc-set-key-bindings 'react-mode))
|
2015-07-27 22:26:47 +00:00
|
|
|
|
2016-04-21 14:35:28 +00:00
|
|
|
(defun react/post-init-smartparens ()
|
|
|
|
(if dotspacemacs-smartparens-strict-mode
|
|
|
|
(add-hook 'react-mode-hook #'smartparens-strict-mode)
|
|
|
|
(add-hook 'react-mode-hook #'smartparens-mode)))
|
|
|
|
|
2016-06-21 23:03:18 +00:00
|
|
|
(defun react/post-init-tern ()
|
|
|
|
(add-hook 'react-mode-hook 'tern-mode)
|
|
|
|
(spacemacs//set-tern-key-bindings 'react-mode))
|
2015-08-27 03:04:53 +00:00
|
|
|
|
2015-08-26 00:57:56 +00:00
|
|
|
(defun react/post-init-web-beautify ()
|
2015-11-18 00:38:05 +00:00
|
|
|
(spacemacs/set-leader-keys-for-major-mode 'react-mode "=" 'web-beautify-js))
|
2015-07-28 22:05:16 +00:00
|
|
|
|
2015-08-25 01:37:42 +00:00
|
|
|
(defun react/post-init-web-mode ()
|
|
|
|
(define-derived-mode react-mode web-mode "react")
|
2016-04-21 15:02:48 +00:00
|
|
|
(add-to-list 'auto-mode-alist '("\\.jsx\\'" . react-mode))
|
2015-08-25 01:37:42 +00:00
|
|
|
(add-to-list 'auto-mode-alist '("\\.react.js\\'" . react-mode))
|
2015-12-22 09:34:58 +00:00
|
|
|
(add-to-list 'auto-mode-alist '("\\index.android.js\\'" . react-mode))
|
|
|
|
(add-to-list 'auto-mode-alist '("\\index.ios.js\\'" . react-mode))
|
2016-02-08 14:54:28 +00:00
|
|
|
(add-to-list 'magic-mode-alist '("/\\*\\* @jsx React\\.DOM \\*/" . react-mode))
|
2016-04-21 15:02:48 +00:00
|
|
|
(add-to-list 'magic-mode-alist '("^import React" . react-mode))
|
2015-08-26 00:57:56 +00:00
|
|
|
(defun spacemacs//setup-react-mode ()
|
|
|
|
"Adjust web-mode to accommodate react-mode"
|
|
|
|
(emmet-mode 0)
|
2015-10-09 06:30:56 +00:00
|
|
|
;; See https://github.com/CestDiego/emmet-mode/commit/3f2904196e856d31b9c95794d2682c4c7365db23
|
|
|
|
(setq-local emmet-expand-jsx-className? t)
|
2015-12-01 08:07:19 +00:00
|
|
|
;; Enable js-mode snippets
|
|
|
|
(yas-activate-extra-mode 'js-mode)
|
2015-09-29 02:03:10 +00:00
|
|
|
;; Force jsx content type
|
|
|
|
(web-mode-set-content-type "jsx")
|
2016-01-22 08:34:12 +00:00
|
|
|
;; Don't auto-quote attribute values
|
2016-04-25 18:02:38 +00:00
|
|
|
(setq-local web-mode-enable-auto-quoting nil))
|
2015-08-26 00:57:56 +00:00
|
|
|
(add-hook 'react-mode-hook 'spacemacs//setup-react-mode))
|