@operato/scene-mpi 1.3.7

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 (125) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/README.md +31 -0
  3. package/assets/favicon.ico +0 -0
  4. package/assets/images/spinner.png +0 -0
  5. package/dist/auto-clicker.d.ts +10 -0
  6. package/dist/auto-clicker.js +84 -0
  7. package/dist/auto-clicker.js.map +1 -0
  8. package/dist/boot-button.d.ts +20 -0
  9. package/dist/boot-button.js +90 -0
  10. package/dist/boot-button.js.map +1 -0
  11. package/dist/gateway-on-button.d.ts +7 -0
  12. package/dist/gateway-on-button.js +88 -0
  13. package/dist/gateway-on-button.js.map +1 -0
  14. package/dist/gateway-on-message.d.ts +3 -0
  15. package/dist/gateway-on-message.js +375 -0
  16. package/dist/gateway-on-message.js.map +1 -0
  17. package/dist/gateway.d.ts +58 -0
  18. package/dist/gateway.js +396 -0
  19. package/dist/gateway.js.map +1 -0
  20. package/dist/index.d.ts +5 -0
  21. package/dist/index.js +7 -0
  22. package/dist/index.js.map +1 -0
  23. package/dist/indicator-on-message.d.ts +2 -0
  24. package/dist/indicator-on-message.js +5 -0
  25. package/dist/indicator-on-message.js.map +1 -0
  26. package/dist/indicator-user-action.d.ts +5 -0
  27. package/dist/indicator-user-action.js +263 -0
  28. package/dist/indicator-user-action.js.map +1 -0
  29. package/dist/indicator.d.ts +83 -0
  30. package/dist/indicator.js +544 -0
  31. package/dist/indicator.js.map +1 -0
  32. package/dist/reply-button.d.ts +20 -0
  33. package/dist/reply-button.js +67 -0
  34. package/dist/reply-button.js.map +1 -0
  35. package/dist/segment-display.d.ts +41 -0
  36. package/dist/segment-display.js +521 -0
  37. package/dist/segment-display.js.map +1 -0
  38. package/dist/seven-segment.d.ts +7 -0
  39. package/dist/seven-segment.js +137 -0
  40. package/dist/seven-segment.js.map +1 -0
  41. package/dist/templates/auto-clicker.d.ts +17 -0
  42. package/dist/templates/auto-clicker.js +19 -0
  43. package/dist/templates/auto-clicker.js.map +1 -0
  44. package/dist/templates/boot-button.d.ts +16 -0
  45. package/dist/templates/boot-button.js +18 -0
  46. package/dist/templates/boot-button.js.map +1 -0
  47. package/dist/templates/gateway.d.ts +16 -0
  48. package/dist/templates/gateway.js +18 -0
  49. package/dist/templates/gateway.js.map +1 -0
  50. package/dist/templates/index.d.ts +16 -0
  51. package/dist/templates/index.js +15 -0
  52. package/dist/templates/index.js.map +1 -0
  53. package/dist/templates/indicator.d.ts +16 -0
  54. package/dist/templates/indicator.js +18 -0
  55. package/dist/templates/indicator.js.map +1 -0
  56. package/dist/templates/reply-button.d.ts +16 -0
  57. package/dist/templates/reply-button.js +18 -0
  58. package/dist/templates/reply-button.js.map +1 -0
  59. package/dist/templates/seven-segment.d.ts +28 -0
  60. package/dist/templates/seven-segment.js +30 -0
  61. package/dist/templates/seven-segment.js.map +1 -0
  62. package/dist/uuid.d.ts +1 -0
  63. package/dist/uuid.js +21 -0
  64. package/dist/uuid.js.map +1 -0
  65. package/helps/scene/component/auto-clicker.ko.md +3 -0
  66. package/helps/scene/component/auto-clicker.md +3 -0
  67. package/helps/scene/component/auto-clicker.zh.md +3 -0
  68. package/helps/scene/component/boot-button.ko.md +3 -0
  69. package/helps/scene/component/boot-button.md +3 -0
  70. package/helps/scene/component/boot-button.zh.md +3 -0
  71. package/helps/scene/component/gateway.ko.md +3 -0
  72. package/helps/scene/component/gateway.md +3 -0
  73. package/helps/scene/component/gateway.zh.md +3 -0
  74. package/helps/scene/component/indicator.ko.md +3 -0
  75. package/helps/scene/component/indicator.md +3 -0
  76. package/helps/scene/component/indicator.zh.md +3 -0
  77. package/helps/scene/component/reply-button.ko.md +3 -0
  78. package/helps/scene/component/reply-button.md +3 -0
  79. package/helps/scene/component/reply-button.zh.md +3 -0
  80. package/helps/scene/component/seven-segment.ko.md +3 -0
  81. package/helps/scene/component/seven-segment.md +3 -0
  82. package/helps/scene/component/seven-segment.zh.md +3 -0
  83. package/icons/boot-button.png +0 -0
  84. package/icons/button-error.png +0 -0
  85. package/icons/button-start.png +0 -0
  86. package/icons/button-status.png +0 -0
  87. package/icons/button-stop.png +0 -0
  88. package/icons/gateway.png +0 -0
  89. package/icons/icon-boot-button.png +0 -0
  90. package/icons/icon-gateway.png +0 -0
  91. package/icons/icon-indicator.png +0 -0
  92. package/icons/icon-reply-button.png +0 -0
  93. package/icons/icon-seven-segment.png +0 -0
  94. package/icons/indicator.png +0 -0
  95. package/icons/no-image.png +0 -0
  96. package/icons/reply-button.png +0 -0
  97. package/package.json +61 -0
  98. package/src/auto-clicker.ts +97 -0
  99. package/src/boot-button.ts +112 -0
  100. package/src/gateway-on-button.ts +97 -0
  101. package/src/gateway-on-message.ts +405 -0
  102. package/src/gateway.ts +484 -0
  103. package/src/index.ts +6 -0
  104. package/src/indicator-on-message.ts +6 -0
  105. package/src/indicator-user-action.ts +292 -0
  106. package/src/indicator.ts +638 -0
  107. package/src/reply-button.ts +88 -0
  108. package/src/segment-display.ts +608 -0
  109. package/src/seven-segment.ts +162 -0
  110. package/src/templates/auto-clicker.ts +19 -0
  111. package/src/templates/boot-button.ts +18 -0
  112. package/src/templates/gateway.ts +18 -0
  113. package/src/templates/index.ts +15 -0
  114. package/src/templates/indicator.ts +18 -0
  115. package/src/templates/reply-button.ts +18 -0
  116. package/src/templates/seven-segment.ts +30 -0
  117. package/src/uuid.ts +20 -0
  118. package/things-scene.config.js +5 -0
  119. package/translations/en.json +26 -0
  120. package/translations/ja.json +26 -0
  121. package/translations/ko.json +26 -0
  122. package/translations/ms.json +23 -0
  123. package/translations/zh.json +23 -0
  124. package/tsconfig.json +22 -0
  125. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,544 @@
