@electerm/electerm-react 1.34.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (273) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +31 -0
  3. package/client/common/auto-complete-data-mapper.js +6 -0
  4. package/client/common/byte-format.js +14 -0
  5. package/client/common/class.js +52 -0
  6. package/client/common/clipboard.js +49 -0
  7. package/client/common/constants.js +308 -0
  8. package/client/common/create-lang-edit-link.js +7 -0
  9. package/client/common/create-title.js +29 -0
  10. package/client/common/db-fix.js +24 -0
  11. package/client/common/db.js +155 -0
  12. package/client/common/download-mirrors.js +10 -0
  13. package/client/common/download.js +16 -0
  14. package/client/common/error-handler.jsx +27 -0
  15. package/client/common/fetch-from-server.js +47 -0
  16. package/client/common/fetch.jsx +71 -0
  17. package/client/common/find-bookmark-group-id.js +15 -0
  18. package/client/common/find-parent.js +30 -0
  19. package/client/common/form-layout.js +27 -0
  20. package/client/common/fs.js +21 -0
  21. package/client/common/get-proxy.js +8 -0
  22. package/client/common/id-with-stamp.js +10 -0
  23. package/client/common/index-sorter.js +4 -0
  24. package/client/common/init-setting-item.js +32 -0
  25. package/client/common/is-absolute-path.js +3 -0
  26. package/client/common/is-ip.js +16 -0
  27. package/client/common/is-valid-path.js +7 -0
  28. package/client/common/key-control-pressed.js +13 -0
  29. package/client/common/key-pressed.js +13 -0
  30. package/client/common/key-shift-pressed.js +7 -0
  31. package/client/common/mode2permission.js +81 -0
  32. package/client/common/new-terminal.js +31 -0
  33. package/client/common/parse-int10.js +3 -0
  34. package/client/common/parse-json-safe.js +11 -0
  35. package/client/common/pass-enc.js +25 -0
  36. package/client/common/post-msg.js +3 -0
  37. package/client/common/pre.js +156 -0
  38. package/client/common/promise-timeout.js +27 -0
  39. package/client/common/resolve.js +31 -0
  40. package/client/common/run-idle.js +1 -0
  41. package/client/common/safe-local-storage.js +35 -0
  42. package/client/common/safe-name.js +19 -0
  43. package/client/common/sftp.js +74 -0
  44. package/client/common/terminal-theme.js +158 -0
  45. package/client/common/test-connection.js +12 -0
  46. package/client/common/time.js +30 -0
  47. package/client/common/to-simple-obj.js +5 -0
  48. package/client/common/track.js +7 -0
  49. package/client/common/transfer.js +76 -0
  50. package/client/common/trzsz.js +62 -0
  51. package/client/common/ui-theme.js +44 -0
  52. package/client/common/uid.js +5 -0
  53. package/client/common/update-check.js +79 -0
  54. package/client/common/upgrade.js +68 -0
  55. package/client/common/wait.js +8 -0
  56. package/client/common/ws.js +161 -0
  57. package/client/components/batch-op/batch-op.jsx +650 -0
  58. package/client/components/bookmark-form/bookmark-form.styl +8 -0
  59. package/client/components/bookmark-form/bookmark-group-tree-format.js +39 -0
  60. package/client/components/bookmark-form/encodes.js +44 -0
  61. package/client/components/bookmark-form/form-ssh-common.jsx +208 -0
  62. package/client/components/bookmark-form/form-tabs.jsx +69 -0
  63. package/client/components/bookmark-form/index.jsx +159 -0
  64. package/client/components/bookmark-form/local-form-ui.jsx +152 -0
  65. package/client/components/bookmark-form/local-form.jsx +16 -0
  66. package/client/components/bookmark-form/proxy.jsx +49 -0
  67. package/client/components/bookmark-form/quick-command-list.jsx +31 -0
  68. package/client/components/bookmark-form/quick-command.jsx +228 -0
  69. package/client/components/bookmark-form/render-auth-ssh.jsx +104 -0
  70. package/client/components/bookmark-form/render-connection-hopping.jsx +229 -0
  71. package/client/components/bookmark-form/render-delayed-scripts.jsx +88 -0
  72. package/client/components/bookmark-form/render-ssh-tunnel.jsx +116 -0
  73. package/client/components/bookmark-form/serial-form-ui.jsx +311 -0
  74. package/client/components/bookmark-form/serial-form.jsx +20 -0
  75. package/client/components/bookmark-form/sftp-enable.jsx +33 -0
  76. package/client/components/bookmark-form/ssh-form-ui.jsx +100 -0
  77. package/client/components/bookmark-form/ssh-form.jsx +348 -0
  78. package/client/components/bookmark-form/telnet-form-ui.jsx +154 -0
  79. package/client/components/bookmark-form/telnet-form.jsx +16 -0
  80. package/client/components/bookmark-form/tree-delete.jsx +87 -0
  81. package/client/components/bookmark-form/use-form-funcs.jsx +50 -0
  82. package/client/components/bookmark-form/use-quick-commands.jsx +83 -0
  83. package/client/components/bookmark-form/use-submit.jsx +77 -0
  84. package/client/components/bookmark-form/use-ui.jsx +82 -0
  85. package/client/components/bookmark-form/x11.jsx +23 -0
  86. package/client/components/common/animate-text.jsx +37 -0
  87. package/client/components/common/animate-text.styl +54 -0
  88. package/client/components/common/external-link.jsx +28 -0
  89. package/client/components/common/help-icon.jsx +25 -0
  90. package/client/components/common/highlight.jsx +23 -0
  91. package/client/components/common/highlight.styl +3 -0
  92. package/client/components/common/input-auto-focus.jsx +68 -0
  93. package/client/components/common/input-confirm.jsx +66 -0
  94. package/client/components/common/logo-elem.jsx +22 -0
  95. package/client/components/common/markdown.jsx +27 -0
  96. package/client/components/common/react-subx.jsx +1 -0
  97. package/client/components/common/resize-wrap.jsx +222 -0
  98. package/client/components/common/resize-wrap.styl +9 -0
  99. package/client/components/common/search.jsx +9 -0
  100. package/client/components/common/show-item.jsx +27 -0
  101. package/client/components/context-menu/boomarks.jsx +15 -0
  102. package/client/components/context-menu/context-menu.jsx +340 -0
  103. package/client/components/context-menu/context-menu.styl +90 -0
  104. package/client/components/context-menu/history.jsx +27 -0
  105. package/client/components/context-menu/icon-holder.jsx +5 -0
  106. package/client/components/context-menu/menu-btn.jsx +224 -0
  107. package/client/components/context-menu/sub-tab-menu.jsx +23 -0
  108. package/client/components/context-menu/tabs.jsx +22 -0
  109. package/client/components/context-menu/zoom.jsx +40 -0
  110. package/client/components/footer/batch-input.jsx +177 -0
  111. package/client/components/footer/footer-entry.jsx +141 -0
  112. package/client/components/footer/footer.styl +47 -0
  113. package/client/components/icons/match-case.jsx +10 -0
  114. package/client/components/icons/match-whole-word.jsx +13 -0
  115. package/client/components/icons/regular-exp.jsx +10 -0
  116. package/client/components/main/css-overwrite.jsx +92 -0
  117. package/client/components/main/error-wrapper.jsx +59 -0
  118. package/client/components/main/index.jsx +11 -0
  119. package/client/components/main/loading.jsx +25 -0
  120. package/client/components/main/main.jsx +149 -0
  121. package/client/components/main/term-fullscreen-control.jsx +21 -0
  122. package/client/components/main/term-fullscreen.styl +27 -0
  123. package/client/components/main/ui-theme.jsx +31 -0
  124. package/client/components/main/upgrade.jsx +351 -0
  125. package/client/components/main/upgrade.styl +27 -0
  126. package/client/components/main/wrapper.styl +41 -0
  127. package/client/components/quick-commands/qm.styl +29 -0
  128. package/client/components/quick-commands/quick-command-item.jsx +36 -0
  129. package/client/components/quick-commands/quick-command-transport-mod.jsx +54 -0
  130. package/client/components/quick-commands/quick-command-transport.jsx +12 -0
  131. package/client/components/quick-commands/quick-commands-box.jsx +233 -0
  132. package/client/components/quick-commands/quick-commands-form-elem.jsx +119 -0
  133. package/client/components/quick-commands/quick-commands-form.jsx +33 -0
  134. package/client/components/quick-commands/quick-commands-list.jsx +128 -0
  135. package/client/components/quick-commands/quick-commands-select.jsx +38 -0
  136. package/client/components/session/session.jsx +533 -0
  137. package/client/components/session/session.styl +53 -0
  138. package/client/components/session/sessions.jsx +445 -0
  139. package/client/components/setting-panel/bookmark-transport.jsx +148 -0
  140. package/client/components/setting-panel/bookmark-tree-list.jsx +14 -0
  141. package/client/components/setting-panel/col.jsx +18 -0
  142. package/client/components/setting-panel/list.jsx +186 -0
  143. package/client/components/setting-panel/list.styl +33 -0
  144. package/client/components/setting-panel/on-tree-drop.js +222 -0
  145. package/client/components/setting-panel/setting-modal.jsx +163 -0
  146. package/client/components/setting-panel/setting-wrap.jsx +37 -0
  147. package/client/components/setting-panel/setting-wrap.styl +52 -0
  148. package/client/components/setting-panel/setting.jsx +858 -0
  149. package/client/components/setting-panel/setting.styl +4 -0
  150. package/client/components/setting-panel/start-session-select.jsx +91 -0
  151. package/client/components/setting-panel/tab-bookmarks.jsx +37 -0
  152. package/client/components/setting-panel/tab-history.jsx +44 -0
  153. package/client/components/setting-panel/tab-quick-commands.jsx +38 -0
  154. package/client/components/setting-panel/tab-settings.jsx +42 -0
  155. package/client/components/setting-panel/tab-themes.jsx +34 -0
  156. package/client/components/setting-panel/tree-list.jsx +978 -0
  157. package/client/components/setting-panel/tree-list.styl +57 -0
  158. package/client/components/setting-sync/data-import.jsx +65 -0
  159. package/client/components/setting-sync/setting-sync-form.jsx +271 -0
  160. package/client/components/setting-sync/setting-sync.jsx +81 -0
  161. package/client/components/setting-sync/sync.styl +7 -0
  162. package/client/components/sftp/address-bar.jsx +139 -0
  163. package/client/components/sftp/address-bookmark-item.jsx +47 -0
  164. package/client/components/sftp/address-bookmark.jsx +81 -0
  165. package/client/components/sftp/address-bookmark.styl +8 -0
  166. package/client/components/sftp/confirm-modal.jsx +184 -0
  167. package/client/components/sftp/file-icon.jsx +22 -0
  168. package/client/components/sftp/file-item.jsx +1226 -0
  169. package/client/components/sftp/file-mode-modal.jsx +205 -0
  170. package/client/components/sftp/file-props-modal.jsx +211 -0
  171. package/client/components/sftp/file-read.js +81 -0
  172. package/client/components/sftp/list-table-ui.jsx +547 -0
  173. package/client/components/sftp/owner-list.js +97 -0
  174. package/client/components/sftp/paged-list.jsx +60 -0
  175. package/client/components/sftp/permission-render.jsx +42 -0
  176. package/client/components/sftp/sftp-entry.jsx +1069 -0
  177. package/client/components/sftp/sftp.styl +217 -0
  178. package/client/components/sftp/transfer-common.js +9 -0
  179. package/client/components/sftp/transfer-conflict.jsx +315 -0
  180. package/client/components/sftp/transfer-speed-format.js +60 -0
  181. package/client/components/sftp/transfer-tag.jsx +40 -0
  182. package/client/components/sftp/transfer-tag.styl +11 -0
  183. package/client/components/sftp/transfer.styl +55 -0
  184. package/client/components/sftp/transport-action.jsx +410 -0
  185. package/client/components/sftp/transport-entry.jsx +108 -0
  186. package/client/components/sftp/transport-types.js +8 -0
  187. package/client/components/sftp/transports-action.jsx +111 -0
  188. package/client/components/sftp/transports-ui.jsx +93 -0
  189. package/client/components/sftp/zip.js +42 -0
  190. package/client/components/sidebar/bookmark-select.jsx +48 -0
  191. package/client/components/sidebar/bookmark.jsx +82 -0
  192. package/client/components/sidebar/history.jsx +66 -0
  193. package/client/components/sidebar/index.jsx +230 -0
  194. package/client/components/sidebar/info-modal.jsx +250 -0
  195. package/client/components/sidebar/info.styl +27 -0
  196. package/client/components/sidebar/side-icon.jsx +25 -0
  197. package/client/components/sidebar/sidebar.styl +128 -0
  198. package/client/components/sidebar/transfer-history-modal.jsx +110 -0
  199. package/client/components/sidebar/transfer-history.styl +3 -0
  200. package/client/components/sidebar/transfer-list-control.jsx +205 -0
  201. package/client/components/sidebar/transfer-list.jsx +55 -0
  202. package/client/components/sidebar/transfer-modal.jsx +76 -0
  203. package/client/components/sidebar/transfer.styl +8 -0
  204. package/client/components/sidebar/transport-ui.jsx +109 -0
  205. package/client/components/tabs/index.jsx +320 -0
  206. package/client/components/tabs/tab.jsx +427 -0
  207. package/client/components/tabs/tabs.styl +220 -0
  208. package/client/components/tabs/window-control.jsx +55 -0
  209. package/client/components/terminal/attach-addon-custom.js +70 -0
  210. package/client/components/terminal/build-ls-term-id.js +5 -0
  211. package/client/components/terminal/index.jsx +1358 -0
  212. package/client/components/terminal/normal-buffer.jsx +33 -0
  213. package/client/components/terminal/term-search.jsx +224 -0
  214. package/client/components/terminal/term-search.styl +15 -0
  215. package/client/components/terminal/terminal-apis.js +31 -0
  216. package/client/components/terminal/terminal-interactive.jsx +148 -0
  217. package/client/components/terminal/terminal.styl +96 -0
  218. package/client/components/terminal/xterm-zmodem.js +48 -0
  219. package/client/components/terminal/zmodem-transfer.jsx +98 -0
  220. package/client/components/terminal/zmodem.styl +14 -0
  221. package/client/components/terminal-info/activity.jsx +54 -0
  222. package/client/components/terminal-info/base.jsx +25 -0
  223. package/client/components/terminal-info/content.jsx +101 -0
  224. package/client/components/terminal-info/data-cols-parser.jsx +50 -0
  225. package/client/components/terminal-info/disk.jsx +29 -0
  226. package/client/components/terminal-info/index.jsx +25 -0
  227. package/client/components/terminal-info/network.jsx +114 -0
  228. package/client/components/terminal-info/resource.jsx +80 -0
  229. package/client/components/terminal-info/run-cmd.jsx +273 -0
  230. package/client/components/terminal-info/terminal-info.styl +29 -0
  231. package/client/components/terminal-info/up.jsx +15 -0
  232. package/client/components/terminal-theme/index.jsx +264 -0
  233. package/client/components/terminal-theme/terminal-theme-list.styl +3 -0
  234. package/client/components/terminal-theme/theme-list.jsx +146 -0
  235. package/client/components/text-editor/text-editor-form.jsx +97 -0
  236. package/client/components/text-editor/text-editor.jsx +182 -0
  237. package/client/css/antd-overwrite.styl +14 -0
  238. package/client/css/basic.styl +38 -0
  239. package/client/css/includes/box.styl +154 -0
  240. package/client/css/includes/font-size.styl +6 -0
  241. package/client/css/includes/index.styl +3 -0
  242. package/client/css/includes/text.styl +31 -0
  243. package/client/css/includes/theme-default.styl +20 -0
  244. package/client/entry/basic.js +58 -0
  245. package/client/entry/index.jsx +15 -0
  246. package/client/entry/worker.js +137 -0
  247. package/client/store/address-bookmark.js +25 -0
  248. package/client/store/app-upgrade.js +23 -0
  249. package/client/store/batch-input-history.js +26 -0
  250. package/client/store/bookmark-group.js +128 -0
  251. package/client/store/bookmark.js +22 -0
  252. package/client/store/common.js +140 -0
  253. package/client/store/context-menu.js +23 -0
  254. package/client/store/db-upgrade.js +43 -0
  255. package/client/store/event.js +70 -0
  256. package/client/store/index.js +335 -0
  257. package/client/store/init-state.js +191 -0
  258. package/client/store/item.js +120 -0
  259. package/client/store/load-data.js +198 -0
  260. package/client/store/quick-command.js +43 -0
  261. package/client/store/session.js +54 -0
  262. package/client/store/setting.js +208 -0
  263. package/client/store/sidebar.js +48 -0
  264. package/client/store/sync.js +390 -0
  265. package/client/store/system-menu.js +120 -0
  266. package/client/store/tab.js +74 -0
  267. package/client/store/terminal-theme.js +116 -0
  268. package/client/store/transfer-history.js +27 -0
  269. package/client/store/transfer-list.js +20 -0
  270. package/client/store/ui-theme.js +71 -0
  271. package/client/store/watch.js +116 -0
  272. package/client/views/index.pug +58 -0
  273. package/package.json +34 -0
