jsgui3-server 0.0.121 → 0.0.123

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 (282) hide show
  1. package/.vscode/settings.json +6 -0
  2. package/README.md +10 -10
  3. package/controls/Active_HTML_Document.js +116 -116
  4. package/controls/README.md +7 -7
  5. package/controls/page/admin.js +74 -74
  6. package/controls/panel/admin.js +11 -11
  7. package/examples/_css/basic.css +913 -913
  8. package/examples/_css/database-control.css +51 -51
  9. package/examples/_css/jsgui.css +66 -66
  10. package/examples/_css/multi-layout.css +23 -23
  11. package/examples/_css/style.css +1669 -1669
  12. package/examples/_css/top-and-bottom-bars.css +54 -54
  13. package/examples/box/1) square box/client.js +188 -188
  14. package/examples/box/1) square box/server.js +112 -112
  15. package/examples/box/2) twenty square boxes/css flex wrap/client.js +112 -248
  16. package/examples/box/2) twenty square boxes/css flex wrap/server.js +39 -112
  17. package/examples/box/3) twenty selectable square boxes/css flex wrap/client.js +129 -0
  18. package/examples/{controls/15) window, text field → box/3) twenty selectable square boxes/css flex wrap}/server.js +38 -38
  19. package/examples/boxes/square_boxes.js +45 -48
  20. package/examples/boxes/square_boxes_client.js +132 -136
  21. package/examples/client-side-popup-menu-button.html +93 -93
  22. package/examples/color_palette.js +51 -51
  23. package/examples/color_palette_client.js +95 -95
  24. package/examples/controls/1) window/client.js +186 -186
  25. package/examples/controls/1) window/server.js +117 -117
  26. package/examples/controls/10) window, mirrored text inputs/client.js +118 -320
  27. package/examples/controls/10) window, mirrored text inputs/server.js +37 -117
  28. package/examples/controls/11) window, mirrored text fields/client.js +493 -251
  29. package/examples/controls/11) window, mirrored text fields/server.js +117 -117
  30. package/examples/controls/11b) window, shared Data_Object model mirrored text fields/client.js +613 -331
  31. package/examples/controls/11b) window, shared Data_Object model mirrored text fields/server.js +117 -117
  32. package/examples/controls/11c) window, shared Data_Value model mirrored text fields/client.js +617 -617
  33. package/examples/controls/11c) window, shared Data_Value model mirrored text fields/server.js +117 -117
  34. package/examples/controls/11d) window, shared model mirrored integer text fields/client.js +611 -280
  35. package/examples/controls/11d) window, shared model mirrored integer text fields/server.js +134 -22
  36. package/examples/controls/12) window, Select_Options control/client.js +66 -452
  37. package/examples/controls/12) window, Select_Options control/server.js +19 -117
  38. package/examples/controls/13) window, Dropdown_Menu control/client.js +66 -0
  39. package/examples/controls/13) window, Dropdown_Menu control/server.js +20 -0
  40. package/examples/controls/2) two windows/client.js +193 -193
  41. package/examples/controls/2) two windows/server.js +113 -113
  42. package/examples/controls/3) five windows/client.js +217 -217
  43. package/examples/controls/3) five windows/server.js +116 -115
  44. package/examples/controls/4) window, tabbed panel/client.js +54 -225
  45. package/examples/controls/4) window, tabbed panel/server.js +17 -117
  46. package/examples/controls/5) window, grid/client.js +204 -484
  47. package/examples/controls/5) window, grid/server.js +117 -119
  48. package/examples/controls/6) window, color_palette/client.js +68 -204
  49. package/examples/controls/6) window, color_palette/server.js +117 -117
  50. package/examples/controls/7) window, month_view/client.js +40 -231
  51. package/examples/controls/7) window, month_view/server.js +117 -117
  52. package/examples/controls/8) window, checkbox/client.js +33 -209
  53. package/examples/controls/8) window, checkbox/server.js +117 -117
  54. package/examples/controls/9) window, date picker/client.js +76 -303
  55. package/examples/controls/9) window, date picker/server.js +117 -117
  56. package/examples/controls/9b) window, shared data.model mirrored date pickers/README.md +51 -0
  57. package/examples/controls/9b) window, shared data.model mirrored date pickers/client.js +83 -398
  58. package/examples/controls/9b) window, shared data.model mirrored date pickers/server.js +117 -117
  59. package/examples/controls/__old/_html-server-color-palette.js +114 -114
  60. package/examples/controls/__old/html-server-combo-box.js +104 -104
  61. package/examples/controls/__old/html-server-list.js +98 -98
  62. package/examples/controls/__old/html-server-popup-menu-button.js +114 -114
  63. package/examples/controls/__old/html-server-start-stop-toggle-button.js +146 -146
  64. package/examples/controls/__old/scs-arrow-button.js +36 -36
  65. package/examples/controls/__old/scs-date-picker.js +157 -157
  66. package/examples/controls/__old/scs-file-browser.js +82 -82
  67. package/examples/controls/__old/scs-item.js +159 -159
  68. package/examples/controls/__old/scs-month-arrow-selector.js +126 -126
  69. package/examples/controls/__old/scs-month-view.js +94 -94
  70. package/examples/controls/__old/scs-start-stop-toggle-button.js +40 -40
  71. package/examples/controls/__old/scs-tree.js +49 -49
  72. package/examples/controls/__old/scs-year-arrow-selector.js +127 -127
  73. package/examples/demos/date-picker.js +119 -119
  74. package/examples/demos/explain-encapsulation.js +9 -9
  75. package/examples/demos/resizing.js +35 -35
  76. package/examples/demos/server_time.js +6 -6
  77. package/examples/grids/grid_1.js +45 -45
  78. package/examples/grids/grid_1_client.js +329 -329
  79. package/examples/html-rendering.js +20 -20
  80. package/examples/html-server.js +105 -105
  81. package/examples/introducing jsgui3/server.js +110 -110
  82. package/examples/mx_display/mx_display_1.js +45 -45
  83. package/examples/mx_display/mx_display_1_client.js +444 -444
  84. package/fs2.js +1836 -1836
  85. package/http/responders/HTTP_Responder.js +15 -15
  86. package/http/responders/static/Static_Route_HTTP_Responder.js +105 -105
  87. package/module.js +34 -34
  88. package/old/_single-control-server.js +418 -418
  89. package/old/single-control-server.js +368 -368
  90. package/old/single-page-app.js +131 -131
  91. package/package.json +42 -42
  92. package/page-context.js +92 -92
  93. package/publishers/helpers/assigners/Assigner.js +10 -10
  94. package/publishers/helpers/assigners/static-compressed-response-buffers/Single_Control_Webpage_Server_Static_Compressed_Response_Buffers_Assigner.js +150 -150
  95. package/publishers/helpers/assigners/static-headers/Single_Control_Webpage_Server_Static_Headers_Assigner.js +109 -109
  96. package/publishers/helpers/assigners/static-routes/Single_Control_Webpage_Server_Static_Routes_Assigner.js +91 -91
  97. package/publishers/helpers/assigners/static-uncompressed-response-buffers/Single_Control_Webpage_Server_Static_Uncompressed_Response_Buffers_Assigner.js +104 -104
  98. package/publishers/helpers/preparers/static/bundle/Ready_To_Serve_Preparer.js +18 -18
  99. package/publishers/helpers/preparers/static/bundle/Static_Routes_Responses_Webpage_Bundle_Preparer.js +44 -44
  100. package/publishers/http-function-publisher.js +212 -212
  101. package/publishers/http-html-page-publisher.js +5 -5
  102. package/publishers/http-html-publisher.js +24 -24
  103. package/publishers/http-js-publisher.js +135 -135
  104. package/publishers/http-observable-publisher.js +124 -124
  105. package/publishers/http-publisher.js +53 -53
  106. package/publishers/http-resource-publisher.js +325 -325
  107. package/publishers/http-webpage-publisher.js +659 -658
  108. package/publishers/http-webpageorsite-publisher.js +343 -343
  109. package/publishers/http-website-publisher.js +640 -640
  110. package/publishers/notes.md +9 -9
  111. package/resources/README.md +16 -16
  112. package/resources/_old_website-javascript-resource.js +994 -994
  113. package/resources/_old_website-resource.js +507 -507
  114. package/resources/compile/server-resource-compilation.js +43 -43
  115. package/resources/data-resource.js +118 -118
  116. package/resources/fs-resource.js +146 -146
  117. package/resources/jsbuilder/Abstract_Single_Declaration.js +105 -105
  118. package/resources/jsbuilder/Abstract_Single_Declaration_Sequence.js +42 -42
  119. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node.js +61 -61
  120. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node_Group.js +41 -41
  121. package/resources/jsbuilder/JS_AST/JS_AST_Group_Shared.js +61 -61
  122. package/resources/jsbuilder/JS_AST/JS_AST_Node.js +93 -93
  123. package/resources/jsbuilder/JS_AST/JS_AST_Node_0-Core.js +253 -253
  124. package/resources/jsbuilder/JS_AST/JS_AST_Node_1-Babel.js +337 -337
  125. package/resources/jsbuilder/JS_AST/JS_AST_Node_10-Changing.js +39 -39
  126. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.1-Child.js +96 -96
  127. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.2-Parent.js +37 -37
  128. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.3-Ancestor.js +61 -61
  129. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.2-Inner.js +43 -43
  130. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.3-All.js +72 -72
  131. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.4-Sibling.js +92 -92
  132. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.5-Available_In_Scope.js +29 -29
  133. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.9-Signature.js +116 -116
  134. package/resources/jsbuilder/JS_AST/JS_AST_Node_3-Basics.js +159 -159
  135. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.0-Basics_First.js +178 -178
  136. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.1-Basics_Second.js +87 -87
  137. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.99-Basics_Last.js +91 -91
  138. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1-Basics_Each.js +136 -136
  139. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1.5-Basics_Count.js +73 -73
  140. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.2-Basics_Filter.js +39 -39
  141. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.3-Basics_Collect.js +85 -85
  142. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.4-Basics_Select.js +42 -42
  143. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.5-Basics_Find.js +40 -40
  144. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.6-Basics_Callmap.js +54 -54
  145. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.0-Index_Indexes.js +45 -45
  146. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.1-Index.js +343 -343
  147. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.0-Category.js +38 -38
  148. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.1-Category_Identifier.js +30 -30
  149. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.2-Category_Literal.js +28 -28
  150. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.3-Category_Expression.js +26 -26
  151. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.4-Category_Pattern.js +8 -8
  152. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.5-Category_Declaration.js +43 -43
  153. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.6-Category_Statement.js +21 -21
  154. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.0-Type.js +89 -89
  155. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.1-Type_Class_Declaration.js +8 -8
  156. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.2-Type_Variable_Declaration.js +27 -27
  157. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.3-Type_Variable_Declarator.js +28 -28
  158. package/resources/jsbuilder/JS_AST/JS_AST_Node_7-Query.js +736 -736
  159. package/resources/jsbuilder/JS_AST/JS_AST_Node_8-Features.js +64 -64
  160. package/resources/jsbuilder/JS_AST/JS_AST_Node_9-Planning.js +31 -31
  161. package/resources/jsbuilder/JS_AST/JS_AST_Node_Arrangement.js +15 -15
  162. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Declared_Object.js +305 -305
  163. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature.js +77 -77
  164. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declaration.js +248 -248
  165. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declarator.js +138 -138
  166. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature.js +10 -10
  167. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exported.js +100 -100
  168. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exports.js +60 -60
  169. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Interpreted.js +179 -179
  170. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/_JSGUI_Root_Node_Interpreted.js +43 -43
  171. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/special_case_objectassign_to_object.js +12 -12
  172. package/resources/jsbuilder/JS_AST/JS_AST_Node_Group.js +35 -35
  173. package/resources/jsbuilder/JS_AST/JS_AST_Operation.js +11 -11
  174. package/resources/jsbuilder/JS_AST/JS_AST_Operation_On_Relationship.js +31 -31
  175. package/resources/jsbuilder/JS_AST/JS_AST_Ordered_Relationship_Node_To_Group.js +37 -37
  176. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal.js +39 -39
  177. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal_Relationship.js +25 -25
  178. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_To_Group.js +200 -200
  179. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_Within_Group_To_Node.js +43 -43
  180. package/resources/jsbuilder/JS_AST/_JS_AST_Node_3.8-Query_Features.js +76 -76
  181. package/resources/jsbuilder/JS_AST/query/enable_array_as_queryable.js +227 -227
  182. package/resources/jsbuilder/JS_AST/query/find_object_keys.js +404 -404
  183. package/resources/jsbuilder/JS_AST/query/node_queries.js +8 -8
  184. package/resources/jsbuilder/JS_AST/query/root_query_identidy.js +11 -11
  185. package/resources/jsbuilder/JS_AST_Node_Extended/JSGUI_Singular_Declaration.js +85 -85
  186. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Declaration.js +123 -123
  187. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended.js +87 -87
  188. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended_0-Core.js +10 -10
  189. package/resources/jsbuilder/JS_Builder.js +10 -10
  190. package/resources/jsbuilder/JS_File/Feature/JS_File_Declared_Object.js +31 -31
  191. package/resources/jsbuilder/JS_File/Feature/JS_File_Exported_Object_Info.js +25 -25
  192. package/resources/jsbuilder/JS_File/Feature/JS_File_Exports.js +78 -78
  193. package/resources/jsbuilder/JS_File/Feature/JS_File_Feature.js +17 -17
  194. package/resources/jsbuilder/JS_File/Feature/JS_File_Imported_Object_Info.js +25 -25
  195. package/resources/jsbuilder/JS_File/Feature/JS_File_Imports.js +8 -8
  196. package/resources/jsbuilder/JS_File/JS_File.js +12 -12
  197. package/resources/jsbuilder/JS_File/JS_File_0-Core.js +202 -202
  198. package/resources/jsbuilder/JS_File/JS_File_1-Early_Parse.js +175 -175
  199. package/resources/jsbuilder/JS_File/JS_File_2-Babel.js +81 -81
  200. package/resources/jsbuilder/JS_File/JS_File_3-JS_AST_Node.js +86 -86
  201. package/resources/jsbuilder/JS_File/JS_File_4-Query.js +413 -413
  202. package/resources/jsbuilder/JS_File/JS_File_4.1-Query_Features.js +414 -414
  203. package/resources/jsbuilder/JS_File/JS_File_5-Planning.js +59 -59
  204. package/resources/jsbuilder/JS_File/JS_File_6-Changing.js +24 -24
  205. package/resources/jsbuilder/JS_File/JS_File_Export_Reference.js +12 -12
  206. package/resources/jsbuilder/JS_File/JS_File_Import_Reference.js +23 -23
  207. package/resources/jsbuilder/JS_File/JS_File_Import_References.js +31 -31
  208. package/resources/jsbuilder/JS_File/JS_File_Processor.js +16 -16
  209. package/resources/jsbuilder/JS_File/JS_Files.js +15 -15
  210. package/resources/jsbuilder/Module.js +14 -14
  211. package/resources/jsbuilder/Platform.js +13 -13
  212. package/resources/jsbuilder/Platforms.js +69 -69
  213. package/resources/jsbuilder/Project.js +109 -109
  214. package/resources/jsbuilder/Reference.js +1 -1
  215. package/resources/jsbuilder/Reference_Sequence.js +16 -16
  216. package/resources/jsbuilder/Scope.js +29 -29
  217. package/resources/jsbuilder/Variable_Name_Provider.js +42 -42
  218. package/resources/jsbuilder/_JS_File.js +225 -225
  219. package/resources/jsbuilder/ast_query.js +20 -20
  220. package/resources/jsbuilder/babel/babel_consts.js +162 -162
  221. package/resources/jsbuilder/babel/babel_node_tools.js +541 -541
  222. package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +923 -904
  223. package/resources/jsbuilder/build.js +16 -16
  224. package/resources/jsbuilder/platform_notes.md +66 -66
  225. package/resources/jsbuilder/test/test_ast_node.js +381 -381
  226. package/resources/jsbuilder/test/test_js_file.js +303 -303
  227. package/resources/jsbuilder/test/test_project.js +157 -157
  228. package/resources/local-server-info-resource.js +96 -96
  229. package/resources/notes.txt +10 -10
  230. package/resources/old/website-image-resource.js +1185 -1185
  231. package/resources/process-js.js +498 -498
  232. package/resources/processors/bundlers/bundle.js +29 -29
  233. package/resources/processors/bundlers/bundler.js +23 -23
  234. package/resources/processors/bundlers/css-bundler.js +234 -234
  235. package/resources/processors/bundlers/js/JS_Bundler.js +51 -51
  236. package/resources/processors/bundlers/js/esbuild/Advanced_JS_Bundler_Using_ESBuild.js +388 -391
  237. package/resources/processors/bundlers/js/esbuild/Bundler_Using_ESBuild.js +8 -8
  238. package/resources/processors/bundlers/js/esbuild/Core_JS_Non_Minifying_Bundler_Using_ESBuild.js +188 -188
  239. package/resources/processors/bundlers/js/esbuild/Core_JS_Single_File_Minifying_Bundler_Using_ESBuild.js +191 -192
  240. package/resources/processors/bundlers/js/esbuild/_Old_CSS_Extractor.js +239 -239
  241. package/resources/processors/bundlers/js-bundler.js +263 -263
  242. package/resources/processors/bundlers/test_ast.js +73 -73
  243. package/resources/processors/bundlers/webpage-bundler.js +404 -404
  244. package/resources/processors/bundlers/website-bundler.js +22 -22
  245. package/resources/processors/extractors/Extractor.js +9 -11
  246. package/resources/processors/extractors/js/css_and_js/AST_Node/CSS_And_JS_From_JS_String_Using_AST_Node_Extractor.js +239 -254
  247. package/resources/processors/extractors/js/css_and_js/CSS_And_JS_From_JS_String_Extractor.js +3 -3
  248. package/resources/processors/extractors/string/Pos_Span_String_Extractor.js +93 -93
  249. package/resources/server-installed-tools.js +28 -28
  250. package/resources/server-resource-pool.js +41 -41
  251. package/resources/website-audio-resource.js +735 -735
  252. package/resources/website-css-resource.js +411 -411
  253. package/resources/website-image-resource.js +412 -412
  254. package/resources/website-javascript-resource-processor.js +908 -908
  255. package/resources/website-javascript-resource.js +874 -874
  256. package/resources/website-resource-processor.js +10 -10
  257. package/resources/website-resource.js +164 -164
  258. package/resources/website-static-html-resource.js +199 -199
  259. package/resources/website-template-html-resource.js +231 -231
  260. package/roadmap.md +75 -75
  261. package/server.js +609 -573
  262. package/static-page-context.js +13 -13
  263. package/website/webpage.js +81 -81
  264. package/website/website-group.js +15 -15
  265. package/website/website.js +260 -260
  266. package/examples/controls/11d) window, shared model mirrored integer text fields/both.js +0 -17
  267. package/examples/controls/13) window, shared model mirrored lat_long/client.js +0 -933
  268. package/examples/controls/13) window, shared model mirrored lat_long/server.js +0 -50
  269. package/examples/controls/14) window, control compositional model/client.js +0 -328
  270. package/examples/controls/14) window, control compositional model/server.js +0 -118
  271. package/examples/controls/14a) window, control spec has compositional model/client.js +0 -440
  272. package/examples/controls/14a) window, control spec has compositional model/server.js +0 -118
  273. package/examples/controls/15) window, text field/client.js +0 -256
  274. package/examples/controls/16) Window([Text_Input])/client.js +0 -266
  275. package/examples/controls/16) Window([Text_Input])/server.js +0 -109
  276. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/client.js +0 -494
  277. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/isomorphic.js +0 -24
  278. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/server.js +0 -73
  279. package/examples/controls/2b) two window, context menus/client.js +0 -193
  280. package/examples/controls/2b) two window, context menus/server.js +0 -114
  281. package/examples/controls/4a) window, tabbed panel with various controls inside/client.js +0 -233
  282. package/examples/controls/4a) window, tabbed panel with various controls inside/server.js +0 -118
