-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmod-react.el
48 lines (34 loc) · 1.55 KB
/
mod-react.el
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
;;; mod-react.el --- Support for React development -*- lexical-binding: t; -*-
;; Copyright (C) 2023 Tommaso Rossi
;; Author: Tommaso Rossi <[email protected]>
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;; Support for React development in JavaScript and TypeScript with
;; `eglot'.
;;; Code:
(require 'mod-node)
;; javascript react
(with-eval-after-load 'js
(setq js-jsx-indent-level 2)
(define-derived-mode js-react-mode js-mode
"JSX")
(add-to-list 'auto-mode-alist '("\\.jsx\\'" . js-react-mode))
(add-hook 'js-react-mode-hook #'eglot-ensure))
(with-eval-after-load 'typescript-mode
;; see https://github.com/joaotavora/eglot/issues/624
;; see https://github.com/joaotavora/eglot#handling-quirky-servers
(define-derived-mode ts-react-mode typescript-mode
"TSX")
(add-to-list 'auto-mode-alist '("\\.tsx\\'" . ts-react-mode))
(add-hook 'ts-react-mode-hook #'eglot-ensure))
(provide 'mod-react)
;;; mod-react.el ends here