clickgo 3.16.27 → 4.0.0

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 (299) hide show
  1. package/README.md +20 -9
  2. package/dist/app/{demo/res/video.mp4 → demo.cga} +0 -0
  3. package/dist/app/task.cga +0 -0
  4. package/dist/control/arteditor.cgc +0 -0
  5. package/dist/control/box.cgc +0 -0
  6. package/dist/control/captcha.cgc +0 -0
  7. package/dist/control/common.cgc +0 -0
  8. package/dist/control/desc.cgc +0 -0
  9. package/dist/control/drawer.cgc +0 -0
  10. package/dist/control/echarts.cgc +0 -0
  11. package/dist/control/form.cgc +0 -0
  12. package/dist/control/iconview.cgc +0 -0
  13. package/dist/control/jodit.cgc +0 -0
  14. package/dist/control/map.cgc +0 -0
  15. package/dist/control/monaco.cgc +0 -0
  16. package/dist/control/mpegts.cgc +0 -0
  17. package/dist/control/nav.cgc +0 -0
  18. package/dist/control/novnc.cgc +0 -0
  19. package/dist/control/page.cgc +0 -0
  20. package/dist/control/pdf.cgc +0 -0
  21. package/dist/control/property.cgc +0 -0
  22. package/dist/control/qrcode.cgc +0 -0
  23. package/dist/control/table.cgc +0 -0
  24. package/dist/control/task.cgc +0 -0
  25. package/dist/control/tplink.cgc +0 -0
  26. package/dist/control/tuieditor.cgc +0 -0
  27. package/dist/control/tuiviewer.cgc +0 -0
  28. package/dist/control/tums.cgc +0 -0
  29. package/dist/control/xterm.cgc +0 -0
  30. package/dist/ext/tums-player/audio.wasm +0 -0
  31. package/dist/ext/tums-player/decoder.worker.js +129 -0
  32. package/dist/ext/tums-player/libaudio.js +1 -0
  33. package/dist/ext/tums-player/libaudio.wasm +0 -0
  34. package/dist/ext/tums-player/libffmpeg.js +1 -0
  35. package/dist/ext/tums-player/libffmpeg.wasm +0 -0
  36. package/dist/ext/tums-player/libs.worker.js +92 -0
  37. package/dist/ext/tums-player/tums-player.umd.min.js +35 -0
  38. package/dist/ext/tums-player/webgl.js +2 -0
  39. package/dist/ext/tums-player/webgl.worker.js +42 -0
  40. package/dist/global.css +1 -1
  41. package/dist/index.js +1 -187
  42. package/dist/theme/dark.cgt +0 -0
  43. package/dist/theme/light.cgt +0 -0
  44. package/package.json +16 -10
  45. package/dist/app/demo/app.js +0 -60
  46. package/dist/app/demo/config.json +0 -249
  47. package/dist/app/demo/form/control/alayout2/alayout2.js +0 -43
  48. package/dist/app/demo/form/control/alayout2/alayout2.xml +0 -16
  49. package/dist/app/demo/form/control/alert/alert.js +0 -43
  50. package/dist/app/demo/form/control/alert/alert.xml +0 -32
  51. package/dist/app/demo/form/control/arteditor/arteditor.js +0 -75
  52. package/dist/app/demo/form/control/arteditor/arteditor.xml +0 -12
  53. package/dist/app/demo/form/control/arteditor/img.js +0 -61
  54. package/dist/app/demo/form/control/arteditor/img.xml +0 -6
  55. package/dist/app/demo/form/control/block/block.css +0 -1
  56. package/dist/app/demo/form/control/block/block.scss +0 -17
  57. package/dist/app/demo/form/control/block/block.xml +0 -7
  58. package/dist/app/demo/form/control/box/box.js +0 -87
  59. package/dist/app/demo/form/control/box/box.xml +0 -23
  60. package/dist/app/demo/form/control/button/button.css +0 -1
  61. package/dist/app/demo/form/control/button/button.js +0 -62
  62. package/dist/app/demo/form/control/button/button.scss +0 -18
  63. package/dist/app/demo/form/control/button/button.xml +0 -133
  64. package/dist/app/demo/form/control/calendar/calendar.js +0 -62
  65. package/dist/app/demo/form/control/calendar/calendar.xml +0 -34
  66. package/dist/app/demo/form/control/captcha/captcha.js +0 -60
  67. package/dist/app/demo/form/control/captcha/captcha.xml +0 -10
  68. package/dist/app/demo/form/control/check/check.js +0 -65
  69. package/dist/app/demo/form/control/check/check.xml +0 -17
  70. package/dist/app/demo/form/control/circle/circle.xml +0 -36
  71. package/dist/app/demo/form/control/content/content.js +0 -58
  72. package/dist/app/demo/form/control/content/content.xml +0 -16
  73. package/dist/app/demo/form/control/date/date.js +0 -56
  74. package/dist/app/demo/form/control/date/date.xml +0 -28
  75. package/dist/app/demo/form/control/datepanel/datepanel.js +0 -63
  76. package/dist/app/demo/form/control/datepanel/datepanel.xml +0 -32
  77. package/dist/app/demo/form/control/daterange/daterange.js +0 -54
  78. package/dist/app/demo/form/control/daterange/daterange.xml +0 -22
  79. package/dist/app/demo/form/control/delete/delete.js +0 -58
  80. package/dist/app/demo/form/control/delete/delete.xml +0 -20
  81. package/dist/app/demo/form/control/desc/desc.js +0 -82
  82. package/dist/app/demo/form/control/desc/desc.xml +0 -44
  83. package/dist/app/demo/form/control/dialog/dialog.js +0 -47
  84. package/dist/app/demo/form/control/dialog/dialog.xml +0 -32
  85. package/dist/app/demo/form/control/drawer/drawer.js +0 -45
  86. package/dist/app/demo/form/control/drawer/drawer.xml +0 -34
  87. package/dist/app/demo/form/control/echarts/echarts.js +0 -137
  88. package/dist/app/demo/form/control/echarts/echarts.xml +0 -12
  89. package/dist/app/demo/form/control/empty/empty.js +0 -44
  90. package/dist/app/demo/form/control/empty/empty.xml +0 -9
  91. package/dist/app/demo/form/control/file/file.js +0 -60
  92. package/dist/app/demo/form/control/file/file.xml +0 -25
  93. package/dist/app/demo/form/control/flow/flow.css +0 -1
  94. package/dist/app/demo/form/control/flow/flow.js +0 -97
  95. package/dist/app/demo/form/control/flow/flow.scss +0 -18
  96. package/dist/app/demo/form/control/flow/flow.xml +0 -101
  97. package/dist/app/demo/form/control/form/form.css +0 -1
  98. package/dist/app/demo/form/control/form/form.js +0 -77
  99. package/dist/app/demo/form/control/form/form.scss +0 -5
  100. package/dist/app/demo/form/control/form/form.xml +0 -29
  101. package/dist/app/demo/form/control/grid/grid.js +0 -45
  102. package/dist/app/demo/form/control/grid/grid.xml +0 -27
  103. package/dist/app/demo/form/control/group/group.js +0 -50
  104. package/dist/app/demo/form/control/group/group.xml +0 -46
  105. package/dist/app/demo/form/control/hske/hske.js +0 -44
  106. package/dist/app/demo/form/control/hske/hske.xml +0 -19
  107. package/dist/app/demo/form/control/html/html.js +0 -70
  108. package/dist/app/demo/form/control/html/html.xml +0 -18
  109. package/dist/app/demo/form/control/icon/icon.xml +0 -49
  110. package/dist/app/demo/form/control/iconview/iconview.js +0 -191
  111. package/dist/app/demo/form/control/iconview/iconview.xml +0 -45
  112. package/dist/app/demo/form/control/img/img.xml +0 -26
  113. package/dist/app/demo/form/control/imgviewer/imgviewer.js +0 -46
  114. package/dist/app/demo/form/control/imgviewer/imgviewer.xml +0 -9
  115. package/dist/app/demo/form/control/jodit/jodit.js +0 -75
  116. package/dist/app/demo/form/control/jodit/jodit.xml +0 -24
  117. package/dist/app/demo/form/control/label/label.js +0 -51
  118. package/dist/app/demo/form/control/label/label.xml +0 -34
  119. package/dist/app/demo/form/control/layout/layout.js +0 -45
  120. package/dist/app/demo/form/control/layout/layout.xml +0 -18
  121. package/dist/app/demo/form/control/link/link.js +0 -53
  122. package/dist/app/demo/form/control/link/link.xml +0 -30
  123. package/dist/app/demo/form/control/list/list.css +0 -1
  124. package/dist/app/demo/form/control/list/list.js +0 -394
  125. package/dist/app/demo/form/control/list/list.scss +0 -7
  126. package/dist/app/demo/form/control/list/list.xml +0 -150
  127. package/dist/app/demo/form/control/loading/loading.xml +0 -8
  128. package/dist/app/demo/form/control/map/map.js +0 -217
  129. package/dist/app/demo/form/control/map/map.xml +0 -44
  130. package/dist/app/demo/form/control/marquee/marquee.js +0 -64
  131. package/dist/app/demo/form/control/marquee/marquee.xml +0 -33
  132. package/dist/app/demo/form/control/menu/menu.js +0 -67
  133. package/dist/app/demo/form/control/menu/menu.xml +0 -125
  134. package/dist/app/demo/form/control/monaco/monaco.js +0 -136
  135. package/dist/app/demo/form/control/monaco/monaco.xml +0 -28
  136. package/dist/app/demo/form/control/mpegts/mpegts.js +0 -70
  137. package/dist/app/demo/form/control/mpegts/mpegts.xml +0 -11
  138. package/dist/app/demo/form/control/nav/nav.js +0 -71
  139. package/dist/app/demo/form/control/nav/nav.xml +0 -106
  140. package/dist/app/demo/form/control/page/page.js +0 -51
  141. package/dist/app/demo/form/control/page/page.xml +0 -22
  142. package/dist/app/demo/form/control/palette/palette.js +0 -46
  143. package/dist/app/demo/form/control/palette/palette.xml +0 -16
  144. package/dist/app/demo/form/control/panel/panel.js +0 -117
  145. package/dist/app/demo/form/control/panel/panel.xml +0 -16
  146. package/dist/app/demo/form/control/panel/test1.js +0 -105
  147. package/dist/app/demo/form/control/panel/test1.xml +0 -22
  148. package/dist/app/demo/form/control/panel/test2.xml +0 -4
  149. package/dist/app/demo/form/control/pdf/pdf.js +0 -78
  150. package/dist/app/demo/form/control/pdf/pdf.xml +0 -12
  151. package/dist/app/demo/form/control/pdf/test.pdf +0 -0
  152. package/dist/app/demo/form/control/progress/progress.js +0 -63
  153. package/dist/app/demo/form/control/progress/progress.xml +0 -9
  154. package/dist/app/demo/form/control/property/property.js +0 -166
  155. package/dist/app/demo/form/control/property/property.xml +0 -6
  156. package/dist/app/demo/form/control/qrcode/qrcode.js +0 -45
  157. package/dist/app/demo/form/control/qrcode/qrcode.xml +0 -13
  158. package/dist/app/demo/form/control/radio/radio.js +0 -62
  159. package/dist/app/demo/form/control/radio/radio.xml +0 -15
  160. package/dist/app/demo/form/control/scroll/scroll.js +0 -52
  161. package/dist/app/demo/form/control/scroll/scroll.xml +0 -38
  162. package/dist/app/demo/form/control/select/select.js +0 -286
  163. package/dist/app/demo/form/control/select/select.xml +0 -141
  164. package/dist/app/demo/form/control/setting/setting.xml +0 -11
  165. package/dist/app/demo/form/control/sgroup/sgroup.xml +0 -28
  166. package/dist/app/demo/form/control/step/step.js +0 -61
  167. package/dist/app/demo/form/control/step/step.xml +0 -16
  168. package/dist/app/demo/form/control/svg/svg.js +0 -61
  169. package/dist/app/demo/form/control/svg/svg.xml +0 -24
  170. package/dist/app/demo/form/control/switch/switch.js +0 -64
  171. package/dist/app/demo/form/control/switch/switch.xml +0 -29
  172. package/dist/app/demo/form/control/tab/tab.js +0 -113
  173. package/dist/app/demo/form/control/tab/tab.xml +0 -22
  174. package/dist/app/demo/form/control/table/table.js +0 -233
  175. package/dist/app/demo/form/control/table/table.xml +0 -97
  176. package/dist/app/demo/form/control/tag/tag.js +0 -44
  177. package/dist/app/demo/form/control/tag/tag.xml +0 -52
  178. package/dist/app/demo/form/control/text/text.js +0 -127
  179. package/dist/app/demo/form/control/text/text.xml +0 -70
  180. package/dist/app/demo/form/control/timeline/timeline.js +0 -43
  181. package/dist/app/demo/form/control/timeline/timeline.xml +0 -19
  182. package/dist/app/demo/form/control/tip/tip.js +0 -43
  183. package/dist/app/demo/form/control/tip/tip.xml +0 -42
  184. package/dist/app/demo/form/control/tplink/tplink.js +0 -74
  185. package/dist/app/demo/form/control/tplink/tplink.xml +0 -13
  186. package/dist/app/demo/form/control/tuieditor/tuieditor.js +0 -73
  187. package/dist/app/demo/form/control/tuieditor/tuieditor.xml +0 -22
  188. package/dist/app/demo/form/control/tuiviewer/tuiviewer.js +0 -45
  189. package/dist/app/demo/form/control/tuiviewer/tuiviewer.xml +0 -14
  190. package/dist/app/demo/form/control/uploader/uploader.js +0 -91
  191. package/dist/app/demo/form/control/uploader/uploader.xml +0 -15
  192. package/dist/app/demo/form/control/vflow/vflow.css +0 -1
  193. package/dist/app/demo/form/control/vflow/vflow.js +0 -112
  194. package/dist/app/demo/form/control/vflow/vflow.scss +0 -22
  195. package/dist/app/demo/form/control/vflow/vflow.xml +0 -89
  196. package/dist/app/demo/form/control/video/video.js +0 -47
  197. package/dist/app/demo/form/control/video/video.xml +0 -14
  198. package/dist/app/demo/form/control/web/web.js +0 -43
  199. package/dist/app/demo/form/control/web/web.xml +0 -4
  200. package/dist/app/demo/form/control/xterm/xterm.js +0 -100
  201. package/dist/app/demo/form/control/xterm/xterm.xml +0 -6
  202. package/dist/app/demo/form/event/form/form.css +0 -1
  203. package/dist/app/demo/form/event/form/form.js +0 -180
  204. package/dist/app/demo/form/event/form/form.scss +0 -24
  205. package/dist/app/demo/form/event/form/form.xml +0 -16
  206. package/dist/app/demo/form/event/other/other.js +0 -78
  207. package/dist/app/demo/form/event/other/other.xml +0 -5
  208. package/dist/app/demo/form/event/screen/screen.js +0 -86
  209. package/dist/app/demo/form/event/screen/screen.xml +0 -9
  210. package/dist/app/demo/form/event/task/task.js +0 -111
  211. package/dist/app/demo/form/event/task/task.xml +0 -20
  212. package/dist/app/demo/form/main.css +0 -1
  213. package/dist/app/demo/form/main.js +0 -521
  214. package/dist/app/demo/form/main.scss +0 -9
  215. package/dist/app/demo/form/main.xml +0 -160
  216. package/dist/app/demo/form/method/acontrol/acontrol.js +0 -53
  217. package/dist/app/demo/form/method/acontrol/acontrol.xml +0 -5
  218. package/dist/app/demo/form/method/aform/aform.js +0 -123
  219. package/dist/app/demo/form/method/aform/aform.xml +0 -60
  220. package/dist/app/demo/form/method/aform/sd.js +0 -58
  221. package/dist/app/demo/form/method/aform/sd.xml +0 -7
  222. package/dist/app/demo/form/method/core/core.js +0 -111
  223. package/dist/app/demo/form/method/core/core.xml +0 -23
  224. package/dist/app/demo/form/method/dom/dom.css +0 -1
  225. package/dist/app/demo/form/method/dom/dom.js +0 -251
  226. package/dist/app/demo/form/method/dom/dom.scss +0 -10
  227. package/dist/app/demo/form/method/dom/dom.xml +0 -76
  228. package/dist/app/demo/form/method/form/form.js +0 -287
  229. package/dist/app/demo/form/method/form/form.xml +0 -74
  230. package/dist/app/demo/form/method/form/test.xml +0 -5
  231. package/dist/app/demo/form/method/fs/fs.js +0 -230
  232. package/dist/app/demo/form/method/fs/fs.xml +0 -18
  233. package/dist/app/demo/form/method/fs/text.js +0 -48
  234. package/dist/app/demo/form/method/fs/text.xml +0 -3
  235. package/dist/app/demo/form/method/native/native.js +0 -128
  236. package/dist/app/demo/form/method/native/native.xml +0 -22
  237. package/dist/app/demo/form/method/storage/storage.js +0 -95
  238. package/dist/app/demo/form/method/storage/storage.xml +0 -18
  239. package/dist/app/demo/form/method/system/system.js +0 -88
  240. package/dist/app/demo/form/method/system/system.xml +0 -14
  241. package/dist/app/demo/form/method/task/locale1.json +0 -3
  242. package/dist/app/demo/form/method/task/locale2.json +0 -3
  243. package/dist/app/demo/form/method/task/task.js +0 -196
  244. package/dist/app/demo/form/method/task/task.xml +0 -61
  245. package/dist/app/demo/form/method/theme/theme.js +0 -107
  246. package/dist/app/demo/form/method/theme/theme.xml +0 -12
  247. package/dist/app/demo/form/method/tool/tool.js +0 -143
  248. package/dist/app/demo/form/method/tool/tool.xml +0 -40
  249. package/dist/app/demo/form/method/zip/zip.js +0 -137
  250. package/dist/app/demo/form/method/zip/zip.xml +0 -12
  251. package/dist/app/demo/form/solution/backpanel/backpanel.js +0 -89
  252. package/dist/app/demo/form/solution/backpanel/backpanel.xml +0 -31
  253. package/dist/app/demo/global.css +0 -3
  254. package/dist/app/demo/res/custombtn.cgc +0 -0
  255. package/dist/app/demo/res/icon.svg +0 -5
  256. package/dist/app/demo/res/img.jpg +0 -0
  257. package/dist/app/demo/res/marker.svg +0 -5
  258. package/dist/app/demo/res/r-1.svg +0 -32
  259. package/dist/app/demo/res/r-2.svg +0 -38
  260. package/dist/app/demo/res/sql.svg +0 -25
  261. package/dist/app/demo/res/txt.svg +0 -21
  262. package/dist/app/demo/res/zip.svg +0 -21
  263. package/dist/app/task/app.js +0 -57
  264. package/dist/app/task/config.json +0 -29
  265. package/dist/app/task/form/bar/bar.js +0 -419
  266. package/dist/app/task/form/bar/bar.xml +0 -46
  267. package/dist/app/task/form/desktop/desktop.xml +0 -1
  268. package/dist/app/task/locale/en.json +0 -11
  269. package/dist/app/task/locale/ja.json +0 -11
  270. package/dist/app/task/locale/sc.json +0 -11
  271. package/dist/app/task/locale/tc.json +0 -11
  272. package/dist/clickgo.d.ts +0 -22
  273. package/dist/clickgo.js +0 -109
  274. package/dist/index.d.ts +0 -55
  275. package/dist/lib/control.d.ts +0 -53
  276. package/dist/lib/control.js +0 -606
  277. package/dist/lib/core.d.ts +0 -47
  278. package/dist/lib/core.js +0 -1028
  279. package/dist/lib/dom.d.ts +0 -75
  280. package/dist/lib/dom.js +0 -2176
  281. package/dist/lib/form.d.ts +0 -222
  282. package/dist/lib/form.js +0 -3033
  283. package/dist/lib/fs.d.ts +0 -35
  284. package/dist/lib/fs.js +0 -1241
  285. package/dist/lib/native.d.ts +0 -43
  286. package/dist/lib/native.js +0 -228
  287. package/dist/lib/storage.d.ts +0 -6
  288. package/dist/lib/storage.js +0 -227
  289. package/dist/lib/task.d.ts +0 -32
  290. package/dist/lib/task.js +0 -1875
  291. package/dist/lib/theme.d.ts +0 -8
  292. package/dist/lib/theme.js +0 -195
  293. package/dist/lib/tool.d.ts +0 -122
  294. package/dist/lib/tool.js +0 -1054
  295. package/dist/lib/zip.d.ts +0 -40
  296. package/dist/lib/zip.js +0 -397
  297. package/dist/theme/blue.cgt +0 -0
  298. package/dist/theme/byterun.cgt +0 -0
  299. package/types/index.d.ts +0 -1374
