nadesiko3 3.3.49 → 3.3.50

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 (342) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +143 -143
  3. package/batch/.DS_Store +0 -0
  4. package/batch/browsers.template.md +3 -3
  5. package/batch/build_browsers.nako3 +72 -72
  6. package/batch/build_command.nako3 +44 -44
  7. package/batch/build_nako_version.nako3 +42 -42
  8. package/batch/calc_hash.nako3 +29 -29
  9. package/batch/cmd_txt2json.nako3 +74 -74
  10. package/batch/command.txt +79 -0
  11. package/batch/command_nakopad.txt +69 -0
  12. package/batch/download-extlib.nako3 +43 -43
  13. package/batch/gen_command_nakopad.nako3 +57 -57
  14. package/batch/jsplugin2text.nako3 +285 -285
  15. package/batch/pickup_command.nako3 +110 -110
  16. package/batch/pickup_reserved_words.nako3 +11 -11
  17. package/batch/publish_version.nako3 +46 -46
  18. package/batch/show_agents.js +14 -14
  19. package/batch/turtle2js.nako3 +21 -21
  20. package/bin/cnako3 +10 -10
  21. package/core/LICENSE +21 -21
  22. package/core/README.md +66 -66
  23. package/core/batch/build_nako_version.nako3 +42 -42
  24. package/core/command/snako.mjs +105 -105
  25. package/core/command/snako.mts +116 -116
  26. package/core/index.mjs +21 -21
  27. package/core/package.json +47 -47
  28. package/core/sample/hello.nako3 +7 -7
  29. package/core/sample/hoge.mjs +4 -4
  30. package/core/sample/hoge.mts +6 -6
  31. package/core/src/nako3.mjs +864 -858
  32. package/core/src/nako3.mts +976 -967
  33. package/core/src/nako_colors.mjs +78 -78
  34. package/core/src/nako_colors.mts +86 -86
  35. package/core/src/nako_core_version.mjs +8 -8
  36. package/core/src/nako_core_version.mts +19 -19
  37. package/core/src/nako_csv.mjs +185 -185
  38. package/core/src/nako_csv.mts +188 -188
  39. package/core/src/nako_errors.mjs +173 -173
  40. package/core/src/nako_errors.mts +197 -197
  41. package/core/src/nako_from_dncl.mjs +255 -255
  42. package/core/src/nako_from_dncl.mts +250 -250
  43. package/core/src/nako_gen.mjs +1647 -1648
  44. package/core/src/nako_gen.mts +1718 -1719
  45. package/core/src/nako_gen_async.mjs +1659 -1659
  46. package/core/src/nako_gen_async.mts +1732 -1732
  47. package/core/src/nako_global.mjs +107 -107
  48. package/core/src/nako_global.mts +138 -138
  49. package/core/src/nako_indent.mjs +445 -445
  50. package/core/src/nako_indent.mts +492 -492
  51. package/core/src/nako_josi_list.mjs +38 -38
  52. package/core/src/nako_josi_list.mts +45 -45
  53. package/core/src/nako_lex_rules.mjs +253 -253
  54. package/core/src/nako_lex_rules.mts +260 -260
  55. package/core/src/nako_lexer.mjs +609 -609
  56. package/core/src/nako_lexer.mts +612 -612
  57. package/core/src/nako_logger.mjs +199 -199
  58. package/core/src/nako_logger.mts +232 -232
  59. package/core/src/nako_parser3.mjs +2439 -2439
  60. package/core/src/nako_parser3.mts +2195 -2195
  61. package/core/src/nako_parser_base.mjs +370 -370
  62. package/core/src/nako_parser_base.mts +370 -370
  63. package/core/src/nako_parser_const.mjs +37 -37
  64. package/core/src/nako_parser_const.mts +37 -37
  65. package/core/src/nako_prepare.mjs +304 -304
  66. package/core/src/nako_prepare.mts +315 -315
  67. package/core/src/nako_reserved_words.mjs +38 -38
  68. package/core/src/nako_reserved_words.mts +38 -38
  69. package/core/src/nako_source_mapping.mjs +207 -207
  70. package/core/src/nako_source_mapping.mts +262 -262
  71. package/core/src/nako_test.mjs +37 -37
  72. package/core/src/nako_types.mjs +25 -25
  73. package/core/src/nako_types.mts +151 -151
  74. package/core/src/plugin_csv.mjs +49 -49
  75. package/core/src/plugin_csv.mts +50 -50
  76. package/core/src/plugin_math.mjs +328 -328
  77. package/core/src/plugin_math.mts +326 -326
  78. package/core/src/plugin_promise.mjs +91 -91
  79. package/core/src/plugin_promise.mts +91 -91
  80. package/core/src/plugin_system.mjs +2832 -2832
  81. package/core/src/plugin_system.mts +2690 -2690
  82. package/core/src/plugin_test.mjs +34 -34
  83. package/core/src/plugin_test.mts +34 -34
  84. package/demo/.DS_Store +0 -0
  85. package/demo/ace_editor.html +89 -89
  86. package/demo/ace_editor_tabs.html +161 -161
  87. package/demo/basic.html +71 -71
  88. package/demo/browsers.html +10 -9
  89. package/demo/css/basic.css +3 -3
  90. package/demo/css/common.css +157 -157
  91. package/demo/css/editor.css +8 -8
  92. package/demo/css/flow.css +3 -3
  93. package/demo/css/index.css +3 -3
  94. package/demo/extlib/.DS_Store +0 -0
  95. package/demo/flow.html +98 -98
  96. package/demo/graph.html +53 -53
  97. package/demo/image/nakopad-icon256.png +0 -0
  98. package/demo/index.html +133 -133
  99. package/demo/js/common.js +17 -17
  100. package/demo/js/turtle3d_test.js +44 -44
  101. package/demo/js/turtle_test.js +45 -45
  102. package/demo/nako3/calc.nako3 +4 -4
  103. package/demo/runscript.html +47 -47
  104. package/demo/runscript2.html +33 -33
  105. package/demo/runscript3.html +35 -35
  106. package/demo/runscript4.html +33 -33
  107. package/demo/turtle.html +58 -58
  108. package/demo/turtle2.html +141 -141
  109. package/demo/turtle3.html +279 -279
  110. package/demo/turtle3d.html +58 -58
  111. package/demo/turtle3d2.html +107 -107
  112. package/demo/version.html +24 -24
  113. package/doc/SETUP.md +157 -157
  114. package/doc/about.md +17 -17
  115. package/doc/browsers.md +26 -26
  116. package/doc/docgen.md +21 -21
  117. package/doc/editor.md +44 -44
  118. package/doc/files.md +39 -39
  119. package/doc/plugins.md +234 -234
  120. package/doc/release.md +79 -79
  121. package/doc/textlint.md +43 -43
  122. package/doc/win32.md +57 -57
  123. package/package.json +195 -195
  124. package/release/_hash.txt +28 -28
  125. package/release/_script-tags.txt +14 -14
  126. package/release/command.json +1 -1
  127. package/release/command.json.js +1 -1
  128. package/release/command_cnako3.json +1 -1
  129. package/release/command_list.json +1 -1
  130. package/release/editor.js +1 -1
  131. package/release/nako_gen_async.js +1 -1
  132. package/release/nako_gen_async.js.LICENSE.txt +35 -0
  133. package/release/plugin_caniuse.js.LICENSE.txt +11 -0
  134. package/release/plugin_csv.js +1 -1
  135. package/release/plugin_csv.js.LICENSE.txt +15 -0
  136. package/release/plugin_datetime.js.LICENSE.txt +15 -0
  137. package/release/plugin_kansuji.js.LICENSE.txt +3 -0
  138. package/release/plugin_markup.js.LICENSE.txt +11 -0
  139. package/release/plugin_turtle.js.LICENSE.txt +15 -0
  140. package/release/plugin_webworker.js.LICENSE.txt +3 -0
  141. package/release/plugin_weykturtle3d.js.LICENSE.txt +3 -0
  142. package/release/stats.json +1 -1
  143. package/release/version.js +1 -1
  144. package/release/wnako3.js +1 -1
  145. package/release/wnako3webworker.js +1 -1
  146. package/release/wnako3webworker.js.LICENSE.txt +131 -0
  147. package/src/.DS_Store +0 -0
  148. package/src/browsers.txt +12 -11
  149. package/src/browsers_agents.json +2 -2
  150. package/src/browsers_agents.mjs +1 -1
  151. package/src/cnako3.mjs +17 -17
  152. package/src/cnako3.mts +18 -18
  153. package/src/cnako3mod.mjs +707 -707
  154. package/src/cnako3mod.mts +712 -712
  155. package/src/commander_ja.mjs +164 -164
  156. package/src/commander_ja.mts +161 -161
  157. package/src/enako3.mjs +68 -68
  158. package/src/era.mjs +22 -22
  159. package/src/image_turtle-elephant.mjs +2 -2
  160. package/src/image_turtle-panda.mjs +2 -2
  161. package/src/image_turtle64.mjs +2 -2
  162. package/src/index.mjs +9 -9
  163. package/src/index.mts +10 -10
  164. package/src/nako3editorfix.sfd +106 -106
  165. package/src/nako_version.mjs +8 -8
  166. package/src/nako_version.mts +2 -2
  167. package/src/plugin_browser.mjs +213 -213
  168. package/src/plugin_browser.mts +206 -206
  169. package/src/plugin_browser_ajax.mjs +399 -399
  170. package/src/plugin_browser_audio.mjs +109 -109
  171. package/src/plugin_browser_canvas.mjs +449 -449
  172. package/src/plugin_browser_chart.mjs +294 -294
  173. package/src/plugin_browser_color.mjs +49 -49
  174. package/src/plugin_browser_crypto.mjs +26 -26
  175. package/src/plugin_browser_dialog.mjs +53 -53
  176. package/src/plugin_browser_dom_basic.mjs +336 -336
  177. package/src/plugin_browser_dom_event.mjs +193 -193
  178. package/src/plugin_browser_dom_parts.mjs +396 -396
  179. package/src/plugin_browser_geolocation.mjs +51 -51
  180. package/src/plugin_browser_hotkey.mjs +25 -25
  181. package/src/plugin_browser_html.mjs +59 -59
  182. package/src/plugin_browser_in_worker.mjs +45 -45
  183. package/src/plugin_browser_location.mjs +21 -21
  184. package/src/plugin_browser_speech.mjs +111 -111
  185. package/src/plugin_browser_storage.mjs +121 -121
  186. package/src/plugin_browser_system.mjs +31 -31
  187. package/src/plugin_browser_websocket.mjs +73 -73
  188. package/src/plugin_caniuse.mjs +29 -29
  189. package/src/plugin_datetime.mjs +394 -394
  190. package/src/plugin_httpserver.mjs +277 -277
  191. package/src/plugin_httpserver.mts +286 -286
  192. package/src/plugin_kansuji.mjs +224 -224
  193. package/src/plugin_keigo.mjs +55 -55
  194. package/src/plugin_markup.mjs +32 -32
  195. package/src/plugin_node.mjs +1047 -1047
  196. package/src/plugin_node.mts +980 -980
  197. package/src/plugin_turtle.mjs +647 -647
  198. package/src/plugin_webworker.mjs +334 -334
  199. package/src/plugin_weykturtle3d.mjs +1214 -1214
  200. package/src/plugin_worker.mjs +95 -95
  201. package/src/repl.nako3 +63 -63
  202. package/src/wnako3.mjs +12 -12
  203. package/src/wnako3.mts +11 -11
  204. package/src/wnako3_editor.css +215 -215
  205. package/src/wnako3_editor.mjs +1542 -1542
  206. package/src/wnako3_editor.mts +1658 -1657
  207. package/src/wnako3mod.mjs +213 -213
  208. package/src/wnako3mod.mts +214 -214
  209. package/src/wnako3webworker.mjs +69 -69
  210. package/test/.DS_Store +0 -0
  211. package/test/ace_editor/karma.config.js +94 -94
  212. package/test/ace_editor/test/.babelrc.json +3 -3
  213. package/test/ace_editor/test/ace_editor_test.js +178 -178
  214. package/test/ace_editor/test/html/custom_context.html +139 -139
  215. package/test/async/async_basic_test.mjs +122 -122
  216. package/test/browser/.DS_Store +0 -0
  217. package/test/browser/karma.config.js +221 -221
  218. package/test/browser/test/.babelrc.json +3 -3
  219. package/test/browser/test/compare_util.js +50 -50
  220. package/test/browser/test/html/div_basic.html +2 -2
  221. package/test/browser/test/html/event_dom_form.html +4 -4
  222. package/test/browser/test/html/event_dom_scrolldiv.html +5 -5
  223. package/test/browser/test/import_plugin_checker.js +24 -24
  224. package/test/browser/test/plugin_browser_test.js +51 -51
  225. package/test/browser/test/plugin_browser_test_ajax.js +123 -123
  226. package/test/browser/test/plugin_browser_test_color.js +18 -18
  227. package/test/browser/test/plugin_browser_test_dialog.js +72 -72
  228. package/test/browser/test/plugin_browser_test_dom_event.js +598 -598
  229. package/test/browser/test/plugin_browser_test_dom_parts.js +125 -125
  230. package/test/browser/test/plugin_browser_test_system.js +9 -9
  231. package/test/browser/test/plugin_turtle_test.js +817 -817
  232. package/test/browser/test/plugin_webworker_test.js +86 -86
  233. package/test/browser/test/require_test.js +68 -68
  234. package/test/bundled/.DS_Store +0 -0
  235. package/test/bundled/karma.config.base.js +117 -117
  236. package/test/bundled/karma.config.js +86 -86
  237. package/test/bundled/test/.babelrc.json +3 -3
  238. package/test/bundled/test/bundled_test.js +69 -69
  239. package/test/bundled/test/html/custom_context.html +65 -65
  240. package/test/bundled/test/html/custom_debug.html +66 -66
  241. package/test/bundled/test4b.cmd +52 -52
  242. package/test/bundled/test_base/.DS_Store +0 -0
  243. package/test/bundled/test_base/.babelrc.json +3 -3
  244. package/test/bundled/test_base/_checktool_test.js +25 -25
  245. package/test/bundled/test_base/basic_ajax_test.js +56 -56
  246. package/test/bundled/test_base/basic_async_test.js +18 -18
  247. package/test/bundled/test_base/basic_test.js +153 -153
  248. package/test/bundled/test_base/calc_test.js +132 -132
  249. package/test/bundled/test_base/css/browsers_box.css +114 -114
  250. package/test/bundled/test_base/html/custom_context.html +69 -69
  251. package/test/bundled/test_base/html/custom_debug.html +71 -71
  252. package/test/bundled/test_base/js/browsers_box.js +72 -72
  253. package/test/bundled/test_base/plugin_csv_test.js +37 -37
  254. package/test/bundled/test_base/plugin_datetime_test.js +115 -115
  255. package/test/bundled/test_base/plugin_kansuji_test.js +49 -49
  256. package/test/bundled/test_base/plugin_system_test.js +410 -410
  257. package/test/bundled/test_base/plugin_webworker_test.js +53 -53
  258. package/test/bundled/test_base/test_utils.js +191 -191
  259. package/test/common/.DS_Store +0 -0
  260. package/test/common/plugin_browser_test.mjs +22 -22
  261. package/test/common/plugin_browser_ut_audio_test.mjs +108 -108
  262. package/test/common/plugin_browser_ut_color_test.mjs +21 -21
  263. package/test/common/plugin_browser_ut_dialog_test.mjs +100 -100
  264. package/test/common/plugin_browser_ut_html_test.mjs +13 -13
  265. package/test/common/plugin_browser_ut_system_test.mjs +10 -10
  266. package/test/common/plugin_markup_test.mjs +23 -23
  267. package/test/jsconfig.json +19 -19
  268. package/test/karma.config.js +91 -91
  269. package/test/node/.DS_Store +0 -0
  270. package/test/node/async_test.mjs +96 -96
  271. package/test/node/commander_ja_test.mjs +89 -89
  272. package/test/node/error_message_test.mjs +243 -243
  273. package/test/node/kai_test.nako3 +6 -6
  274. package/test/node/node_test.mjs +60 -60
  275. package/test/node/plugin_broken.js.txt +3 -3
  276. package/test/node/plugin_browser_ut_ajax_test.mjs.todo +357 -357
  277. package/test/node/plugin_browser_ut_location_test.mjs +42 -42
  278. package/test/node/plugin_markup_test.mjs +47 -47
  279. package/test/node/plugin_math_test.mjs +45 -45
  280. package/test/node/plugin_node_test.mjs +98 -98
  281. package/test/node/plugin_test.mjs +44 -44
  282. package/test/node/relative_import_test_1.nako3 +1 -1
  283. package/test/node/relative_import_test_2.nako3 +2 -2
  284. package/test/node/require_nako3_test.mjs +67 -67
  285. package/test/node/requiretest.nako3 +4 -4
  286. package/test/node/requiretest_indirect.nako3 +1 -1
  287. package/test/node/requiretest_name.nako3 +5 -5
  288. package/test/node/runtime_error.nako3 +2 -2
  289. package/test/node/scope1.nako3 +10 -10
  290. package/test/node/scope2.nako3 +12 -12
  291. package/test/node/side_effects_test.mjs +39 -39
  292. package/test/node/sjis.txt +5 -5
  293. package/test/node/syntax_error.nako3 +1 -1
  294. package/test/node/wnako3_editor_test.mjs +384 -384
  295. package/tools/.DS_Store +0 -0
  296. package/tools/README.md +12 -12
  297. package/tools/check_new_version.nako3 +25 -25
  298. package/tools/nako3edit/.DS_Store +0 -0
  299. package/tools/nako3edit/a.sqlite3 +0 -0
  300. package/tools/nako3edit/html/.DS_Store +0 -0
  301. package/tools/nako3edit/html/daisyui/LICENSE +22 -22
  302. package/tools/nako3edit/html/daisyui/version_2.14.1 +1 -1
  303. package/tools/nako3edit/html/edit.html +170 -170
  304. package/tools/nako3edit/html/edit_plugin.js +6 -6
  305. package/tools/nako3edit/html/files.html +125 -125
  306. package/tools/nako3edit/html/nako3edit.css +65 -65
  307. package/tools/nako3edit/index.mjs +248 -248
  308. package/tools/nako3server/index.html +10 -10
  309. package/tools/nako3server/index.mjs +116 -116
  310. package/tools/nako3server/index.nako3 +34 -34
  311. package/core/.editorconfig +0 -6
  312. package/core/.eslintrc.cjs +0 -33
  313. package/core/.github/dependabot.yml +0 -7
  314. package/core/.github/workflows/nodejs.yml +0 -37
  315. package/core/.github/workflows/super-linter.yml +0 -61
  316. package/core/.github/workflows/textlint.yml +0 -199
  317. package/core/index.mts +0 -21
  318. package/core/test/array_test.mjs +0 -34
  319. package/core/test/basic_test.mjs +0 -344
  320. package/core/test/calc_test.mjs +0 -140
  321. package/core/test/core_module_test.mjs +0 -23
  322. package/core/test/debug_test.mjs +0 -16
  323. package/core/test/dncl_test.mjs +0 -94
  324. package/core/test/error_message_test.mjs +0 -210
  325. package/core/test/error_test.mjs +0 -16
  326. package/core/test/flow_test.mjs +0 -373
  327. package/core/test/func_call.mjs +0 -160
  328. package/core/test/func_test.mjs +0 -149
  329. package/core/test/indent_test.mjs +0 -364
  330. package/core/test/lex_test.mjs +0 -168
  331. package/core/test/literal_test.mjs +0 -73
  332. package/core/test/nako_lexer_test.mjs +0 -35
  333. package/core/test/nako_logger_test.mjs +0 -76
  334. package/core/test/nako_logger_test.mts +0 -78
  335. package/core/test/plugin_csv_test.mjs +0 -38
  336. package/core/test/plugin_promise_test.mjs +0 -18
  337. package/core/test/plugin_system_test.mjs +0 -630
  338. package/core/test/prepare_test.mjs +0 -96
  339. package/core/test/re_test.mjs +0 -22
  340. package/core/test/side_effects_test.mjs +0 -92
  341. package/core/test/variable_scope_test.mjs +0 -149
  342. package/core/tsconfig.json +0 -101