@@ -0,0 +1,116 @@
1
+ import {
2
+ Form,
3
+ InputNumber,
4
+ Radio,
5
+ Space,
6
+ Button,
7
+ Tooltip
8
+ } from 'antd'
9
+ import { MinusCircleOutlined, PlusOutlined, QuestionCircleOutlined } from '@ant-design/icons'
10
+ import { formItemLayout } from '../../common/form-layout'
11
+
12
+ const FormItem = Form.Item
13
+ const FormList = Form.List
14
+ const {
15
+ Button: RadioButton,
16
+ Group: RadioGroup
17
+ } = Radio
18
+ const { prefix } = window
19
+ const e = prefix('ssh')
20
+
21
+ export default function renderSshTunnel () {
22
+ function renderItem (field, i, add, remove) {
23
+ return (
24
+ <Space
25
+ align='center'
26
+ key={field.key}
27
+ >
28
+ <FormItem
29
+ label={e('sshTunnel')}
30
+ name={[field.name, 'sshTunnel']}
31
+ required
32
+ >
33
+ <RadioGroup>
34
+ <RadioButton
35
+ value='forwardRemoteToLocal'
36
+ >
37
+ <Tooltip title={e('remoteToLocal')}>
38
+ <span>R→L <QuestionCircleOutlined /></span>
39
+ </Tooltip>
40
+ </RadioButton>
41
+ <RadioButton
42
+ value='forwardLocalToRemote'
43
+ >
44
+ <Tooltip title={e('localToRemote')}>
45
+ <span>L→R <QuestionCircleOutlined /></span>
46
+ </Tooltip>
47
+ </RadioButton>
48
+ </RadioGroup>
49
+ </FormItem>
50
+ <FormItem
51
+ label=''
52
+ name={[field.name, 'sshTunnelRemotePort']}
53
+ required
54
+ >
55
+ <InputNumber
56
+ min={1}
57
+ max={65535}
58
+ addonBefore={e('remotePort')}
59
+ className='compact-input'
60
+ />
61
+ </FormItem>
62
+ <FormItem
63
+ label=''
64
+ name={[field.name, 'sshTunnelLocalPort']}
65
+ required
66
+ className='mg2x'
67
+ >
68
+ <InputNumber
69
+ min={1}
70
+ max={65535}
71
+ addonBefore={e('localPort')}
72
+ className='compact-input'
73
+ />
74
+ </FormItem>
75
+ <Button
76
+ icon={<MinusCircleOutlined />}
77
+ onClick={() => remove(field.name)}
78
+ className='mg24b'
79
+ />
80
+ </Space>
81
+ )
82
+ }
83
+
84
+ return [
85
+ <FormList
86
+ {...formItemLayout}
87
+ label={e('sshTunnel')}
88
+ name='sshTunnels'
89
+ key='sshTunnels'
90
+ >
91
+ {
92
+ (fields, { add, remove }, { errors }) => {
93
+ return (
94
+ <div>
95
+ {
96
+ fields.map((field, i) => {
97
+ return renderItem(field, i, add, remove)
98
+ })
99
+ }
100
+ <FormItem>
101
+ <Button
102
+ type='dashed'
103
+ onClick={() => add()}
104
+ block
105
+ icon={<PlusOutlined />}
106
+ >
107
+ {e('sshTunnel')}
108
+ </Button>
109
+ </FormItem>
110
+ </div>
111
+ )
112
+ }
113
+ }
114
+ </FormList>
115
+ ]
116
+ }
@@ -0,0 +1,311 @@
1
+ /**
2
+ * bookmark form
3
+ */
4
+
5
+ import { useEffect } from 'react'
6
+ import { ReloadOutlined } from '@ant-design/icons'
7
+ import {
8
+ Tabs,
9
+ Spin,
10
+ Input,
11
+ Select,
12
+ Switch,
13
+ AutoComplete,
14
+ Form,
15
+ TreeSelect
16
+ } from 'antd'
17
+ import { formItemLayout } from '../../common/form-layout'
18
+ import parseInt10 from '../../common/parse-int10'
19
+ import {
20
+ commonBaudRates,
21
+ commonDataBits,
22
+ commonStopBits,
23
+ commonParities,
24
+ terminalSerialType,
25
+ newBookmarkIdPrefix
26
+ } from '../../common/constants'
27
+ import formatBookmarkGroups from './bookmark-group-tree-format'
28
+ import defaultSettings from '../../../app/common/default-setting'
29
+ import findBookmarkGroupId from '../../common/find-bookmark-group-id'
30
+ import useSubmit from './use-submit'
31
+ import useUI from './use-ui'
32
+ import useQm from './use-quick-commands'
33
+ import copy from 'json-deep-copy'
34
+ import { defaults } from 'lodash-es'
35
+
36
+ const FormItem = Form.Item
37
+ const { Option } = Select
38
+ const { prefix } = window
39
+ const e = prefix('form')
40
+ const c = prefix('common')
41
+ const s = prefix('setting')
42
+ const m = prefix('menu')
43
+
44
+ export default function SerialFormUi (props) {
45
+ const [
46
+ form,
47
+ handleFinish,
48
+ submitUi
49
+ ] = useSubmit(props)
50
+ useEffect(() => {
51
+ if (props.formData.id.startsWith(newBookmarkIdPrefix)) {
52
+ form.setFieldsValue({
53
+ category: props.currentBookmarkGroupId
54
+ })
55
+ }
56
+ }, [props.currentBookmarkGroupId])
57
+ const qms = useQm(form, props.formData)
58
+ const uis = useUI(props)
59
+ const {
60
+ id = ''
61
+ } = props.formData
62
+ const {
63
+ bookmarkGroups = [],
64
+ currentBookmarkGroupId
65
+ } = props
66
+ const initBookmarkGroupId = !id.startsWith(newBookmarkIdPrefix)
67
+ ? findBookmarkGroupId(bookmarkGroups, id)
68
+ : currentBookmarkGroupId
69
+ let initialValues = copy(props.formData)
70
+ const defaultValues = {
71
+ baudRate: 9600,
72
+ dataBits: 8,
73
+ lock: true,
74
+ stopBits: 1,
75
+ parity: 'none',
76
+ rtscts: false,
77
+ xon: false,
78
+ xoff: false,
79
+ xany: false,
80
+ type: terminalSerialType,
81
+ term: defaultSettings.terminalType,
82
+ category: initBookmarkGroupId,
83
+ runScripts: [{}],
84
+ ignoreKeyboardInteractive: false
85
+ }
86
+ initialValues = defaults(initialValues, defaultValues)
87
+ function renderCommon () {
88
+ const {
89
+ bookmarkGroups = [],
90
+ serials = [],
91
+ loaddingSerials
92
+ } = props
93
+ const tree = formatBookmarkGroups(bookmarkGroups)
94
+ return (
95
+ <div className='pd1x'>
96
+ <FormItem
97
+ {...formItemLayout}
98
+ label='path'
99
+ rules={[{
100
+ required: true, message: 'path required'
101
+ }]}
102
+ normalize={props.trim}
103
+ >
104
+ <FormItem noStyle name='path'>
105
+ <AutoComplete
106
+ options={serials.map(d => {
107
+ return {
108
+ value: d.path
109
+ }
110
+ })}
111
+ />
112
+ </FormItem>
113
+ <Spin spinning={loaddingSerials}>
114
+ <span onClick={props.store.handleGetSerials}>
115
+ <ReloadOutlined /> {m('reload')} serials
116
+ </span>
117
+ </Spin>
118
+ </FormItem>
119
+ <FormItem
120
+ {...formItemLayout}
121
+ label='baudRate'
122
+ name='baudRate'
123
+ normalize={parseInt10}
124
+ >
125
+ <AutoComplete
126
+ options={commonBaudRates.map(d => {
127
+ return {
128
+ value: d + ''
129
+ }
130
+ })}
131
+ />
132
+ </FormItem>
133
+ <FormItem
134
+ {...formItemLayout}
135
+ label='dataBits'
136
+ name='dataBits'
137
+ normalize={parseInt10}
138
+ >
139
+ <Select>
140
+ {
141
+ commonDataBits.map(s => {
142
+ return (
143
+ <Option
144
+ value={s}
145
+ key={s}
146
+ >
147
+ {s}
148
+ </Option>
149
+ )
150
+ })
151
+ }
152
+ </Select>
153
+ </FormItem>
154
+ <FormItem
155
+ {...formItemLayout}
156
+ label='stopBits'
157
+ name='stopBits'
158
+ normalize={parseInt}
159
+ >
160
+ <Select>
161
+ {
162
+ commonStopBits.map(s => {
163
+ return (
164
+ <Option
165
+ value={s}
166
+ key={s}
167
+ >
168
+ {s}
169
+ </Option>
170
+ )
171
+ })
172
+ }
173
+ </Select>
174
+ </FormItem>
175
+ <FormItem
176
+ {...formItemLayout}
177
+ label='parity'
178
+ name='parity'
179
+ >
180
+ <Select>
181
+ {
182
+ commonParities.map(s => {
183
+ return (
184
+ <Option
185
+ value={s}
186
+ key={s}
187
+ >
188
+ {s}
189
+ </Option>
190
+ )
191
+ })
192
+ }
193
+ </Select>
194
+ </FormItem>
195
+ <FormItem
196
+ {...formItemLayout}
197
+ label='lock'
198
+ name='lock'
199
+ valuePropName='checked'
200
+ >
201
+ <Switch />
202
+ </FormItem>
203
+ <FormItem
204
+ {...formItemLayout}
205
+ label='rtscts'
206
+ name='rtscts'
207
+ valuePropName='checked'
208
+ >
209
+ <Switch />
210
+ </FormItem>
211
+ <FormItem
212
+ {...formItemLayout}
213
+ label='xon'
214
+ name='xon'
215
+ valuePropName='checked'
216
+ >
217
+ <Switch />
218
+ </FormItem>
219
+ <FormItem
220
+ {...formItemLayout}
221
+ label='xoff'
222
+ name='xoff'
223
+ valuePropName='checked'
224
+ >
225
+ <Switch />
226
+ </FormItem>
227
+ <FormItem
228
+ {...formItemLayout}
229
+ label='xany'
230
+ name='xany'
231
+ valuePropName='checked'
232
+ >
233
+ <Switch />
234
+ </FormItem>
235
+ <FormItem
236
+ {...formItemLayout}
237
+ label={e('title')}
238
+ name='title'
239
+ hasFeedback
240
+ >
241
+ <Input />
242
+ </FormItem>
243
+ <FormItem
244
+ {...formItemLayout}
245
+ label={e('description')}
246
+ name='description'
247
+ hasFeedback
248
+ >
249
+ <Input.TextArea rows={1} />
250
+ </FormItem>
251
+ <FormItem
252
+ {...formItemLayout}
253
+ label={e('type')}
254
+ name='type'
255
+ className='hide'
256
+ >
257
+ <Input />
258
+ </FormItem>
259
+ <FormItem
260
+ {...formItemLayout}
261
+ label={c('bookmarkCategory')}
262
+ name='category'
263
+ >
264
+ <TreeSelect
265
+ treeData={tree}
266
+ treeDefaultExpandAll
267
+ showSearch
268
+ />
269
+ </FormItem>
270
+ </div>
271
+ )
272
+ }
273
+
274
+ function renderTabs () {
275
+ const items = [
276
+ {
277
+ key: 'auth',
278
+ label: e('auth'),
279
+ forceRender: true,
280
+ children: renderCommon()
281
+ },
282
+ {
283
+ key: 'settings',
284
+ label: s('settings'),
285
+ forceRender: true,
286
+ children: uis
287
+ },
288
+ {
289
+ key: 'quickCommands',
290
+ label: e('quickCommands'),
291
+ forceRender: true,
292
+ children: qms
293
+ }
294
+ ]
295
+ return (
296
+ <Tabs items={items} />
297
+ )
298
+ }
299
+
300
+ return (
301
+ <Form
302
+ form={form}
303
+ onFinish={handleFinish}
304
+ initialValues={initialValues}
305
+ name='serial-form'
306
+ >
307
+ {renderTabs()}
308
+ {submitUi}
309
+ </Form>
310
+ )
311
+ }
@@ -0,0 +1,20 @@
1
+ /**
2
+ * bookmark form
3
+ */
4
+ import BookmarkForm from './ssh-form'
5
+ import SerialFormUi from './serial-form-ui'
6
+
7
+ export default class SerialForm extends BookmarkForm {
8
+ componentDidMount () {
9
+ this.props.store.handleGetSerials()
10
+ }
11
+
12
+ render () {
13
+ return (
14
+ <SerialFormUi
15
+ {...this.props}
16
+ {...this.getProps()}
17
+ />
18
+ )
19
+ }
20
+ }
@@ -0,0 +1,33 @@
1
+ import {
2
+ Form,
3
+ Switch
4
+ } from 'antd'
5
+
6
+ import { formItemLayout } from '../../common/form-layout'
7
+
8
+ const FormItem = Form.Item
9
+ const { prefix } = window
10
+ const e = prefix('form')
11
+
12
+ export default function renderEnableSftp () {
13
+ return [
14
+ <FormItem
15
+ {...formItemLayout}
16
+ label='SSH'
17
+ name='enableSsh'
18
+ key='ssh'
19
+ valuePropName='checked'
20
+ >
21
+ <Switch />
22
+ </FormItem>,
23
+ <FormItem
24
+ {...formItemLayout}
25
+ label={e('ignoreKeyboardInteractive')}
26
+ name='ignoreKeyboardInteractive'
27
+ key='ignoreKeyboardInteractive'
28
+ valuePropName='checked'
29
+ >
30
+ <Switch />
31
+ </FormItem>
32
+ ]
33
+ }
@@ -0,0 +1,100 @@
1
+ /**
2
+ * bookmark form
3
+ */
4
+ import { useState, useEffect } from 'react'
5
+ import {
6
+ Form
7
+ } from 'antd'
8
+ import {
9
+ authTypeMap,
10
+ newBookmarkIdPrefix,
11
+ defaultEnvLang
12
+ } from '../../common/constants'
13
+ import encodes from './encodes'
14
+ import findBookmarkGroupId from '../../common/find-bookmark-group-id'
15
+ import useSubmit from './use-submit'
16
+ import useUI from './use-ui'
17
+ import useQm from './use-quick-commands'
18
+ import copy from 'json-deep-copy'
19
+ import { defaultsDeep } from 'lodash-es'
20
+ import renderTabs from './form-tabs'
21
+ import renderCommon from './form-ssh-common'
22
+ import renderEnableSftp from './sftp-enable'
23
+ import renderProxy from './proxy'
24
+ import renderX11 from './x11'
25
+ import renderAuth from './render-auth-ssh'
26
+ import renderSshTunnel from './render-ssh-tunnel'
27
+ import renderConnectionHopping from './render-connection-hopping'
28
+ import './bookmark-form.styl'
29
+
30
+ export default function BookmarkFormUI (props) {
31
+ const [
32
+ form,
33
+ handleFinish,
34
+ submitUi
35
+ ] = useSubmit(props)
36
+ useEffect(() => {
37
+ if ((props.formData.id || '').startsWith(newBookmarkIdPrefix)) {
38
+ form.setFieldsValue({
39
+ category: props.currentBookmarkGroupId
40
+ })
41
+ }
42
+ }, [props.currentBookmarkGroupId])
43
+ const [authType, setAuthType] = useState(props.formData.authType || authTypeMap.password)
44
+ const qms = useQm(form, props.formData)
45
+ const uis = useUI(props)
46
+ const {
47
+ id = ''
48
+ } = props.formData
49
+ const {
50
+ bookmarkGroups = [],
51
+ currentBookmarkGroupId
52
+ } = props
53
+ const initBookmarkGroupId = !id.startsWith(newBookmarkIdPrefix)
54
+ ? findBookmarkGroupId(bookmarkGroups, id)
55
+ : currentBookmarkGroupId
56
+ let initialValues = copy(props.formData)
57
+ const defaultValues = {
58
+ port: 22,
59
+ authType: authTypeMap.password,
60
+ id: '',
61
+ term: props.store.config.terminalType,
62
+ encode: encodes[0],
63
+ envLang: defaultEnvLang,
64
+ enableSsh: true,
65
+ sshTunnels: [{}],
66
+ runScripts: [{}],
67
+ category: initBookmarkGroupId,
68
+ connectionHoppings: []
69
+ }
70
+ initialValues = defaultsDeep(initialValues, defaultValues)
71
+ function onChangeAuthType (e) {
72
+ setAuthType(e.target.value)
73
+ }
74
+ const tprops = {
75
+ ...props,
76
+ uis,
77
+ qms,
78
+ onChangeAuthType,
79
+ form,
80
+ authType,
81
+ renderCommon,
82
+ renderEnableSftp,
83
+ renderProxy,
84
+ renderX11,
85
+ renderAuth,
86
+ renderSshTunnel,
87
+ renderConnectionHopping
88
+ }
89
+ return (
90
+ <Form
91
+ form={form}
92
+ name='ssh-form'
93
+ onFinish={handleFinish}
94
+ initialValues={initialValues}
95
+ >
96
+ {renderTabs(tprops)}
97
+ {submitUi}
98
+ </Form>
99
+ )
100
+ }