@@ -1,100 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- const clickgo = __importStar(require("clickgo"));
37
- class default_1 extends clickgo.form.AbstractForm {
38
- constructor() {
39
- super(...arguments);
40
- this.r = {
41
- 'cols': 0,
42
- 'rows': 0,
43
- 'width': 0,
44
- 'height': 0
45
- };
46
- this.access = {
47
- 'term': undefined
48
- };
49
- this.input = '';
50
- }
51
- onData(data) {
52
- switch (data) {
53
- case '\u0003': {
54
- this.access.term.writeln('^C');
55
- this.access.term.write('~$ ');
56
- this.input = '';
57
- break;
58
- }
59
- case '\r': {
60
- this.access.term.writeln('');
61
- if (this.input.length > 0) {
62
- this.access.term.writeln(`${this.input}: command not found`);
63
- }
64
- this.access.term.write('~$ ');
65
- this.input = '';
66
- break;
67
- }
68
- case '\u007F': {
69
- if (this.input.length === 0) {
70
- break;
71
- }
72
- this.input = this.input.slice(0, -1);
73
- this.access.term.write('\b \b');
74
- break;
75
- }
76
- default: {
77
- if ((data >= String.fromCharCode(0x20) && data <= String.fromCharCode(0x7E)) || (data === '\u00a0')) {
78
- for (const item of data) {
79
- if (this.input.length < 15) {
80
- this.input += item;
81
- this.access.term.write(item);
82
- }
83
- }
84
- }
85
- else {
86
- console.log('data', data);
87
- }
88
- }
89
- }
90
- }
91
- onInit(term) {
92
- this.access.term = term;
93
- this.access.term.write('~$ ');
94
- this.access.term.focus();
95
- }
96
- onResize(r) {
97
- this.r = r;
98
- }
99
- }
100
- exports.default = default_1;
@@ -1,6 +0,0 @@
1
- <form title="Xterm" width="500" height="450">
2
- <layout direction="v" style="flex: 1;">
3
- <xterm ref="xterm" style="flex: 1; height: 0;" @data="onData" @resize="onResize" @init="onInit"></xterm>
4
- <label style="padding: 5px;">cols: {{r.cols}}, rows: {{r.rows}}, width: {{r.width}}, height: {{r.height}}</label>
5
- </layout>
6
- </form>
@@ -1 +0,0 @@
1
- @keyframes flash{0%,50%{border:solid 1px rgba(0,0,0,.8);color:initial}51%,100%{border-color:#000;background-color:#333;color:#fff}}.item{border:solid 1px #333;padding:5px;min-height:30px;min-width:150px}.item.focus{background-color:#fff;color:#333}.item:hover{background-color:rgba(0,0,0,.1)}.item:active{background-color:#333;color:#fff}.item.flash{animation:flash .2s linear infinite}
@@ -1,180 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
36
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
37
- return new (P || (P = Promise))(function (resolve, reject) {
38
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
39
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
40
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
41
- step((generator = generator.apply(thisArg, _arguments || [])).next());
42
- });
43
- };
44
- Object.defineProperty(exports, "__esModule", { value: true });
45
- const clickgo = __importStar(require("clickgo"));
46
- class default_1 extends clickgo.form.AbstractForm {
47
- constructor() {
48
- super(...arguments);
49
- this.flist = {};
50
- this.list = [];
51
- }
52
- pushConsole(name, text) {
53
- const date = new Date();
54
- this.list.unshift({
55
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
56
- 'name': name,
57
- 'text': text
58
- });
59
- }
60
- changeFocus(fid) {
61
- clickgo.form.changeFocus(parseInt(fid));
62
- }
63
- onMounted() {
64
- const list = clickgo.task.getList();
65
- for (const taskId in list) {
66
- const flist = clickgo.form.getList(parseInt(taskId));
67
- for (const fid in flist) {
68
- this.flist[fid] = {
69
- 'title': flist[fid].title,
70
- 'icon': flist[fid].icon,
71
- 'stateMax': flist[fid].stateMax,
72
- 'stateMin': flist[fid].stateMin,
73
- 'show': flist[fid].show,
74
- 'focus': flist[fid].focus,
75
- 'flash': false,
76
- 'showInTask': flist[fid].showInSystemTask
77
- };
78
- }
79
- }
80
- }
81
- onFormCreated(taskId, formId, title, icon, showInSystemTask) {
82
- this.flist[formId] = {
83
- 'title': title,
84
- 'icon': icon,
85
- 'stateMax': false,
86
- 'stateMin': false,
87
- 'show': false,
88
- 'focus': false,
89
- 'flash': false,
90
- 'showInTask': true
91
- };
92
- this.pushConsole('formCreated', `taskId: ${taskId}, formId: ${formId}, title: ${title}, icon: ${icon ? icon.slice(0, 10) + '...' : 'null'}, sist: ${showInSystemTask ? 'true' : 'false'}`);
93
- }
94
- onFormRemoved(taskId, formId, title, icon) {
95
- if (!this.flist[formId]) {
96
- return;
97
- }
98
- this.flist[formId] = undefined;
99
- delete this.flist[formId];
100
- this.pushConsole('formRemoved', `taskId: ${taskId}, formId: ${formId}, title: ${title}, icon: ${icon ? icon.slice(0, 10) + '...' : 'null'}`);
101
- }
102
- onFormTitleChanged(taskId, formId, title) {
103
- if (!this.flist[formId]) {
104
- return;
105
- }
106
- this.flist[formId].title = title;
107
- this.pushConsole('formTitleChanged', `taskId: ${taskId}, formId: ${formId}, title: ${title}`);
108
- }
109
- onFormIconChanged(taskId, formId, icon) {
110
- if (!this.flist[formId]) {
111
- return;
112
- }
113
- this.flist[formId].icon = icon;
114
- this.pushConsole('formIconChanged', `taskId: ${taskId}, formId: ${formId}, icon: ${icon ? icon.slice(0, 10) + '...' : 'null'}`);
115
- }
116
- onFormStateMinChanged(taskId, formId, state) {
117
- if (!this.flist[formId]) {
118
- return;
119
- }
120
- this.flist[formId].min = state;
121
- this.pushConsole('formStateMinChanged', `taskId: ${taskId}, formId: ${formId}, state: ${state ? 'true' : 'false'}`);
122
- }
123
- onFormStateMaxChanged(taskId, formId, state) {
124
- if (!this.flist[formId]) {
125
- return;
126
- }
127
- this.flist[formId].max = state;
128
- this.pushConsole('formStateMaxChanged', `taskId: ${taskId}, formId: ${formId}, state: ${state ? 'true' : 'false'}`);
129
- }
130
- onFormShowChanged(taskId, formId, state) {
131
- if (!this.flist[formId]) {
132
- return;
133
- }
134
- this.flist[formId].show = state;
135
- this.pushConsole('formShowChanged', `taskId: ${taskId}, formId: ${formId}, state: ${state ? 'true' : 'false'}`);
136
- }
137
- onFormFocused(taskId, formId) {
138
- if (!this.flist[formId]) {
139
- return;
140
- }
141
- this.flist[formId].focus = true;
142
- this.pushConsole('formFocused', `taskId: ${taskId}, formId: ${formId}`);
143
- }
144
- onFormBlurred(taskId, formId) {
145
- if (!this.flist[formId]) {
146
- return;
147
- }
148
- this.flist[formId].focus = false;
149
- this.pushConsole('formBlurred', `taskId: ${taskId}, formId: ${formId}`);
150
- }
151
- onFormFlash(taskId, formId) {
152
- return __awaiter(this, void 0, void 0, function* () {
153
- if (!this.flist[formId]) {
154
- return;
155
- }
156
- if (this.flist[formId].flash) {
157
- clickgo.task.removeTimer(this.flist[formId].flash);
158
- }
159
- this.pushConsole('formFlash', `taskId: ${taskId}, formId: ${formId}`);
160
- this.flist[formId].flash = true;
161
- yield clickgo.tool.sleep(1000);
162
- this.flist[formId].flash = false;
163
- });
164
- }
165
- onFormShowInSystemTaskChange(taskId, formId, value) {
166
- if (!this.flist[formId]) {
167
- return;
168
- }
169
- this.flist[formId].title = value;
170
- this.pushConsole('formShowInSystemTaskChange', `taskId: ${taskId}, formId: ${formId}, value: ${value}`);
171
- }
172
- onFormHashChange(taskId, formId, value, data) {
173
- if (!this.flist[formId]) {
174
- return;
175
- }
176
- this.pushConsole('formHashChange', `taskId: ${taskId}, formId: ${formId}, value: ${value}, data: ${JSON.stringify(data).slice(0, 20)}...`);
177
- return;
178
- }
179
- }
180
- exports.default = default_1;
@@ -1,24 +0,0 @@
1
- @keyframes flash {
2
- 0%, 50% {
3
- border: solid 1px rgba(0, 0, 0, .8); color: initial;
4
- }
5
- 51%, 100% {
6
- border-color: rgba(0, 0, 0, 1); background-color: hsl(0, 0%, 20%); color: #FFF;
7
- }
8
- }
9
-
10
- .item {
11
- border: solid 1px hsl(0, 0%, 20%); padding: 5px; min-height: 30px; min-width: 150px;
12
- &.focus {
13
- background-color: #FFF; color: hsl(0, 0%, 20%);
14
- }
15
- &:hover {
16
- background-color: rgba(0, 0, 0, .1);
17
- }
18
- &:active {
19
- background-color: hsl(0, 0%, 20%); color: #FFF;
20
- }
21
- &.flash {
22
- animation: flash .2s linear infinite;
23
- }
24
- }
@@ -1,16 +0,0 @@
1
- <form width="550" height="550" title="About form" padding="10" direction="v">
2
- <label>The form list:</label>
3
- <layout align-h="center" align-v="center" style="margin-top: 10px; flex: 1; height: 0;">
4
- <layout gutter="10" direction="v">
5
- <layout align-v="center" v-for="(form, fid) of flist" gutter="5" @click="changeFocus(fid)" class="item" :class="{'flash': form.flash, 'focus': form.focus}">
6
- <img v-if="form.icon" :src="form.icon" style="width: 16px; height: 16px;" /><label>{{form.title}}{{form.max ? ' (max)' : ''}}{{form.min ? ' (min)' : ''}}</label>
7
- </layout>
8
- </layout>
9
- </layout>
10
- <layout gutter="10" style="margin-top: 10px; height: 120px;">
11
- <list :data="['formCreated', 'formRemoved', 'formTitleChanged', 'formIconChanged', 'formStateMinChanged', 'formStateMaxChanged', 'formShowChanged', 'formFocused', 'formBlurred', 'formFlash', 'formShowInSystemTaskChange', 'formHashChange']" style="width: 150px;"></list>
12
- <vflow v-slot="data" :data="list" direction="v" style="color: #FFF; background: hsl(0, 0%, 20%); line-height: 1.5; flex: 1; width: 0; padding: 10px;" same>
13
- <label>[{{data.row.time}}] {{data.row.name}}, {{data.row.text}}.</label>
14
- </vflow>
15
- </layout>
16
- </form>
@@ -1,78 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- const clickgo = __importStar(require("clickgo"));
37
- class default_1 extends clickgo.form.AbstractForm {
38
- constructor() {
39
- super(...arguments);
40
- this.list = [];
41
- }
42
- onLauncherFolderNameChanged(id, name) {
43
- const date = new Date();
44
- this.list.unshift({
45
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
46
- 'name': 'launcherFolderNameChanged',
47
- 'content': JSON.stringify({
48
- 'id': id,
49
- 'name': name
50
- })
51
- });
52
- }
53
- onHashChanged(hash) {
54
- const date = new Date();
55
- this.list.unshift({
56
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
57
- 'name': 'hashChanged',
58
- 'content': hash
59
- });
60
- }
61
- onKeydown(e) {
62
- const date = new Date();
63
- this.list.unshift({
64
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
65
- 'name': 'keydown',
66
- 'content': e.key
67
- });
68
- }
69
- onKeyup(e) {
70
- const date = new Date();
71
- this.list.unshift({
72
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
73
- 'name': 'keyup',
74
- 'content': e.key
75
- });
76
- }
77
- }
78
- exports.default = default_1;
@@ -1,5 +0,0 @@
1
- <form width="500" height="550" title="About other" padding="10">
2
- <vflow v-slot="data" :data="list" direction="v" style="color: #FFF; background: hsl(0, 0%, 20%); line-height: 1.5; padding: 10px; flex: 1;">
3
- <label>[{{data.row.time}}] {{data.row.name}}, {{data.row.content}}.</label>
4
- </vflow>
5
- </form>
@@ -1,86 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- const clickgo = __importStar(require("clickgo"));
37
- class default_1 extends clickgo.form.AbstractForm {
38
- constructor() {
39
- super(...arguments);
40
- this.width = 0;
41
- this.height = 0;
42
- this.scale = 4;
43
- this.list = [];
44
- }
45
- onScreenResize() {
46
- const area = clickgo.core.getAvailArea();
47
- this.width = area.width;
48
- this.height = area.height;
49
- if (this.width > 1100 || this.height > 1100) {
50
- this.scale = 5;
51
- }
52
- else if (this.width < 420 || this.height < 420) {
53
- this.scale = 3;
54
- }
55
- else {
56
- this.scale = 4;
57
- }
58
- const date = new Date();
59
- this.list.unshift({
60
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
61
- 'width': area.width,
62
- 'height': area.height
63
- });
64
- }
65
- onMounted() {
66
- const area = clickgo.core.getAvailArea();
67
- this.width = area.width;
68
- this.height = area.height;
69
- if (this.width > 1100 || this.height > 1100) {
70
- this.scale = 5;
71
- }
72
- else if (this.width < 420 || this.height < 420) {
73
- this.scale = 3;
74
- }
75
- else {
76
- this.scale = 4;
77
- }
78
- const date = new Date();
79
- this.list.unshift({
80
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
81
- 'width': this.width,
82
- 'height': this.height
83
- });
84
- }
85
- }
86
- exports.default = default_1;
@@ -1,9 +0,0 @@
1
- <form width="400" height="550" title="About screen" padding="10" direction="v">
2
- <label>The screen size:</label>
3
- <layout align-h="center" align-v="center" style="margin-top: 10px; flex: 1; height: 0;">
4
- <block style="border: solid 1px hsl(0, 0%, 20%); display: flex; align-items: center; justify-content: center; font-size: 20px;" :style="{'width': width / scale + 'px', 'height': height / scale + 'px'}">{{width}} x {{height}}</block>
5
- </layout>
6
- <vflow v-slot="data" :data="list" direction="v" style="margin-top: 10px; color: #FFF; background: hsl(0, 0%, 20%); line-height: 1.5; height: 80px; padding: 10px;">
7
- <label>[{{data.row.time}}] screenResize, width: {{data.row.width}}, height: {{data.row.height}}.</label>
8
- </vflow>
9
- </form>
@@ -1,111 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
36
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
37
- return new (P || (P = Promise))(function (resolve, reject) {
38
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
39
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
40
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
41
- step((generator = generator.apply(thisArg, _arguments || [])).next());
42
- });
43
- };
44
- Object.defineProperty(exports, "__esModule", { value: true });
45
- const clickgo = __importStar(require("clickgo"));
46
- class default_1 extends clickgo.form.AbstractForm {
47
- constructor() {
48
- super(...arguments);
49
- this.tlist = [];
50
- this.list = [];
51
- this.tid = [];
52
- }
53
- pushConsole(name, text) {
54
- const date = new Date();
55
- this.list.unshift({
56
- 'time': date.getHours().toString() + ':' + date.getMinutes().toString() + ':' + date.getSeconds().toString(),
57
- 'name': name,
58
- 'text': text
59
- });
60
- }
61
- run() {
62
- return __awaiter(this, void 0, void 0, function* () {
63
- const taskId = yield clickgo.task.run('/clickgo/app/demo/');
64
- yield clickgo.form.dialog(`Successfully run, task id is: ${taskId}.`);
65
- });
66
- }
67
- end() {
68
- return __awaiter(this, void 0, void 0, function* () {
69
- if (yield clickgo.form.confirm(`Are you sure to end Task ${this.tid[0]}?`)) {
70
- clickgo.task.end(this.tid[0]);
71
- }
72
- });
73
- }
74
- runTask() {
75
- return __awaiter(this, void 0, void 0, function* () {
76
- if (clickgo.task.systemTaskInfo.taskId > 0) {
77
- yield clickgo.form.dialog('The Task APP is already running.');
78
- return;
79
- }
80
- const taskId = yield clickgo.task.run('/clickgo/app/task/');
81
- yield clickgo.form.dialog(`Successfully run, task id is: ${taskId}.`);
82
- });
83
- }
84
- onTaskStarted(taskId) {
85
- this.tlist.push({
86
- 'label': 'Task ' + taskId.toString(),
87
- 'value': taskId
88
- });
89
- this.pushConsole('taskStarted', `taskId: ${taskId}`);
90
- }
91
- onTaskEnded(taskId) {
92
- for (let i = 0; i < this.tlist.length; ++i) {
93
- if (this.tlist[i].value !== taskId) {
94
- continue;
95
- }
96
- this.tlist.splice(i, 1);
97
- break;
98
- }
99
- this.pushConsole('taskEnded', `taskId: ${taskId}`);
100
- }
101
- onMounted() {
102
- const list = clickgo.task.getList();
103
- for (const tid in list) {
104
- this.tlist.push({
105
- 'label': 'Task ' + tid,
106
- 'value': parseInt(tid)
107
- });
108
- }
109
- }
110
- }
111
- exports.default = default_1;
@@ -1,20 +0,0 @@
1
- <form width="400" height="550" title="About task" padding="10" direction="v">
2
- <label>The task list:</label>
3
- <layout align-h="center" align-v="center" style="margin-top: 10px; flex: 1; height: 0;">
4
- <layout direction="v" gutter="10">
5
- <label>Select task id: {{tid[0]}}</label>
6
- <list v-model="tid" :data="tlist" style="width: 200px; height: 200px;"></list>
7
- <button @click="runTask">Run task app</button>
8
- <layout gutter="10">
9
- <button @click="run" style="flex: 1; width: 0;">Run self</button>
10
- <button @click="end" style="flex: 1; width: 0;">End</button>
11
- </layout>
12
- </layout>
13
- </layout>
14
- <layout gutter="10" style="margin-top: 10px; height: 80px;">
15
- <list :data="['taskStarted', 'taskEnded']" width="150" style="width: 150px;"></list>
16
- <vflow v-slot="data" :data="list" direction="v" style="color: #FFF; background: hsl(0, 0%, 20%); line-height: 1.5; flex: 1; width: 0; padding: 10px;" same>
17
- <label>[{{data.row.time}}] {{data.row.name}}, {{data.row.text}}.</label>
18
- </vflow>
19
- </layout>
20
- </form>
@@ -1 +0,0 @@
1
- .inner{padding:10px;flex:1}.buttons button{flex:1}