nadesiko3 3.2.28 → 3.2.32
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/demo/index.html +0 -1
- package/package.json +5 -4
- package/release/_hash.txt +24 -24
- package/release/_script-tags.txt +13 -13
- 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 +1 -1
- package/release/stats.json +1 -1
- package/release/version.js +1 -1
- package/release/wnako3.js +1 -1
- package/release/wnako3webworker.js +1 -1
- package/release/wnako3webworker.js.LICENSE.txt +164 -0
- package/src/nako3.js +1 -0
- package/src/nako_gen_async.js +97 -10
- package/src/nako_parser3.js +4 -2
- package/src/nako_version.js +2 -2
- package/src/plugin_browser.js +14 -0
- package/src/plugin_browser_ajax.js +4 -3
- package/src/plugin_browser_dom_parts.js +194 -73
- package/src/plugin_node.js +2 -2
- package/src/plugin_system.js +414 -19
- package/test/common/plugin_system_test.js +131 -0
|
@@ -2,8 +2,9 @@
|
|
|
2
2
|
module.exports = {
|
|
3
3
|
// @DOM部品操作
|
|
4
4
|
'DOM親要素': { type: 'const', value: '' }, // @DOMおやようそ
|
|
5
|
-
'DOM
|
|
6
|
-
'DOM
|
|
5
|
+
'DOM部品個数': { type: 'const', value: 0 }, // @DOMせいせいこすう
|
|
6
|
+
'DOM部品オプション': { type: 'const', value: {'自動改行': false, 'テーブル背景色': ['#AA4040', '#ffffff','#fff0f0']} }, // @DOMぶひんおぷしょん
|
|
7
|
+
'DOM親要素設定': { // @「ボタン作成」「エディタ作成」など『DOM部品作成』で追加する要素の親要素を指定(デフォルトはdocument)して要素を返す。 // @DOMおやようそせってい
|
|
7
8
|
type: 'func',
|
|
8
9
|
josi: [['に', 'へ']],
|
|
9
10
|
pure: false,
|
|
@@ -13,23 +14,45 @@ module.exports = {
|
|
|
13
14
|
return el
|
|
14
15
|
}
|
|
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
|
+
},
|
|
16
25
|
'DOMスキン': { type: 'const', value: '' }, // @DOMすきん
|
|
17
26
|
'DOMスキン辞書': { type: 'const', value: {} }, // @DOMすきんじしょ
|
|
18
|
-
'
|
|
27
|
+
'DOM部品作成': { // @elmの要素を作成して『DOM親要素設定』で指定した要素に追加して、DOMオブジェクトを返す。(elmがDOM要素なら追加する) // @DOMぶひんさくせい
|
|
19
28
|
type: 'func',
|
|
20
29
|
josi: [['の']],
|
|
21
30
|
pure: false,
|
|
22
|
-
fn: function (
|
|
31
|
+
fn: function (elm, sys) {
|
|
23
32
|
const parent = sys.__v0['DOM親要素']
|
|
24
|
-
const btn = document.createElement(
|
|
25
|
-
btn.
|
|
26
|
-
btn.id = 'nadesi-dom-' + sys.__v0['DOM生成個数']
|
|
33
|
+
const btn = (typeof(elm) === 'string') ? document.createElement(elm) : elm
|
|
34
|
+
btn.id = 'nadesi-dom-' + sys.__v0['DOM部品個数']
|
|
27
35
|
// スキン適用
|
|
28
36
|
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
29
|
-
if (typeof (func) === 'function') { func(
|
|
37
|
+
if (typeof (func) === 'function') { func(elm, btn, sys) }
|
|
30
38
|
// DOM追加
|
|
31
39
|
parent.appendChild(btn)
|
|
32
|
-
sys.__v0['DOM
|
|
40
|
+
sys.__v0['DOM部品個数']++
|
|
41
|
+
// オプションを適用
|
|
42
|
+
const opt = sys.__v0['DOM部品オプション']
|
|
43
|
+
if (opt['自動改行']) {
|
|
44
|
+
parent.appendChild(document.createElement('br'));
|
|
45
|
+
}
|
|
46
|
+
return btn
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
'ボタン作成': { // @ラベルlabelを持つbutton要素を追加しDOMオブジェクトを返す // @ぼたんさくせい
|
|
50
|
+
type: 'func',
|
|
51
|
+
josi: [['の']],
|
|
52
|
+
pure: false,
|
|
53
|
+
fn: function (label, sys) {
|
|
54
|
+
const btn = sys.__exec('DOM部品作成', ['button', sys])
|
|
55
|
+
btn.innerHTML = label
|
|
33
56
|
return btn
|
|
34
57
|
}
|
|
35
58
|
},
|
|
@@ -38,17 +61,9 @@ module.exports = {
|
|
|
38
61
|
josi: [['の']],
|
|
39
62
|
pure: false,
|
|
40
63
|
fn: function (text, sys) {
|
|
41
|
-
const
|
|
42
|
-
const inp = document.createElement('input')
|
|
64
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
43
65
|
inp.type = 'text'
|
|
44
66
|
inp.value = text
|
|
45
|
-
inp.id = 'nadesi-dom-' + sys.__v0['DOM生成個数']
|
|
46
|
-
// スキン適用
|
|
47
|
-
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
48
|
-
if (typeof (func) === 'function') { func('エディタ作成', inp, sys) }
|
|
49
|
-
// DOM追加
|
|
50
|
-
parent.appendChild(inp)
|
|
51
|
-
sys.__v0['DOM生成個数']++
|
|
52
67
|
return inp
|
|
53
68
|
}
|
|
54
69
|
},
|
|
@@ -57,16 +72,8 @@ module.exports = {
|
|
|
57
72
|
josi: [['の']],
|
|
58
73
|
pure: false,
|
|
59
74
|
fn: function (text, sys) {
|
|
60
|
-
const
|
|
61
|
-
const te = document.createElement('textarea')
|
|
75
|
+
const te = sys.__exec('DOM部品作成', ['textarea', sys])
|
|
62
76
|
te.value = text
|
|
63
|
-
te.id = 'nadesi-dom-' + sys.__v0['DOM生成個数']
|
|
64
|
-
// スキン適用
|
|
65
|
-
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
66
|
-
if (typeof (func) === 'function') { func('テキストエリア作成', te, sys) }
|
|
67
|
-
// DOM追加
|
|
68
|
-
parent.appendChild(te)
|
|
69
|
-
sys.__v0['DOM生成個数']++
|
|
70
77
|
return te
|
|
71
78
|
}
|
|
72
79
|
},
|
|
@@ -75,17 +82,9 @@ module.exports = {
|
|
|
75
82
|
josi: [['の']],
|
|
76
83
|
pure: false,
|
|
77
84
|
fn: function (text, sys) {
|
|
78
|
-
const
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
te.id = 'nadesi-dom-' + sys.__v0['DOM生成個数']
|
|
82
|
-
// スキン適用
|
|
83
|
-
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
84
|
-
if (typeof (func) === 'function') { func('ラベル作成', te, sys) }
|
|
85
|
-
// DOM追加
|
|
86
|
-
parent.appendChild(te)
|
|
87
|
-
sys.__v0['DOM生成個数']++
|
|
88
|
-
return te
|
|
85
|
+
const lbl = sys.__exec('DOM部品作成', ['span', sys])
|
|
86
|
+
lbl.innerHTML = text
|
|
87
|
+
return lbl
|
|
89
88
|
}
|
|
90
89
|
},
|
|
91
90
|
'キャンバス作成': { // @大きさ[幅, 高]のcanvas要素を追加しDOMオブジェクトを返す // @きゃんばすさくせい
|
|
@@ -93,40 +92,33 @@ module.exports = {
|
|
|
93
92
|
josi: [['の']],
|
|
94
93
|
pure: false,
|
|
95
94
|
fn: function (size, sys) {
|
|
96
|
-
const
|
|
97
|
-
const cv = document.createElement('canvas')
|
|
95
|
+
const cv = sys.__exec('DOM部品作成', ['canvas', sys])
|
|
98
96
|
cv.width = size[0]
|
|
99
97
|
cv.height = size[1]
|
|
100
98
|
cv.style.width = size[0]
|
|
101
99
|
cv.style.height = size[1]
|
|
102
|
-
cv.id = 'nadesi-dom-' + sys.__v0['DOM生成個数']
|
|
103
|
-
// スキン適用
|
|
104
|
-
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
105
|
-
if (typeof (func) === 'function') { func('キャンバス作成', cv, sys) }
|
|
106
|
-
// DOM追加
|
|
107
|
-
parent.appendChild(cv)
|
|
108
|
-
sys.__v0['DOM生成個数']++
|
|
109
100
|
// 描画中キャンバスを移動する
|
|
110
101
|
sys.__exec('描画開始', [cv, sys])
|
|
111
|
-
console.log(cv)
|
|
112
102
|
return cv
|
|
113
103
|
}
|
|
114
104
|
},
|
|
105
|
+
'画像作成': { // @URLを指定してimg要素を追加しDOMオブジェクトを返す // @がぞうさくせい
|
|
106
|
+
type: 'func',
|
|
107
|
+
josi: [['の', 'から']],
|
|
108
|
+
pure: false,
|
|
109
|
+
fn: function (url, sys) {
|
|
110
|
+
const img = sys.__exec('DOM部品作成', ['img', sys])
|
|
111
|
+
img.src = url
|
|
112
|
+
return img
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
115
|
'改行作成': { // @改行(br要素)を追加しDOMオブジェクトを返す // @かいぎょうさくせい
|
|
116
116
|
type: 'func',
|
|
117
117
|
josi: [],
|
|
118
118
|
pure: false,
|
|
119
119
|
fn: function (sys) {
|
|
120
|
-
const
|
|
121
|
-
|
|
122
|
-
te.id = 'nadesi-dom-' + sys.__v0['DOM生成個数']
|
|
123
|
-
// スキン適用
|
|
124
|
-
const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
|
|
125
|
-
if (typeof (func) === 'function') { func('改行作成', te, sys) }
|
|
126
|
-
// DOM追加
|
|
127
|
-
parent.appendChild(te)
|
|
128
|
-
sys.__v0['DOM生成個数']++
|
|
129
|
-
return te
|
|
120
|
+
const br = sys.__exec('DOM部品作成', ['br', sys])
|
|
121
|
+
return br
|
|
130
122
|
}
|
|
131
123
|
},
|
|
132
124
|
'チェックボックス作成': { // @textのラベルを持つチェックボックス(input[type='checkbox'])要素を追加しDOMオブジェクトを返す // @ちぇっくぼっくすさくせい
|
|
@@ -134,22 +126,19 @@ module.exports = {
|
|
|
134
126
|
josi: [['の']],
|
|
135
127
|
pure: false,
|
|
136
128
|
fn: function (text, sys) {
|
|
137
|
-
|
|
129
|
+
// チェックボックスは、<span><input><label></span>で成り立つように構築
|
|
138
130
|
const span = document.createElement('span')
|
|
139
131
|
const inp = document.createElement('input')
|
|
140
132
|
inp.type = 'checkbox'
|
|
141
|
-
inp.id = 'nadesi-dom-' + sys.__v0['DOM
|
|
133
|
+
inp.id = 'nadesi-dom-' + sys.__v0['DOM部品個数']
|
|
134
|
+
sys.__v0['DOM部品個数']++
|
|
142
135
|
const label = document.createElement('label')
|
|
143
136
|
label.innerHTML = text
|
|
144
137
|
label.htmlFor = inp.id
|
|
145
138
|
span.appendChild(inp)
|
|
146
139
|
span.appendChild(label)
|
|
147
|
-
//
|
|
148
|
-
|
|
149
|
-
if (typeof (func) === 'function') { func('チェックボックス作成', span, sys) }
|
|
150
|
-
// DOM追加
|
|
151
|
-
parent.appendChild(span)
|
|
152
|
-
sys.__v0['DOM生成個数']++
|
|
140
|
+
// 親部品に追加
|
|
141
|
+
sys.__exec('DOM部品作成', [span, sys])
|
|
153
142
|
return inp
|
|
154
143
|
}
|
|
155
144
|
},
|
|
@@ -158,23 +147,155 @@ module.exports = {
|
|
|
158
147
|
josi: [['の']],
|
|
159
148
|
pure: false,
|
|
160
149
|
fn: function (options, sys) {
|
|
161
|
-
const parent = sys.__v0['DOM親要素']
|
|
162
150
|
const dom = document.createElement('select')
|
|
163
|
-
dom.id = 'nadesi-dom-' + (sys.__v0['DOM生成個数']++)
|
|
164
151
|
for (let i = 0; i < options.length; i++) {
|
|
165
152
|
const item = document.createElement('option')
|
|
166
153
|
item.value = options[i]
|
|
167
154
|
item.appendChild(document.createTextNode(options[i]))
|
|
168
155
|
dom.appendChild(item)
|
|
169
156
|
}
|
|
170
|
-
//
|
|
171
|
-
const
|
|
172
|
-
if (typeof (func) === 'function') { func('セレクトボックス作成', dom, sys) }
|
|
173
|
-
// DOM追加
|
|
174
|
-
parent.appendChild(dom)
|
|
157
|
+
// 親部品に追加
|
|
158
|
+
const obj = sys.__exec('DOM部品作成', [dom, sys])
|
|
175
159
|
return dom
|
|
176
160
|
}
|
|
177
161
|
},
|
|
162
|
+
'色選択ボックス作成': { // @色選択ボックス(input[type='color'])を作成しDOMオブジェクトを返す // @いろせんたくぼっくすさくせい
|
|
163
|
+
type: 'func',
|
|
164
|
+
josi: [],
|
|
165
|
+
pure: false,
|
|
166
|
+
fn: function (sys) {
|
|
167
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
168
|
+
inp.type = 'color'
|
|
169
|
+
return inp
|
|
170
|
+
}
|
|
171
|
+
},
|
|
172
|
+
'日付選択ボックス作成': { // @日付選択ボックス(input[type='date'])を作成しDOMオブジェクトを返す // @ひづけせんたくぼっくすさくせい
|
|
173
|
+
type: 'func',
|
|
174
|
+
josi: [],
|
|
175
|
+
pure: false,
|
|
176
|
+
fn: function (sys) {
|
|
177
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
178
|
+
inp.type = 'date'
|
|
179
|
+
return inp
|
|
180
|
+
}
|
|
181
|
+
},
|
|
182
|
+
'パスワード入力エディタ作成': { // @パスワード入力エディタ(input[type='password'])を作成しDOMオブジェクトを返す // @ぱすわーどにゅうりょくさくせい
|
|
183
|
+
type: 'func',
|
|
184
|
+
josi: [],
|
|
185
|
+
pure: false,
|
|
186
|
+
fn: function (sys) {
|
|
187
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
188
|
+
inp.type = 'date'
|
|
189
|
+
return inp
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
'値指定バー作成': { // @範囲RANGE(配列で[最小,最大[,値]])を指定するバー(input[type='range'])を作成しDOMオブジェクトを返す // @ぱすわーどにゅうりょくさくせい
|
|
193
|
+
type: 'func',
|
|
194
|
+
josi: [['の','で']],
|
|
195
|
+
pure: false,
|
|
196
|
+
fn: function (range, sys) {
|
|
197
|
+
if (!(range instanceof Array) || range.length < 2) {
|
|
198
|
+
range = [0, 100, 50]
|
|
199
|
+
}
|
|
200
|
+
if (range.length <= 2) { // 3つ目を省略したとき
|
|
201
|
+
range.push(Math.floor((range[1] - range[0]) / 2))
|
|
202
|
+
}
|
|
203
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
204
|
+
inp.type = 'range'
|
|
205
|
+
inp.min = range[0]
|
|
206
|
+
inp.max = range[1]
|
|
207
|
+
inp.value = range[2]
|
|
208
|
+
return inp
|
|
209
|
+
}
|
|
210
|
+
},
|
|
211
|
+
'送信ボタン作成': { // @ラベルSの送信ボタン(input[type='submit'])を作成しDOMオブジェクトを返す // @そうしんぼたんさくせい
|
|
212
|
+
type: 'func',
|
|
213
|
+
josi: [['の']],
|
|
214
|
+
pure: false,
|
|
215
|
+
fn: function (label, sys) {
|
|
216
|
+
const inp = sys.__exec('DOM部品作成', ['input', sys])
|
|
217
|
+
inp.type = 'submit'
|
|
218
|
+
inp.value = label
|
|
219
|
+
return inp
|
|
220
|
+
}
|
|
221
|
+
},
|
|
222
|
+
'フォーム作成': { // @属性OBJ{method:"GET",action:"..."}で項目一覧S「a=初期値{改行}b=初期値{改行}=?送信」を送信フォームを作成しDOMオブジェクトを返す // @ふぉーむさくせい
|
|
223
|
+
type: 'func',
|
|
224
|
+
josi: [['で','の'],['を']],
|
|
225
|
+
pure: false,
|
|
226
|
+
fn: function (obj, s, sys) {
|
|
227
|
+
const frm = sys.__exec('DOM部品作成', ['form', sys])
|
|
228
|
+
for (let key in obj) {
|
|
229
|
+
if (frm[key]) { frm[key] = obj[key] }
|
|
230
|
+
}
|
|
231
|
+
const rows = s.split('\n')
|
|
232
|
+
const table = document.createElement('table')
|
|
233
|
+
for (let rowIndex in rows) {
|
|
234
|
+
let row = '' + (rows[rowIndex])
|
|
235
|
+
if (row === '') {continue}
|
|
236
|
+
if (row.indexOf('=') < 0) { row += '=' }
|
|
237
|
+
const cols = row.split('=')
|
|
238
|
+
const key = cols[0]
|
|
239
|
+
const val = cols[1]
|
|
240
|
+
// key
|
|
241
|
+
const th = document.createElement('th')
|
|
242
|
+
th.innerHTML = sys.__tohtmlQ(key)
|
|
243
|
+
// val
|
|
244
|
+
const td = document.createElement('td')
|
|
245
|
+
const inp = document.createElement('input')
|
|
246
|
+
td.appendChild(inp)
|
|
247
|
+
inp.id = 'nako3form_' + key
|
|
248
|
+
if (val === '?送信' || val === '?submit') {
|
|
249
|
+
inp.type = 'submit'
|
|
250
|
+
inp.value = val.substring(1)
|
|
251
|
+
} else {
|
|
252
|
+
inp.type = 'text'
|
|
253
|
+
inp.value = val
|
|
254
|
+
inp.name = key
|
|
255
|
+
}
|
|
256
|
+
const tr = document.createElement('tr')
|
|
257
|
+
tr.appendChild(th)
|
|
258
|
+
tr.appendChild(td)
|
|
259
|
+
table.appendChild(tr)
|
|
260
|
+
}
|
|
261
|
+
frm.appendChild(table)
|
|
262
|
+
return frm
|
|
263
|
+
}
|
|
264
|
+
},
|
|
265
|
+
'テーブル作成': { // @二次元配列AA(あるいは文字列の簡易CSVデータ)からTABLE要素を作成し、DOMオブジェクトを返す // @てーぶるさくせい
|
|
266
|
+
type: 'func',
|
|
267
|
+
josi: [['の', 'から']],
|
|
268
|
+
pure: false,
|
|
269
|
+
fn: function (aa, sys) {
|
|
270
|
+
if (typeof(aa) === 'string') {
|
|
271
|
+
const rr = []
|
|
272
|
+
const rows = aa.split('\n')
|
|
273
|
+
for (let row of rows) { rr.push(row.split(',')) }
|
|
274
|
+
aa = rr
|
|
275
|
+
}
|
|
276
|
+
const bgColor = JSON.parse(JSON.stringify(sys.__v0['DOM部品オプション']['テーブル背景色']))
|
|
277
|
+
const bgHead = bgColor.shift()
|
|
278
|
+
const table = sys.__exec('DOM部品作成', ['table', sys])
|
|
279
|
+
for (let rowNo in aa) {
|
|
280
|
+
const row = aa[rowNo]
|
|
281
|
+
const tr = document.createElement('tr')
|
|
282
|
+
tr.style.backgroundColor = (rowNo == 0) ? bgHead : bgColor[rowNo % 2]
|
|
283
|
+
tr.style.color = (rowNo == 0) ? 'white' : 'black'
|
|
284
|
+
for (let col of row) {
|
|
285
|
+
col = '' + col
|
|
286
|
+
const td = document.createElement((rowNo == 0) ? 'th' : 'td')
|
|
287
|
+
td.innerHTML = sys.__tohtml(col)
|
|
288
|
+
if (col.match(/^\d+$/)) { // number?
|
|
289
|
+
td.style.textAlign = 'right'
|
|
290
|
+
}
|
|
291
|
+
tr.appendChild(td)
|
|
292
|
+
}
|
|
293
|
+
table.appendChild(tr)
|
|
294
|
+
}
|
|
295
|
+
sys.__exec('DOM親要素設定', [table, sys])
|
|
296
|
+
return table
|
|
297
|
+
}
|
|
298
|
+
},
|
|
178
299
|
'DOMスキン設定': { // @「ボタン作成」「エディタ作成」などで適用するスキンを指定する(#1033) // @DOMすきんせってい
|
|
179
300
|
type: 'func',
|
|
180
301
|
josi: [['を', 'に', 'の']],
|
package/src/plugin_node.js
CHANGED
|
@@ -882,7 +882,7 @@ const PluginNode = {
|
|
|
882
882
|
if (sys.__genMode !== '非同期モード') {
|
|
883
883
|
throw new Error('『AJAX受信』を使うには、プログラムの冒頭で「!非同期モード」と宣言してください。')
|
|
884
884
|
}
|
|
885
|
-
|
|
885
|
+
const sysenv = sys.setAsync(sys)
|
|
886
886
|
let options = sys.__v0['AJAXオプション']
|
|
887
887
|
if (options === '') { options = { method: 'GET' } }
|
|
888
888
|
// fetch 実行
|
|
@@ -894,7 +894,7 @@ const PluginNode = {
|
|
|
894
894
|
}
|
|
895
895
|
}).then(text => {
|
|
896
896
|
sys.__v0['対象'] = text
|
|
897
|
-
sys.
|
|
897
|
+
sys.compAsync(sys, sysenv)
|
|
898
898
|
}).catch(err => {
|
|
899
899
|
console.error('[AJAX受信のエラー]', err)
|
|
900
900
|
sys.__errorAsync(err, sys)
|