nadesiko3 3.3.49 → 3.3.52
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.
- package/LICENSE +21 -21
- package/README.md +143 -143
- package/batch/.DS_Store +0 -0
- package/batch/browsers.template.md +3 -3
- package/batch/build_browsers.nako3 +72 -72
- package/batch/build_command.nako3 +44 -44
- package/batch/build_nako_version.nako3 +42 -42
- package/batch/calc_hash.nako3 +29 -29
- package/batch/cmd_txt2json.nako3 +74 -74
- package/batch/command.txt +162 -83
- package/batch/command_nakopad.txt +69 -0
- package/batch/download-extlib.nako3 +43 -43
- package/batch/gen_command_nakopad.nako3 +57 -57
- package/batch/jsplugin2text.nako3 +285 -285
- package/batch/pickup_command.nako3 +113 -110
- package/batch/pickup_reserved_words.nako3 +11 -11
- package/batch/publish_version.nako3 +46 -46
- package/batch/show_agents.js +14 -14
- package/batch/turtle2js.nako3 +21 -21
- package/bin/cnako3 +10 -10
- package/core/LICENSE +21 -21
- package/core/README.md +66 -66
- package/core/batch/build_nako_version.nako3 +42 -42
- package/core/command/snako.mjs +105 -105
- package/core/command/snako.mts +116 -116
- package/core/index.mjs +21 -21
- package/core/package.json +47 -47
- package/core/sample/hello.nako3 +7 -7
- package/core/sample/hoge.mjs +4 -4
- package/core/sample/hoge.mts +6 -6
- package/core/src/nako3.mjs +870 -858
- package/core/src/nako3.mts +983 -967
- package/core/src/nako_colors.mjs +78 -78
- package/core/src/nako_colors.mts +86 -86
- package/core/src/nako_core_version.mjs +8 -8
- package/core/src/nako_core_version.mts +19 -19
- package/core/src/nako_csv.mjs +185 -185
- package/core/src/nako_csv.mts +188 -188
- package/core/src/nako_errors.mjs +173 -173
- package/core/src/nako_errors.mts +197 -197
- package/core/src/nako_from_dncl.mjs +255 -255
- package/core/src/nako_from_dncl.mts +250 -250
- package/core/src/nako_gen.mjs +1647 -1648
- package/core/src/nako_gen.mts +1718 -1719
- package/core/src/nako_gen_async.mjs +1659 -1659
- package/core/src/nako_gen_async.mts +1732 -1732
- package/core/src/nako_global.mjs +109 -107
- package/core/src/nako_global.mts +141 -138
- package/core/src/nako_indent.mjs +445 -445
- package/core/src/nako_indent.mts +492 -492
- package/core/src/nako_josi_list.mjs +38 -38
- package/core/src/nako_josi_list.mts +45 -45
- package/core/src/nako_lex_rules.mjs +253 -253
- package/core/src/nako_lex_rules.mts +260 -260
- package/core/src/nako_lexer.mjs +609 -609
- package/core/src/nako_lexer.mts +612 -612
- package/core/src/nako_logger.mjs +199 -199
- package/core/src/nako_logger.mts +232 -232
- package/core/src/nako_parser3.mjs +2441 -2439
- package/core/src/nako_parser3.mts +2197 -2195
- package/core/src/nako_parser_base.mjs +371 -370
- package/core/src/nako_parser_base.mts +372 -370
- package/core/src/nako_parser_const.mjs +37 -37
- package/core/src/nako_parser_const.mts +37 -37
- package/core/src/nako_prepare.mjs +304 -304
- package/core/src/nako_prepare.mts +315 -315
- package/core/src/nako_reserved_words.mjs +38 -38
- package/core/src/nako_reserved_words.mts +38 -38
- package/core/src/nako_source_mapping.mjs +207 -207
- package/core/src/nako_source_mapping.mts +262 -262
- package/core/src/nako_test.mjs +37 -37
- package/core/src/nako_types.mjs +13 -25
- package/core/src/nako_types.mts +144 -151
- package/core/src/plugin_csv.mjs +49 -49
- package/core/src/plugin_csv.mts +50 -50
- package/core/src/plugin_math.mjs +328 -328
- package/core/src/plugin_math.mts +326 -326
- package/core/src/plugin_promise.mjs +91 -91
- package/core/src/plugin_promise.mts +91 -91
- package/core/src/plugin_system.mjs +2832 -2832
- package/core/src/plugin_system.mts +2690 -2690
- package/core/src/plugin_test.mjs +34 -34
- package/core/src/plugin_test.mts +34 -34
- package/demo/.DS_Store +0 -0
- package/demo/ace_editor.html +89 -89
- package/demo/ace_editor_tabs.html +161 -161
- package/demo/basic.html +71 -71
- package/demo/browsers.html +10 -9
- package/demo/css/basic.css +3 -3
- package/demo/css/common.css +157 -157
- package/demo/css/editor.css +8 -8
- package/demo/css/flow.css +3 -3
- package/demo/css/index.css +3 -3
- package/demo/extlib/.DS_Store +0 -0
- package/demo/flow.html +98 -98
- package/demo/graph.html +53 -53
- package/demo/image/nakopad-icon256.png +0 -0
- package/demo/index.html +133 -133
- package/demo/js/common.js +17 -17
- package/demo/js/turtle3d_test.js +44 -44
- package/demo/js/turtle_test.js +45 -45
- package/demo/nako3/calc.nako3 +4 -4
- package/demo/runscript.html +47 -47
- package/demo/runscript2.html +33 -33
- package/demo/runscript3.html +35 -35
- package/demo/runscript4.html +33 -33
- package/demo/turtle.html +58 -58
- package/demo/turtle2.html +141 -141
- package/demo/turtle3.html +279 -279
- package/demo/turtle3d.html +58 -58
- package/demo/turtle3d2.html +107 -107
- package/demo/version.html +24 -24
- package/doc/SETUP.md +157 -157
- package/doc/about.md +17 -17
- package/doc/browsers.md +26 -26
- package/doc/docgen.md +21 -21
- package/doc/editor.md +44 -44
- package/doc/files.md +39 -39
- package/doc/plugins.md +234 -234
- package/doc/release.md +79 -79
- package/doc/textlint.md +43 -43
- package/doc/win32.md +57 -57
- package/package.json +195 -195
- package/release/_hash.txt +28 -28
- package/release/_script-tags.txt +14 -14
- package/release/command.json +1 -1
- package/release/command.json.js +1 -1
- package/release/command_cnako3.json +1 -1
- package/release/command_list.json +1 -1
- package/release/editor.js +1 -1
- package/release/nako_gen_async.js +2 -1
- package/release/nako_gen_async.js.LICENSE.txt +35 -0
- package/release/plugin_caniuse.js.LICENSE.txt +11 -0
- package/release/plugin_csv.js +1 -1
- package/release/plugin_csv.js.LICENSE.txt +15 -0
- package/release/plugin_datetime.js.LICENSE.txt +15 -0
- package/release/plugin_kansuji.js.LICENSE.txt +3 -0
- package/release/plugin_markup.js.LICENSE.txt +11 -0
- package/release/plugin_turtle.js.LICENSE.txt +15 -0
- package/release/plugin_webworker.js.LICENSE.txt +3 -0
- package/release/plugin_weykturtle3d.js.LICENSE.txt +3 -0
- package/release/stats.json +1 -1
- package/release/version.js +1 -1
- package/release/wnako3.js +1 -1
- package/release/wnako3.js.LICENSE.txt +203 -1
- package/release/wnako3webworker.js +2 -1
- package/release/wnako3webworker.js.LICENSE.txt +131 -0
- package/src/.DS_Store +0 -0
- package/src/browsers.txt +12 -11
- package/src/browsers_agents.json +2 -2
- package/src/browsers_agents.mjs +1 -1
- package/src/cnako3.mjs +17 -17
- package/src/cnako3.mts +18 -18
- package/src/cnako3mod.mjs +682 -707
- package/src/cnako3mod.mts +688 -712
- package/src/commander_ja.mjs +164 -164
- package/src/commander_ja.mts +161 -161
- package/src/enako3.mjs +68 -68
- package/src/era.mjs +22 -22
- package/src/image_turtle-elephant.mjs +2 -2
- package/src/image_turtle-panda.mjs +2 -2
- package/src/image_turtle64.mjs +2 -2
- package/src/index.mjs +9 -9
- package/src/index.mts +10 -10
- package/src/nako3editorfix.sfd +106 -106
- package/src/nako_version.mjs +8 -8
- package/src/nako_version.mts +2 -2
- package/src/plugin_browser.mjs +213 -213
- package/src/plugin_browser.mts +206 -206
- package/src/plugin_browser_ajax.mjs +399 -399
- package/src/plugin_browser_audio.mjs +109 -109
- package/src/plugin_browser_canvas.mjs +449 -449
- package/src/plugin_browser_chart.mjs +294 -294
- package/src/plugin_browser_color.mjs +49 -49
- package/src/plugin_browser_crypto.mjs +26 -26
- package/src/plugin_browser_dialog.mjs +53 -53
- package/src/plugin_browser_dom_basic.mjs +336 -336
- package/src/plugin_browser_dom_event.mjs +193 -193
- package/src/plugin_browser_dom_parts.mjs +396 -396
- package/src/plugin_browser_geolocation.mjs +51 -51
- package/src/plugin_browser_hotkey.mjs +25 -25
- package/src/plugin_browser_html.mjs +59 -59
- package/src/plugin_browser_in_worker.mjs +45 -45
- package/src/plugin_browser_location.mjs +21 -21
- package/src/plugin_browser_speech.mjs +111 -111
- package/src/plugin_browser_storage.mjs +121 -121
- package/src/plugin_browser_system.mjs +31 -31
- package/src/plugin_browser_websocket.mjs +73 -73
- package/src/plugin_caniuse.mjs +29 -29
- package/src/plugin_datetime.mjs +394 -394
- package/src/plugin_httpserver.mjs +277 -277
- package/src/plugin_httpserver.mts +286 -286
- package/src/plugin_kansuji.mjs +224 -224
- package/src/plugin_keigo.mjs +55 -55
- package/src/plugin_markup.mjs +32 -32
- package/src/plugin_node.mjs +1047 -1047
- package/src/plugin_node.mts +980 -980
- package/src/plugin_turtle.mjs +647 -647
- package/src/plugin_webworker.mjs +334 -334
- package/src/plugin_weykturtle3d.mjs +1214 -1214
- package/src/plugin_worker.mjs +95 -95
- package/src/repl.nako3 +63 -63
- package/src/wnako3.mjs +12 -12
- package/src/wnako3.mts +11 -11
- package/src/wnako3_editor.css +215 -215
- package/src/wnako3_editor.mjs +1542 -1542
- package/src/wnako3_editor.mts +1658 -1657
- package/src/wnako3mod.mjs +213 -213
- package/src/wnako3mod.mts +214 -214
- package/src/wnako3webworker.mjs +69 -69
- package/test/.DS_Store +0 -0
- package/test/ace_editor/karma.config.js +94 -94
- package/test/ace_editor/test/.babelrc.json +3 -3
- package/test/ace_editor/test/ace_editor_test.js +178 -178
- package/test/ace_editor/test/html/custom_context.html +139 -139
- package/test/async/async_basic_test.mjs +122 -122
- package/test/browser/.DS_Store +0 -0
- package/test/browser/karma.config.js +221 -221
- package/test/browser/test/.babelrc.json +3 -3
- package/test/browser/test/compare_util.js +50 -50
- package/test/browser/test/html/div_basic.html +2 -2
- package/test/browser/test/html/event_dom_form.html +4 -4
- package/test/browser/test/html/event_dom_scrolldiv.html +5 -5
- package/test/browser/test/import_plugin_checker.js +24 -24
- package/test/browser/test/plugin_browser_test.js +51 -51
- package/test/browser/test/plugin_browser_test_ajax.js +123 -123
- package/test/browser/test/plugin_browser_test_color.js +18 -18
- package/test/browser/test/plugin_browser_test_dialog.js +72 -72
- package/test/browser/test/plugin_browser_test_dom_event.js +598 -598
- package/test/browser/test/plugin_browser_test_dom_parts.js +125 -125
- package/test/browser/test/plugin_browser_test_system.js +9 -9
- package/test/browser/test/plugin_turtle_test.js +817 -817
- package/test/browser/test/plugin_webworker_test.js +86 -86
- package/test/browser/test/require_test.js +68 -68
- package/test/bundled/.DS_Store +0 -0
- package/test/bundled/karma.config.base.js +117 -117
- package/test/bundled/karma.config.js +86 -86
- package/test/bundled/test/.babelrc.json +3 -3
- package/test/bundled/test/bundled_test.js +69 -69
- package/test/bundled/test/html/custom_context.html +65 -65
- package/test/bundled/test/html/custom_debug.html +66 -66
- package/test/bundled/test4b.cmd +52 -52
- package/test/bundled/test_base/.DS_Store +0 -0
- package/test/bundled/test_base/.babelrc.json +3 -3
- package/test/bundled/test_base/_checktool_test.js +25 -25
- package/test/bundled/test_base/basic_ajax_test.js +56 -56
- package/test/bundled/test_base/basic_async_test.js +18 -18
- package/test/bundled/test_base/basic_test.js +153 -153
- package/test/bundled/test_base/calc_test.js +132 -132
- package/test/bundled/test_base/css/browsers_box.css +114 -114
- package/test/bundled/test_base/html/custom_context.html +69 -69
- package/test/bundled/test_base/html/custom_debug.html +71 -71
- package/test/bundled/test_base/js/browsers_box.js +72 -72
- package/test/bundled/test_base/plugin_csv_test.js +37 -37
- package/test/bundled/test_base/plugin_datetime_test.js +115 -115
- package/test/bundled/test_base/plugin_kansuji_test.js +49 -49
- package/test/bundled/test_base/plugin_system_test.js +410 -410
- package/test/bundled/test_base/plugin_webworker_test.js +53 -53
- package/test/bundled/test_base/test_utils.js +191 -191
- package/test/common/.DS_Store +0 -0
- package/test/common/plugin_browser_test.mjs +22 -22
- package/test/common/plugin_browser_ut_audio_test.mjs +108 -108
- package/test/common/plugin_browser_ut_color_test.mjs +21 -21
- package/test/common/plugin_browser_ut_dialog_test.mjs +100 -100
- package/test/common/plugin_browser_ut_html_test.mjs +13 -13
- package/test/common/plugin_browser_ut_system_test.mjs +10 -10
- package/test/common/plugin_markup_test.mjs +23 -23
- package/test/jsconfig.json +19 -19
- package/test/karma.config.js +91 -91
- package/test/node/.DS_Store +0 -0
- package/test/node/async_test.mjs +96 -96
- package/test/node/commander_ja_test.mjs +89 -89
- package/test/node/error_message_test.mjs +243 -243
- package/test/node/kai_test.nako3 +6 -6
- package/test/node/node_test.mjs +60 -60
- package/test/node/plugin_broken.js.txt +3 -3
- package/test/node/plugin_browser_ut_ajax_test.mjs.todo +357 -357
- package/test/node/plugin_browser_ut_location_test.mjs +42 -42
- package/test/node/plugin_markup_test.mjs +47 -47
- package/test/node/plugin_math_test.mjs +45 -45
- package/test/node/plugin_node_test.mjs +98 -98
- package/test/node/plugin_test.mjs +44 -44
- package/test/node/relative_import_test_1.nako3 +1 -1
- package/test/node/relative_import_test_2.nako3 +2 -2
- package/test/node/require_nako3_test.mjs +67 -67
- package/test/node/requiretest.nako3 +4 -4
- package/test/node/requiretest_indirect.nako3 +1 -1
- package/test/node/requiretest_name.nako3 +5 -5
- package/test/node/runtime_error.nako3 +2 -2
- package/test/node/scope1.nako3 +10 -10
- package/test/node/scope2.nako3 +12 -12
- package/test/node/side_effects_test.mjs +39 -39
- package/test/node/sjis.txt +5 -5
- package/test/node/syntax_error.nako3 +1 -1
- package/test/node/wnako3_editor_test.mjs +384 -384
- package/tools/.DS_Store +0 -0
- package/tools/README.md +12 -12
- package/tools/check_new_version.nako3 +25 -25
- package/tools/nako3edit/.DS_Store +0 -0
- package/tools/nako3edit/a.sqlite3 +0 -0
- package/tools/nako3edit/html/.DS_Store +0 -0
- package/tools/nako3edit/html/daisyui/LICENSE +22 -22
- package/tools/nako3edit/html/daisyui/version_2.14.1 +1 -1
- package/tools/nako3edit/html/edit.html +170 -170
- package/tools/nako3edit/html/edit_plugin.js +6 -6
- package/tools/nako3edit/html/files.html +125 -125
- package/tools/nako3edit/html/nako3edit.css +65 -65
- package/tools/nako3edit/index.mjs +248 -248
- package/tools/nako3server/index.html +10 -10
- package/tools/nako3server/index.mjs +116 -116
- package/tools/nako3server/index.nako3 +34 -34
- package/core/.editorconfig +0 -6
- package/core/.eslintrc.cjs +0 -33
- package/core/.github/dependabot.yml +0 -7
- package/core/.github/workflows/nodejs.yml +0 -37
- package/core/.github/workflows/super-linter.yml +0 -61
- package/core/.github/workflows/textlint.yml +0 -199
- package/core/index.mts +0 -21
- package/core/test/array_test.mjs +0 -34
- package/core/test/basic_test.mjs +0 -344
- package/core/test/calc_test.mjs +0 -140
- package/core/test/core_module_test.mjs +0 -23
- package/core/test/debug_test.mjs +0 -16
- package/core/test/dncl_test.mjs +0 -94
- package/core/test/error_message_test.mjs +0 -210
- package/core/test/error_test.mjs +0 -16
- package/core/test/flow_test.mjs +0 -373
- package/core/test/func_call.mjs +0 -160
- package/core/test/func_test.mjs +0 -149
- package/core/test/indent_test.mjs +0 -364
- package/core/test/lex_test.mjs +0 -168
- package/core/test/literal_test.mjs +0 -73
- package/core/test/nako_lexer_test.mjs +0 -35
- package/core/test/nako_logger_test.mjs +0 -76
- package/core/test/nako_logger_test.mts +0 -78
- package/core/test/plugin_csv_test.mjs +0 -38
- package/core/test/plugin_promise_test.mjs +0 -18
- package/core/test/plugin_system_test.mjs +0 -630
- package/core/test/prepare_test.mjs +0 -96
- package/core/test/re_test.mjs +0 -22
- package/core/test/side_effects_test.mjs +0 -92
- package/core/test/variable_scope_test.mjs +0 -149
- package/core/tsconfig.json +0 -101
|
@@ -1,396 +1,396 @@
|
|
|
1
|
-
// @ts-nocheck
|
|
2
|
-
export default {
|
|
3
|
-
// @DOM部品操作
|
|
4
|
-
'DOM親要素': { type: 'const', value: '' }, // @DOMおやようそ
|
|
5
|
-
'DOM部品個数': { type: 'const', value: 0 }, // @DOMせいせいこすう
|
|
6
|
-
'DOM部品オプション': { type: 'const', value: { '自動改行': false, 'テーブル背景色': ['#AA4040', '#ffffff', '#fff0f0'] } }, // @DOMぶひんおぷしょん
|
|
7
|
-
'DOM親要素設定': { // @「ボタン作成」「エディタ作成」など『DOM部品作成』で追加する要素の親要素を指定(デフォルトはdocument)して要素を返す。 // @DOMおやようそせってい
|
|
8
|
-
type: 'func',
|
|
9
|
-
josi: [['に', 'へ']],
|
|
10
|
-
pure: false,
|
|
11
|
-
fn: function (el, sys) {
|
|
12
|
-
if (typeof el === 'string') { el = document.querySelector(el) || document.getElementById(el) }
|
|
13
|
-
sys.__v0['DOM親要素'] = el
|
|
14
|
-
return el
|
|
15
|
-
}
|
|
16
|
-
},
|
|
17
|
-
'DOM親部品設定': { // @ DOM部品作成でDOM要素を追加する親の対象を指定。『DOM親要素設定』と同じ。// @DOMおやぶひんせってい
|
|
18
|
-
type: 'func',
|
|
19
|
-
josi: [['に', 'へ']],
|
|
20
|
-
pure: false,
|
|
21
|
-
fn: function (el, sys) {
|
|
22
|
-
return sys.__exec('DOM親要素設定', [el, sys])
|
|
23
|
-
}
|
|
24
|
-
},
|
|
25
|
-
'DOMスキン': { type: 'const', value: '' }, // @DOMすきん
|
|
26
|
-
'DOMスキン辞書': { type: 'const', value: {} }, // @DOMすきんじしょ
|
|
27
|
-
'DOMスキン設定': { // @「ボタン作成」「エディタ作成」などで適用するスキンを指定する(#1033) // @DOMすきんせってい
|
|
28
|
-
type: 'func',
|
|
29
|
-
josi: [['を', 'に', 'の']],
|
|
30
|
-
pure: false,
|
|
31
|
-
fn: function (skin, sys) {
|
|
32
|
-
sys.__v0['DOMスキン'] = skin
|
|
33
|
-
},
|
|
34
|
-
return_none: true
|
|
35
|
-
},
|
|
36
|
-
'DOM部品作成': { // @elmの要素を作成して『DOM親要素設定』で指定した要素に追加して、DOMオブジェクトを返す。(elmがDOM要素なら追加する) // @DOMぶひんさくせい
|
|
37
|
-
type: 'func',
|
|
38
|
-
josi: [['の']],
|
|
39
|
-
pure: false,
|
|
40
|
-
fn: function (elm, sys) {
|
|
41
|
-
const parent = sys.__v0['DOM親要素']
|
|
42
|
-
const btn = (typeof (elm) === 'string') ? document.createElement(elm) : elm
|
|
43
|
-
btn.id = 'nadesi-dom-' + sys.__v0['DOM部品個数']
|
|
44
|
-
// スキン適用
|
|
45
|
-
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
46
|
-
if (typeof (func) === 'function') { func(elm, btn, sys) }
|
|
47
|
-
// DOM追加
|
|
48
|
-
parent.appendChild(btn)
|
|
49
|
-
sys.__v0['DOM部品個数']++
|
|
50
|
-
// オプションを適用
|
|
51
|
-
const opt = sys.__v0['DOM部品オプション']
|
|
52
|
-
if (opt['自動改行']) {
|
|
53
|
-
parent.appendChild(document.createElement('br'))
|
|
54
|
-
}
|
|
55
|
-
return btn
|
|
56
|
-
}
|
|
57
|
-
},
|
|
58
|
-
'ボタン作成': { // @ラベルlabelを持つbutton要素を追加しDOMオブジェクトを返す // @ぼたんさくせい
|
|
59
|
-
type: 'func',
|
|
60
|
-
josi: [['の']],
|
|
61
|
-
pure: false,
|
|
62
|
-
fn: function (label, sys) {
|
|
63
|
-
const btn = sys.__exec('DOM部品作成', ['button', sys])
|
|
64
|
-
btn.innerHTML = label
|
|
65
|
-
return btn
|
|
66
|
-
}
|
|
67
|
-
},
|
|
68
|
-
'エディタ作成': { // @textの値を持つテキストボックス(input[type='text'])の要素を追加しDOMオブジェクトを返す // @えでぃたさくせい
|
|
69
|
-
type: 'func',
|
|
70
|
-
josi: [['の']],
|
|
71
|
-
pure: false,
|
|
72
|
-
fn: function (text, sys) {
|
|
73
|
-
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
74
|
-
inp.type = 'text'
|
|
75
|
-
inp.value = text
|
|
76
|
-
return inp
|
|
77
|
-
}
|
|
78
|
-
},
|
|
79
|
-
'テキストエリア作成': { // @textの値を持つtextarea要素を追加しDOMオブジェクトを返す // @てきすとえりあさくせい
|
|
80
|
-
type: 'func',
|
|
81
|
-
josi: [['の']],
|
|
82
|
-
pure: false,
|
|
83
|
-
fn: function (text, sys) {
|
|
84
|
-
const te = sys.__exec('DOM部品作成', ['textarea', sys])
|
|
85
|
-
te.value = text
|
|
86
|
-
return te
|
|
87
|
-
}
|
|
88
|
-
},
|
|
89
|
-
'ラベル作成': { // @textの値を持つラベル(span要素)を追加しDOMオブジェクトを返す // @らべるさくせい
|
|
90
|
-
type: 'func',
|
|
91
|
-
josi: [['の']],
|
|
92
|
-
pure: false,
|
|
93
|
-
fn: function (text, sys) {
|
|
94
|
-
const lbl = sys.__exec('DOM部品作成', ['span', sys])
|
|
95
|
-
lbl.innerHTML = text
|
|
96
|
-
return lbl
|
|
97
|
-
}
|
|
98
|
-
},
|
|
99
|
-
'キャンバス作成': { // @大きさ[幅, 高]のcanvas要素を追加しDOMオブジェクトを返す // @きゃんばすさくせい
|
|
100
|
-
type: 'func',
|
|
101
|
-
josi: [['の']],
|
|
102
|
-
pure: false,
|
|
103
|
-
fn: function (size, sys) {
|
|
104
|
-
const cv = sys.__exec('DOM部品作成', ['canvas', sys])
|
|
105
|
-
cv.width = size[0]
|
|
106
|
-
cv.height = size[1]
|
|
107
|
-
cv.style.width = size[0]
|
|
108
|
-
cv.style.height = size[1]
|
|
109
|
-
// 描画中キャンバスを移動する
|
|
110
|
-
sys.__exec('描画開始', [cv, sys])
|
|
111
|
-
return cv
|
|
112
|
-
}
|
|
113
|
-
},
|
|
114
|
-
'画像作成': { // @URLを指定してimg要素を追加しDOMオブジェクトを返す // @がぞうさくせい
|
|
115
|
-
type: 'func',
|
|
116
|
-
josi: [['の', 'から']],
|
|
117
|
-
pure: false,
|
|
118
|
-
fn: function (url, sys) {
|
|
119
|
-
const img = sys.__exec('DOM部品作成', ['img', sys])
|
|
120
|
-
img.src = url
|
|
121
|
-
return img
|
|
122
|
-
}
|
|
123
|
-
},
|
|
124
|
-
'改行作成': { // @改行(br要素)を追加しDOMオブジェクトを返す // @かいぎょうさくせい
|
|
125
|
-
type: 'func',
|
|
126
|
-
josi: [],
|
|
127
|
-
pure: false,
|
|
128
|
-
fn: function (sys) {
|
|
129
|
-
const br = sys.__exec('DOM部品作成', ['br', sys])
|
|
130
|
-
return br
|
|
131
|
-
}
|
|
132
|
-
},
|
|
133
|
-
'チェックボックス作成': { // @textのラベルを持つチェックボックス(input[type='checkbox'])要素を追加しDOMオブジェクトを返す // @ちぇっくぼっくすさくせい
|
|
134
|
-
type: 'func',
|
|
135
|
-
josi: [['の']],
|
|
136
|
-
pure: false,
|
|
137
|
-
fn: function (text, sys) {
|
|
138
|
-
// チェックボックスは、<span><input><label></span>で成り立つように構築
|
|
139
|
-
const span = document.createElement('span')
|
|
140
|
-
const inp = document.createElement('input')
|
|
141
|
-
inp.type = 'checkbox'
|
|
142
|
-
inp.id = 'nadesi-dom-' + sys.__v0['DOM部品個数']
|
|
143
|
-
sys.__v0['DOM部品個数']++
|
|
144
|
-
const label = document.createElement('label')
|
|
145
|
-
label.innerHTML = text
|
|
146
|
-
label.htmlFor = inp.id
|
|
147
|
-
span.appendChild(inp)
|
|
148
|
-
span.appendChild(label)
|
|
149
|
-
// 親部品に追加
|
|
150
|
-
sys.__exec('DOM部品作成', [span, sys])
|
|
151
|
-
return inp
|
|
152
|
-
}
|
|
153
|
-
},
|
|
154
|
-
'セレクトボックス作成': { // @配列optionsの選択肢を持つselect要素を追加しDOMオブジェクトを返す // @せれくとぼっくすさくせい
|
|
155
|
-
type: 'func',
|
|
156
|
-
josi: [['の']],
|
|
157
|
-
pure: false,
|
|
158
|
-
fn: function (options, sys) {
|
|
159
|
-
const dom = document.createElement('select')
|
|
160
|
-
for (let i = 0; i < options.length; i++) {
|
|
161
|
-
const item = document.createElement('option')
|
|
162
|
-
item.value = options[i]
|
|
163
|
-
item.appendChild(document.createTextNode(options[i]))
|
|
164
|
-
dom.appendChild(item)
|
|
165
|
-
}
|
|
166
|
-
// 親部品に追加
|
|
167
|
-
const obj = sys.__exec('DOM部品作成', [dom, sys])
|
|
168
|
-
return dom
|
|
169
|
-
}
|
|
170
|
-
},
|
|
171
|
-
'セレクトボックスアイテム設定': { // @配列データをセレクトボックスdomのアイテムに差し替える // @せれくとぼっくすあいてむさくせい
|
|
172
|
-
type: 'func',
|
|
173
|
-
josi: [['を'], ['へ', 'に']],
|
|
174
|
-
pure: false,
|
|
175
|
-
fn: function (options, dom, sys) {
|
|
176
|
-
if (typeof dom === 'string') { dom = document.querySelector(dom) }
|
|
177
|
-
// 既存のoptionsをクリア
|
|
178
|
-
dom.options.length = 0
|
|
179
|
-
// アイテムを追加
|
|
180
|
-
for (let i = 0; i < options.length; i++) {
|
|
181
|
-
const item = document.createElement('option')
|
|
182
|
-
item.value = options[i]
|
|
183
|
-
item.appendChild(document.createTextNode(options[i]))
|
|
184
|
-
dom.appendChild(item)
|
|
185
|
-
}
|
|
186
|
-
},
|
|
187
|
-
return_none: true
|
|
188
|
-
},
|
|
189
|
-
'色選択ボックス作成': { // @色選択ボックス(input[type='color'])を作成しDOMオブジェクトを返す // @いろせんたくぼっくすさくせい
|
|
190
|
-
type: 'func',
|
|
191
|
-
josi: [],
|
|
192
|
-
pure: false,
|
|
193
|
-
fn: function (sys) {
|
|
194
|
-
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
195
|
-
inp.type = 'color'
|
|
196
|
-
return inp
|
|
197
|
-
}
|
|
198
|
-
},
|
|
199
|
-
'日付選択ボックス作成': { // @日付選択ボックス(input[type='date'])を作成しDOMオブジェクトを返す // @ひづけせんたくぼっくすさくせい
|
|
200
|
-
type: 'func',
|
|
201
|
-
josi: [],
|
|
202
|
-
pure: false,
|
|
203
|
-
fn: function (sys) {
|
|
204
|
-
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
205
|
-
inp.type = 'date'
|
|
206
|
-
return inp
|
|
207
|
-
}
|
|
208
|
-
},
|
|
209
|
-
'パスワード入力エディタ作成': { // @パスワード入力エディタ(input[type='password'])を作成し初期値Sを設定し、DOMオブジェクトを返す // @ぱすわーどにゅうりょくさくせい
|
|
210
|
-
type: 'func',
|
|
211
|
-
josi: [['の', 'で']],
|
|
212
|
-
pure: false,
|
|
213
|
-
fn: function (s, sys) {
|
|
214
|
-
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
215
|
-
inp.type = 'password'
|
|
216
|
-
inp.value = s
|
|
217
|
-
return inp
|
|
218
|
-
}
|
|
219
|
-
},
|
|
220
|
-
'値指定バー作成': { // @範囲RANGE(配列で[最小,最大[,値]])を指定するバー(input[type='range'])を作成しDOMオブジェクトを返す // @ぱすわーどにゅうりょくさくせい
|
|
221
|
-
type: 'func',
|
|
222
|
-
josi: [['の', 'で']],
|
|
223
|
-
pure: false,
|
|
224
|
-
fn: function (range, sys) {
|
|
225
|
-
if (!(range instanceof Array) || range.length < 2) {
|
|
226
|
-
range = [0, 100, 50]
|
|
227
|
-
}
|
|
228
|
-
if (range.length <= 2) { // 3つ目を省略したとき
|
|
229
|
-
range.push(Math.floor((range[1] - range[0]) / 2))
|
|
230
|
-
}
|
|
231
|
-
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
232
|
-
inp.type = 'range'
|
|
233
|
-
inp.min = range[0]
|
|
234
|
-
inp.max = range[1]
|
|
235
|
-
inp.value = range[2]
|
|
236
|
-
return inp
|
|
237
|
-
}
|
|
238
|
-
},
|
|
239
|
-
'送信ボタン作成': { // @ラベルSの送信ボタン(input[type='submit'])を作成しDOMオブジェクトを返す // @そうしんぼたんさくせい
|
|
240
|
-
type: 'func',
|
|
241
|
-
josi: [['の']],
|
|
242
|
-
pure: false,
|
|
243
|
-
fn: function (label, sys) {
|
|
244
|
-
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
245
|
-
inp.type = 'submit'
|
|
246
|
-
inp.value = label
|
|
247
|
-
return inp
|
|
248
|
-
}
|
|
249
|
-
},
|
|
250
|
-
'フォーム作成': { // @属性OBJ{method:"GET",action:"..."}で項目一覧S「a=初期値{改行}b=初期値{改行}色=?c#fff0f0{改行}=?送信」を送信フォームを作成しDOMオブジェクトを返す // @ふぉーむさくせい
|
|
251
|
-
type: 'func',
|
|
252
|
-
josi: [['で', 'の'], ['を']],
|
|
253
|
-
pure: false,
|
|
254
|
-
fn: function (obj, s, sys) {
|
|
255
|
-
const frm = sys.__exec('DOM部品作成', ['form', sys])
|
|
256
|
-
// 可能ならformにobjの値を移し替える
|
|
257
|
-
if (obj instanceof Object) {
|
|
258
|
-
for (const key in obj) {
|
|
259
|
-
if (frm[key]) { frm[key] = obj[key] }
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
// 入力項目をtableで作る
|
|
263
|
-
const rows = s.split('\n')
|
|
264
|
-
const table = document.createElement('table')
|
|
265
|
-
for (const rowIndex in rows) {
|
|
266
|
-
let row = '' + (rows[rowIndex])
|
|
267
|
-
if (row === '') { continue }
|
|
268
|
-
if (row.indexOf('=') < 0) { row += '=' }
|
|
269
|
-
const cols = row.split('=')
|
|
270
|
-
const key = cols[0]
|
|
271
|
-
const val = cols[1]
|
|
272
|
-
// key
|
|
273
|
-
const th = document.createElement('th')
|
|
274
|
-
th.innerHTML = sys.__tohtmlQ(key)
|
|
275
|
-
// val
|
|
276
|
-
const td = document.createElement('td')
|
|
277
|
-
if (val.substring(0, 2) === '?(') {
|
|
278
|
-
// select box
|
|
279
|
-
const it = val.substring(2) + ')'
|
|
280
|
-
const ita = it.split(')')
|
|
281
|
-
const its = ita[0]
|
|
282
|
-
const def = ita[1]
|
|
283
|
-
const items = its.split('|')
|
|
284
|
-
const select = document.createElement('select')
|
|
285
|
-
select.name = key
|
|
286
|
-
for (const it of items) {
|
|
287
|
-
const option = document.createElement('option')
|
|
288
|
-
option.value = it
|
|
289
|
-
option.text = it
|
|
290
|
-
select.appendChild(option)
|
|
291
|
-
}
|
|
292
|
-
const idx = items.indexOf(def)
|
|
293
|
-
if (idx >= 0) { select.selectedIndex = idx }
|
|
294
|
-
td.appendChild(select)
|
|
295
|
-
} else {
|
|
296
|
-
// input element
|
|
297
|
-
const inp = document.createElement('input')
|
|
298
|
-
td.appendChild(inp)
|
|
299
|
-
inp.id = 'nako3form_' + key
|
|
300
|
-
if (val === '?送信' || val === '?submit') {
|
|
301
|
-
inp.type = 'submit'
|
|
302
|
-
inp.value = val.substring(1)
|
|
303
|
-
if (key !== '') { inp.name = key }
|
|
304
|
-
} else if (val.substring(0, 2) === '?c') {
|
|
305
|
-
inp.type = 'color'
|
|
306
|
-
inp.value = val.substring(2)
|
|
307
|
-
inp.name = key
|
|
308
|
-
} else {
|
|
309
|
-
inp.type = 'text'
|
|
310
|
-
inp.value = val
|
|
311
|
-
inp.name = key
|
|
312
|
-
}
|
|
313
|
-
}
|
|
314
|
-
const tr = document.createElement('tr')
|
|
315
|
-
tr.appendChild(th)
|
|
316
|
-
tr.appendChild(td)
|
|
317
|
-
table.appendChild(tr)
|
|
318
|
-
}
|
|
319
|
-
frm.appendChild(table)
|
|
320
|
-
return frm
|
|
321
|
-
}
|
|
322
|
-
},
|
|
323
|
-
'フォーム入力一括取得': { // @DOMのフォームを取得し、そのフォーム以下にある入力項目のnameとvalueを辞書形式で返す // @ふぉーむにゅうりょくいっかつしゅとく
|
|
324
|
-
type: 'func',
|
|
325
|
-
josi: [['の', 'から']],
|
|
326
|
-
pure: true,
|
|
327
|
-
fn: function (dom) {
|
|
328
|
-
if (typeof (dom) === 'string') { dom = document.querySelector(dom) }
|
|
329
|
-
const res = {}
|
|
330
|
-
const getChildren = (pa) => {
|
|
331
|
-
if (!pa || !pa.childNodes) { return }
|
|
332
|
-
for (let i = 0; i < pa.childNodes.length; i++) {
|
|
333
|
-
const el = pa.childNodes[i]
|
|
334
|
-
if (!el.tagName) { return }
|
|
335
|
-
const tag = el.tagName.toLowerCase()
|
|
336
|
-
if (tag === 'input') {
|
|
337
|
-
if (el.type === 'checkbox') {
|
|
338
|
-
res[el.name] = el.checked ? el.value : ''
|
|
339
|
-
continue
|
|
340
|
-
}
|
|
341
|
-
res[el.name] = el.value
|
|
342
|
-
continue
|
|
343
|
-
} else if (tag === 'textarea') {
|
|
344
|
-
res[el.name] = el.value
|
|
345
|
-
} else if (tag === 'select') {
|
|
346
|
-
if (el.selectedIndex >= 0) {
|
|
347
|
-
res[el.name] = el.options[el.selectedIndex].value
|
|
348
|
-
} else {
|
|
349
|
-
res[el.name] = ''
|
|
350
|
-
}
|
|
351
|
-
}
|
|
352
|
-
getChildren(el)
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
getChildren(dom)
|
|
356
|
-
return res
|
|
357
|
-
}
|
|
358
|
-
},
|
|
359
|
-
'テーブル作成': { // @二次元配列AA(あるいは文字列の簡易CSVデータ)からTABLE要素を作成し、DOMオブジェクトを返す // @てーぶるさくせい
|
|
360
|
-
type: 'func',
|
|
361
|
-
josi: [['の', 'から']],
|
|
362
|
-
pure: false,
|
|
363
|
-
fn: function (aa, sys) {
|
|
364
|
-
if (typeof (aa) === 'string') {
|
|
365
|
-
const rr = []
|
|
366
|
-
const rows = aa.split('\n')
|
|
367
|
-
for (const row of rows) { rr.push(row.split(',')) }
|
|
368
|
-
aa = rr
|
|
369
|
-
}
|
|
370
|
-
const bgColor = JSON.parse(JSON.stringify(sys.__v0['DOM部品オプション']['テーブル背景色']))
|
|
371
|
-
for (let i = 0; i < 3; i++) { bgColor.push('') }
|
|
372
|
-
const bgHead = bgColor.shift()
|
|
373
|
-
const table = sys.__exec('DOM部品作成', ['table', sys])
|
|
374
|
-
for (const rowNo in aa) {
|
|
375
|
-
const row = aa[rowNo]
|
|
376
|
-
const tr = document.createElement('tr')
|
|
377
|
-
for (let col of row) {
|
|
378
|
-
col = '' + col
|
|
379
|
-
const td = document.createElement((rowNo === 0) ? 'th' : 'td')
|
|
380
|
-
td.innerHTML = sys.__tohtml(col)
|
|
381
|
-
// 色指定
|
|
382
|
-
if (bgHead !== '') {
|
|
383
|
-
td.style.backgroundColor = (rowNo === 0) ? bgHead : bgColor[rowNo % 2]
|
|
384
|
-
td.style.color = (rowNo === 0) ? 'white' : 'black'
|
|
385
|
-
}
|
|
386
|
-
if (col.match(/^(\+|-)?\d+(\.\d+)?$/)) { // number?
|
|
387
|
-
td.style.textAlign = 'right'
|
|
388
|
-
}
|
|
389
|
-
tr.appendChild(td)
|
|
390
|
-
}
|
|
391
|
-
table.appendChild(tr)
|
|
392
|
-
}
|
|
393
|
-
return table
|
|
394
|
-
}
|
|
395
|
-
}
|
|
396
|
-
}
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
export default {
|
|
3
|
+
// @DOM部品操作
|
|
4
|
+
'DOM親要素': { type: 'const', value: '' }, // @DOMおやようそ
|
|
5
|
+
'DOM部品個数': { type: 'const', value: 0 }, // @DOMせいせいこすう
|
|
6
|
+
'DOM部品オプション': { type: 'const', value: { '自動改行': false, 'テーブル背景色': ['#AA4040', '#ffffff', '#fff0f0'] } }, // @DOMぶひんおぷしょん
|
|
7
|
+
'DOM親要素設定': { // @「ボタン作成」「エディタ作成」など『DOM部品作成』で追加する要素の親要素を指定(デフォルトはdocument)して要素を返す。 // @DOMおやようそせってい
|
|
8
|
+
type: 'func',
|
|
9
|
+
josi: [['に', 'へ']],
|
|
10
|
+
pure: false,
|
|
11
|
+
fn: function (el, sys) {
|
|
12
|
+
if (typeof el === 'string') { el = document.querySelector(el) || document.getElementById(el) }
|
|
13
|
+
sys.__v0['DOM親要素'] = el
|
|
14
|
+
return el
|
|
15
|
+
}
|
|
16
|
+
},
|
|
17
|
+
'DOM親部品設定': { // @ DOM部品作成でDOM要素を追加する親の対象を指定。『DOM親要素設定』と同じ。// @DOMおやぶひんせってい
|
|
18
|
+
type: 'func',
|
|
19
|
+
josi: [['に', 'へ']],
|
|
20
|
+
pure: false,
|
|
21
|
+
fn: function (el, sys) {
|
|
22
|
+
return sys.__exec('DOM親要素設定', [el, sys])
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
'DOMスキン': { type: 'const', value: '' }, // @DOMすきん
|
|
26
|
+
'DOMスキン辞書': { type: 'const', value: {} }, // @DOMすきんじしょ
|
|
27
|
+
'DOMスキン設定': { // @「ボタン作成」「エディタ作成」などで適用するスキンを指定する(#1033) // @DOMすきんせってい
|
|
28
|
+
type: 'func',
|
|
29
|
+
josi: [['を', 'に', 'の']],
|
|
30
|
+
pure: false,
|
|
31
|
+
fn: function (skin, sys) {
|
|
32
|
+
sys.__v0['DOMスキン'] = skin
|
|
33
|
+
},
|
|
34
|
+
return_none: true
|
|
35
|
+
},
|
|
36
|
+
'DOM部品作成': { // @elmの要素を作成して『DOM親要素設定』で指定した要素に追加して、DOMオブジェクトを返す。(elmがDOM要素なら追加する) // @DOMぶひんさくせい
|
|
37
|
+
type: 'func',
|
|
38
|
+
josi: [['の']],
|
|
39
|
+
pure: false,
|
|
40
|
+
fn: function (elm, sys) {
|
|
41
|
+
const parent = sys.__v0['DOM親要素']
|
|
42
|
+
const btn = (typeof (elm) === 'string') ? document.createElement(elm) : elm
|
|
43
|
+
btn.id = 'nadesi-dom-' + sys.__v0['DOM部品個数']
|
|
44
|
+
// スキン適用
|
|
45
|
+
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
46
|
+
if (typeof (func) === 'function') { func(elm, btn, sys) }
|
|
47
|
+
// DOM追加
|
|
48
|
+
parent.appendChild(btn)
|
|
49
|
+
sys.__v0['DOM部品個数']++
|
|
50
|
+
// オプションを適用
|
|
51
|
+
const opt = sys.__v0['DOM部品オプション']
|
|
52
|
+
if (opt['自動改行']) {
|
|
53
|
+
parent.appendChild(document.createElement('br'))
|
|
54
|
+
}
|
|
55
|
+
return btn
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
'ボタン作成': { // @ラベルlabelを持つbutton要素を追加しDOMオブジェクトを返す // @ぼたんさくせい
|
|
59
|
+
type: 'func',
|
|
60
|
+
josi: [['の']],
|
|
61
|
+
pure: false,
|
|
62
|
+
fn: function (label, sys) {
|
|
63
|
+
const btn = sys.__exec('DOM部品作成', ['button', sys])
|
|
64
|
+
btn.innerHTML = label
|
|
65
|
+
return btn
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
'エディタ作成': { // @textの値を持つテキストボックス(input[type='text'])の要素を追加しDOMオブジェクトを返す // @えでぃたさくせい
|
|
69
|
+
type: 'func',
|
|
70
|
+
josi: [['の']],
|
|
71
|
+
pure: false,
|
|
72
|
+
fn: function (text, sys) {
|
|
73
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
74
|
+
inp.type = 'text'
|
|
75
|
+
inp.value = text
|
|
76
|
+
return inp
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
'テキストエリア作成': { // @textの値を持つtextarea要素を追加しDOMオブジェクトを返す // @てきすとえりあさくせい
|
|
80
|
+
type: 'func',
|
|
81
|
+
josi: [['の']],
|
|
82
|
+
pure: false,
|
|
83
|
+
fn: function (text, sys) {
|
|
84
|
+
const te = sys.__exec('DOM部品作成', ['textarea', sys])
|
|
85
|
+
te.value = text
|
|
86
|
+
return te
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
'ラベル作成': { // @textの値を持つラベル(span要素)を追加しDOMオブジェクトを返す // @らべるさくせい
|
|
90
|
+
type: 'func',
|
|
91
|
+
josi: [['の']],
|
|
92
|
+
pure: false,
|
|
93
|
+
fn: function (text, sys) {
|
|
94
|
+
const lbl = sys.__exec('DOM部品作成', ['span', sys])
|
|
95
|
+
lbl.innerHTML = text
|
|
96
|
+
return lbl
|
|
97
|
+
}
|
|
98
|
+
},
|
|
99
|
+
'キャンバス作成': { // @大きさ[幅, 高]のcanvas要素を追加しDOMオブジェクトを返す // @きゃんばすさくせい
|
|
100
|
+
type: 'func',
|
|
101
|
+
josi: [['の']],
|
|
102
|
+
pure: false,
|
|
103
|
+
fn: function (size, sys) {
|
|
104
|
+
const cv = sys.__exec('DOM部品作成', ['canvas', sys])
|
|
105
|
+
cv.width = size[0]
|
|
106
|
+
cv.height = size[1]
|
|
107
|
+
cv.style.width = size[0]
|
|
108
|
+
cv.style.height = size[1]
|
|
109
|
+
// 描画中キャンバスを移動する
|
|
110
|
+
sys.__exec('描画開始', [cv, sys])
|
|
111
|
+
return cv
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
'画像作成': { // @URLを指定してimg要素を追加しDOMオブジェクトを返す // @がぞうさくせい
|
|
115
|
+
type: 'func',
|
|
116
|
+
josi: [['の', 'から']],
|
|
117
|
+
pure: false,
|
|
118
|
+
fn: function (url, sys) {
|
|
119
|
+
const img = sys.__exec('DOM部品作成', ['img', sys])
|
|
120
|
+
img.src = url
|
|
121
|
+
return img
|
|
122
|
+
}
|
|
123
|
+
},
|
|
124
|
+
'改行作成': { // @改行(br要素)を追加しDOMオブジェクトを返す // @かいぎょうさくせい
|
|
125
|
+
type: 'func',
|
|
126
|
+
josi: [],
|
|
127
|
+
pure: false,
|
|
128
|
+
fn: function (sys) {
|
|
129
|
+
const br = sys.__exec('DOM部品作成', ['br', sys])
|
|
130
|
+
return br
|
|
131
|
+
}
|
|
132
|
+
},
|
|
133
|
+
'チェックボックス作成': { // @textのラベルを持つチェックボックス(input[type='checkbox'])要素を追加しDOMオブジェクトを返す // @ちぇっくぼっくすさくせい
|
|
134
|
+
type: 'func',
|
|
135
|
+
josi: [['の']],
|
|
136
|
+
pure: false,
|
|
137
|
+
fn: function (text, sys) {
|
|
138
|
+
// チェックボックスは、<span><input><label></span>で成り立つように構築
|
|
139
|
+
const span = document.createElement('span')
|
|
140
|
+
const inp = document.createElement('input')
|
|
141
|
+
inp.type = 'checkbox'
|
|
142
|
+
inp.id = 'nadesi-dom-' + sys.__v0['DOM部品個数']
|
|
143
|
+
sys.__v0['DOM部品個数']++
|
|
144
|
+
const label = document.createElement('label')
|
|
145
|
+
label.innerHTML = text
|
|
146
|
+
label.htmlFor = inp.id
|
|
147
|
+
span.appendChild(inp)
|
|
148
|
+
span.appendChild(label)
|
|
149
|
+
// 親部品に追加
|
|
150
|
+
sys.__exec('DOM部品作成', [span, sys])
|
|
151
|
+
return inp
|
|
152
|
+
}
|
|
153
|
+
},
|
|
154
|
+
'セレクトボックス作成': { // @配列optionsの選択肢を持つselect要素を追加しDOMオブジェクトを返す // @せれくとぼっくすさくせい
|
|
155
|
+
type: 'func',
|
|
156
|
+
josi: [['の']],
|
|
157
|
+
pure: false,
|
|
158
|
+
fn: function (options, sys) {
|
|
159
|
+
const dom = document.createElement('select')
|
|
160
|
+
for (let i = 0; i < options.length; i++) {
|
|
161
|
+
const item = document.createElement('option')
|
|
162
|
+
item.value = options[i]
|
|
163
|
+
item.appendChild(document.createTextNode(options[i]))
|
|
164
|
+
dom.appendChild(item)
|
|
165
|
+
}
|
|
166
|
+
// 親部品に追加
|
|
167
|
+
const obj = sys.__exec('DOM部品作成', [dom, sys])
|
|
168
|
+
return dom
|
|
169
|
+
}
|
|
170
|
+
},
|
|
171
|
+
'セレクトボックスアイテム設定': { // @配列データをセレクトボックスdomのアイテムに差し替える // @せれくとぼっくすあいてむさくせい
|
|
172
|
+
type: 'func',
|
|
173
|
+
josi: [['を'], ['へ', 'に']],
|
|
174
|
+
pure: false,
|
|
175
|
+
fn: function (options, dom, sys) {
|
|
176
|
+
if (typeof dom === 'string') { dom = document.querySelector(dom) }
|
|
177
|
+
// 既存のoptionsをクリア
|
|
178
|
+
dom.options.length = 0
|
|
179
|
+
// アイテムを追加
|
|
180
|
+
for (let i = 0; i < options.length; i++) {
|
|
181
|
+
const item = document.createElement('option')
|
|
182
|
+
item.value = options[i]
|
|
183
|
+
item.appendChild(document.createTextNode(options[i]))
|
|
184
|
+
dom.appendChild(item)
|
|
185
|
+
}
|
|
186
|
+
},
|
|
187
|
+
return_none: true
|
|
188
|
+
},
|
|
189
|
+
'色選択ボックス作成': { // @色選択ボックス(input[type='color'])を作成しDOMオブジェクトを返す // @いろせんたくぼっくすさくせい
|
|
190
|
+
type: 'func',
|
|
191
|
+
josi: [],
|
|
192
|
+
pure: false,
|
|
193
|
+
fn: function (sys) {
|
|
194
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
195
|
+
inp.type = 'color'
|
|
196
|
+
return inp
|
|
197
|
+
}
|
|
198
|
+
},
|
|
199
|
+
'日付選択ボックス作成': { // @日付選択ボックス(input[type='date'])を作成しDOMオブジェクトを返す // @ひづけせんたくぼっくすさくせい
|
|
200
|
+
type: 'func',
|
|
201
|
+
josi: [],
|
|
202
|
+
pure: false,
|
|
203
|
+
fn: function (sys) {
|
|
204
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
205
|
+
inp.type = 'date'
|
|
206
|
+
return inp
|
|
207
|
+
}
|
|
208
|
+
},
|
|
209
|
+
'パスワード入力エディタ作成': { // @パスワード入力エディタ(input[type='password'])を作成し初期値Sを設定し、DOMオブジェクトを返す // @ぱすわーどにゅうりょくさくせい
|
|
210
|
+
type: 'func',
|
|
211
|
+
josi: [['の', 'で']],
|
|
212
|
+
pure: false,
|
|
213
|
+
fn: function (s, sys) {
|
|
214
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
215
|
+
inp.type = 'password'
|
|
216
|
+
inp.value = s
|
|
217
|
+
return inp
|
|
218
|
+
}
|
|
219
|
+
},
|
|
220
|
+
'値指定バー作成': { // @範囲RANGE(配列で[最小,最大[,値]])を指定するバー(input[type='range'])を作成しDOMオブジェクトを返す // @ぱすわーどにゅうりょくさくせい
|
|
221
|
+
type: 'func',
|
|
222
|
+
josi: [['の', 'で']],
|
|
223
|
+
pure: false,
|
|
224
|
+
fn: function (range, sys) {
|
|
225
|
+
if (!(range instanceof Array) || range.length < 2) {
|
|
226
|
+
range = [0, 100, 50]
|
|
227
|
+
}
|
|
228
|
+
if (range.length <= 2) { // 3つ目を省略したとき
|
|
229
|
+
range.push(Math.floor((range[1] - range[0]) / 2))
|
|
230
|
+
}
|
|
231
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
232
|
+
inp.type = 'range'
|
|
233
|
+
inp.min = range[0]
|
|
234
|
+
inp.max = range[1]
|
|
235
|
+
inp.value = range[2]
|
|
236
|
+
return inp
|
|
237
|
+
}
|
|
238
|
+
},
|
|
239
|
+
'送信ボタン作成': { // @ラベルSの送信ボタン(input[type='submit'])を作成しDOMオブジェクトを返す // @そうしんぼたんさくせい
|
|
240
|
+
type: 'func',
|
|
241
|
+
josi: [['の']],
|
|
242
|
+
pure: false,
|
|
243
|
+
fn: function (label, sys) {
|
|
244
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
245
|
+
inp.type = 'submit'
|
|
246
|
+
inp.value = label
|
|
247
|
+
return inp
|
|
248
|
+
}
|
|
249
|
+
},
|
|
250
|
+
'フォーム作成': { // @属性OBJ{method:"GET",action:"..."}で項目一覧S「a=初期値{改行}b=初期値{改行}色=?c#fff0f0{改行}=?送信」を送信フォームを作成しDOMオブジェクトを返す // @ふぉーむさくせい
|
|
251
|
+
type: 'func',
|
|
252
|
+
josi: [['で', 'の'], ['を']],
|
|
253
|
+
pure: false,
|
|
254
|
+
fn: function (obj, s, sys) {
|
|
255
|
+
const frm = sys.__exec('DOM部品作成', ['form', sys])
|
|
256
|
+
// 可能ならformにobjの値を移し替える
|
|
257
|
+
if (obj instanceof Object) {
|
|
258
|
+
for (const key in obj) {
|
|
259
|
+
if (frm[key]) { frm[key] = obj[key] }
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
// 入力項目をtableで作る
|
|
263
|
+
const rows = s.split('\n')
|
|
264
|
+
const table = document.createElement('table')
|
|
265
|
+
for (const rowIndex in rows) {
|
|
266
|
+
let row = '' + (rows[rowIndex])
|
|
267
|
+
if (row === '') { continue }
|
|
268
|
+
if (row.indexOf('=') < 0) { row += '=' }
|
|
269
|
+
const cols = row.split('=')
|
|
270
|
+
const key = cols[0]
|
|
271
|
+
const val = cols[1]
|
|
272
|
+
// key
|
|
273
|
+
const th = document.createElement('th')
|
|
274
|
+
th.innerHTML = sys.__tohtmlQ(key)
|
|
275
|
+
// val
|
|
276
|
+
const td = document.createElement('td')
|
|
277
|
+
if (val.substring(0, 2) === '?(') {
|
|
278
|
+
// select box
|
|
279
|
+
const it = val.substring(2) + ')'
|
|
280
|
+
const ita = it.split(')')
|
|
281
|
+
const its = ita[0]
|
|
282
|
+
const def = ita[1]
|
|
283
|
+
const items = its.split('|')
|
|
284
|
+
const select = document.createElement('select')
|
|
285
|
+
select.name = key
|
|
286
|
+
for (const it of items) {
|
|
287
|
+
const option = document.createElement('option')
|
|
288
|
+
option.value = it
|
|
289
|
+
option.text = it
|
|
290
|
+
select.appendChild(option)
|
|
291
|
+
}
|
|
292
|
+
const idx = items.indexOf(def)
|
|
293
|
+
if (idx >= 0) { select.selectedIndex = idx }
|
|
294
|
+
td.appendChild(select)
|
|
295
|
+
} else {
|
|
296
|
+
// input element
|
|
297
|
+
const inp = document.createElement('input')
|
|
298
|
+
td.appendChild(inp)
|
|
299
|
+
inp.id = 'nako3form_' + key
|
|
300
|
+
if (val === '?送信' || val === '?submit') {
|
|
301
|
+
inp.type = 'submit'
|
|
302
|
+
inp.value = val.substring(1)
|
|
303
|
+
if (key !== '') { inp.name = key }
|
|
304
|
+
} else if (val.substring(0, 2) === '?c') {
|
|
305
|
+
inp.type = 'color'
|
|
306
|
+
inp.value = val.substring(2)
|
|
307
|
+
inp.name = key
|
|
308
|
+
} else {
|
|
309
|
+
inp.type = 'text'
|
|
310
|
+
inp.value = val
|
|
311
|
+
inp.name = key
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
const tr = document.createElement('tr')
|
|
315
|
+
tr.appendChild(th)
|
|
316
|
+
tr.appendChild(td)
|
|
317
|
+
table.appendChild(tr)
|
|
318
|
+
}
|
|
319
|
+
frm.appendChild(table)
|
|
320
|
+
return frm
|
|
321
|
+
}
|
|
322
|
+
},
|
|
323
|
+
'フォーム入力一括取得': { // @DOMのフォームを取得し、そのフォーム以下にある入力項目のnameとvalueを辞書形式で返す // @ふぉーむにゅうりょくいっかつしゅとく
|
|
324
|
+
type: 'func',
|
|
325
|
+
josi: [['の', 'から']],
|
|
326
|
+
pure: true,
|
|
327
|
+
fn: function (dom) {
|
|
328
|
+
if (typeof (dom) === 'string') { dom = document.querySelector(dom) }
|
|
329
|
+
const res = {}
|
|
330
|
+
const getChildren = (pa) => {
|
|
331
|
+
if (!pa || !pa.childNodes) { return }
|
|
332
|
+
for (let i = 0; i < pa.childNodes.length; i++) {
|
|
333
|
+
const el = pa.childNodes[i]
|
|
334
|
+
if (!el.tagName) { return }
|
|
335
|
+
const tag = el.tagName.toLowerCase()
|
|
336
|
+
if (tag === 'input') {
|
|
337
|
+
if (el.type === 'checkbox') {
|
|
338
|
+
res[el.name] = el.checked ? el.value : ''
|
|
339
|
+
continue
|
|
340
|
+
}
|
|
341
|
+
res[el.name] = el.value
|
|
342
|
+
continue
|
|
343
|
+
} else if (tag === 'textarea') {
|
|
344
|
+
res[el.name] = el.value
|
|
345
|
+
} else if (tag === 'select') {
|
|
346
|
+
if (el.selectedIndex >= 0) {
|
|
347
|
+
res[el.name] = el.options[el.selectedIndex].value
|
|
348
|
+
} else {
|
|
349
|
+
res[el.name] = ''
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
getChildren(el)
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
getChildren(dom)
|
|
356
|
+
return res
|
|
357
|
+
}
|
|
358
|
+
},
|
|
359
|
+
'テーブル作成': { // @二次元配列AA(あるいは文字列の簡易CSVデータ)からTABLE要素を作成し、DOMオブジェクトを返す // @てーぶるさくせい
|
|
360
|
+
type: 'func',
|
|
361
|
+
josi: [['の', 'から']],
|
|
362
|
+
pure: false,
|
|
363
|
+
fn: function (aa, sys) {
|
|
364
|
+
if (typeof (aa) === 'string') {
|
|
365
|
+
const rr = []
|
|
366
|
+
const rows = aa.split('\n')
|
|
367
|
+
for (const row of rows) { rr.push(row.split(',')) }
|
|
368
|
+
aa = rr
|
|
369
|
+
}
|
|
370
|
+
const bgColor = JSON.parse(JSON.stringify(sys.__v0['DOM部品オプション']['テーブル背景色']))
|
|
371
|
+
for (let i = 0; i < 3; i++) { bgColor.push('') }
|
|
372
|
+
const bgHead = bgColor.shift()
|
|
373
|
+
const table = sys.__exec('DOM部品作成', ['table', sys])
|
|
374
|
+
for (const rowNo in aa) {
|
|
375
|
+
const row = aa[rowNo]
|
|
376
|
+
const tr = document.createElement('tr')
|
|
377
|
+
for (let col of row) {
|
|
378
|
+
col = '' + col
|
|
379
|
+
const td = document.createElement((rowNo === 0) ? 'th' : 'td')
|
|
380
|
+
td.innerHTML = sys.__tohtml(col)
|
|
381
|
+
// 色指定
|
|
382
|
+
if (bgHead !== '') {
|
|
383
|
+
td.style.backgroundColor = (rowNo === 0) ? bgHead : bgColor[rowNo % 2]
|
|
384
|
+
td.style.color = (rowNo === 0) ? 'white' : 'black'
|
|
385
|
+
}
|
|
386
|
+
if (col.match(/^(\+|-)?\d+(\.\d+)?$/)) { // number?
|
|
387
|
+
td.style.textAlign = 'right'
|
|
388
|
+
}
|
|
389
|
+
tr.appendChild(td)
|
|
390
|
+
}
|
|
391
|
+
table.appendChild(tr)
|
|
392
|
+
}
|
|
393
|
+
return table
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
}
|