keyboard-events.ts 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466
  1. /***
  2. * Author: Junyi Du <[email protected]>
  3. * References:
  4. * https://stackoverflow.com/questions/8892238/detect-keyboard-layout-with-javascript
  5. * ***/
  6. import { Page } from '@playwright/test'
  7. interface RecordedEvent {
  8. event_type: string;
  9. event: any; // KeyboardEvent is too heavy
  10. latency: number;
  11. }
  12. export let dispatch_kb_events = async function (page: Page, selector: string, keyboard_events: RecordedEvent[] ){
  13. for (let kbev of keyboard_events){
  14. let { event_type, event, latency } = kbev
  15. await page.waitForTimeout(latency)
  16. await page.dispatchEvent(selector, event_type, event)
  17. }
  18. }
  19. export let macos_pinyin_left_full_square_bracket: RecordedEvent[] = [
  20. {
  21. "event_type": "keydown",
  22. "event": {
  23. "key": "【",
  24. "code": "BracketLeft",
  25. "location": 0,
  26. "ctrlKey": false,
  27. "shiftKey": false,
  28. "altKey": false,
  29. "metaKey": false,
  30. "repeat": false,
  31. "isComposing": false
  32. },
  33. "latency": 0
  34. },
  35. {
  36. "event_type": "keypress",
  37. "event": {
  38. "key": "【",
  39. "code": "BracketLeft",
  40. "location": 0,
  41. "ctrlKey": false,
  42. "shiftKey": false,
  43. "altKey": false,
  44. "metaKey": false,
  45. "repeat": false,
  46. "isComposing": false
  47. },
  48. "latency": 1
  49. },
  50. {
  51. "event_type": "keyup",
  52. "event": {
  53. "key": "【",
  54. "code": "BracketLeft",
  55. "location": 0,
  56. "ctrlKey": false,
  57. "shiftKey": false,
  58. "altKey": false,
  59. "metaKey": false,
  60. "repeat": false,
  61. "isComposing": false
  62. },
  63. "latency": 17
  64. }
  65. ]
  66. export let win10_pinyin_left_full_square_bracket: RecordedEvent[] = [
  67. {
  68. "event_type": "keydown",
  69. "event": {
  70. "key": "Process",
  71. "code": "BracketLeft",
  72. "location": 0,
  73. "ctrlKey": false,
  74. "shiftKey": false,
  75. "altKey": false,
  76. "metaKey": false,
  77. "repeat": false,
  78. "isComposing": false
  79. },
  80. "latency": 0
  81. },
  82. {
  83. "event_type": "compositionstart",
  84. "event": {},
  85. "latency": 4
  86. },
  87. {
  88. "event_type": "compositionupdate",
  89. "event": {},
  90. "latency": 0
  91. },
  92. {
  93. "event_type": "compositionupdate",
  94. "event": {},
  95. "latency": 12
  96. },
  97. {
  98. "event_type": "compositionend",
  99. "event": {},
  100. "latency": 1
  101. },
  102. {
  103. "event_type": "keyup",
  104. "event": {
  105. "key": "Process",
  106. "code": "BracketLeft",
  107. "location": 0,
  108. "ctrlKey": false,
  109. "shiftKey": false,
  110. "altKey": false,
  111. "metaKey": false,
  112. "repeat": false,
  113. "isComposing": false
  114. },
  115. "latency": 61
  116. },
  117. {
  118. "event_type": "keyup",
  119. "event": {
  120. "key": "[",
  121. "code": "BracketLeft",
  122. "location": 0,
  123. "ctrlKey": false,
  124. "shiftKey": false,
  125. "altKey": false,
  126. "metaKey": false,
  127. "repeat": false,
  128. "isComposing": false
  129. },
  130. "latency": 1
  131. }
  132. ]
  133. export let win10_legacy_pinyin_left_full_square_bracket: RecordedEvent[] = [
  134. {
  135. "event_type": "keydown",
  136. "event": {
  137. "key": "Process",
  138. "code": "BracketLeft",
  139. "location": 0,
  140. "ctrlKey": false,
  141. "shiftKey": false,
  142. "altKey": false,
  143. "metaKey": false,
  144. "repeat": false,
  145. "isComposing": false
  146. },
  147. "latency": 0
  148. },
  149. {
  150. "event_type": "compositionstart",
  151. "event": {},
  152. "latency": 1
  153. },
  154. {
  155. "event_type": "compositionupdate",
  156. "event": {},
  157. "latency": 0
  158. },
  159. {
  160. "event_type": "compositionupdate",
  161. "event": {},
  162. "latency": 0
  163. },
  164. {
  165. "event_type": "compositionend",
  166. "event": {},
  167. "latency": 1
  168. },
  169. {
  170. "event_type": "keyup",
  171. "event": {
  172. "key": "Process",
  173. "code": "BracketLeft",
  174. "location": 0,
  175. "ctrlKey": false,
  176. "shiftKey": false,
  177. "altKey": false,
  178. "metaKey": false,
  179. "repeat": false,
  180. "isComposing": false
  181. },
  182. "latency": 93
  183. }
  184. ]
  185. export let macos_pinyin_selecting_candidate_double_left_square_bracket: RecordedEvent[] = [
  186. {
  187. "event_type": "keydown",
  188. "event": {
  189. "key": "b",
  190. "code": "KeyB",
  191. "location": 0,
  192. "ctrlKey": false,
  193. "shiftKey": false,
  194. "altKey": false,
  195. "metaKey": false,
  196. "repeat": false,
  197. "isComposing": false
  198. },
  199. "latency": 0
  200. },
  201. {
  202. "event_type": "compositionstart",
  203. "event": {},
  204. "latency": 1
  205. },
  206. {
  207. "event_type": "compositionupdate",
  208. "event": {},
  209. "latency": 0
  210. },
  211. {
  212. "event_type": "keyup",
  213. "event": {
  214. "key": "b",
  215. "code": "KeyB",
  216. "location": 0,
  217. "ctrlKey": false,
  218. "shiftKey": false,
  219. "altKey": false,
  220. "metaKey": false,
  221. "repeat": false,
  222. "isComposing": true
  223. },
  224. "latency": 48
  225. },
  226. {
  227. "event_type": "keydown",
  228. "event": {
  229. "key": "】",
  230. "code": "BracketRight",
  231. "location": 0,
  232. "ctrlKey": false,
  233. "shiftKey": false,
  234. "altKey": false,
  235. "metaKey": false,
  236. "repeat": false,
  237. "isComposing": true
  238. },
  239. "latency": 200
  240. },
  241. {
  242. "event_type": "keyup",
  243. "event": {
  244. "key": "】",
  245. "code": "BracketRight",
  246. "location": 0,
  247. "ctrlKey": false,
  248. "shiftKey": false,
  249. "altKey": false,
  250. "metaKey": false,
  251. "repeat": false,
  252. "isComposing": true
  253. },
  254. "latency": 59
  255. },
  256. {
  257. "event_type": "keydown",
  258. "event": {
  259. "key": "】",
  260. "code": "BracketRight",
  261. "location": 0,
  262. "ctrlKey": false,
  263. "shiftKey": false,
  264. "altKey": false,
  265. "metaKey": false,
  266. "repeat": false,
  267. "isComposing": true
  268. },
  269. "latency": 289
  270. },
  271. {
  272. "event_type": "keyup",
  273. "event": {
  274. "key": "】",
  275. "code": "BracketRight",
  276. "location": 0,
  277. "ctrlKey": false,
  278. "shiftKey": false,
  279. "altKey": false,
  280. "metaKey": false,
  281. "repeat": false,
  282. "isComposing": true
  283. },
  284. "latency": 73
  285. },
  286. {
  287. "event_type": "keydown",
  288. "event": {
  289. "key": "【",
  290. "code": "BracketLeft",
  291. "location": 0,
  292. "ctrlKey": false,
  293. "shiftKey": false,
  294. "altKey": false,
  295. "metaKey": false,
  296. "repeat": false,
  297. "isComposing": true
  298. },
  299. "latency": 443
  300. },
  301. {
  302. "event_type": "keyup",
  303. "event": {
  304. "key": "【",
  305. "code": "BracketLeft",
  306. "location": 0,
  307. "ctrlKey": false,
  308. "shiftKey": false,
  309. "altKey": false,
  310. "metaKey": false,
  311. "repeat": false,
  312. "isComposing": true
  313. },
  314. "latency": 79
  315. },
  316. {
  317. "event_type": "keydown",
  318. "event": {
  319. "key": "【",
  320. "code": "BracketLeft",
  321. "location": 0,
  322. "ctrlKey": false,
  323. "shiftKey": false,
  324. "altKey": false,
  325. "metaKey": false,
  326. "repeat": false,
  327. "isComposing": true
  328. },
  329. "latency": 155
  330. },
  331. {
  332. "event_type": "keyup",
  333. "event": {
  334. "key": "【",
  335. "code": "BracketLeft",
  336. "location": 0,
  337. "ctrlKey": false,
  338. "shiftKey": false,
  339. "altKey": false,
  340. "metaKey": false,
  341. "repeat": false,
  342. "isComposing": true
  343. },
  344. "latency": 44
  345. },
  346. {
  347. "event_type": "compositionend",
  348. "event": {},
  349. "latency": 200
  350. }
  351. ]
  352. export let win10_RIME_selecting_candidate_double_left_square_bracket: RecordedEvent[] = [
  353. {
  354. "event_type": "keydown",
  355. "event": {
  356. "key": "Process",
  357. "code": "BracketRight",
  358. "location": 0,
  359. "ctrlKey": false,
  360. "shiftKey": false,
  361. "altKey": false,
  362. "metaKey": false,
  363. "repeat": false,
  364. "isComposing": false
  365. },
  366. "latency": 0
  367. },
  368. {
  369. "event_type": "compositionstart",
  370. "event": {},
  371. "latency": 0
  372. },
  373. {
  374. "event_type": "compositionupdate",
  375. "event": {},
  376. "latency": 0
  377. },
  378. {
  379. "event_type": "keyup",
  380. "event": {
  381. "key": "Process",
  382. "code": "BracketRight",
  383. "location": 0,
  384. "ctrlKey": false,
  385. "shiftKey": false,
  386. "altKey": false,
  387. "metaKey": false,
  388. "repeat": false,
  389. "isComposing": true
  390. },
  391. "latency": 79
  392. },
  393. {
  394. "event_type": "keyup",
  395. "event": {
  396. "key": "]",
  397. "code": "BracketRight",
  398. "location": 0,
  399. "ctrlKey": false,
  400. "shiftKey": false,
  401. "altKey": false,
  402. "metaKey": false,
  403. "repeat": false,
  404. "isComposing": true
  405. },
  406. "latency": 3
  407. },
  408. {
  409. "event_type": "keydown",
  410. "event": {
  411. "key": "Process",
  412. "code": "BracketRight",
  413. "location": 0,
  414. "ctrlKey": false,
  415. "shiftKey": false,
  416. "altKey": false,
  417. "metaKey": false,
  418. "repeat": false,
  419. "isComposing": true
  420. },
  421. "latency": 200
  422. },
  423. {
  424. "event_type": "keyup",
  425. "event": {
  426. "key": "Process",
  427. "code": "BracketRight",
  428. "location": 0,
  429. "ctrlKey": false,
  430. "shiftKey": false,
  431. "altKey": false,
  432. "metaKey": false,
  433. "repeat": false,
  434. "isComposing": true
  435. },
  436. "latency": 96
  437. },
  438. {
  439. "event_type": "keyup",
  440. "event": {
  441. "key": "]",
  442. "code": "BracketRight",
  443. "location": 0,
  444. "ctrlKey": false,
  445. "shiftKey": false,
  446. "altKey": false,
  447. "metaKey": false,
  448. "repeat": false,
  449. "isComposing": true
  450. },
  451. "latency": 3
  452. },
  453. {
  454. "event_type": "compositionend",
  455. "event": {},
  456. "latency": 200
  457. }
  458. ]