1
+ const IMAGE = new URL('../../icons/indicator.png', import.meta.url).href;
2
+ import { Component, RectPath, Shape } from '@hatiolab/things-scene';
3
+ import SegmentDisplay from './segment-display';
4
+ import { onMouseDownMButton, onMouseDownFButton, onMouseDownCButton, onMouseDownBigButton } from './indicator-user-action';
5
+ import { onmessage } from './indicator-on-message';
6
+ const NATURE = {
7
+ mutable: false,
8
+ resizable: true,
9
+ rotatable: true,
10
+ properties: [
11
+ {
12
+ type: 'string',
13
+ label: 'segment_role',
14
+ name: 'segments'
15
+ },
16
+ {
17
+ type: 'select',
18
+ label: 'button_color',
19
+ name: 'buttonColor',
20
+ property: {
21
+ options: [
22
+ {
23
+ display: 'BASIC',
24
+ value: '#0000'
25
+ },
26
+ {
27
+ display: 'YELLOW',
28
+ value: '#ff0'
29
+ },
30
+ {
31
+ display: 'GREEN',
32
+ value: '#0f0'
33
+ },
34
+ {
35
+ display: 'RED',
36
+ value: '#f00'
37
+ },
38
+ {
39
+ display: 'BLUE',
40
+ value: '#00f'
41
+ }
42
+ ]
43
+ }
44
+ },
45
+ {
46
+ type: 'select',
47
+ label: 'boot_flag',
48
+ name: 'boot_flag',
49
+ property: {
50
+ options: [
51
+ {
52
+ display: '',
53
+ value: ''
54
+ },
55
+ {
56
+ display: 'TRUE',
57
+ value: 'true'
58
+ },
59
+ {
60
+ display: 'FALSE',
61
+ value: 'false'
62
+ }
63
+ ]
64
+ }
65
+ },
66
+ {
67
+ type: 'select',
68
+ label: 'reply_target',
69
+ name: 'reply_target',
70
+ property: {
71
+ options: [
72
+ {
73
+ display: '',
74
+ value: ''
75
+ },
76
+ {
77
+ display: 'MQTT',
78
+ value: 'MQTT'
79
+ },
80
+ {
81
+ display: 'GraphQl',
82
+ value: 'GraphQl'
83
+ }
84
+ ]
85
+ }
86
+ }
87
+ ],
88
+ help: 'scene/component/indicator'
89
+ };
90
+ const WIDTH = 449;
91
+ const HEIGHT = 53;
92
+ const RECT_BUTTON_EDGE = 3;
93
+ export default class Indicator extends RectPath(Shape) {
94
+ constructor() {
95
+ super(...arguments);
96
+ this.lit = false;
97
+ this.ledLit = false;
98
+ this.store = {};
99
+ this.conf = {
100
+ seg_role: ['S', 'S'],
101
+ alignment: 'R',
102
+ btn_mode: 'S',
103
+ btn_intvl: 5,
104
+ bf_on_msg: '',
105
+ bf_on_msg_t: 1,
106
+ bf_on_delay: 1,
107
+ cncl_delay: 10,
108
+ blink_if_full: true,
109
+ off_use_res: false,
110
+ led_bar_mode: 'S',
111
+ led_bar_intvl: 5,
112
+ led_bar_brtns: 6
113
+ };
114
+ this.currentTask = 'ready';
115
+ this.cookedData = {};
116
+ }
117
+ static get image() {
118
+ if (!Indicator._image) {
119
+ Indicator._image = new Image();
120
+ Indicator._image.src = IMAGE;
121
+ }
122
+ return Indicator._image;
123
+ }
124
+ get colors() {
125
+ return {
126
+ R: '#f00',
127
+ G: '#0f0',
128
+ B: '#00f',
129
+ C: '#0ff',
130
+ M: '#f0f',
131
+ Y: '#ff0',
132
+ K: '#0000',
133
+ W: '#fff'
134
+ };
135
+ }
136
+ get btnModes() {
137
+ return {
138
+ BLINK: 'B', // 깜박
139
+ ALWAYS: 'S' // 항상
140
+ };
141
+ }
142
+ get tasks() {
143
+ return {
144
+ PICK: 'pick',
145
+ STOCK: 'stock',
146
+ FULL: 'full',
147
+ MODIFY: 'modify',
148
+ END: 'end',
149
+ DISPLAY: 'display',
150
+ READY: 'ready',
151
+ STRSHOW: 'strshow'
152
+ };
153
+ }
154
+ get alignmentOptions() {
155
+ return {
156
+ LEFT: 'L',
157
+ RIGHT: 'R'
158
+ };
159
+ }
160
+ get segmentRoles() {
161
+ return {
162
+ RELAY_SEQ: {
163
+ INITIAL: 'R',
164
+ KEY: 'org_relay'
165
+ },
166
+ BOXES: {
167
+ INITIAL: 'B',
168
+ KEY: 'org_box_qty'
169
+ },
170
+ PCS: {
171
+ INITIAL: 'P',
172
+ KEY: 'org_ea_qty'
173
+ }
174
+ };
175
+ }
176
+ get getConf() {
177
+ return this.conf;
178
+ }
179
+ set setConf(conf) {
180
+ this.conf = conf;
181
+ }
182
+ get gateway() {
183
+ return this.root.findFirst('gateway');
184
+ // var gateway = this.parent
185
+ // while (gateway.constructor.name !== ('Gateway' || 'Window')) {
186
+ // gateway = gateway.parent
187
+ // }
188
+ // if (gateway.constructor.name === 'Window') return
189
+ // return gateway
190
+ }
191
+ get ledRect() {
192
+ return this.parent.findFirst('rect') || {};
193
+ }
194
+ dispose() {
195
+ super.dispose();
196
+ }
197
+ /**
198
+ *
199
+ * @param {array} args
200
+ */
201
+ setSegmentsState(args) {
202
+ var stateArr = [];
203
+ var currentRole = this.store.seg_role ? this.store.seg_role : this.getConf.seg_role;
204
+ currentRole.forEach((role) => {
205
+ var ele;
206
+ args.forEach(arg => {
207
+ if (role == arg.role && (arg.value || arg.value >= 0)) {
208
+ ele = arg.value;
209
+ }
210
+ });
211
+ stateArr.push(ele);
212
+ });
213
+ var stateStr = stateArr.join(',');
214
+ this.setState('segments', stateStr);
215
+ }
216
+ /**
217
+ *
218
+ * @param {object} data
219
+ */
220
+ jobLightOn(data, lit = true) {
221
+ var toutDisplayMessage = (indicator) => {
222
+ indicator.displayMessage(indicator.getConf.bf_on_msg, indicator.cookedData.buttonColor, false);
223
+ setTimeout(() => {
224
+ toutDelayBeforeLightOn(indicator);
225
+ }, indicator.getConf.bf_on_msg_t * 100);
226
+ };
227
+ var toutDelayBeforeLightOn = (indicator) => {
228
+ indicator.lightOff();
229
+ setTimeout(() => {
230
+ indicator.lightOn(data, lit);
231
+ }, indicator.getConf.bf_on_delay * 100);
232
+ };
233
+ if (typeof this.getConf.bf_on_msg === 'string' && this.getConf.bf_on_msg.length > 0) {
234
+ toutDisplayMessage(this);
235
+ }
236
+ else if (this.getConf.bf_on_delay > 0) {
237
+ toutDelayBeforeLightOn(this);
238
+ }
239
+ else {
240
+ this.lightOn(data, lit);
241
+ }
242
+ }
243
+ /**
244
+ *
245
+ * @param {object} data
246
+ */
247
+ lightOn(data, lit = true) {
248
+ var sublen = 6 / this.getConf.seg_role.length;
249
+ switch (this.getConf.alignment) {
250
+ case this.alignmentOptions.LEFT:
251
+ {
252
+ let arr = [];
253
+ Object.values(this.segmentRoles).forEach(role => {
254
+ if (data[role.KEY] || data[role.KEY] >= 0) {
255
+ var obj = {
256
+ role: role.INITIAL,
257
+ value: data[role.KEY]
258
+ };
259
+ arr.push(obj);
260
+ }
261
+ });
262
+ this.setSegmentsState(arr);
263
+ }
264
+ break;
265
+ case this.alignmentOptions.RIGHT:
266
+ default:
267
+ {
268
+ let arr = [];
269
+ Object.values(this.segmentRoles).forEach(role => {
270
+ if (data[role.KEY] || data[role.KEY] >= 0) {
271
+ var obj = {
272
+ role: role.INITIAL,
273
+ value: (' ' + data[role.KEY]).substr(-sublen)
274
+ };
275
+ arr.push(obj);
276
+ }
277
+ });
278
+ this.setSegmentsState(arr);
279
+ }
280
+ break;
281
+ }
282
+ if (data.buttonColor)
283
+ this.setState('buttonColor', String(data.buttonColor));
284
+ this.lit = lit;
285
+ }
286
+ lightOff() {
287
+ this.setState('segments', this.displays.length == 3 ? ',,' : ',');
288
+ this.setState('buttonColor', '#0000');
289
+ this.lit = false;
290
+ }
291
+ /**
292
+ *
293
+ * @param {string} msg
294
+ * @param {string} color
295
+ */
296
+ displayMessage(msg, color = 'K', lit = true) {
297
+ var eachSegLen = this.displays[0].pattern.length;
298
+ var allSegLen = eachSegLen * this.displays.length;
299
+ var d = msg || this.getConf.bf_on_msg;
300
+ switch (this.conf.alignment) {
301
+ case this.alignmentOptions.LEFT:
302
+ {
303
+ d = (d + ' ').substr(0, allSegLen);
304
+ }
305
+ break;
306
+ case this.alignmentOptions.RIGHT:
307
+ default:
308
+ {
309
+ d = (' ' + d).substr(-allSegLen);
310
+ }
311
+ break;
312
+ }
313
+ var da = [];
314
+ var i = 1;
315
+ var startIdx = 0;
316
+ while (i <= allSegLen) {
317
+ if (i % eachSegLen == 0) {
318
+ da.push(d.substr(startIdx, eachSegLen));
319
+ startIdx = i;
320
+ }
321
+ i++;
322
+ }
323
+ this.setState('segments', da.join(','));
324
+ this.setState('buttonColor', this.colors[color]);
325
+ this.lit = lit;
326
+ }
327
+ rectButtonContains(x, y, WRATE, HRATE) {
328
+ var left = 310 * WRATE;
329
+ var top = 8 * HRATE;
330
+ var width = 62 * WRATE;
331
+ var height = 36 * HRATE;
332
+ var extend = RECT_BUTTON_EDGE;
333
+ return (x < Math.max(left + width, left) + extend &&
334
+ x > Math.min(left + width, left) - extend &&
335
+ y < Math.max(top + height, top) + extend &&
336
+ y > Math.min(top + height, top) - extend);
337
+ }
338
+ mfcButtonContains(x, y, WRATE, HRATE) {
339
+ var left = 38 * WRATE;
340
+ var top = 14 * HRATE;
341
+ var width = 17 * WRATE;
342
+ var height = 25 * HRATE;
343
+ var extend = RECT_BUTTON_EDGE;
344
+ if (x < Math.max(left + width, left) + extend &&
345
+ x > Math.min(left + width, left) - extend &&
346
+ y < Math.max(top + height, top) + extend &&
347
+ y > Math.min(top + height, top) - extend) {
348
+ return 'M';
349
+ }
350
+ var rx = 9 * WRATE;
351
+ var ry = 9 * HRATE;
352
+ var cx = 70 * WRATE;
353
+ var cy = 17 * HRATE;
354
+ var normx = (x - cx) / (rx * 2 - 0.5);
355
+ var normy = (y - cy) / (ry * 2 - 0.5);
356
+ if (normx * normx + normy * normy < 0.25) {
357
+ return 'F';
358
+ }
359
+ cx = 70 * WRATE;
360
+ cy = 39 * HRATE;
361
+ normx = (x - cx) / (rx * 2 - 0.5);
362
+ normy = (y - cy) / (ry * 2 - 0.5);
363
+ if (normx * normx + normy * normy < 0.25) {
364
+ return 'C';
365
+ }
366
+ }
367
+ onmousedown(e, hint) {
368
+ var { left, top, width, height } = this.bounds;
369
+ var WRATE = width / WIDTH;
370
+ var HRATE = height / HEIGHT;
371
+ var { x, y } = this.transcoordC2S(e.offsetX, e.offsetY);
372
+ if (this.rectButtonContains(x - left, y - top, WRATE, HRATE)) {
373
+ onMouseDownBigButton(this);
374
+ }
375
+ else {
376
+ switch (this.mfcButtonContains(x - left, y - top, WRATE, HRATE)) {
377
+ case 'M':
378
+ onMouseDownMButton(this);
379
+ break;
380
+ case 'F':
381
+ onMouseDownFButton(this);
382
+ break;
383
+ case 'C':
384
+ onMouseDownCButton(this);
385
+ break;
386
+ default:
387
+ }
388
+ }
389
+ }
390
+ get displays() {
391
+ var { width, height } = this.bounds;
392
+ var WRATE = width / WIDTH;
393
+ var HRATE = height / HEIGHT;
394
+ var { segments = new Array(this.getConf.seg_role.length).join(',') } = this.state;
395
+ return segments.split(',', 3).map((value, idx, array) => {
396
+ var display = new SegmentDisplay(63 * WRATE, 28 * HRATE);
397
+ display.pattern = array.length == 2 ? '###' : array.length == 3 ? '##' : '###'; // 3 넘는 건 안 함
398
+ display.displayAngle = 8;
399
+ display.digitHeight = 20;
400
+ display.digitWidth = 11;
401
+ display.digitDistance = 6;
402
+ display.segmentWidth = 2.5;
403
+ display.segmentDistance = 0.2;
404
+ display.segmentCount = SegmentDisplay.SevenSegment;
405
+ display.cornerType = SegmentDisplay.SymmetricCorner;
406
+ display.colorOn = idx == 0 ? '#007dfe' : idx == 1 ? '#fd0000' : '#fee400';
407
+ display.colorOff = '#2c2c2c';
408
+ display.setValue(value);
409
+ return display;
410
+ });
411
+ }
412
+ _drawRectButton(context, WRATE, HRATE, color) {
413
+ var w = 62 * WRATE;
414
+ var h = 36 * HRATE;
415
+ var r = Math.min(7 * WRATE, 7 * HRATE);
416
+ var edge = Math.floor(r / 2);
417
+ var highlight = Math.floor(r / 5);
418
+ if (w < 2 * r)
419
+ r = w / 2;
420
+ if (h < 2 * r)
421
+ r = h / 2;
422
+ context.beginPath();
423
+ context.moveTo(r, 0);
424
+ context.arcTo(w, 0, w, h, r);
425
+ context.arcTo(w, h, 0, h, r);
426
+ context.arcTo(0, h, 0, 0, r);
427
+ context.arcTo(0, 0, w, 0, r);
428
+ context.globalAlpha = 1;
429
+ context.fillStyle = color;
430
+ context.strokeStyle = color;
431
+ context.lineWidth = edge - 2;
432
+ context.fill();
433
+ context.stroke();
434
+ context.strokeStyle = 'black';
435
+ context.globalAlpha = 0.3;
436
+ context.stroke();
437
+ context.beginPath();
438
+ context.moveTo(highlight, h - r);
439
+ context.arcTo(highlight, highlight, r, highlight, r - highlight);
440
+ context.lineTo(w - r, highlight);
441
+ context.strokeStyle = 'white';
442
+ context.globalAlpha = 0.6;
443
+ context.lineWidth = highlight;
444
+ context.stroke();
445
+ context.beginPath();
446
+ context.moveTo(w - r, highlight);
447
+ context.arcTo(w - highlight, highlight, w - highlight, r, r - highlight);
448
+ context.arcTo(w - highlight, h - highlight, w - r, h - highlight, r - highlight);
449
+ context.arcTo(highlight, h - highlight, highlight, h - r, r - highlight);
450
+ context.strokeStyle = 'white';
451
+ context.globalAlpha = 0.4;
452
+ context.lineWidth = highlight;
453
+ context.stroke();
454
+ context.globalAlpha = 1;
455
+ }
456
+ _drawMFCButton(context, WRATE, HRATE) {
457
+ context.textAlign = 'center';
458
+ context.textBaseline = 'middle';
459
+ context.font = `${Math.min(13 * WRATE, 13 * HRATE)}px Arial`;
460
+ context.lineJoin = 'round';
461
+ var r = Math.min(7 * WRATE, 7 * HRATE);
462
+ var edge = Math.floor(r / 3);
463
+ // console.log('r', r, 'wrate', WRATE, 'hrate', HRATE, 'edge', edge)
464
+ context.lineWidth = edge;
465
+ context.beginPath();
466
+ // context.ellipse(96 * WRATE, 27 * HRATE, 7 * WRATE, 7 * HRATE, 0, 0, 2 * Math.PI)
467
+ context.fillStyle = 'rgba(255, 0, 0, 0.0)';
468
+ context.strokeStyle = 'rgba(255, 0, 0, 0.0)';
469
+ context.strokeRect(38 * WRATE, 14 * HRATE, 17 * WRATE, 25 * HRATE);
470
+ context.fillRect(38 * WRATE, 14 * HRATE, 17 * WRATE, 25 * HRATE);
471
+ context.fill();
472
+ // context.fillStyle = 'black'
473
+ // context.fillText('M', 40 * WRATE, 27 * HRATE)
474
+ context.beginPath();
475
+ context.ellipse(70 * WRATE, 15 * HRATE, 9 * WRATE, 9 * HRATE, 0, 0, 2 * Math.PI);
476
+ context.fillStyle = 'rgba(255, 0, 0, 0.0)';
477
+ context.fill();
478
+ // context.fillStyle = 'white'
479
+ // context.fillText('F', 70 * WRATE, 17 * HRATE)
480
+ context.beginPath();
481
+ context.ellipse(70 * WRATE, 39 * HRATE, 9 * WRATE, 9 * HRATE, 0, 0, 2 * Math.PI);
482
+ context.fillStyle = 'rgba(255, 0, 0, 0.0)';
483
+ context.fill();
484
+ // context.fillStyle = 'white'
485
+ // context.fillText('C', 70 * WRATE, 39 * HRATE)
486
+ }
487
+ render(context) {
488
+ var { left, top, width, height } = this.bounds;
489
+ var color = this.state.buttonColor || '#0000';
490
+ var WRATE = width / WIDTH;
491
+ var HRATE = height / HEIGHT;
492
+ context.translate(left, top);
493
+ context.save();
494
+ context.beginPath();
495
+ this.drawImage(context, Indicator.image, 0, 0, width, height);
496
+ this._drawMFCButton(context, WRATE, HRATE);
497
+ var displays = this.displays;
498
+ var myCursor = displays.length == 3 ? 1 : 0;
499
+ context.translate((135 - myCursor * 12) * WRATE, 12 * HRATE);
500
+ displays[0].draw(context);
501
+ if (displays.length >= 2) {
502
+ context.translate((75 - myCursor * 25) * WRATE, 0);
503
+ displays[1].draw(context);
504
+ }
505
+ if (displays.length >= 3) {
506
+ context.translate((75 - myCursor * 25) * WRATE, 0);
507
+ displays[2].draw(context);
508
+ }
509
+ context.beginPath();
510
+ context.restore();
511
+ context.translate(310 * WRATE, 8 * HRATE);
512
+ this._drawRectButton(context, WRATE, HRATE, color);
513
+ context.beginPath();
514
+ }
515
+ onchangeData(after, before) {
516
+ super.onchangeData(after, before);
517
+ onmessage(this, after.data);
518
+ }
519
+ get hasTextProperty() {
520
+ return false;
521
+ }
522
+ get nature() {
523
+ return NATURE;
524
+ }
525
+ onButton() {
526
+ switch (this.currentTask) {
527
+ case this.tasks.END:
528
+ {
529
+ // onMouseDownFButton(this);
530
+ }
531
+ break;
532
+ case this.tasks.DISPLAY: {
533
+ return;
534
+ }
535
+ default:
536
+ {
537
+ onMouseDownBigButton(this);
538
+ }
539
+ break;
540
+ }
541
+ }
542
+ }
543
+ Component.register('indicator', Indicator);
544
+ //# sourceMappingURL=indicator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"indicator.js","sourceRoot":"","sources":["../src/indicator.ts"],"names":[],"mappings":"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","sourcesContent":["const IMAGE = new URL('../../icons/indicator.png', import.meta.url).href\n\nimport { Component, ComponentNature, RectPath, Shape } from '@hatiolab/things-scene'\nimport SegmentDisplay from './segment-display'\n\nimport {\n onMouseDownMButton,\n onMouseDownFButton,\n onMouseDownCButton,\n onMouseDownBigButton\n} from './indicator-user-action'\n\nimport { onmessage } from './indicator-on-message'\nimport Gateway from './gateway'\n\nconst NATURE: ComponentNature = {\n mutable: false,\n resizable: true,\n rotatable: true,\n properties: [\n {\n type: 'string',\n label: 'segment_role',\n name: 'segments'\n },\n {\n type: 'select',\n label: 'button_color',\n name: 'buttonColor',\n property: {\n options: [\n {\n display: 'BASIC',\n value: '#0000'\n },\n {\n display: 'YELLOW',\n value: '#ff0'\n },\n {\n display: 'GREEN',\n value: '#0f0'\n },\n {\n display: 'RED',\n value: '#f00'\n },\n {\n display: 'BLUE',\n value: '#00f'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'boot_flag',\n name: 'boot_flag',\n property: {\n options: [\n {\n display: '',\n value: ''\n },\n {\n display: 'TRUE',\n value: 'true'\n },\n {\n display: 'FALSE',\n value: 'false'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'reply_target',\n name: 'reply_target',\n property: {\n options: [\n {\n display: '',\n value: ''\n },\n {\n display: 'MQTT',\n value: 'MQTT'\n },\n {\n display: 'GraphQl',\n value: 'GraphQl'\n }\n ]\n }\n }\n ],\n help: 'scene/component/indicator'\n}\n\nconst WIDTH = 449\nconst HEIGHT = 53\n\nconst RECT_BUTTON_EDGE = 3\n\nexport default class Indicator extends RectPath(Shape) {\n lit = false\n ledLit = false\n store = {} as any\n conf = {\n seg_role: ['S', 'S'],\n alignment: 'R',\n btn_mode: 'S',\n btn_intvl: 5,\n bf_on_msg: '',\n bf_on_msg_t: 1,\n bf_on_delay: 1,\n cncl_delay: 10,\n blink_if_full: true,\n off_use_res: false,\n led_bar_mode: 'S',\n led_bar_intvl: 5,\n led_bar_brtns: 6\n } as any\n currentTask = 'ready'\n cookedData: any = {}\n readOnly?: boolean\n version?: any\n\n static _image: HTMLImageElement\n\n static get image() {\n if (!Indicator._image) {\n Indicator._image = new Image()\n Indicator._image.src = IMAGE\n }\n\n return Indicator._image\n }\n\n get colors(): { [key: string]: string } {\n return {\n R: '#f00',\n G: '#0f0',\n B: '#00f',\n C: '#0ff',\n M: '#f0f',\n Y: '#ff0',\n K: '#0000',\n W: '#fff'\n }\n }\n\n get btnModes() {\n return {\n BLINK: 'B', // 깜박\n ALWAYS: 'S' // 항상\n }\n }\n\n get tasks(): { [key: string]: string } {\n return {\n PICK: 'pick',\n STOCK: 'stock',\n FULL: 'full',\n MODIFY: 'modify',\n END: 'end',\n DISPLAY: 'display',\n READY: 'ready',\n STRSHOW: 'strshow'\n }\n }\n\n get alignmentOptions() {\n return {\n LEFT: 'L',\n RIGHT: 'R'\n }\n }\n\n get segmentRoles() {\n return {\n RELAY_SEQ: {\n INITIAL: 'R',\n KEY: 'org_relay'\n },\n BOXES: {\n INITIAL: 'B',\n KEY: 'org_box_qty'\n },\n PCS: {\n INITIAL: 'P',\n KEY: 'org_ea_qty'\n }\n }\n }\n\n get getConf() {\n return this.conf\n }\n\n set setConf(conf: any) {\n this.conf = conf\n }\n\n get gateway(): Gateway {\n return this.root.findFirst('gateway') as Gateway\n // var gateway = this.parent\n // while (gateway.constructor.name !== ('Gateway' || 'Window')) {\n // gateway = gateway.parent\n // }\n\n // if (gateway.constructor.name === 'Window') return\n\n // return gateway\n }\n\n get ledRect() {\n return this.parent.findFirst('rect') || {}\n }\n\n dispose() {\n super.dispose()\n }\n\n /**\n *\n * @param {array} args\n */\n setSegmentsState(args: any[]) {\n var stateArr: any[] = []\n\n var currentRole = this.store.seg_role ? this.store.seg_role : this.getConf.seg_role\n currentRole.forEach((role: any) => {\n var ele\n args.forEach(arg => {\n if (role == arg.role && (arg.value || arg.value >= 0)) {\n ele = arg.value\n }\n })\n stateArr.push(ele)\n })\n var stateStr = stateArr.join(',')\n this.setState('segments', stateStr)\n }\n\n /**\n *\n * @param {object} data\n */\n jobLightOn(data: any, lit = true) {\n var toutDisplayMessage = (indicator: Indicator) => {\n indicator.displayMessage(indicator.getConf.bf_on_msg, indicator.cookedData.buttonColor, false)\n setTimeout(() => {\n toutDelayBeforeLightOn(indicator)\n }, indicator.getConf.bf_on_msg_t * 100)\n }\n\n var toutDelayBeforeLightOn = (indicator: Indicator) => {\n indicator.lightOff()\n setTimeout(() => {\n indicator.lightOn(data, lit)\n }, indicator.getConf.bf_on_delay * 100)\n }\n\n if (typeof this.getConf.bf_on_msg === 'string' && this.getConf.bf_on_msg.length > 0) {\n toutDisplayMessage(this)\n } else if (this.getConf.bf_on_delay > 0) {\n toutDelayBeforeLightOn(this)\n } else {\n this.lightOn(data, lit)\n }\n }\n\n /**\n *\n * @param {object} data\n */\n lightOn(data: any, lit = true) {\n var sublen = 6 / this.getConf.seg_role.length\n switch (this.getConf.alignment) {\n case this.alignmentOptions.LEFT:\n {\n let arr: any[] = []\n Object.values(this.segmentRoles).forEach(role => {\n if (data[role.KEY] || data[role.KEY] >= 0) {\n var obj = {\n role: role.INITIAL,\n value: data[role.KEY]\n }\n arr.push(obj)\n }\n })\n this.setSegmentsState(arr)\n }\n break\n case this.alignmentOptions.RIGHT:\n default:\n {\n let arr: any[] = []\n Object.values(this.segmentRoles).forEach(role => {\n if (data[role.KEY] || data[role.KEY] >= 0) {\n var obj = {\n role: role.INITIAL,\n value: (' ' + data[role.KEY]).substr(-sublen)\n }\n arr.push(obj)\n }\n })\n this.setSegmentsState(arr)\n }\n break\n }\n if (data.buttonColor) this.setState('buttonColor', String(data.buttonColor))\n this.lit = lit\n }\n\n lightOff() {\n this.setState('segments', this.displays.length == 3 ? ',,' : ',')\n this.setState('buttonColor', '#0000')\n\n this.lit = false\n }\n\n /**\n *\n * @param {string} msg\n * @param {string} color\n */\n displayMessage(msg: string, color = 'K', lit = true) {\n var eachSegLen = this.displays[0].pattern.length\n var allSegLen = eachSegLen * this.displays.length\n\n var d = msg || this.getConf.bf_on_msg\n\n switch (this.conf.alignment) {\n case this.alignmentOptions.LEFT:\n {\n d = (d + ' ').substr(0, allSegLen)\n }\n break\n case this.alignmentOptions.RIGHT:\n default:\n {\n d = (' ' + d).substr(-allSegLen)\n }\n break\n }\n\n var da = []\n\n var i = 1\n var startIdx = 0\n while (i <= allSegLen) {\n if (i % eachSegLen == 0) {\n da.push(d.substr(startIdx, eachSegLen))\n startIdx = i\n }\n i++\n }\n this.setState('segments', da.join(','))\n this.setState('buttonColor', this.colors[color])\n this.lit = lit\n }\n\n rectButtonContains(x: number, y: number, WRATE: number, HRATE: number) {\n var left = 310 * WRATE\n var top = 8 * HRATE\n var width = 62 * WRATE\n var height = 36 * HRATE\n\n var extend = RECT_BUTTON_EDGE\n\n return (\n x < Math.max(left + width, left) + extend &&\n x > Math.min(left + width, left) - extend &&\n y < Math.max(top + height, top) + extend &&\n y > Math.min(top + height, top) - extend\n )\n }\n\n mfcButtonContains(x: number, y: number, WRATE: number, HRATE: number) {\n var left = 38 * WRATE\n var top = 14 * HRATE\n var width = 17 * WRATE\n var height = 25 * HRATE\n\n var extend = RECT_BUTTON_EDGE\n if (\n x < Math.max(left + width, left) + extend &&\n x > Math.min(left + width, left) - extend &&\n y < Math.max(top + height, top) + extend &&\n y > Math.min(top + height, top) - extend\n ) {\n return 'M'\n }\n\n var rx = 9 * WRATE\n var ry = 9 * HRATE\n var cx = 70 * WRATE\n var cy = 17 * HRATE\n var normx = (x - cx) / (rx * 2 - 0.5)\n var normy = (y - cy) / (ry * 2 - 0.5)\n\n if (normx * normx + normy * normy < 0.25) {\n return 'F'\n }\n\n cx = 70 * WRATE\n cy = 39 * HRATE\n normx = (x - cx) / (rx * 2 - 0.5)\n normy = (y - cy) / (ry * 2 - 0.5)\n\n if (normx * normx + normy * normy < 0.25) {\n return 'C'\n }\n }\n\n onmousedown(e: MouseEvent, hint: any) {\n var { left, top, width, height } = this.bounds\n\n var WRATE = width / WIDTH\n var HRATE = height / HEIGHT\n\n var { x, y } = this.transcoordC2S(e.offsetX, e.offsetY)\n\n if (this.rectButtonContains(x - left, y - top, WRATE, HRATE)) {\n onMouseDownBigButton(this)\n } else {\n switch (this.mfcButtonContains(x - left, y - top, WRATE, HRATE)) {\n case 'M':\n onMouseDownMButton(this)\n break\n case 'F':\n onMouseDownFButton(this)\n break\n case 'C':\n onMouseDownCButton(this)\n break\n default:\n }\n }\n }\n\n get displays() {\n var { width, height } = this.bounds\n\n var WRATE = width / WIDTH\n var HRATE = height / HEIGHT\n\n var { segments = new Array(this.getConf.seg_role.length).join(',') } = this.state\n\n return (segments as string).split(',', 3).map((value, idx, array) => {\n var display = new SegmentDisplay(63 * WRATE, 28 * HRATE)\n\n display.pattern = array.length == 2 ? '###' : array.length == 3 ? '##' : '###' // 3 넘는 건 안 함\n display.displayAngle = 8\n display.digitHeight = 20\n display.digitWidth = 11\n display.digitDistance = 6\n display.segmentWidth = 2.5\n display.segmentDistance = 0.2\n display.segmentCount = SegmentDisplay.SevenSegment\n display.cornerType = SegmentDisplay.SymmetricCorner\n display.colorOn = idx == 0 ? '#007dfe' : idx == 1 ? '#fd0000' : '#fee400'\n display.colorOff = '#2c2c2c'\n\n display.setValue(value)\n\n return display\n })\n }\n\n _drawRectButton(context: CanvasRenderingContext2D, WRATE: number, HRATE: number, color: string) {\n var w = 62 * WRATE\n var h = 36 * HRATE\n var r = Math.min(7 * WRATE, 7 * HRATE)\n var edge = Math.floor(r / 2)\n var highlight = Math.floor(r / 5)\n\n if (w < 2 * r) r = w / 2\n if (h < 2 * r) r = h / 2\n\n context.beginPath()\n context.moveTo(r, 0)\n context.arcTo(w, 0, w, h, r)\n context.arcTo(w, h, 0, h, r)\n context.arcTo(0, h, 0, 0, r)\n context.arcTo(0, 0, w, 0, r)\n\n context.globalAlpha = 1\n context.fillStyle = color\n context.strokeStyle = color\n context.lineWidth = edge - 2\n context.fill()\n context.stroke()\n context.strokeStyle = 'black'\n context.globalAlpha = 0.3\n context.stroke()\n\n context.beginPath()\n context.moveTo(highlight, h - r)\n context.arcTo(highlight, highlight, r, highlight, r - highlight)\n context.lineTo(w - r, highlight)\n context.strokeStyle = 'white'\n context.globalAlpha = 0.6\n context.lineWidth = highlight\n context.stroke()\n\n context.beginPath()\n context.moveTo(w - r, highlight)\n context.arcTo(w - highlight, highlight, w - highlight, r, r - highlight)\n context.arcTo(w - highlight, h - highlight, w - r, h - highlight, r - highlight)\n context.arcTo(highlight, h - highlight, highlight, h - r, r - highlight)\n\n context.strokeStyle = 'white'\n context.globalAlpha = 0.4\n context.lineWidth = highlight\n context.stroke()\n\n context.globalAlpha = 1\n }\n\n _drawMFCButton(context: CanvasRenderingContext2D, WRATE: number, HRATE: number) {\n context.textAlign = 'center'\n context.textBaseline = 'middle'\n context.font = `${Math.min(13 * WRATE, 13 * HRATE)}px Arial`\n\n context.lineJoin = 'round'\n var r = Math.min(7 * WRATE, 7 * HRATE)\n var edge = Math.floor(r / 3)\n // console.log('r', r, 'wrate', WRATE, 'hrate', HRATE, 'edge', edge)\n context.lineWidth = edge\n\n context.beginPath()\n // context.ellipse(96 * WRATE, 27 * HRATE, 7 * WRATE, 7 * HRATE, 0, 0, 2 * Math.PI)\n context.fillStyle = 'rgba(255, 0, 0, 0.0)'\n context.strokeStyle = 'rgba(255, 0, 0, 0.0)'\n context.strokeRect(38 * WRATE, 14 * HRATE, 17 * WRATE, 25 * HRATE)\n context.fillRect(38 * WRATE, 14 * HRATE, 17 * WRATE, 25 * HRATE)\n context.fill()\n\n // context.fillStyle = 'black'\n // context.fillText('M', 40 * WRATE, 27 * HRATE)\n\n context.beginPath()\n context.ellipse(70 * WRATE, 15 * HRATE, 9 * WRATE, 9 * HRATE, 0, 0, 2 * Math.PI)\n context.fillStyle = 'rgba(255, 0, 0, 0.0)'\n context.fill()\n\n // context.fillStyle = 'white'\n // context.fillText('F', 70 * WRATE, 17 * HRATE)\n\n context.beginPath()\n context.ellipse(70 * WRATE, 39 * HRATE, 9 * WRATE, 9 * HRATE, 0, 0, 2 * Math.PI)\n context.fillStyle = 'rgba(255, 0, 0, 0.0)'\n context.fill()\n\n // context.fillStyle = 'white'\n // context.fillText('C', 70 * WRATE, 39 * HRATE)\n }\n\n render(context: CanvasRenderingContext2D) {\n var { left, top, width, height } = this.bounds\n\n var color = this.state.buttonColor || '#0000'\n\n var WRATE = width / WIDTH\n var HRATE = height / HEIGHT\n\n context.translate(left, top)\n context.save()\n\n context.beginPath()\n this.drawImage(context, Indicator.image, 0, 0, width, height)\n\n this._drawMFCButton(context, WRATE, HRATE)\n\n var displays = this.displays\n\n var myCursor = displays.length == 3 ? 1 : 0\n\n context.translate((135 - myCursor * 12) * WRATE, 12 * HRATE)\n displays[0].draw(context)\n\n if (displays.length >= 2) {\n context.translate((75 - myCursor * 25) * WRATE, 0)\n displays[1].draw(context)\n }\n\n if (displays.length >= 3) {\n context.translate((75 - myCursor * 25) * WRATE, 0)\n displays[2].draw(context)\n }\n\n context.beginPath()\n\n context.restore()\n context.translate(310 * WRATE, 8 * HRATE)\n this._drawRectButton(context, WRATE, HRATE, color)\n\n context.beginPath()\n }\n\n onchangeData(after: any, before: any) {\n super.onchangeData(after, before)\n\n onmessage(this, after.data)\n }\n\n get hasTextProperty() {\n return false\n }\n\n get nature() {\n return NATURE\n }\n\n onButton() {\n switch (this.currentTask) {\n case this.tasks.END:\n {\n // onMouseDownFButton(this);\n }\n break\n case this.tasks.DISPLAY: {\n return\n }\n default:\n {\n onMouseDownBigButton(this)\n }\n break\n }\n }\n}\n\nComponent.register('indicator', Indicator)\n"]}
@@ -0,0 +1,20 @@
1
+ import { Component, ComponentNature, Shape } from '@hatiolab/things-scene';
2
+ export declare const buttons: {
3
+ icon: string;
4
+ handler: typeof onClickReply;
5
+ }[];
6
+ declare const ReplyButton_base: typeof Shape;
7
+ export default class ReplyButton extends ReplyButton_base {
8
+ static _image?: HTMLImageElement;
9
+ static get image(): HTMLImageElement;
10
+ get publisher(): Component | undefined;
11
+ render(context: CanvasRenderingContext2D): void;
12
+ onmousedown(e: MouseEvent, hint: any): void;
13
+ buttonContains(): {
14
+ icon: string;
15
+ handler: typeof onClickReply;
16
+ };
17
+ get nature(): ComponentNature;
18
+ }
19
+ declare function onClickReply(button: Component): void;
20
+ export {};