@@ -1,444 +1,444 @@
1
- const jsgui = require('jsgui3-client'); // and will replace this with jsgui-client, I presume.
2
- const {controls, Control, mixins} = jsgui;
3
- const {dragable} = mixins;
4
-
5
- /*
6
- class Square_Box extends Control {
7
- constructor(spec) {
8
- spec.__type_name = spec.__type_name || 'square_box';
9
- super(spec);
10
- this.add_class('square-box');
11
- }
12
- activate() {
13
- if (!this.__active) {
14
- super.activate();
15
- console.log('Activate square box');
16
-
17
- dragable(this, {
18
- drag_mode: 'translate'
19
- });
20
-
21
- //console.log('dragable mixin applied to square');
22
- this.dragable = true;
23
- //console.log('this.dragable = true;');
24
-
25
- this.on('dragend', e => {
26
- console.log('square box dragend e', e);
27
- });
28
-
29
- }
30
- }
31
- }
32
- Square_Box.css = `
33
- .square-box {
34
- background-color: #BB3333;
35
- width: 220px;
36
- height: 220px;
37
- }
38
- `;
39
- */
40
-
41
- // Relies on extracting CSS from JS files.
42
-
43
- const {press_events} = jsgui.mixins;
44
-
45
- const Grid = controls.Grid;
46
-
47
- class Demo_UI extends Control {
48
- constructor(spec) {
49
- spec.__type_name = spec.__type_name || 'demo_ui';
50
- super(spec);
51
- const {context} = this;
52
- this.add_class('demo-ui');
53
-
54
- const compose = () => {
55
-
56
- // Would be nice to have a grid / other control that expands to fit available space.
57
- // Like height and width 100%? May be a bit different in css implementation.
58
-
59
-
60
- // Then indicating how much space it's supposed to take...?
61
- // Could it automatically size itself depending on space available?
62
-
63
- // Grid should use the 'display' mixin by default?
64
- // display_modes may be a better name after all.
65
- //
66
-
67
- // Have Grid and other controls able to adaptively choose / grow to a size.
68
- // Could that be css flexbox though?
69
-
70
- // cell size being content item size.
71
- //
72
-
73
- const grid = new Grid({
74
- context: context,
75
- grid_size: [32, 32],
76
- cell_size: [10, 10]
77
- });
78
-
79
- //grid.size = [320, 200];
80
-
81
- this.add(grid);
82
-
83
- this._ctrl_fields = this._ctrl_fields || {};
84
- this._ctrl_fields.grid = grid;
85
-
86
- // cell_size property perhaps?
87
- // cell_size auto?
88
-
89
- // Want basic usage of .display mixin...
90
- // display_mode may well be the better name....
91
- // display.mode makes sense though!
92
-
93
- // mx display makes a lot of sense for higher level display properties and functionality.
94
- // or even .ui rather than display?
95
-
96
- // .ui mixin perhaps?
97
- // easy naming.
98
- // .ui and .data
99
- // so a control represents actual data (model in mvc)
100
- // .view perhaps?
101
- // .model even?
102
-
103
- // Could move towards some MVC naming fundamentals.
104
- // It would be as a higher level then some core things like CSS.
105
- // .data = .model probably.
106
-
107
- // the .mvc or .mv 'overhaul' mixin should come.
108
- // .model could / should refer to a part of a larger model.
109
- // the data being represented by the control.
110
-
111
- // view.editable property could be standard.
112
- // as in user_editable possibly.
113
-
114
- // Dividing into .model and .view could make sense.
115
- // view.dom.attributes for example
116
- // of course there can be models of the view.
117
-
118
- // ctrl.model would (always?) hold and represent the core data.
119
- // class Model_Data_Access
120
- // full_model
121
- // access_path (string???)
122
- // part of model (model for that control)
123
-
124
- // model = {text: 'hello'}
125
- // then the view we tell it to display the text (maybe it knows to do that, or its one very simple setting.)
126
-
127
- // Even make a Control_View component?
128
- // That seemed to be what the Control was before?
129
- // Being more explicit about referencing the View may help.
130
- // Especially with different view / display modes.
131
-
132
- // Also, keeping control data model logic while changing view logic...?
133
- // Keeping code separate should help with upgradability.
134
-
135
- // .model.data_type for example.
136
- // such as date.
137
- // or some types / structs which have definitions.
138
-
139
- // Then when making a View, we can specify that it only works for a set data_type
140
- // Then different implementations could compete / be compared.
141
-
142
- // Editors for specific data types, only supposed to or designed to work to edit a limited range of data.
143
- // Enforced programatically.
144
- // Have a schema of the data or something like it.
145
- // Then with the data defined, an editor could be put together programatically automatically.
146
- // May be a bit of a rudimentary / unflexible one but may be useful.
147
-
148
- // UI components for viewing and editing data
149
- // Could / should start with some really simple types of data
150
- // Need data type definitions within the code so that the editiors know what to do.
151
- // Could have them within JSON of course.
152
-
153
- // Max number, min number, integers only, etc...
154
-
155
- // so .view rather than .display probably...
156
- // .controller even could refer to various algorithms / hooks that get used when connecting the model and the view.
157
- // may be possible to use the control without accessing control.controller?
158
- // or the control itself is the controller?
159
- // .controller may make sense for accessing some properties.
160
-
161
- // const [mvc] = ctrl.mvc for example.
162
- //
163
-
164
- // Doing this more gradually...?
165
- // Where properties may have two means of accessing them?
166
- // or move some lower level view things into .view perhaps.
167
-
168
-
169
- // making .view as a mixin perhaps...?
170
- // could make some of the functions more universally callable perhaps?
171
- // not so sure about performance when used so widely. Could still make good use of prototypes somehow though.
172
-
173
-
174
-
175
-
176
-
177
-
178
-
179
-
180
-
181
-
182
-
183
-
184
-
185
-
186
-
187
-
188
-
189
-
190
-
191
-
192
-
193
-
194
-
195
-
196
- // size: auto for various controls?
197
- // a 'size' mixin? Autosize mixin?
198
-
199
- // resizable
200
- // user-resizable
201
-
202
- // probably want mixins to represent a fair few behavious that could apply reasonably to different controls.
203
- // making multi-mode rendering more of a standard too.
204
-
205
-
206
-
207
-
208
-
209
- // Then if the grid is made flexbox...?
210
- // A way to make it fill the available space from CSS.
211
-
212
- // Maybe a mixin to handle more sizing and positioning options?
213
- // The grid itself autofilling the space may help.
214
- // Then it can calculate what size to display / render the cells at.
215
-
216
-
217
-
218
-
219
-
220
-
221
- }
222
- if (!spec.el) {
223
- compose();
224
- }
225
- }
226
- activate() {
227
- if (!this.__active) {
228
- super.activate();
229
- const {context, grid} = this;
230
-
231
- console.log('activate Demo_UI');
232
- console.log('grid', grid);
233
-
234
- // .dimensions?
235
- // Not available yet...?
236
- // A clearer post-activate time would be best.
237
- // .do_once_active possibly?
238
-
239
-
240
- console.log('grid.grid_size', grid.grid_size);
241
- grid.refresh_size();
242
-
243
- press_events(grid);
244
-
245
- // the grid press start should contain the cell.
246
- // that is the specific kind of API improvement that helps the grid with customised specific events.
247
-
248
- // This is having trouble on iOS with touch events.
249
-
250
- // Better ways to check which cell is being pressed?
251
- // Seems like we don't get the new cell upon the touch move event.
252
-
253
- // Pressing and moving to a different ctrl / cell not working on iOS mobile safari.
254
-
255
- // Maybe improve grid painting for iOS?
256
- // Maybe improve the 'move on grid' event handlings?
257
-
258
- // Maybe press events isn't the best way?
259
- // Or need better handling of iOS within press events even?
260
- // Determining grid square by the coordinates would be possible if there is a rendering model.
261
- // Maybe further work within mixins.
262
- // Maybe within grid / grid mixins.
263
-
264
- // More work within Grid to better enable cell retrieval?
265
- // And then specific work on grid press events?
266
-
267
-
268
-
269
- const setup_grid_painting = () => {
270
-
271
- // ctrl_target maybe is not stable accross all devices and browsers.
272
- // Could be better to get some lower level things working right....
273
-
274
- let paint_color = '#000000';
275
- grid.on('press-start', e => {
276
- //console.log('grid press-start ', e);
277
- const {ctrl_target} = e;
278
- const [x, y] = [ctrl_target.x, ctrl_target.y];
279
-
280
- // grid.get_cell_at_px_coords([xpx, ypx]);
281
- // grid.get_cell_at_pos([x, y]);
282
-
283
- //console.log('[x, y]', [x, y]);
284
-
285
- // the colour of the cell there at start determines colour of paint brush?
286
- // will be best to incorporate painting / grid painting code into the mixins?
287
- // probably only a few lines of code for the right API.
288
-
289
- if (ctrl_target.dom.attributes.style['background-color'] === '#000000') {
290
- paint_color = '#FFFFFF';
291
- } else {
292
- paint_color = '#000000';
293
- }
294
- ctrl_target.dom.attributes.style['background-color'] = paint_color;
295
-
296
- e.preventDefault();
297
- });
298
-
299
- // and that would be a press-grid-move? press-gridcell-move?
300
- // this is just a place to set up and test different behaviours for grid ui.
301
- // may have things like area fills, or select area.
302
-
303
- let lastx, lasty;
304
- grid.on('press-move', e => {
305
-
306
- // Not getting the expeced ctrl_target that is right under the movement touch event on iOS.
307
- // Could we get the specific cell by using its display coords to determine which cell it is over?
308
-
309
- // Gets the right pixel coords from the event for this.
310
-
311
-
312
- console.log('grid press-move ', e);
313
-
314
- // Not working right on iOS. Not detecting which cell is directly underneith.
315
- const {ctrl_target} = e;
316
- //const {ctrl} = e;
317
- const [x, y] = [ctrl_target.x, ctrl_target.y];
318
-
319
- if (x !== lastx || y !== lasty) {
320
- grid.raise('press-cell-move', e);
321
- }
322
-
323
- //console.log('[x, y]', [x, y]);
324
- lastx = x;
325
- lasty = y;
326
-
327
- //e.preventDefault();
328
- });
329
-
330
- grid.on('press-cell-move', e => {
331
- const {ctrl_target} = e;
332
- const [x, y] = [ctrl_target.x, ctrl_target.y];
333
- //console.log('press-cell-move [x, y]', [x, y]);
334
- ctrl_target.dom.attributes.style['background-color'] = paint_color;
335
- });
336
- }
337
- setup_grid_painting();
338
-
339
-
340
-
341
- // 'press-move'
342
-
343
-
344
- // listen for the context events regarding frames, changes, resizing.
345
-
346
- context.on('window-resize', e_resize => {
347
- console.log('window-resize', e_resize);
348
- });
349
-
350
- // A delegated click or other event handler may work nicely (for the cells).
351
-
352
- // Could use press events to deal with events more smoothly?
353
- // A grid-events mixin?
354
- // Want to make high quality and specific code that is outside of the grid js component.
355
- // More swappable, composable, and upgradable components.
356
-
357
- // More functionality within the mixins makes sense.
358
- // Mixins as interfaces too.
359
-
360
- // grid.enable(Drag_Box)
361
- // or similar.
362
- // grid.mx_grid_press_ui possibly.
363
- // details of ui handling behavious moving out of the controls themselves.
364
- // more general within the mixins.
365
-
366
- // grid.on('drag-over') or similar.
367
- // specialised events within the appropriate mixins.
368
- // could try them here first though?
369
-
370
- // a different box-area-select mixin? or just a bit different when on a grid...?
371
- // may need to repeat code a little, but code will be simple at the app level at least.
372
-
373
-
374
-
375
-
376
-
377
-
378
-
379
-
380
- grid.each_cell(cell => {
381
-
382
- /*
383
- cell.on('click', e_click => {
384
- //console.log('e_click', e_click);
385
- //console.log('cell', cell);
386
- const xy = [cell.x, cell.y];
387
- //const xy = [cell._.x, cell._.y];
388
- console.log('xy', xy);
389
-
390
- if (cell.dom.attributes.style['background-color'] === '#000000') {
391
- cell.dom.attributes.style['background-color'] = '#FFFFFF';
392
- } else {
393
- cell.dom.attributes.style['background-color'] = '#000000';
394
- }
395
-
396
-
397
- })
398
- */
399
- })
400
-
401
- }
402
- }
403
- }
404
-
405
- // Include this in bundling.
406
- // Want CSS bundling so that styles are read out from the JS document and compiled to a stylesheet.
407
-
408
- //controls.Demo_UI = Demo_UI;
409
- Demo_UI.css = `
410
- .demo-ui {
411
- display: flex;
412
- flex-direction: column;
413
- justify-content: center;
414
- align-items: center;
415
- text-align: center;
416
- min-height: 100vh;
417
- }
418
- `;
419
-
420
- // then if running on the client...?
421
-
422
-
423
-
424
- //controls.Square_Box = Square_Box;
425
- // could export jsgui with the updated controls....
426
- // so that they are in the correct Page Context.?
427
-
428
-
429
- controls.Demo_UI = Demo_UI;
430
- //controls.Square_Box = Square_Box;
431
-
432
- module.exports = jsgui;
433
-
434
- /*
435
- module.exports = {
436
- Square_Box: Square_Box,
437
- Demo_UI: Demo_UI
438
- }
439
- */
440
-
441
- // Then if window...?
442
-
443
- // Need to add the Square_Box control to the context or original map of controls...
444
-
1
+ const jsgui = require('jsgui3-client'); // and will replace this with jsgui-client, I presume.
2
+ const {controls, Control, mixins} = jsgui;
3
+ const {dragable} = mixins;
4
+
5
+ /*
6
+ class Square_Box extends Control {
7
+ constructor(spec) {
8
+ spec.__type_name = spec.__type_name || 'square_box';
9
+ super(spec);
10
+ this.add_class('square-box');
11
+ }
12
+ activate() {
13
+ if (!this.__active) {
14
+ super.activate();
15
+ console.log('Activate square box');
16
+
17
+ dragable(this, {
18
+ drag_mode: 'translate'
19
+ });
20
+
21
+ //console.log('dragable mixin applied to square');
22
+ this.dragable = true;
23
+ //console.log('this.dragable = true;');
24
+
25
+ this.on('dragend', e => {
26
+ console.log('square box dragend e', e);
27
+ });
28
+
29
+ }
30
+ }
31
+ }
32
+ Square_Box.css = `
33
+ .square-box {
34
+ background-color: #BB3333;
35
+ width: 220px;
36
+ height: 220px;
37
+ }
38
+ `;
39
+ */
40
+
41
+ // Relies on extracting CSS from JS files.
42
+
43
+ const {press_events} = jsgui.mixins;
44
+
45
+ const Grid = controls.Grid;
46
+
47
+ class Demo_UI extends Control {
48
+ constructor(spec) {
49
+ spec.__type_name = spec.__type_name || 'demo_ui';
50
+ super(spec);
51
+ const {context} = this;
52
+ this.add_class('demo-ui');
53
+
54
+ const compose = () => {
55
+
56
+ // Would be nice to have a grid / other control that expands to fit available space.
57
+ // Like height and width 100%? May be a bit different in css implementation.
58
+
59
+
60
+ // Then indicating how much space it's supposed to take...?
61
+ // Could it automatically size itself depending on space available?
62
+
63
+ // Grid should use the 'display' mixin by default?
64
+ // display_modes may be a better name after all.
65
+ //
66
+
67
+ // Have Grid and other controls able to adaptively choose / grow to a size.
68
+ // Could that be css flexbox though?
69
+
70
+ // cell size being content item size.
71
+ //
72
+
73
+ const grid = new Grid({
74
+ context: context,
75
+ grid_size: [32, 32],
76
+ cell_size: [10, 10]
77
+ });
78
+
79
+ //grid.size = [320, 200];
80
+
81
+ this.add(grid);
82
+
83
+ this._ctrl_fields = this._ctrl_fields || {};
84
+ this._ctrl_fields.grid = grid;
85
+
86
+ // cell_size property perhaps?
87
+ // cell_size auto?
88
+
89
+ // Want basic usage of .display mixin...
90
+ // display_mode may well be the better name....
91
+ // display.mode makes sense though!
92
+
93
+ // mx display makes a lot of sense for higher level display properties and functionality.
94
+ // or even .ui rather than display?
95
+
96
+ // .ui mixin perhaps?
97
+ // easy naming.
98
+ // .ui and .data
99
+ // so a control represents actual data (model in mvc)
100
+ // .view perhaps?
101
+ // .model even?
102
+
103
+ // Could move towards some MVC naming fundamentals.
104
+ // It would be as a higher level then some core things like CSS.
105
+ // .data = .model probably.
106
+
107
+ // the .mvc or .mv 'overhaul' mixin should come.
108
+ // .model could / should refer to a part of a larger model.
109
+ // the data being represented by the control.
110
+
111
+ // view.editable property could be standard.
112
+ // as in user_editable possibly.
113
+
114
+ // Dividing into .model and .view could make sense.
115
+ // view.dom.attributes for example
116
+ // of course there can be models of the view.
117
+
118
+ // ctrl.model would (always?) hold and represent the core data.
119
+ // class Model_Data_Access
120
+ // full_model
121
+ // access_path (string???)
122
+ // part of model (model for that control)
123
+
124
+ // model = {text: 'hello'}
125
+ // then the view we tell it to display the text (maybe it knows to do that, or its one very simple setting.)
126
+
127
+ // Even make a Control_View component?
128
+ // That seemed to be what the Control was before?
129
+ // Being more explicit about referencing the View may help.
130
+ // Especially with different view / display modes.
131
+
132
+ // Also, keeping control data model logic while changing view logic...?
133
+ // Keeping code separate should help with upgradability.
134
+
135
+ // .model.data_type for example.
136
+ // such as date.
137
+ // or some types / structs which have definitions.
138
+
139
+ // Then when making a View, we can specify that it only works for a set data_type
140
+ // Then different implementations could compete / be compared.
141
+
142
+ // Editors for specific data types, only supposed to or designed to work to edit a limited range of data.
143
+ // Enforced programatically.
144
+ // Have a schema of the data or something like it.
145
+ // Then with the data defined, an editor could be put together programatically automatically.
146
+ // May be a bit of a rudimentary / unflexible one but may be useful.
147
+
148
+ // UI components for viewing and editing data
149
+ // Could / should start with some really simple types of data
150
+ // Need data type definitions within the code so that the editiors know what to do.
151
+ // Could have them within JSON of course.
152
+
153
+ // Max number, min number, integers only, etc...
154
+
155
+ // so .view rather than .display probably...
156
+ // .controller even could refer to various algorithms / hooks that get used when connecting the model and the view.
157
+ // may be possible to use the control without accessing control.controller?
158
+ // or the control itself is the controller?
159
+ // .controller may make sense for accessing some properties.
160
+
161
+ // const [mvc] = ctrl.mvc for example.
162
+ //
163
+
164
+ // Doing this more gradually...?
165
+ // Where properties may have two means of accessing them?
166
+ // or move some lower level view things into .view perhaps.
167
+
168
+
169
+ // making .view as a mixin perhaps...?
170
+ // could make some of the functions more universally callable perhaps?
171
+ // not so sure about performance when used so widely. Could still make good use of prototypes somehow though.
172
+
173
+
174
+
175
+
176
+
177
+
178
+
179
+
180
+
181
+
182
+
183
+
184
+
185
+
186
+
187
+
188
+
189
+
190
+
191
+
192
+
193
+
194
+
195
+
196
+ // size: auto for various controls?
197
+ // a 'size' mixin? Autosize mixin?
198
+
199
+ // resizable
200
+ // user-resizable
201
+
202
+ // probably want mixins to represent a fair few behavious that could apply reasonably to different controls.
203
+ // making multi-mode rendering more of a standard too.
204
+
205
+
206
+
207
+
208
+
209
+ // Then if the grid is made flexbox...?
210
+ // A way to make it fill the available space from CSS.
211
+
212
+ // Maybe a mixin to handle more sizing and positioning options?
213
+ // The grid itself autofilling the space may help.
214
+ // Then it can calculate what size to display / render the cells at.
215
+
216
+
217
+
218
+
219
+
220
+
221
+ }
222
+ if (!spec.el) {
223
+ compose();
224
+ }
225
+ }
226
+ activate() {
227
+ if (!this.__active) {
228
+ super.activate();
229
+ const {context, grid} = this;
230
+
231
+ console.log('activate Demo_UI');
232
+ console.log('grid', grid);
233
+
234
+ // .dimensions?
235
+ // Not available yet...?
236
+ // A clearer post-activate time would be best.
237
+ // .do_once_active possibly?
238
+
239
+
240
+ console.log('grid.grid_size', grid.grid_size);
241
+ grid.refresh_size();
242
+
243
+ press_events(grid);
244
+
245
+ // the grid press start should contain the cell.
246
+ // that is the specific kind of API improvement that helps the grid with customised specific events.
247
+
248
+ // This is having trouble on iOS with touch events.
249
+
250
+ // Better ways to check which cell is being pressed?
251
+ // Seems like we don't get the new cell upon the touch move event.
252
+
253
+ // Pressing and moving to a different ctrl / cell not working on iOS mobile safari.
254
+
255
+ // Maybe improve grid painting for iOS?
256
+ // Maybe improve the 'move on grid' event handlings?
257
+
258
+ // Maybe press events isn't the best way?
259
+ // Or need better handling of iOS within press events even?
260
+ // Determining grid square by the coordinates would be possible if there is a rendering model.
261
+ // Maybe further work within mixins.
262
+ // Maybe within grid / grid mixins.
263
+
264
+ // More work within Grid to better enable cell retrieval?
265
+ // And then specific work on grid press events?
266
+
267
+
268
+
269
+ const setup_grid_painting = () => {
270
+
271
+ // ctrl_target maybe is not stable accross all devices and browsers.
272
+ // Could be better to get some lower level things working right....
273
+
274
+ let paint_color = '#000000';
275
+ grid.on('press-start', e => {
276
+ //console.log('grid press-start ', e);
277
+ const {ctrl_target} = e;
278
+ const [x, y] = [ctrl_target.x, ctrl_target.y];
279
+
280
+ // grid.get_cell_at_px_coords([xpx, ypx]);
281
+ // grid.get_cell_at_pos([x, y]);
282
+
283
+ //console.log('[x, y]', [x, y]);
284
+
285
+ // the colour of the cell there at start determines colour of paint brush?
286
+ // will be best to incorporate painting / grid painting code into the mixins?
287
+ // probably only a few lines of code for the right API.
288
+
289
+ if (ctrl_target.dom.attributes.style['background-color'] === '#000000') {
290
+ paint_color = '#FFFFFF';
291
+ } else {
292
+ paint_color = '#000000';
293
+ }
294
+ ctrl_target.dom.attributes.style['background-color'] = paint_color;
295
+
296
+ e.preventDefault();
297
+ });
298
+
299
+ // and that would be a press-grid-move? press-gridcell-move?
300
+ // this is just a place to set up and test different behaviours for grid ui.
301
+ // may have things like area fills, or select area.
302
+
303
+ let lastx, lasty;
304
+ grid.on('press-move', e => {
305
+
306
+ // Not getting the expeced ctrl_target that is right under the movement touch event on iOS.
307
+ // Could we get the specific cell by using its display coords to determine which cell it is over?
308
+
309
+ // Gets the right pixel coords from the event for this.
310
+
311
+
312
+ console.log('grid press-move ', e);
313
+
314
+ // Not working right on iOS. Not detecting which cell is directly underneith.
315
+ const {ctrl_target} = e;
316
+ //const {ctrl} = e;
317
+ const [x, y] = [ctrl_target.x, ctrl_target.y];
318
+
319
+ if (x !== lastx || y !== lasty) {
320
+ grid.raise('press-cell-move', e);
321
+ }
322
+
323
+ //console.log('[x, y]', [x, y]);
324
+ lastx = x;
325
+ lasty = y;
326
+
327
+ //e.preventDefault();
328
+ });
329
+
330
+ grid.on('press-cell-move', e => {
331
+ const {ctrl_target} = e;
332
+ const [x, y] = [ctrl_target.x, ctrl_target.y];
333
+ //console.log('press-cell-move [x, y]', [x, y]);
334
+ ctrl_target.dom.attributes.style['background-color'] = paint_color;
335
+ });
336
+ }
337
+ setup_grid_painting();
338
+
339
+
340
+
341
+ // 'press-move'
342
+
343
+
344
+ // listen for the context events regarding frames, changes, resizing.
345
+
346
+ context.on('window-resize', e_resize => {
347
+ console.log('window-resize', e_resize);
348
+ });
349
+
350
+ // A delegated click or other event handler may work nicely (for the cells).
351
+
352
+ // Could use press events to deal with events more smoothly?
353
+ // A grid-events mixin?
354
+ // Want to make high quality and specific code that is outside of the grid js component.
355
+ // More swappable, composable, and upgradable components.
356
+
357
+ // More functionality within the mixins makes sense.
358
+ // Mixins as interfaces too.
359
+
360
+ // grid.enable(Drag_Box)
361
+ // or similar.
362
+ // grid.mx_grid_press_ui possibly.
363
+ // details of ui handling behavious moving out of the controls themselves.
364
+ // more general within the mixins.
365
+
366
+ // grid.on('drag-over') or similar.
367
+ // specialised events within the appropriate mixins.
368
+ // could try them here first though?
369
+
370
+ // a different box-area-select mixin? or just a bit different when on a grid...?
371
+ // may need to repeat code a little, but code will be simple at the app level at least.
372
+
373
+
374
+
375
+
376
+
377
+
378
+
379
+
380
+ grid.each_cell(cell => {
381
+
382
+ /*
383
+ cell.on('click', e_click => {
384
+ //console.log('e_click', e_click);
385
+ //console.log('cell', cell);
386
+ const xy = [cell.x, cell.y];
387
+ //const xy = [cell._.x, cell._.y];
388
+ console.log('xy', xy);
389
+
390
+ if (cell.dom.attributes.style['background-color'] === '#000000') {
391
+ cell.dom.attributes.style['background-color'] = '#FFFFFF';
392
+ } else {
393
+ cell.dom.attributes.style['background-color'] = '#000000';
394
+ }
395
+
396
+
397
+ })
398
+ */
399
+ })
400
+
401
+ }
402
+ }
403
+ }
404
+
405
+ // Include this in bundling.
406
+ // Want CSS bundling so that styles are read out from the JS document and compiled to a stylesheet.
407
+
408
+ //controls.Demo_UI = Demo_UI;
409
+ Demo_UI.css = `
410
+ .demo-ui {
411
+ display: flex;
412
+ flex-direction: column;
413
+ justify-content: center;
414
+ align-items: center;
415
+ text-align: center;
416
+ min-height: 100vh;
417
+ }
418
+ `;
419
+
420
+ // then if running on the client...?
421
+
422
+
423
+
424
+ //controls.Square_Box = Square_Box;
425
+ // could export jsgui with the updated controls....
426
+ // so that they are in the correct Page Context.?
427
+
428
+
429
+ controls.Demo_UI = Demo_UI;
430
+ //controls.Square_Box = Square_Box;
431
+
432
+ module.exports = jsgui;
433
+
434
+ /*
435
+ module.exports = {
436
+ Square_Box: Square_Box,
437
+ Demo_UI: Demo_UI
438
+ }
439
+ */
440
+
441
+ // Then if window...?
442
+
443
+ // Need to add the Square_Box control to the context or original map of controls...
444
+