@@ -1,598 +1,598 @@
1
- /* global __html__ */
2
- import { CompareUtil, waitTimer, assert } from './compare_util'
3
-
4
- const htmlPath = 'test/html/'
5
-
6
- export default (nako) => {
7
- const cu = new CompareUtil(nako)
8
-
9
- describe('DOMイベント', () => {
10
- describe('汎用命令', () => {
11
- const createMouseEvent = (type, t) => {
12
- const box = t.target.getBoundingClientRect()
13
- const x = 30
14
- const y = 10
15
- if (MouseEvent && MouseEvent.length > 0) {
16
- return new MouseEvent(type, {
17
- view: window,
18
- bubbles: true,
19
- cancelable: true,
20
- button: t.btn || 0,
21
- buttons: t.btns || 1,
22
- clientX: box.left + x,
23
- clientY: box.top + y,
24
- screenX: window.screenLeft + box.left + x,
25
- screenY: window.screenTop + box.top + y,
26
- pageX: window.scrollX + box.left + x,
27
- pageY: window.scrollY + box.top + y
28
- })
29
- } else {
30
- const evt = new UIEvent(type, {
31
- view: window,
32
- bubbles: true,
33
- cancelable: true
34
- })
35
- evt.button = t.btn || 0,
36
- evt.buttons = t.btns || 1,
37
- evt.clientX = box.left + x,
38
- evt.clientY = box.top + y,
39
- evt.screenX = window.screenLeft + box.left + x,
40
- evt.screenY = window.screenTop + box.top + y,
41
- evt.pageX = window.scrollX + box.left + x,
42
- evt.pageY = window.scrollY + box.top + y
43
- return evt
44
- }
45
- }
46
-
47
- const check_event_set = (selectmethod) => {
48
- document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
49
-
50
- const code = `
51
- 要素は${selectmethod}
52
- 要素の「onclick」に「ボタンクリック」をDOMイベント設定する。
53
- ●ボタンクリックとは
54
- 「C:設定」を報告する。
55
- ここまで。
56
- `
57
- const cr = window.cr
58
- cr.reset()
59
- nako.run(code)
60
-
61
- const e = document.getElementById('button')
62
- if (e) {
63
- const evt = createMouseEvent('click', { target: e })
64
- e.dispatchEvent(evt)
65
- }
66
-
67
- assert.ok(cr.isCalled, 'イベント呼び出し')
68
- assert.strictEqual(cr.getMessageAsJson(), '["C:設定"]')
69
- }
70
-
71
- const check_event_fire = (selectmethod) => {
72
- document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
73
-
74
- const code = `
75
- 要素は${selectmethod}
76
- 要素の「click」がDOMイベント発火した時には、
77
- 「C:設定」を報告する。
78
- ここまで。
79
- `
80
- const cr = window.cr
81
- cr.reset()
82
- nako.run(code)
83
-
84
- const e = document.getElementById('button')
85
- if (e) {
86
- const evt = createMouseEvent('click', { target: e })
87
- e.dispatchEvent(evt)
88
- }
89
-
90
- assert.ok(cr.isCalled, 'イベント呼び出し')
91
- assert.strictEqual(cr.getMessageAsJson(), '["C:設定"]')
92
- }
93
-
94
- const check_event_add = (selectmethod) => {
95
- document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
96
-
97
- const code = `
98
- 要素は${selectmethod}
99
- 要素の「click」に「ボタンクリック」をDOMイベント追加する。
100
- ●ボタンクリックとは
101
- 「C:追加」を報告する。
102
- ここまで。
103
- `
104
- const cr = window.cr
105
- cr.reset()
106
- nako.run(code)
107
-
108
- const e = document.getElementById('button')
109
- if (e) {
110
- const evt = createMouseEvent('click', { target: e })
111
- e.dispatchEvent(evt)
112
- }
113
-
114
- assert.ok(cr.isCalled, 'イベント呼び出し')
115
- assert.strictEqual(cr.getMessageAsJson(), '["C:追加"]')
116
- }
117
-
118
- const check_event_remove = (selectmethod) => {
119
- document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
120
-
121
- const code = `
122
- 要素は${selectmethod}
123
- 要素の「click」に「ボタンクリック」をDOMイベント追加する。
124
- 要素の「click」から「ボタンクリック」をDOMイベント削除する。
125
- ●ボタンクリックとは
126
- 「C:追加」を報告する。
127
- ここまで。
128
- `
129
- const cr = window.cr
130
- cr.reset()
131
- nako.run(code)
132
-
133
- const e = document.getElementById('button')
134
- if (e) {
135
- const evt = createMouseEvent('click', { target: e })
136
- e.dispatchEvent(evt)
137
- } else {
138
- assert.fail('要素が見つからないためイベント発火に失敗しました。')
139
- }
140
-
141
- assert.ok(!cr.isCalled, 'イベント呼び出し')
142
- assert.strictEqual(cr.getMessageAsJson(), '[]')
143
- }
144
-
145
- it('イベント設定', () => {
146
- check_event_set('「#button」')
147
- })
148
- it('イベント設定 - dom', () => {
149
- check_event_set('「button」をDOM要素ID取得')
150
- })
151
-
152
- it('イベント発火した時', () => {
153
- check_event_fire('「#button」')
154
- })
155
- it('イベント発火した時 - dom', () => {
156
- check_event_fire('「button」をDOM要素ID取得')
157
- })
158
-
159
- it('イベント追加', () => {
160
- check_event_add('「#button」')
161
- })
162
- it('イベント追加 - dom', () => {
163
- check_event_add('「button」をDOM要素ID取得')
164
- })
165
-
166
- it('イベント削除', () => {
167
- check_event_remove('「#button」')
168
- })
169
- it('イベント削除 - dom', () => {
170
- check_event_remove('「button」をDOM要素ID取得')
171
- })
172
- })
173
-
174
- describe('読み込み時', () => {
175
- const check_img_load = async (selectmethod) => {
176
- document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
177
-
178
- const code = `
179
- IMGは「img」のDOM要素作成
180
- IMG["id"]は「img」
181
- 親は「form」をDOM要素ID取得
182
- 親にIMGをDOM子要素追加
183
- 要素は${selectmethod}
184
- 要素を読み込んだ時には、
185
- 「L:{IMG["naturalWidth"]},{IMG["naturalHeight"]}」を報告する。
186
- ここまで。
187
- IMG["src"]は「/turtle.png」
188
- `
189
- const cr = window.cr
190
- cr.reset()
191
- nako.run(code)
192
-
193
- await waitTimer(1.0)
194
-
195
- assert.ok(cr.isCalled, 'イベント呼び出し')
196
- assert.strictEqual(cr.getMessageAsJson(), '["L:64,64"]')
197
- }
198
-
199
- it('読み込み時', async () => {
200
- await check_img_load('「#img」')
201
- })
202
- it('読み込み時 - dom', async () => {
203
- await check_img_load('「img」をDOM要素ID取得')
204
- })
205
- it('読み込み時 - image', async () => {
206
- const code = `
207
- 要素は「new Image()」をJS実行
208
- 要素を読み込んだ時には、
209
- 「I:{要素["naturalWidth"]},{要素["naturalHeight"]}」を報告する。
210
- ここまで。
211
- 要素["src"]は「/turtle.png」
212
- `
213
- const cr = window.cr
214
- cr.reset()
215
- nako.run(code)
216
-
217
- await waitTimer(1.0)
218
-
219
- assert.ok(cr.isCalled, 'イベント呼び出し')
220
- assert.strictEqual(cr.getMessageAsJson(), '["I:64,64"]')
221
- })
222
- })
223
-
224
- describe('フォーム', () => {
225
- const createSubmitEvent = (t) => {
226
- if (SubmitEvent && SubmitEvent.length > 0) {
227
- return new SubmitEvent('submit', {
228
- bubbles: true,
229
- cancelable: true,
230
- submitter: t.submitter
231
- })
232
- } else {
233
- const evt = new Event('submit', {
234
- bubbles: true,
235
- cancelable: true
236
- })
237
- evt.submitter = t.submitter
238
- return evt
239
- }
240
- }
241
-
242
- const check_form_submit = (selectmethod) => {
243
- document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
244
-
245
- const code = `
246
- 要素は${selectmethod}
247
- 要素をフォーム送信した時には、
248
- WINDOW["event"]をDOMイベント処理停止する。
249
- 「SUBMITED」を報告する。
250
- ここまで。
251
- `
252
- const cr = window.cr
253
- cr.reset()
254
- nako.run(code)
255
-
256
- const e = document.getElementById('form')
257
- if (e) {
258
- e.addEventListener('submit', (event) => {
259
- event.preventDefault()
260
- })
261
-
262
- const btn = document.getElementById('submit')
263
- let evt = createSubmitEvent({ submitter: btn })
264
- e.dispatchEvent(evt)
265
- }
266
-
267
- assert.ok(cr.isCalled, 'イベント呼び出し')
268
- assert.strictEqual(cr.getMessageAsJson(), '["SUBMITED"]')
269
- }
270
-
271
- it('フォーム送信', () => {
272
- check_form_submit('「#form」')
273
- })
274
-
275
- it('フォーム送信 - dom', () => {
276
- check_form_submit('「form」をDOM要素ID取得')
277
- })
278
- })
279
-
280
- describe('キーボード', () => {
281
- const createKeyboardEvent = (type, t) => {
282
- const box = t.target.getBoundingClientRect()
283
- const { x, y } = t
284
- if (KeyboardEvent && KeyboardEvent.length > 0) {
285
- return new KeyboardEvent(type, {
286
- view: window,
287
- bubbles: true,
288
- cancelable: true,
289
- key: t.key || 0,
290
- code: t.code || 0
291
- })
292
- } else {
293
- const evt = new UIEvent(type, {
294
- view: window,
295
- bubbles: true,
296
- cancelable: true
297
- })
298
- evt.key = t.key || '',
299
- evt.code = t.code || ''
300
- return evt
301
- }
302
- }
303
-
304
- const check_event_key = (selectmethod) => {
305
- document.body.innerHTML = __html__[htmlPath+'event_dom_scrolldiv.html']
306
- window.scrollX = 50
307
- window.scrollY = 50
308
-
309
- const code = `
310
- 要素は${selectmethod}
311
- 要素をキー押した時には、
312
- 「D:{押キー}」を報告する。
313
- ここまで。
314
- 要素をキー離した時には、
315
- 「U:{押キー}」を報告する。
316
- ここまで。
317
- 要素をキータイピングした時には、
318
- 「P:{押キー}」を報告する。
319
- ここまで。
320
- `
321
- const cr = window.cr
322
- cr.reset()
323
- nako.run(code)
324
-
325
- const e = document.getElementById('tgt')
326
- if (e) {
327
- const targetOffsets = [
328
- { target: e, key: 'A', code: 'D' },
329
- { target: e, key: 'C', code: 'E' },
330
- { target: e, key: 'Q', code: 'W' }
331
- ]
332
-
333
- let evt = createKeyboardEvent('keydown', targetOffsets[0])
334
- e.dispatchEvent(evt)
335
-
336
- evt = createKeyboardEvent('keyup', targetOffsets[1])
337
- e.dispatchEvent(evt)
338
-
339
- evt = createKeyboardEvent('keypress', targetOffsets[2])
340
- e.dispatchEvent(evt)
341
- }
342
-
343
- assert.ok(cr.isCalled, 'イベント呼び出し')
344
- assert.strictEqual(cr.getMessageAsJson(), '["D:A","U:C","P:Q"]')
345
- }
346
-
347
- it('キーボード押・話・押下', () => {
348
- check_event_key('「#tgt」')
349
- })
350
- it('キーボード押・話・押下 - dom', () => {
351
- check_event_key('「tgt」をDOM要素ID取得')
352
- })
353
- })
354
-
355
- describe('マウス', () => {
356
- const createMouseEvent = (type, t) => {
357
- const box = t.target.getBoundingClientRect()
358
- const { x, y } = t
359
- if (MouseEvent && MouseEvent.length > 0) {
360
- return new MouseEvent(type, {
361
- view: window,
362
- bubbles: true,
363
- cancelable: true,
364
- button: t.btn || 0,
365
- buttons: t.btns || 0,
366
- clientX: box.left + x,
367
- clientY: box.top + y,
368
- screenX: window.screenLeft + box.left + x,
369
- screenY: window.screenTop + box.top + y,
370
- pageX: window.scrollX + box.left + x,
371
- pageY: window.scrollY + box.top + y
372
- })
373
- } else {
374
- const evt = new UIEvent(type, {
375
- view: window,
376
- bubbles: true,
377
- cancelable: true
378
- })
379
- evt.button = t.btn || 0,
380
- evt.buttons = t.btns || 0,
381
- evt.clientX = box.left + x,
382
- evt.clientY = box.top + y,
383
- evt.screenX = window.screenLeft + box.left + x,
384
- evt.screenY = window.screenTop + box.top + y,
385
- evt.pageX = window.scrollX + box.left + x,
386
- evt.pageY = window.scrollY + box.top + y
387
- return evt
388
- }
389
- }
390
-
391
- const check_event_mouse = (selectmethod) => {
392
- document.body.innerHTML = __html__[htmlPath+'event_dom_scrolldiv.html']
393
- window.scrollX = 50
394
- window.scrollY = 50
395
-
396
- const code = `
397
- 要素は${selectmethod}
398
- 要素をクリックした時には、
399
- 「C:」を報告する。
400
- ここまで。
401
- 要素をマウス押した時には、
402
- 「D:{マウスX},{マウスY}」を報告する。
403
- ここまで。
404
- 要素をマウス移動した時には、
405
- 「M:{マウスX},{マウスY}」を報告する。
406
- ここまで。
407
- 要素をマウス離した時には、
408
- 「U:{マウスX},{マウスY}」を報告する。
409
- ここまで。
410
- `
411
- const cr = window.cr
412
- cr.reset()
413
- nako.run(code)
414
-
415
- const e = document.getElementById('tgt')
416
- if (e) {
417
- const targetOffsets = [
418
- { target: e, x: 0, y: 0, btn: 0, btns: 1 },
419
- { target: e, x: 30, y: 35, btn: 1, btns: 3 },
420
- { target: e, x: 30, y: 40, btn: 0, btns: 3 },
421
- { target: e, x: 20, y: 35, btn: 1, btns: 2 }
422
- ]
423
-
424
- let evt = createMouseEvent('click', targetOffsets[0])
425
- e.dispatchEvent(evt)
426
-
427
- evt = createMouseEvent('mousedown', targetOffsets[1])
428
- e.dispatchEvent(evt)
429
-
430
- evt = createMouseEvent('mousemove', targetOffsets[2])
431
- e.dispatchEvent(evt)
432
-
433
- evt = createMouseEvent('mouseup', targetOffsets[3])
434
- e.dispatchEvent(evt)
435
- }
436
-
437
- assert.ok(cr.isCalled, 'イベント呼び出し')
438
- assert.strictEqual(cr.getMessageAsJson(), '["C:","D:30,35","M:30,40","U:20,35"]')
439
- }
440
-
441
- it('マウス押・離・クリック', () => {
442
- check_event_mouse('「#tgt」')
443
- })
444
- it('マウス押・離・クリック - dom', () => {
445
- check_event_mouse('「tgt」をDOM要素ID取得')
446
- })
447
- })
448
-
449
- describe('タッチ', () => {
450
- const createTouches = (infos) => {
451
- const touches = []
452
- const createTouchFactory = () => {
453
- if (Touch && TouchEvent && Touch.length > 0 && TouchEvent.length > 0) {
454
- return (params) => {
455
- return new Touch(params)
456
- }
457
- } else {
458
- return (params) => {
459
- return params
460
- }
461
- }
462
- }
463
- const createTouch = createTouchFactory()
464
-
465
- infos.forEach(t => {
466
- const box = t.target.getBoundingClientRect()
467
- const { x, y } = t
468
- const params = {
469
- identifier: t.id,
470
- target: t.target,
471
- clientX: box.left + x,
472
- clientY: box.top + y,
473
- screenX: window.screenLeft + box.left + x,
474
- screenY: window.screenTop + box.top + y,
475
- pageX: window.scrollX + box.left + x,
476
- pageY: window.scrollY + box.top + y,
477
- radiusX: t.r || 1.0,
478
- radiusY: t.r || 1.0
479
- }
480
- touches.push(createTouch(params))
481
- })
482
- return touches
483
- }
484
- const createTouchEvent = (type, touches) => {
485
- if (Touch && TouchEvent && Touch.length > 0 && TouchEvent.length > 0) {
486
- return new TouchEvent(type, {
487
- view: window,
488
- bubbles: true,
489
- cancelable: true,
490
- changedTouches: touches.changed,
491
- targetTouches: touches.target,
492
- touches: touches.all
493
- })
494
- } else {
495
- const evt = new UIEvent(type, {
496
- view: window,
497
- bubbles: true,
498
- cancelable: true
499
- })
500
- evt.changedTouches = touches.changed
501
- evt.targetTouches = touches.target
502
- evt.touches = touches.all
503
- return evt
504
- }
505
- }
506
- const check_event_touch = (selectmethod) => {
507
- document.body.innerHTML = __html__[htmlPath+'event_dom_scrolldiv.html']
508
- window.scrollX = 50
509
- window.scrollY = 50
510
-
511
- const code = `
512
- 要素は${selectmethod}
513
- 要素をタッチ開始した時には、
514
- 「S:{タッチX},{タッチY}」を報告する。
515
- タッチ配列を反復する。
516
- これはそれ
517
- 「{これ[0]},{これ[1]}」を報告する。
518
- ここまで。
519
- ここまで。
520
- 要素をタッチ終了した時には、
521
- 「E:{タッチX},{タッチY}」を報告する。
522
- タッチ配列を反復する。
523
- これはそれ
524
- 「{これ[0]},{これ[1]}」を報告する。
525
- ここまで。
526
- ここまで。
527
- 要素をタッチした時には、
528
- 「M:{タッチX},{タッチY}」を報告する。
529
- タッチ配列を反復する。
530
- これはそれ
531
- 「{これ[0]},{これ[1]}」を報告する。
532
- ここまで。
533
- ここまで。
534
- 要素をタッチキャンセルした時には、
535
- 「C:{タッチX},{タッチY}」を報告する。
536
- タッチ配列を反復する。
537
- これはそれ
538
- 「{これ[0]},{これ[1]}」を報告する。
539
- ここまで。
540
- ここまで。
541
- `
542
- const cr = window.cr
543
- cr.reset()
544
- nako.run(code)
545
-
546
- const e = document.getElementById('tgt')
547
- if (e) {
548
- const targetOffsets = [
549
- { target: e, id: 42, x: 20, y: 30, r: 5 },
550
- { target: e, id: 43, x: 30, y: 35, r: 2 },
551
- { target: e, id: 42, x: 25, y: 35, r: 3 },
552
- { target: e, id: 42, x: 20, y: 35, r: 1 },
553
- { target: e, id: 43, x: 30, y: 35, r: 5 }
554
- ]
555
- const touchesList = createTouches(targetOffsets)
556
-
557
- let evt = createTouchEvent('touchstart', {
558
- changed: [ touchesList[0], touchesList[1] ],
559
- target: [ touchesList[0], touchesList[1] ],
560
- all: [ touchesList[0], touchesList[1] ]
561
- })
562
- e.dispatchEvent(evt)
563
-
564
- evt = createTouchEvent('touchmove', {
565
- changed: [ touchesList[2] ],
566
- target: [ touchesList[2], touchesList[1] ],
567
- all: [ touchesList[2], touchesList[1] ]
568
- })
569
- e.dispatchEvent(evt)
570
-
571
- evt = createTouchEvent('touchcancel', {
572
- changed: [ touchesList[3] ],
573
- target: [ touchesList[1] ],
574
- all: [ touchesList[1] ]
575
- })
576
- e.dispatchEvent(evt)
577
-
578
- evt = createTouchEvent('touchend', {
579
- changed: [ touchesList[4] ],
580
- target: [],
581
- all: []
582
- })
583
- e.dispatchEvent(evt)
584
- }
585
-
586
- assert.ok(cr.isCalled, 'イベント呼び出し')
587
- assert.strictEqual(cr.getMessageAsJson(), '["S:20,30","20,30","30,35","M:25,35","25,35","C:20,35","20,35","E:30,35","30,35"]')
588
- }
589
-
590
- it('タッチ開始・終了・移動・キャンセル', () => {
591
- check_event_touch('「#tgt」')
592
- })
593
- it('タッチ開始・終了・移動・キャンセル - dom', () => {
594
- check_event_touch('「tgt」をDOM要素ID取得')
595
- })
596
- })
597
- })
598
- }
1
+ /* global __html__ */
2
+ import { CompareUtil, waitTimer, assert } from './compare_util'
3
+
4
+ const htmlPath = 'test/html/'
5
+
6
+ export default (nako) => {
7
+ const cu = new CompareUtil(nako)
8
+
9
+ describe('DOMイベント', () => {
10
+ describe('汎用命令', () => {
11
+ const createMouseEvent = (type, t) => {
12
+ const box = t.target.getBoundingClientRect()
13
+ const x = 30
14
+ const y = 10
15
+ if (MouseEvent && MouseEvent.length > 0) {
16
+ return new MouseEvent(type, {
17
+ view: window,
18
+ bubbles: true,
19
+ cancelable: true,
20
+ button: t.btn || 0,
21
+ buttons: t.btns || 1,
22
+ clientX: box.left + x,
23
+ clientY: box.top + y,
24
+ screenX: window.screenLeft + box.left + x,
25
+ screenY: window.screenTop + box.top + y,
26
+ pageX: window.scrollX + box.left + x,
27
+ pageY: window.scrollY + box.top + y
28
+ })
29
+ } else {
30
+ const evt = new UIEvent(type, {
31
+ view: window,
32
+ bubbles: true,
33
+ cancelable: true
34
+ })
35
+ evt.button = t.btn || 0,
36
+ evt.buttons = t.btns || 1,
37
+ evt.clientX = box.left + x,
38
+ evt.clientY = box.top + y,
39
+ evt.screenX = window.screenLeft + box.left + x,
40
+ evt.screenY = window.screenTop + box.top + y,
41
+ evt.pageX = window.scrollX + box.left + x,
42
+ evt.pageY = window.scrollY + box.top + y
43
+ return evt
44
+ }
45
+ }
46
+
47
+ const check_event_set = (selectmethod) => {
48
+ document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
49
+
50
+ const code = `
51
+ 要素は${selectmethod}
52
+ 要素の「onclick」に「ボタンクリック」をDOMイベント設定する。
53
+ ●ボタンクリックとは
54
+ 「C:設定」を報告する。
55
+ ここまで。
56
+ `
57
+ const cr = window.cr
58
+ cr.reset()
59
+ nako.run(code)
60
+
61
+ const e = document.getElementById('button')
62
+ if (e) {
63
+ const evt = createMouseEvent('click', { target: e })
64
+ e.dispatchEvent(evt)
65
+ }
66
+
67
+ assert.ok(cr.isCalled, 'イベント呼び出し')
68
+ assert.strictEqual(cr.getMessageAsJson(), '["C:設定"]')
69
+ }
70
+
71
+ const check_event_fire = (selectmethod) => {
72
+ document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
73
+
74
+ const code = `
75
+ 要素は${selectmethod}
76
+ 要素の「click」がDOMイベント発火した時には、
77
+ 「C:設定」を報告する。
78
+ ここまで。
79
+ `
80
+ const cr = window.cr
81
+ cr.reset()
82
+ nako.run(code)
83
+
84
+ const e = document.getElementById('button')
85
+ if (e) {
86
+ const evt = createMouseEvent('click', { target: e })
87
+ e.dispatchEvent(evt)
88
+ }
89
+
90
+ assert.ok(cr.isCalled, 'イベント呼び出し')
91
+ assert.strictEqual(cr.getMessageAsJson(), '["C:設定"]')
92
+ }
93
+
94
+ const check_event_add = (selectmethod) => {
95
+ document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
96
+
97
+ const code = `
98
+ 要素は${selectmethod}
99
+ 要素の「click」に「ボタンクリック」をDOMイベント追加する。
100
+ ●ボタンクリックとは
101
+ 「C:追加」を報告する。
102
+ ここまで。
103
+ `
104
+ const cr = window.cr
105
+ cr.reset()
106
+ nako.run(code)
107
+
108
+ const e = document.getElementById('button')
109
+ if (e) {
110
+ const evt = createMouseEvent('click', { target: e })
111
+ e.dispatchEvent(evt)
112
+ }
113
+
114
+ assert.ok(cr.isCalled, 'イベント呼び出し')
115
+ assert.strictEqual(cr.getMessageAsJson(), '["C:追加"]')
116
+ }
117
+
118
+ const check_event_remove = (selectmethod) => {
119
+ document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
120
+
121
+ const code = `
122
+ 要素は${selectmethod}
123
+ 要素の「click」に「ボタンクリック」をDOMイベント追加する。
124
+ 要素の「click」から「ボタンクリック」をDOMイベント削除する。
125
+ ●ボタンクリックとは
126
+ 「C:追加」を報告する。
127
+ ここまで。
128
+ `
129
+ const cr = window.cr
130
+ cr.reset()
131
+ nako.run(code)
132
+
133
+ const e = document.getElementById('button')
134
+ if (e) {
135
+ const evt = createMouseEvent('click', { target: e })
136
+ e.dispatchEvent(evt)
137
+ } else {
138
+ assert.fail('要素が見つからないためイベント発火に失敗しました。')
139
+ }
140
+
141
+ assert.ok(!cr.isCalled, 'イベント呼び出し')
142
+ assert.strictEqual(cr.getMessageAsJson(), '[]')
143
+ }
144
+
145
+ it('イベント設定', () => {
146
+ check_event_set('「#button」')
147
+ })
148
+ it('イベント設定 - dom', () => {
149
+ check_event_set('「button」をDOM要素ID取得')
150
+ })
151
+
152
+ it('イベント発火した時', () => {
153
+ check_event_fire('「#button」')
154
+ })
155
+ it('イベント発火した時 - dom', () => {
156
+ check_event_fire('「button」をDOM要素ID取得')
157
+ })
158
+
159
+ it('イベント追加', () => {
160
+ check_event_add('「#button」')
161
+ })
162
+ it('イベント追加 - dom', () => {
163
+ check_event_add('「button」をDOM要素ID取得')
164
+ })
165
+
166
+ it('イベント削除', () => {
167
+ check_event_remove('「#button」')
168
+ })
169
+ it('イベント削除 - dom', () => {
170
+ check_event_remove('「button」をDOM要素ID取得')
171
+ })
172
+ })
173
+
174
+ describe('読み込み時', () => {
175
+ const check_img_load = async (selectmethod) => {
176
+ document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
177
+
178
+ const code = `
179
+ IMGは「img」のDOM要素作成
180
+ IMG["id"]は「img」
181
+ 親は「form」をDOM要素ID取得
182
+ 親にIMGをDOM子要素追加
183
+ 要素は${selectmethod}
184
+ 要素を読み込んだ時には、
185
+ 「L:{IMG["naturalWidth"]},{IMG["naturalHeight"]}」を報告する。
186
+ ここまで。
187
+ IMG["src"]は「/turtle.png」
188
+ `
189
+ const cr = window.cr
190
+ cr.reset()
191
+ nako.run(code)
192
+
193
+ await waitTimer(1.0)
194
+
195
+ assert.ok(cr.isCalled, 'イベント呼び出し')
196
+ assert.strictEqual(cr.getMessageAsJson(), '["L:64,64"]')
197
+ }
198
+
199
+ it('読み込み時', async () => {
200
+ await check_img_load('「#img」')
201
+ })
202
+ it('読み込み時 - dom', async () => {
203
+ await check_img_load('「img」をDOM要素ID取得')
204
+ })
205
+ it('読み込み時 - image', async () => {
206
+ const code = `
207
+ 要素は「new Image()」をJS実行
208
+ 要素を読み込んだ時には、
209
+ 「I:{要素["naturalWidth"]},{要素["naturalHeight"]}」を報告する。
210
+ ここまで。
211
+ 要素["src"]は「/turtle.png」
212
+ `
213
+ const cr = window.cr
214
+ cr.reset()
215
+ nako.run(code)
216
+
217
+ await waitTimer(1.0)
218
+
219
+ assert.ok(cr.isCalled, 'イベント呼び出し')
220
+ assert.strictEqual(cr.getMessageAsJson(), '["I:64,64"]')
221
+ })
222
+ })
223
+
224
+ describe('フォーム', () => {
225
+ const createSubmitEvent = (t) => {
226
+ if (SubmitEvent && SubmitEvent.length > 0) {
227
+ return new SubmitEvent('submit', {
228
+ bubbles: true,
229
+ cancelable: true,
230
+ submitter: t.submitter
231
+ })
232
+ } else {
233
+ const evt = new Event('submit', {
234
+ bubbles: true,
235
+ cancelable: true
236
+ })
237
+ evt.submitter = t.submitter
238
+ return evt
239
+ }
240
+ }
241
+
242
+ const check_form_submit = (selectmethod) => {
243
+ document.body.innerHTML = __html__[htmlPath+'event_dom_form.html']
244
+
245
+ const code = `
246
+ 要素は${selectmethod}
247
+ 要素をフォーム送信した時には、
248
+ WINDOW["event"]をDOMイベント処理停止する。
249
+ 「SUBMITED」を報告する。
250
+ ここまで。
251
+ `
252
+ const cr = window.cr
253
+ cr.reset()
254
+ nako.run(code)
255
+
256
+ const e = document.getElementById('form')
257
+ if (e) {
258
+ e.addEventListener('submit', (event) => {
259
+ event.preventDefault()
260
+ })
261
+
262
+ const btn = document.getElementById('submit')
263
+ let evt = createSubmitEvent({ submitter: btn })
264
+ e.dispatchEvent(evt)
265
+ }
266
+
267
+ assert.ok(cr.isCalled, 'イベント呼び出し')
268
+ assert.strictEqual(cr.getMessageAsJson(), '["SUBMITED"]')
269
+ }
270
+
271
+ it('フォーム送信', () => {
272
+ check_form_submit('「#form」')
273
+ })
274
+
275
+ it('フォーム送信 - dom', () => {
276
+ check_form_submit('「form」をDOM要素ID取得')
277
+ })
278
+ })
279
+
280
+ describe('キーボード', () => {
281
+ const createKeyboardEvent = (type, t) => {
282
+ const box = t.target.getBoundingClientRect()
283
+ const { x, y } = t
284
+ if (KeyboardEvent && KeyboardEvent.length > 0) {
285
+ return new KeyboardEvent(type, {
286
+ view: window,
287
+ bubbles: true,
288
+ cancelable: true,
289
+ key: t.key || 0,
290
+ code: t.code || 0
291
+ })
292
+ } else {
293
+ const evt = new UIEvent(type, {
294
+ view: window,
295
+ bubbles: true,
296
+ cancelable: true
297
+ })
298
+ evt.key = t.key || '',
299
+ evt.code = t.code || ''
300
+ return evt
301
+ }
302
+ }
303
+
304
+ const check_event_key = (selectmethod) => {
305
+ document.body.innerHTML = __html__[htmlPath+'event_dom_scrolldiv.html']
306
+ window.scrollX = 50
307
+ window.scrollY = 50
308
+
309
+ const code = `
310
+ 要素は${selectmethod}
311
+ 要素をキー押した時には、
312
+ 「D:{押キー}」を報告する。
313
+ ここまで。
314
+ 要素をキー離した時には、
315
+ 「U:{押キー}」を報告する。
316
+ ここまで。
317
+ 要素をキータイピングした時には、
318
+ 「P:{押キー}」を報告する。
319
+ ここまで。
320
+ `
321
+ const cr = window.cr
322
+ cr.reset()
323
+ nako.run(code)
324
+
325
+ const e = document.getElementById('tgt')
326
+ if (e) {
327
+ const targetOffsets = [
328
+ { target: e, key: 'A', code: 'D' },
329
+ { target: e, key: 'C', code: 'E' },
330
+ { target: e, key: 'Q', code: 'W' }
331
+ ]
332
+
333
+ let evt = createKeyboardEvent('keydown', targetOffsets[0])
334
+ e.dispatchEvent(evt)
335
+
336
+ evt = createKeyboardEvent('keyup', targetOffsets[1])
337
+ e.dispatchEvent(evt)
338
+
339
+ evt = createKeyboardEvent('keypress', targetOffsets[2])
340
+ e.dispatchEvent(evt)
341
+ }
342
+
343
+ assert.ok(cr.isCalled, 'イベント呼び出し')
344
+ assert.strictEqual(cr.getMessageAsJson(), '["D:A","U:C","P:Q"]')
345
+ }
346
+
347
+ it('キーボード押・話・押下', () => {
348
+ check_event_key('「#tgt」')
349
+ })
350
+ it('キーボード押・話・押下 - dom', () => {
351
+ check_event_key('「tgt」をDOM要素ID取得')
352
+ })
353
+ })
354
+
355
+ describe('マウス', () => {
356
+ const createMouseEvent = (type, t) => {
357
+ const box = t.target.getBoundingClientRect()
358
+ const { x, y } = t
359
+ if (MouseEvent && MouseEvent.length > 0) {
360
+ return new MouseEvent(type, {
361
+ view: window,
362
+ bubbles: true,
363
+ cancelable: true,
364
+ button: t.btn || 0,
365
+ buttons: t.btns || 0,
366
+ clientX: box.left + x,
367
+ clientY: box.top + y,
368
+ screenX: window.screenLeft + box.left + x,
369
+ screenY: window.screenTop + box.top + y,
370
+ pageX: window.scrollX + box.left + x,
371
+ pageY: window.scrollY + box.top + y
372
+ })
373
+ } else {
374
+ const evt = new UIEvent(type, {
375
+ view: window,
376
+ bubbles: true,
377
+ cancelable: true
378
+ })
379
+ evt.button = t.btn || 0,
380
+ evt.buttons = t.btns || 0,
381
+ evt.clientX = box.left + x,
382
+ evt.clientY = box.top + y,
383
+ evt.screenX = window.screenLeft + box.left + x,
384
+ evt.screenY = window.screenTop + box.top + y,
385
+ evt.pageX = window.scrollX + box.left + x,
386
+ evt.pageY = window.scrollY + box.top + y
387
+ return evt
388
+ }
389
+ }
390
+
391
+ const check_event_mouse = (selectmethod) => {
392
+ document.body.innerHTML = __html__[htmlPath+'event_dom_scrolldiv.html']
393
+ window.scrollX = 50
394
+ window.scrollY = 50
395
+
396
+ const code = `
397
+ 要素は${selectmethod}
398
+ 要素をクリックした時には、
399
+ 「C:」を報告する。
400
+ ここまで。
401
+ 要素をマウス押した時には、
402
+ 「D:{マウスX},{マウスY}」を報告する。
403
+ ここまで。
404
+ 要素をマウス移動した時には、
405
+ 「M:{マウスX},{マウスY}」を報告する。
406
+ ここまで。
407
+ 要素をマウス離した時には、
408
+ 「U:{マウスX},{マウスY}」を報告する。
409
+ ここまで。
410
+ `
411
+ const cr = window.cr
412
+ cr.reset()
413
+ nako.run(code)
414
+
415
+ const e = document.getElementById('tgt')
416
+ if (e) {
417
+ const targetOffsets = [
418
+ { target: e, x: 0, y: 0, btn: 0, btns: 1 },
419
+ { target: e, x: 30, y: 35, btn: 1, btns: 3 },
420
+ { target: e, x: 30, y: 40, btn: 0, btns: 3 },
421
+ { target: e, x: 20, y: 35, btn: 1, btns: 2 }
422
+ ]
423
+
424
+ let evt = createMouseEvent('click', targetOffsets[0])
425
+ e.dispatchEvent(evt)
426
+
427
+ evt = createMouseEvent('mousedown', targetOffsets[1])
428
+ e.dispatchEvent(evt)
429
+
430
+ evt = createMouseEvent('mousemove', targetOffsets[2])
431
+ e.dispatchEvent(evt)
432
+
433
+ evt = createMouseEvent('mouseup', targetOffsets[3])
434
+ e.dispatchEvent(evt)
435
+ }
436
+
437
+ assert.ok(cr.isCalled, 'イベント呼び出し')
438
+ assert.strictEqual(cr.getMessageAsJson(), '["C:","D:30,35","M:30,40","U:20,35"]')
439
+ }
440
+
441
+ it('マウス押・離・クリック', () => {
442
+ check_event_mouse('「#tgt」')
443
+ })
444
+ it('マウス押・離・クリック - dom', () => {
445
+ check_event_mouse('「tgt」をDOM要素ID取得')
446
+ })
447
+ })
448
+
449
+ describe('タッチ', () => {
450
+ const createTouches = (infos) => {
451
+ const touches = []
452
+ const createTouchFactory = () => {
453
+ if (Touch && TouchEvent && Touch.length > 0 && TouchEvent.length > 0) {
454
+ return (params) => {
455
+ return new Touch(params)
456
+ }
457
+ } else {
458
+ return (params) => {
459
+ return params
460
+ }
461
+ }
462
+ }
463
+ const createTouch = createTouchFactory()
464
+
465
+ infos.forEach(t => {
466
+ const box = t.target.getBoundingClientRect()
467
+ const { x, y } = t
468
+ const params = {
469
+ identifier: t.id,
470
+ target: t.target,
471
+ clientX: box.left + x,
472
+ clientY: box.top + y,
473
+ screenX: window.screenLeft + box.left + x,
474
+ screenY: window.screenTop + box.top + y,
475
+ pageX: window.scrollX + box.left + x,
476
+ pageY: window.scrollY + box.top + y,
477
+ radiusX: t.r || 1.0,
478
+ radiusY: t.r || 1.0
479
+ }
480
+ touches.push(createTouch(params))
481
+ })
482
+ return touches
483
+ }
484
+ const createTouchEvent = (type, touches) => {
485
+ if (Touch && TouchEvent && Touch.length > 0 && TouchEvent.length > 0) {
486
+ return new TouchEvent(type, {
487
+ view: window,
488
+ bubbles: true,
489
+ cancelable: true,
490
+ changedTouches: touches.changed,
491
+ targetTouches: touches.target,
492
+ touches: touches.all
493
+ })
494
+ } else {
495
+ const evt = new UIEvent(type, {
496
+ view: window,
497
+ bubbles: true,
498
+ cancelable: true
499
+ })
500
+ evt.changedTouches = touches.changed
501
+ evt.targetTouches = touches.target
502
+ evt.touches = touches.all
503
+ return evt
504
+ }
505
+ }
506
+ const check_event_touch = (selectmethod) => {
507
+ document.body.innerHTML = __html__[htmlPath+'event_dom_scrolldiv.html']
508
+ window.scrollX = 50
509
+ window.scrollY = 50
510
+
511
+ const code = `
512
+ 要素は${selectmethod}
513
+ 要素をタッチ開始した時には、
514
+ 「S:{タッチX},{タッチY}」を報告する。
515
+ タッチ配列を反復する。
516
+ これはそれ
517
+ 「{これ[0]},{これ[1]}」を報告する。
518
+ ここまで。
519
+ ここまで。
520
+ 要素をタッチ終了した時には、
521
+ 「E:{タッチX},{タッチY}」を報告する。
522
+ タッチ配列を反復する。
523
+ これはそれ
524
+ 「{これ[0]},{これ[1]}」を報告する。
525
+ ここまで。
526
+ ここまで。
527
+ 要素をタッチした時には、
528
+ 「M:{タッチX},{タッチY}」を報告する。
529
+ タッチ配列を反復する。
530
+ これはそれ
531
+ 「{これ[0]},{これ[1]}」を報告する。
532
+ ここまで。
533
+ ここまで。
534
+ 要素をタッチキャンセルした時には、
535
+ 「C:{タッチX},{タッチY}」を報告する。
536
+ タッチ配列を反復する。
537
+ これはそれ
538
+ 「{これ[0]},{これ[1]}」を報告する。
539
+ ここまで。
540
+ ここまで。
541
+ `
542
+ const cr = window.cr
543
+ cr.reset()
544
+ nako.run(code)
545
+
546
+ const e = document.getElementById('tgt')
547
+ if (e) {
548
+ const targetOffsets = [
549
+ { target: e, id: 42, x: 20, y: 30, r: 5 },
550
+ { target: e, id: 43, x: 30, y: 35, r: 2 },
551
+ { target: e, id: 42, x: 25, y: 35, r: 3 },
552
+ { target: e, id: 42, x: 20, y: 35, r: 1 },
553
+ { target: e, id: 43, x: 30, y: 35, r: 5 }
554
+ ]
555
+ const touchesList = createTouches(targetOffsets)
556
+
557
+ let evt = createTouchEvent('touchstart', {
558
+ changed: [ touchesList[0], touchesList[1] ],
559
+ target: [ touchesList[0], touchesList[1] ],
560
+ all: [ touchesList[0], touchesList[1] ]
561
+ })
562
+ e.dispatchEvent(evt)
563
+
564
+ evt = createTouchEvent('touchmove', {
565
+ changed: [ touchesList[2] ],
566
+ target: [ touchesList[2], touchesList[1] ],
567
+ all: [ touchesList[2], touchesList[1] ]
568
+ })
569
+ e.dispatchEvent(evt)
570
+
571
+ evt = createTouchEvent('touchcancel', {
572
+ changed: [ touchesList[3] ],
573
+ target: [ touchesList[1] ],
574
+ all: [ touchesList[1] ]
575
+ })
576
+ e.dispatchEvent(evt)
577
+
578
+ evt = createTouchEvent('touchend', {
579
+ changed: [ touchesList[4] ],
580
+ target: [],
581
+ all: []
582
+ })
583
+ e.dispatchEvent(evt)
584
+ }
585
+
586
+ assert.ok(cr.isCalled, 'イベント呼び出し')
587
+ assert.strictEqual(cr.getMessageAsJson(), '["S:20,30","20,30","30,35","M:25,35","25,35","C:20,35","20,35","E:30,35","30,35"]')
588
+ }
589
+
590
+ it('タッチ開始・終了・移動・キャンセル', () => {
591
+ check_event_touch('「#tgt」')
592
+ })
593
+ it('タッチ開始・終了・移動・キャンセル - dom', () => {
594
+ check_event_touch('「tgt」をDOM要素ID取得')
595
+ })
596
+ })
597
+ })
598
+ }