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.
@@ -2,8 +2,9 @@
2
2
  module.exports = {
3
3
  // @DOM部品操作
4
4
  'DOM親要素': { type: 'const', value: '' }, // @DOMおやようそ
5
- 'DOM生成個数': { type: 'const', value: 0 }, // @DOMせいせいこすう
6
- 'DOM親要素設定': { // @「ボタン作成」「エディタ作成」などのDOM要素を追加する対象を指定(デフォルトはdocument)して親要素のDOMオブジェクトを返す // @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
- 'ボタン作成': { // @ラベルlabelを持つbutton要素を追加しDOMオブジェクトを返す // @ぼたんさくせい
27
+ 'DOM部品作成': { // @elmの要素を作成して『DOM親要素設定』で指定した要素に追加して、DOMオブジェクトを返す。(elmがDOM要素なら追加する) // @DOMぶひんさくせい
19
28
  type: 'func',
20
29
  josi: [['の']],
21
30
  pure: false,
22
- fn: function (label, sys) {
31
+ fn: function (elm, sys) {
23
32
  const parent = sys.__v0['DOM親要素']
24
- const btn = document.createElement('button')
25
- btn.innerHTML = label
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('ボタン作成', btn, sys) }
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 parent = sys.__v0['DOM親要素']
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 parent = sys.__v0['DOM親要素']
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 parent = sys.__v0['DOM親要素']
79
- const te = document.createElement('span')
80
- te.innerHTML = text
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 parent = sys.__v0['DOM親要素']
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 parent = sys.__v0['DOM親要素']
121
- const te = document.createElement('br')
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
- const parent = sys.__v0['DOM親要素']
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
- const func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
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 func = sys.__v0['DOMスキン辞書'][sys.__v0['DOMスキン']]
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: [['を', 'に', 'の']],
@@ -882,7 +882,7 @@ const PluginNode = {
882
882
  if (sys.__genMode !== '非同期モード') {
883
883
  throw new Error('『AJAX受信』を使うには、プログラムの冒頭で「!非同期モード」と宣言してください。')
884
884
  }
885
- sys.async = true
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.nextAsync(sys)
897
+ sys.compAsync(sys, sysenv)
898
898
  }).catch(err => {
899
899
  console.error('[AJAX受信のエラー]', err)
900
900
  sys.__errorAsync(err, sys)